/* ═══════════════════════════════════════════════════════════════
   COMMUNE — Design System
   iOS 26 Liquid Glass · Midnight Cosmos · Refined Editorial
   Fonts: Fraunces (display) + Figtree (body) — self-hosted fallbacks
   ═══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,200;0,9..144,400;0,9..144,600;0,9..144,700;1,9..144,200;1,9..144,400;1,9..144,600&family=Figtree:wght@300;400;500;600;700&display=swap');

/* ── Tokens ────────────────────────────────────────────────── */
:root {
  /* Night palette */
  --night-0:  #050810;
  --night-1:  #080C16;
  --night-2:  #0C1220;
  --night-3:  #111827;
  --night-4:  #1A2234;

  /* Glass layers — iOS 26 Liquid Glass effect */
  --gl-0:     rgba(255,255,255,0.040);
  --gl-1:     rgba(255,255,255,0.068);
  --gl-2:     rgba(255,255,255,0.100);
  --gl-3:     rgba(255,255,255,0.140);
  --gl-bd-0:  rgba(255,255,255,0.080);
  --gl-bd-1:  rgba(255,255,255,0.160);
  --gl-bd-2:  rgba(255,255,255,0.260);
  --gl-shine: rgba(255,255,255,0.100);

  /* Brand spectrum */
  --iris:     #7C6FFF;
  --iris-d:   rgba(124,111,255,0.14);
  --iris-g:   rgba(124,111,255,0.32);
  --teal:     #2DD4BF;
  --teal-d:   rgba(45,212,191,0.12);
  --coral:    #FB7185;
  --coral-d:  rgba(251,113,133,0.12);
  --amber:    #FBBF24;
  --amber-d:  rgba(251,191,36,0.12);
  --sage:     #4ADE80;

  /* Text */
  --tx-0:  #F2EFE8;   /* primary   */
  --tx-1:  #9CA3B0;   /* secondary */
  --tx-2:  #596070;   /* muted     */
  --tx-3:  #343B48;   /* faint     */

  /* Typography */
  --ff-display: 'Fraunces', 'Palatino Linotype', serif;
  --ff-body:    'Figtree', system-ui, sans-serif;

  /* Spatial */
  --nav-h:   66px;
  --wrap:   1280px;

  /* Radius */
  --r-xs:   6px;
  --r-sm:  12px;
  --r-md:  18px;
  --r-lg:  24px;
  --r-xl:  32px;
  --r-2xl: 44px;
  --r-oo:  9999px;

  /* Shadows */
  --sh-sm:   0 2px 12px rgba(0,0,0,0.30);
  --sh-md:   0 6px 28px rgba(0,0,0,0.40);
  --sh-lg:   0 14px 50px rgba(0,0,0,0.55);
  --sh-iris: 0 0 40px rgba(124,111,255,0.28);
  --sh-teal: 0 0 36px rgba(45,212,191,0.20);
  --sh-glass:0 8px 32px rgba(0,0,0,0.40), 0 1px 0 var(--gl-shine) inset;

  /* Motion */
  --spring:  cubic-bezier(0.34,1.56,0.64,1);
  --smooth:  cubic-bezier(0.4,0,0.2,1);
  --ease-o:  cubic-bezier(0,0,0.2,1);
  --t-xs: 0.12s;
  --t-sm: 0.22s;
  --t-md: 0.36s;
  --t-lg: 0.52s;
}

/* ── Reset ─────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--ff-body);
  background:var(--night-0);
  color:var(--tx-0);
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit;color:inherit}
input,textarea,select{font-family:inherit;color:inherit}
::selection{background:var(--iris-g);color:#fff}

/* ── Noise grain overlay (subtle film) ─────────────────────── */
body::before{
  content:'';
  position:fixed;inset:0;z-index:1;
  pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.80' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.046'/%3E%3C/svg%3E");
  background-size:260px;
  opacity:.4;
  mix-blend-mode:overlay;
}

