/* ============================================================
   gl-* Design System — giuseppelibrandi.com
   Modern Minimal · Warm Stone · Pink accent (#FF6B81)
   ============================================================ */
:root{
  --gray-50:#FAFAF9;--gray-100:#F5F5F4;--gray-200:#E7E5E4;--gray-300:#D6D3D1;
  --gray-400:#A8A29E;--gray-500:#78716C;--gray-600:#57534E;--gray-700:#44403C;
  --gray-800:#292524;--gray-900:#1C1917;
  --pink-50:#FFF5F6;--pink-100:#FFE4E8;--pink-200:#FFCCD5;--pink-400:#FF6B81;
  --pink-500:#E8455E;--pink-600:#D43A56;
  --success:#22C55E;--success-bg:#F0FDF4;--danger:#EF4444;--danger-bg:#FEF2F2;
  --warning:#F59E0B;--warning-bg:#FFFBEB;--info:#3B82F6;--info-bg:#EFF6FF;

  --font-sans:'Inter',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  --font-mono:'JetBrains Mono','Fira Code',ui-monospace,monospace;

  --r-sm:6px;--r-md:8px;--r-lg:12px;--r-xl:16px;--r-2xl:24px;--r-full:9999px;
  --sh-sm:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --sh-md:0 4px 6px rgba(0,0,0,.05),0 2px 4px rgba(0,0,0,.03);
  --sh-lg:0 10px 15px rgba(0,0,0,.07),0 4px 6px rgba(0,0,0,.03);
  --sh-pink:0 0 20px rgba(255,107,129,.3);
  --ease:cubic-bezier(.4,0,.2,1);
  /* backward compat */
  --primary-color:var(--pink-400);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--gray-50);color:var(--gray-600);font-family:var(--font-sans);
     line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--pink-400);text-decoration:none}
.gl-container{max-width:1100px;margin:0 auto;padding:0 24px}

/* ---------- Navbar ---------- */
.gl-navbar{position:sticky;top:0;z-index:20;backdrop-filter:blur(12px) saturate(180%);
  background:rgba(250,250,249,.82);border-bottom:1px solid var(--gray-200)}
.gl-navbar-in{display:flex;align-items:center;gap:10px;height:60px;max-width:1100px;margin:0 auto;padding:0 24px}
.gl-brand{display:flex;align-items:center;gap:9px;font-weight:700;color:var(--gray-900);letter-spacing:-.01em}
.gl-brand-dot{width:8px;height:8px;border-radius:var(--r-full);background:var(--pink-400)}
.gl-nav-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.gl-nav-link{font-size:14px;font-weight:500;color:var(--gray-600)}
.gl-nav-link:hover{color:var(--gray-900)}
.gl-nav-cta{background:var(--pink-400);color:#fff;font-size:14px;font-weight:600;
  padding:8px 18px;border-radius:var(--r-full);transition:all .2s var(--ease)}
.gl-nav-cta:hover{background:var(--pink-500);box-shadow:var(--sh-md)}
.gl-nav-avatar{width:34px;height:34px;border-radius:var(--r-full);background:var(--pink-100);
  color:var(--pink-500);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}

/* ---------- Hero / CV ---------- */
.gl-hero{max-width:760px;margin:0 auto;padding:80px 24px 36px;text-align:center}
.gl-hero-eyebrow{font-family:var(--font-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--pink-500);display:inline-flex;align-items:center;gap:8px;margin-bottom:22px}
.gl-hero-eyebrow .gl-brand-dot{width:7px;height:7px}
.gl-hero h1{font-size:clamp(36px,6.5vw,56px);font-weight:700;line-height:1.1;letter-spacing:-.02em;
  color:var(--gray-900);margin-bottom:8px}
.gl-hero .role{font-size:clamp(18px,3vw,22px);font-weight:600;
  background:linear-gradient(90deg,var(--pink-400),var(--pink-600));-webkit-background-clip:text;background-clip:text;color:transparent;
  margin-bottom:20px}
.gl-hero .tagline{font-size:19px;color:var(--gray-600);max-width:54ch;margin:0 auto}
.gl-hero .pitch{font-size:16px;color:var(--gray-500);margin-top:14px}

/* ---------- Skills ---------- */
.gl-skills{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:30px}
.gl-skill{font-size:14px;font-weight:500;color:var(--gray-700);background:#fff;
  border:1px solid var(--gray-200);border-radius:var(--r-full);padding:8px 16px;transition:all .2s var(--ease)}
.gl-skill:hover{border-color:var(--pink-200);color:var(--gray-900);box-shadow:var(--sh-sm)}

/* ---------- Section heading ---------- */
.gl-section{padding:48px 0 0}
.gl-section-head{display:flex;align-items:baseline;gap:12px;margin-bottom:22px}
.gl-section-head h2{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-700)}
.gl-section-head .hr{flex:1;height:1px;background:var(--gray-200)}
.gl-section-head .count{font-family:var(--font-mono);font-size:12px;color:var(--gray-400)}

/* ---------- Portfolio grid ---------- */
.gl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:18px;padding-bottom:8px}
.gl-card{position:relative;display:flex;flex-direction:column;padding:22px;border-radius:var(--r-lg);
  background:#fff;border:1px solid var(--gray-200);box-shadow:var(--sh-sm);
  text-decoration:none;color:inherit;transition:all .2s var(--ease);overflow:hidden}
.gl-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--pink-400);
  transform:scaleY(0);transform-origin:top;transition:transform .2s var(--ease)}