/* ── Animated orb background ───────────────────────────────── */
.orb-layer{
  position:fixed;inset:0;z-index:0;
  pointer-events:none;overflow:hidden;
}
.orb{
  position:absolute;border-radius:50%;
  filter:blur(90px);
  animation:drift var(--dur,24s) ease-in-out infinite;
  will-change:transform;
}
.orb-1{
  --dur:28s;
  width:700px;height:700px;
  background:radial-gradient(circle,rgba(124,111,255,.16) 0%,transparent 65%);
  top:-250px;left:-180px;
}
.orb-2{
  --dur:34s;
  width:550px;height:550px;
  background:radial-gradient(circle,rgba(45,212,191,.11) 0%,transparent 65%);
  top:15%;right:-200px;
  animation-delay:-10s;
}
.orb-3{
  --dur:22s;
  width:420px;height:420px;
  background:radial-gradient(circle,rgba(251,113,133,.09) 0%,transparent 65%);
  bottom:8%;left:15%;
  animation-delay:-17s;
}
.orb-4{
  --dur:40s;
  width:320px;height:320px;
  background:radial-gradient(circle,rgba(251,191,36,.07) 0%,transparent 65%);
  bottom:25%;right:8%;
  animation-delay:-6s;
}
@keyframes drift{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(40px,-60px) scale(1.06)}
  66%{transform:translate(-30px,30px) scale(0.96)}
}

/* ── Content z-layer ───────────────────────────────────────── */
.layer{position:relative;z-index:2}

/* ── Container ─────────────────────────────────────────────── */
.wrap{
  max-width:var(--wrap);
  margin:0 auto;
  padding:0 28px;
}

/* ══ GLASS SYSTEM ════════════════════════════════════════════ */

/* Specular highlight (iOS 26 liquid edge) */
.glass,.glass-md,.glass-heavy{position:relative}
.glass::after,.glass-md::after,.glass-heavy::after{
  content:'';
  position:absolute;top:0;left:0;right:0;
  height:1px;border-radius:inherit;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);
  pointer-events:none;
}

.glass{
  background:var(--gl-0);
  backdrop-filter:blur(18px) saturate(1.8);
  -webkit-backdrop-filter:blur(18px) saturate(1.8);
  border:1px solid var(--gl-bd-0);
  box-shadow:var(--sh-glass);
}
.glass-md{
  background:var(--gl-1);
  backdrop-filter:blur(24px) saturate(2.0);
  -webkit-backdrop-filter:blur(24px) saturate(2.0);
  border:1px solid var(--gl-bd-0);
  box-shadow:var(--sh-glass);
}
.glass-heavy{
  background:var(--gl-2);
  backdrop-filter:blur(36px) saturate(2.4);
  -webkit-backdrop-filter:blur(36px) saturate(2.4);
  border:1px solid var(--gl-bd-1);
  box-shadow:var(--sh-lg),0 1px 0 var(--gl-shine) inset;
}
.glass-ultra{
  background:var(--gl-3);
  backdrop-filter:blur(48px) saturate(2.8);
  -webkit-backdrop-filter:blur(48px) saturate(2.8);
  border:1px solid var(--gl-bd-2);
  box-shadow:0 20px 60px rgba(0,0,0,.6),0 1px 0 rgba(255,255,255,.22) inset;
  position:relative;
}
.glass-ultra::after{
  content:'';
  position:absolute;top:0;left:0;right:0;
  height:1px;border-radius:inherit;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.28),transparent);
  pointer-events:none;
}