.gl-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px);border-color:var(--gray-300)}
.gl-card:hover::before{transform:scaleY(1)}
.gl-card-top{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.gl-card-name{font-size:18px;font-weight:600;color:var(--gray-900)}
.gl-card-badge{margin-left:auto;display:inline-flex;align-items:center;gap:5px;font-size:11px;
  font-family:var(--font-mono);color:var(--gray-400)}
.gl-dot{width:6px;height:6px;border-radius:var(--r-full)}
.gl-dot.live{background:var(--success);box-shadow:0 0 0 3px rgba(34,197,94,.15)}
.gl-dot.down{background:var(--danger)}
.gl-dot.soon,.gl-dot.unknown{background:var(--gray-400)}
.gl-lock{margin-left:auto;color:var(--gray-400);font-size:13px}
.gl-card-desc{font-size:14px;color:var(--gray-500);line-height:1.5;flex:1}
.gl-card-foot{display:flex;justify-content:space-between;align-items:center;margin-top:16px;
  padding-top:13px;border-top:1px solid var(--gray-100)}
.gl-card-dom{font-family:var(--font-mono);font-size:11px;color:var(--gray-400)}
.gl-card-arrow{color:var(--gray-400);transition:all .2s var(--ease)}
.gl-card:hover .gl-card-arrow{transform:translateX(4px);color:var(--pink-400)}
.gl-card.is-protected .gl-card-dom{color:var(--gray-400)}
.gl-card.is-private{border-style:dashed}

/* tag pill for surface in dashboard */
.gl-tag{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.04em;
  padding:2px 8px;border-radius:var(--r-full);border:1px solid var(--gray-200);color:var(--gray-500)}
.gl-tag.public{color:var(--success);border-color:#bbf7d0;background:var(--success-bg)}
.gl-tag.protected{color:var(--pink-600);border-color:var(--pink-200);background:var(--pink-50)}
.gl-tag.private{color:var(--gray-700);background:var(--gray-100)}
.gl-tag.unlisted{color:var(--gray-400)}

/* ---------- Dashboard header ---------- */
.gl-dash-head{padding:40px 0 8px}
.gl-dash-head h1{font-size:clamp(28px,5vw,38px);font-weight:700;color:var(--gray-900);letter-spacing:-.01em}
.gl-dash-head h1 .nm{background:linear-gradient(90deg,var(--pink-400),var(--pink-600));-webkit-background-clip:text;background-clip:text;color:transparent}
.gl-dash-head p{color:var(--gray-500);margin-top:4px}

/* ---------- Empty state ---------- */
.gl-empty{text-align:center;padding:48px 24px;color:var(--gray-500);
  border:1px dashed var(--gray-300);border-radius:var(--r-lg);background:#fff}

/* ---------- Buttons ---------- */
.gl-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:var(--r-md);
  font-size:15px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:all .2s var(--ease);text-decoration:none}
.gl-btn-primary{background:var(--pink-400);color:#fff}
.gl-btn-primary:hover{background:var(--pink-500);box-shadow:var(--sh-md);transform:translateY(-1px)}
.gl-btn-ghost{background:transparent;color:var(--gray-800);border-color:var(--gray-300)}
.gl-btn-ghost:hover{background:var(--gray-100);border-color:var(--gray-400)}

/* ---------- Forms ---------- */
.gl-label{display:block;font-size:14px;font-weight:500;color:var(--gray-700);margin-bottom:8px}
.gl-input{display:block;width:100%;padding:12px 14px;border:1px solid var(--gray-300);border-radius:var(--r-md);
  background:#fff;font-family:var(--font-sans);font-size:16px;color:var(--gray-900);
  transition:border-color .15s var(--ease),box-shadow .15s var(--ease)}
.gl-input::placeholder{color:var(--gray-400)}
.gl-input:focus{outline:none;border-color:var(--pink-400);box-shadow:0 0 0 3px rgba(255,107,129,.15)}
.gl-form-group{margin-bottom:20px}

/* ---------- Auth split ---------- */
.gl-auth{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}
.gl-auth-panel{background:var(--gray-900);color:var(--gray-50);padding:64px;display:flex;flex-direction:column;justify-content:center}
.gl-auth-panel .gl-brand-dot{width:12px;height:12px;margin-bottom:24px}
.gl-auth-panel h2{font-size:24px;color:#fff;margin-bottom:8px}
.gl-auth-panel p{color:var(--gray-400)}
.gl-auth-form{background:#fff;display:flex;align-items:center;justify-content:center;padding:48px}
.gl-auth-form-inner{width:100%;max-width:380px}
.gl-auth-form h1{font-size:28px;color:var(--gray-900);margin-bottom:6px}
.gl-auth-sub{color:var(--gray-500);margin-bottom:28px}
.gl-form-foot{margin-top:24px;text-align:center;color:var(--gray-500);font-size:14px}

/* ---------- Alerts ---------- */
.gl-alerts{position:fixed;top:74px;left:50%;transform:translateX(-50%);z-index:50;width:min(440px,92vw)}
.gl-alert{display:flex;gap:12px;align-items:flex-start;padding:14px 16px;border-radius:var(--r-md);
  border-left:4px solid;margin-bottom:10px;background:#fff;box-shadow:var(--sh-lg);
  animation:glIn .2s var(--ease)}
.gl-alert-success{background:var(--success-bg);border-color:var(--success)}
.gl-alert-danger,.gl-alert-error{background:var(--danger-bg);border-color:var(--danger)}
.gl-alert-info{background:var(--info-bg);border-color:var(--info)}
.gl-alert-content{flex:1;font-size:14px;color:var(--gray-800)}
@keyframes glIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}

/* ---------- Footer ---------- */
.gl-footer{border-top:1px solid var(--gray-200);padding:24px 0;margin-top:64px}
.gl-footer-in{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--gray-500);
  max-width:1100px;margin:0 auto;padding:0 24px;flex-wrap:wrap;gap:8px}
.gl-footer-in .mono{font-family:var(--font-mono);font-size:12px;color:var(--gray-400)}

@media(max-width:768px){
  .gl-auth{grid-template-columns:1fr}
  .gl-auth-panel{display:none}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