/* ══ NAVIGATION ══════════════════════════════════════════════ */
.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:900;
  height:var(--nav-h);
  background:rgba(5,8,16,.72);
  backdrop-filter:blur(28px) saturate(2);
  -webkit-backdrop-filter:blur(28px) saturate(2);
  border-bottom:1px solid var(--gl-bd-0);
  transition:background var(--t-sm) var(--smooth),
             box-shadow var(--t-sm) var(--smooth);
}
.site-nav.scrolled{
  background:rgba(5,8,16,.92);
  box-shadow:0 4px 40px rgba(0,0,0,.45);
}
.nav-wrap{
  display:flex;align-items:center;
  height:100%;gap:0;
  padding:0 4px;
  position:relative;
}
.brand{
  display:flex;align-items:center;gap:11px;
  text-decoration:none;
  flex-shrink:0;
  margin-right:0;
}
.brand-gem{
  width:36px;height:36px;border-radius:10px;
  background:linear-gradient(135deg,var(--iris),var(--teal));
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--sh-iris);
  transition:transform var(--t-sm) var(--spring),
             box-shadow var(--t-sm) var(--smooth);
  flex-shrink:0;
}
.brand:hover .brand-gem{transform:scale(1.1) rotate(-4deg);box-shadow:0 0 32px rgba(124,111,255,.5)}
.brand-name{
  font-family:var(--ff-display);
  font-size:1.45rem;font-weight:600;
  letter-spacing:-.025em;color:var(--tx-0);
}
.nav-links{
  display:flex;align-items:center;gap:2px;
  position:absolute;
  left:50%;transform:translateX(-50%);
}
.nav-a{
  padding:7px 15px;
  font-size:.875rem;font-weight:500;
  color:var(--tx-1);border-radius:var(--r-oo);
  transition:all var(--t-xs) var(--smooth);
}
.nav-a:hover{color:var(--tx-0);background:var(--gl-1)}
.nav-a.on{color:var(--tx-0);background:var(--gl-1)}
.nav-cta{
  display:flex;align-items:center;gap:12px;
  padding-right:4px;
  margin-left:auto;
}
/* Avatar + online ring */
.nav-avatar{
  width:36px;height:36px;border-radius:50%;
  border:2px solid var(--gl-bd-1);
  object-fit:cover;cursor:pointer;
  transition:all var(--t-xs) var(--spring);
}
.nav-avatar:hover{border-color:var(--iris);transform:scale(1.08)}
.nav-notif{
  position:relative;width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;color:var(--tx-1);
  transition:all var(--t-xs);
}
.nav-notif:hover{background:var(--gl-1);color:var(--tx-0)}
.badge{
  position:absolute;top:3px;right:3px;
  min-width:16px;height:16px;padding:0 4px;
  background:var(--coral);color:#fff;
  font-size:.6rem;font-weight:700;
  border-radius:var(--r-oo);
  display:flex;align-items:center;justify-content:center;
  border:2px solid var(--night-0);
  animation:badge-pulse 2.2s ease-in-out infinite;
}
@keyframes badge-pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(251,113,133,.5)}
  50%{box-shadow:0 0 0 5px rgba(251,113,133,0)}
}

/* ══ BUTTONS ═════════════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 22px;
  font-size:.875rem;font-weight:600;font-family:var(--ff-body);
  border-radius:var(--r-oo);
  border:none;cursor:pointer;
  white-space:nowrap;position:relative;overflow:hidden;
  transition:all var(--t-sm) var(--spring);
}
.btn::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.12),transparent);
  opacity:0;transition:opacity var(--t-xs);
}
.btn:hover::before{opacity:1}
.btn:active{transform:scale(.97)}

.btn-primary{
  background:linear-gradient(135deg,var(--iris) 0%,#9B6DFF 100%);
  color:#fff;
  box-shadow:0 4px 20px var(--iris-g),0 1px 0 rgba(255,255,255,.18) inset;
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px var(--iris-g)}
.btn-glass{
  background:var(--gl-1);color:var(--tx-0);
  border:1px solid var(--gl-bd-1);
  backdrop-filter:blur(12px);
}
.btn-glass:hover{background:var(--gl-2);transform:translateY(-1px);box-shadow:var(--sh-glass)}
.btn-teal{
  background:linear-gradient(135deg,var(--teal),#22D3EE);
  color:#021a18;
  box-shadow:0 4px 20px var(--teal-d);
}
.btn-teal:hover{transform:translateY(-2px);box-shadow:0 8px 28px var(--teal-d)}
.btn-sm{padding:7px 16px;font-size:.8rem}
.btn-lg{padding:14px 32px;font-size:1rem}
.btn-icon{padding:9px}
.btn-danger{background:rgba(239,68,68,.14);color:#F87171;border:1px solid rgba(239,68,68,.22)}
.btn-danger:hover{background:rgba(239,68,68,.24)}

/* ══ FORM CONTROLS ═══════════════════════════════════════════ */
.fg{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.fl{
  font-size:.76rem;font-weight:700;
  color:var(--tx-1);letter-spacing:.055em;text-transform:uppercase;
}
.fc{
  background:var(--gl-0);
  border:1px solid var(--gl-bd-0);
  border-radius:var(--r-sm);
  padding:12px 16px;
  font-size:.9375rem;color:var(--tx-0);
  outline:none;
  transition:border-color var(--t-xs),box-shadow var(--t-xs),background var(--t-xs);
}
.fc::placeholder{color:var(--tx-2)}
.fc:focus{
  border-color:var(--iris);
  background:var(--gl-1);
  box-shadow:0 0 0 3px var(--iris-d);
}
.fc.err{border-color:var(--coral);box-shadow:0 0 0 3px var(--coral-d)}
textarea.fc{resize:vertical;min-height:110px;line-height:1.6}
.fhint{font-size:.76rem;color:var(--tx-2);margin-top:3px}
.ferr{font-size:.76rem;color:var(--coral);margin-top:3px}

/* ══ CARDS ═══════════════════════════════════════════════════ */
.card{
  background:var(--gl-0);
  border:1px solid var(--gl-bd-0);
  border-radius:var(--r-lg);
  overflow:hidden;position:relative;
  backdrop-filter:blur(14px);
  transition:all var(--t-sm) var(--smooth);
}
.card:hover{
  border-color:var(--gl-bd-1);
  transform:translateY(-5px);
  box-shadow:var(--sh-lg),0 0 0 1px var(--gl-bd-0);
}
.card-img{
  width:100%;aspect-ratio:16/9;
  object-fit:cover;
  transition:transform var(--t-md) var(--smooth);
}
.card:hover .card-img{transform:scale(1.04)}
.card-img-wrap{overflow:hidden}
.card-body{padding:22px}
.card-cat{
  font-size:.68rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--iris);margin-bottom:9px;
  display:inline-flex;align-items:center;gap:5px;
}
.card-title{
  font-family:var(--ff-display);
  font-size:1.35rem;font-weight:600;
  color:var(--tx-0);line-height:1.2;
  letter-spacing:-.02em;margin-bottom:9px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  transition:color var(--t-xs);
}
.card:hover .card-title{color:var(--iris)}
.card-exc{
  font-size:.86rem;color:var(--tx-1);line-height:1.65;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  margin-bottom:14px;
}
.card-meta{
  display:flex;align-items:center;gap:10px;
  font-size:.78rem;color:var(--tx-2);
}
.meta-av{
  width:26px;height:26px;border-radius:50%;
  object-fit:cover;border:1.5px solid var(--gl-bd-1);
  flex-shrink:0;
}

/* ══ BADGES / PILLS ══════════════════════════════════════════ */
.pill-member{
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 10px;border-radius:var(--r-oo);
  font-size:.68rem;font-weight:700;
  background:rgba(251,191,36,.12);color:var(--amber);
  border:1px solid rgba(251,191,36,.22);
}
.pill-cat{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 12px;border-radius:var(--r-oo);
  font-size:.76rem;font-weight:500;
  background:var(--gl-0);border:1px solid var(--gl-bd-0);
  color:var(--tx-1);
  transition:all var(--t-xs);
}
.pill-cat:hover{border-color:var(--iris);color:var(--iris);background:var(--iris-d)}
.pill-tag{
  padding:3px 10px;border-radius:var(--r-oo);
  font-size:.72rem;font-weight:500;
  background:var(--gl-0);border:1px solid var(--gl-bd-0);
  color:var(--tx-2);display:inline-block;
}

/* ══ AVATARS ════════════════════════════════════════════════ */
.av{border-radius:50%;object-fit:cover;flex-shrink:0}
.av-xs{width:24px;height:24px}
.av-sm{width:32px;height:32px}
.av-md{width:44px;height:44px}
.av-lg{width:60px;height:60px}
.av-xl{width:84px;height:84px}
.av-border{border:2px solid var(--gl-bd-1)}
.av-ring{
  position:relative;display:inline-block;
}
.av-ring::after{
  content:'';position:absolute;
  bottom:1px;right:1px;
  width:9px;height:9px;
  background:var(--sage);border-radius:50%;
  border:2px solid var(--night-0);
  animation:pulse-online 2s ease-in-out infinite;
}
@keyframes pulse-online{
  0%,100%{box-shadow:0 0 0 0 rgba(74,222,128,.5)}
  50%{box-shadow:0 0 0 5px rgba(74,222,128,0)}
}

/* ══ SECTION HEADINGS ════════════════════════════════════════ */
.eyebrow{
  font-size:.68rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--iris);margin-bottom:7px;
  display:flex;align-items:center;gap:8px;
}
.eyebrow::before{
  content:'';display:block;width:20px;height:1.5px;
  background:var(--iris);border-radius:2px;
}
.section-title{
  font-family:var(--ff-display);
  font-size:clamp(1.9rem,4vw,3rem);
  font-weight:600;line-height:1.1;
  letter-spacing:-.035em;color:var(--tx-0);
}
.section-sub{
  font-size:1rem;color:var(--tx-1);
  margin-top:12px;line-height:1.65;
}

/* ══ TOAST SYSTEM ════════════════════════════════════════════ */
.toast-tray{
  position:fixed;bottom:24px;right:24px;z-index:9999;
  display:flex;flex-direction:column;gap:10px;pointer-events:none;
}
.toast{
  background:var(--gl-2);
  border:1px solid var(--gl-bd-1);
  border-radius:var(--r-md);
  padding:13px 17px;
  backdrop-filter:blur(28px);
  box-shadow:var(--sh-lg);
  display:flex;align-items:center;gap:10px;
  font-size:.86rem;color:var(--tx-0);
  pointer-events:all;max-width:320px;
  animation:toast-in var(--t-sm) var(--spring) both;
}
.toast.out{animation:toast-out var(--t-xs) var(--smooth) both}
@keyframes toast-in{
  from{opacity:0;transform:translateX(18px) scale(.94)}
  to{opacity:1;transform:translateX(0) scale(1)}
}
@keyframes toast-out{
  to{opacity:0;transform:translateX(18px) scale(.94)}
}
.ti{font-size:1.05rem;flex-shrink:0}
.ts .ti::before{content:'✓';color:var(--sage)}
.te .ti::before{content:'✕';color:var(--coral)}
.tn .ti::before{content:'ℹ';color:var(--iris)}
.ts{border-color:rgba(74,222,128,.25)}
.te{border-color:rgba(251,113,133,.25)}
.tn{border-color:rgba(124,111,255,.25)}

/* ══ SKELETON LOADER ══════════════════════════════════════════ */
.skel{
  background:linear-gradient(90deg,var(--gl-0) 25%,var(--gl-1) 50%,var(--gl-0) 75%);
  background-size:200% 100%;
  animation:shimmer 1.6s infinite;
  border-radius:var(--r-xs);
}
@keyframes shimmer{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}

/* ══ SCROLL REVEAL ════════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(22px)}
.reveal.in{
  opacity:1;transform:translateY(0);
  transition:opacity .5s var(--ease-o),transform .5s var(--ease-o);
}

/* ══ READING PROGRESS ════════════════════════════════════════ */
.read-prog{
  position:fixed;top:0;left:0;z-index:9999;
  height:2px;width:0%;
  background:linear-gradient(90deg,var(--iris),var(--teal));
  box-shadow:0 0 10px var(--iris-g);
  transition:width .08s linear;
}

/* ══ SCROLLBAR ════════════════════════════════════════════════ */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.09);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.18)}
*{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.09) transparent}

/* ══ DIVIDER ═════════════════════════════════════════════════ */
.hr{
  border:none;height:1px;
  background:linear-gradient(90deg,transparent,var(--gl-bd-0),transparent);
  margin:40px 0;
}

/* ══ MOBILE NAV ══════════════════════════════════════════════ */
.ham{
  display:none;flex-direction:column;gap:5px;
  width:36px;height:36px;
  align-items:center;justify-content:center;
  border-radius:var(--r-xs);color:var(--tx-1);
}
.ham span{
  width:19px;height:1.5px;background:currentColor;
  border-radius:2px;
  transition:all var(--t-sm) var(--smooth);display:block;
}
.mob-menu{
  /* Right-side slide-in drawer */
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: min(340px, 88vw);
  z-index: 850;
  /* Always in DOM — use transform to hide, NOT display:none */
  display: flex;
  flex-direction: column;
  background: var(--night-0, #050810);
  border-left: 1px solid var(--gl-bd-1);
  box-shadow: -8px 0 48px rgba(0,0,0,.6);
  transform: translateX(100%);
  visibility: hidden;
  transition: transform .3s cubic-bezier(.4,0,.2,1),
              visibility 0s linear .3s;
  overflow-y: auto;
  overflow-x: hidden;
}
.mob-menu.open {
  transform: translateX(0);
  visibility: visible;
  transition: transform .3s cubic-bezier(.4,0,.2,1),
              visibility 0s linear 0s;
}
/* Overlay behind drawer */
.mob-menu-overlay {
  position: fixed; inset: 0; z-index: 840;
  background: rgba(0,0,0,.5);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  opacity: 0;
  visibility: hidden;
  transition: opacity .3s ease, visibility 0s linear .3s;
}
.mob-menu-overlay.show {
  opacity: 1;
  visibility: visible;
  transition: opacity .3s ease, visibility 0s linear 0s;
}

/* Drawer header */
.mob-menu-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px;
  border-bottom: 1px solid var(--gl-bd-0);
  flex-shrink: 0;
}
.mob-menu-brand {
  display: flex; align-items: center; gap: 10px;
  text-decoration: none;
}
.mob-menu-brand-gem {
  width: 32px; height: 32px; border-radius: 8px;
  background: linear-gradient(135deg, var(--iris), var(--teal));
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.mob-menu-brand-name {
  font-family: var(--ff-display);
  font-size: .85rem; font-weight: 600;
  color: var(--tx-0); line-height: 1.2;
}
.mob-menu-close {
  width: 40px; height: 40px;
  border-radius: var(--r-sm);
  display: flex; align-items: center; justify-content: center;
  color: var(--tx-1); cursor: pointer;
  background: var(--gl-1); border: 1px solid var(--gl-bd-1);
  transition: all var(--t-xs);
  flex-shrink: 0;
}
.mob-menu-close:hover { background: rgba(232,68,90,.15); color: var(--coral); border-color: var(--coral); }

/* Nav links inside drawer */
.mob-menu-nav {
  display: flex; flex-direction: column;
  padding: 12px 16px;
  gap: 2px; flex: 1;
}
.mob-menu .nav-a {
  display: flex; align-items: center; gap: 12px;
  padding: 13px 16px;
  font-size: .9rem; font-weight: 500;
  color: var(--tx-1);
  border-radius: var(--r-sm);
  transition: all var(--t-xs);
  border-bottom: none;
}
.mob-menu .nav-a:hover,
.mob-menu .nav-a.on {
  color: var(--tx-0);
  background: var(--gl-1);
}
.mob-menu .nav-a.on { color: var(--iris); }
.mob-menu .nav-a svg { flex-shrink: 0; color: var(--tx-2); }
.mob-menu .nav-a:hover svg,
.mob-menu .nav-a.on svg { color: var(--iris); }
.mob-menu-sep {
  height: 1px; background: var(--gl-bd-0);
  margin: 8px 16px;
}
/* Bottom actions */
.mob-menu-foot {
  padding: 16px;
  border-top: 1px solid var(--gl-bd-0);
  display: flex; flex-direction: column; gap: 10px;
  flex-shrink: 0;
}
.mob-menu-foot .btn {
  width: 100%; justify-content: center;
  padding: 13px 20px;
}
/* Theme row in footer */
.mob-menu-theme {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  padding: 12px 16px;
  background: var(--gl-0);
  border: 1px solid var(--gl-bd-0);
  border-radius: var(--r-sm);
}
.mob-menu-theme-label {
  font-size: .85rem; font-weight: 600; color: var(--tx-1);
  flex: 1; white-space: nowrap;
}
.mob-theme-btn {
  width: 36px !important;
  height: 36px !important;
  min-width: 36px !important;
  border-radius: 50% !important;
  background: var(--gl-1) !important;
  border: 1px solid var(--gl-bd-1) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--tx-1) !important;
  cursor: pointer;
  transition: all var(--t-xs);
  flex-shrink: 0;
}
.mob-theme-btn:hover { background: var(--gl-2) !important; color: var(--tx-0) !important; }
.mob-theme-btn::after { content: none !important; }

/* ══ UTILITY ═════════════════════════════════════════════════ */
.hidden{display:none!important}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}
.tc-iris{color:var(--iris)}
.tc-teal{color:var(--teal)}
.tc-coral{color:var(--coral)}
.tc-amber{color:var(--amber)}
.tc-muted{color:var(--tx-2)}
.fw-display{font-family:var(--ff-display)}
.mt-a{margin-top:auto}
.flex-c{display:flex;align-items:center}
.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}

/* ══════════════════════════════════════════════════════════
   GLOBAL MOBILE FIXES
   ══════════════════════════════════════════════════════════ */

/* Prevent orbs from causing horizontal scroll on mobile */
.orb-layer { contain: strict; }

/* Auth pages: fill full screen on mobile so no background bleed */
@media (max-width: 768px) {
  body { min-height: 100vh; }
  .orb { filter: blur(60px); } /* lighter blur on mobile for perf */
}

/* Mobile nav: ensure theme toggle in nav-cta is hidden (using hamburger instead) */
@media (max-width: 640px) {
  .nav-cta .theme-toggle:not(.mob-menu .theme-toggle) {
    display: none;
  }
}

/* ── Hide desktop nav theme toggle on mobile (hamburger menu has it) ── */
@media (max-width: 640px) {
  .nav-cta > .theme-toggle {
    display: none;
  }
  /* Also ensure hamburger is shown */
  .ham { display: flex; }
}

/* ── Professional focus ring ─────────────────────────────────── */
:focus-visible {
  outline: 2px solid var(--iris);
  outline-offset: 2px;
  border-radius: 3px;
}
button:focus-visible,
a:focus-visible {
  outline: 2px solid var(--iris);
  outline-offset: 3px;
}

/* ── Text selection ──────────────────────────────────────────── */
::selection {
  background: rgba(91, 79, 232, 0.25);
  color: var(--tx-0);
}

/* ── Global: hide desktop nav-links and show hamburger on mobile ── */
@media (max-width: 768px) {
  .nav-links { display: none !important; }
  .ham       { display: flex !important; }
  .nav-cta .btn-glass,
  .nav-cta .btn-primary { display: none !important; }
}

