/* ============================================================
   TOKENS
   ============================================================ */
:root{
  --bg:        #07070C;
  --bg-2:      #0C0C16;
  --bg-3:      #14142A;

  --glass:        rgba(255,255,255,.035);
  --glass-strong: rgba(255,255,255,.06);
  --glass-hi:     rgba(255,255,255,.09);
  --bd:           rgba(255,255,255,.07);
  --bd-hi:        rgba(255,255,255,.16);

  --ink:    #F2F0FA;
  --ink-2:  #C8C5DC;
  --mute:   #6F6D8A;
  --mute-2: #4A4862;

  --violet: #8B7BFF;
  --indigo: #5D5BFF;
  --cyan:   #4FC3DC;
  --pink:   #C77DFF;
  --gold:   #D8C58E;

  /* one signature gradient used everywhere */
  --grad: linear-gradient(135deg, #B5A6FF 0%, #8B7BFF 35%, #4FC3DC 100%);
  --grad-soft: linear-gradient(135deg, rgba(181,166,255,.18), rgba(79,195,220,.18));
  --grad-text: linear-gradient(95deg, #F2F0FA 0%, #D8C58E 40%, #B5A6FF 70%, #4FC3DC 100%);

  --pad: clamp(20px, 4vw, 64px);
  --gutter: clamp(16px, 2vw, 32px);

  --ease:     cubic-bezier(.16,1,.3,1);
  --ease-out: cubic-bezier(.22,1,.36,1);
  --ease-in:  cubic-bezier(.7,0,.84,0);

  --r-sm: 10px;
  --r:    18px;
  --r-lg: 28px;
  --r-xl: 36px;
}

/* ============================================================
   RESET / BASE
   ============================================================ */
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth;background:var(--bg)}
body{
  font-family:'Onest','Helvetica Neue',sans-serif;
  background:var(--bg);
  color:var(--ink);
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  cursor:none;
  line-height:1.4;
}
@media (max-width:980px){ body{cursor:auto} }
a{color:inherit;text-decoration:none;cursor:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:none}
@media (hover:none){body,button,a{cursor:auto}}
img,svg{display:block;max-width:100%}
::selection{background:var(--violet);color:#fff}

/* ============================================================
   ATMOSPHERE — aurora blobs, grain, vignette
   ============================================================ */
.aurora{
  position:fixed;inset:0;z-index:-1;overflow:hidden;pointer-events:none;
  background:radial-gradient(ellipse at 70% -10%, rgba(93,91,255,.18), transparent 50%),
             radial-gradient(ellipse at 0% 90%, rgba(79,195,220,.12), transparent 45%),
             var(--bg);
}
.orb{
  position:absolute;border-radius:50%;filter:blur(110px);opacity:.55;
  will-change:transform;mix-blend-mode:screen;
}
.orb-1{width:620px;height:620px;background:#6B3FA0;top:-220px;left:-180px;animation:drift1 28s ease-in-out infinite}
.orb-2{width:540px;height:540px;background:#2E8DAB;top:30%;right:-220px;animation:drift2 32s ease-in-out infinite}
.orb-3{width:480px;height:480px;background:#3E3F8F;bottom:-200px;left:30%;animation:drift3 26s ease-in-out infinite}
@keyframes drift1{50%{transform:translate(220px,180px) scale(1.15)}}
@keyframes drift2{50%{transform:translate(-180px,-120px) scale(.9)}}
@keyframes drift3{50%{transform:translate(80px,-180px) scale(1.2)}}

.grain{
  position:fixed;inset:0;z-index:90;pointer-events:none;mix-blend-mode:overlay;opacity:.25;
  background-image:url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.92' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .55 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
.vignette{
  position:fixed;inset:0;z-index:85;pointer-events:none;
  background:radial-gradient(ellipse at center, transparent 40%, rgba(0,0,0,.45) 100%);
}

/* glow that follows mouse */
.spot{
  position:fixed;width:600px;height:600px;border-radius:50%;pointer-events:none;z-index:1;
  background:radial-gradient(circle, rgba(181,166,255,.10), transparent 60%);
  transform:translate(-50%,-50%);
  transition:opacity .3s ease;
  filter:blur(20px);
}

/* ============================================================
   CUSTOM CURSOR
   ============================================================ */
.cursor{
  position:fixed;z-index:9999;
  width:12px;height:12px;border-radius:50%;
  background:#fff;
  pointer-events:none;
  left:0;top:0;
  transform:translate(-50%,-50%);
  mix-blend-mode:difference;
  will-change:transform;
  transition:width .15s cubic-bezier(.2,.8,.2,1),
             height .15s cubic-bezier(.2,.8,.2,1),
             background .15s cubic-bezier(.2,.8,.2,1);
}
.cursor-ring{
  position:fixed;z-index:9998;
  width:42px;height:42px;border-radius:50%;
  border:1px solid rgba(255,255,255,.35);
  pointer-events:none;
  left:0;top:0;
  transform:translate(-50%,-50%);
  mix-blend-mode:difference;
  will-change:transform;
  transition:width .18s cubic-bezier(.2,.8,.2,1),
             height .18s cubic-bezier(.2,.8,.2,1),
             border-color .18s cubic-bezier(.2,.8,.2,1);
}
.cursor.lg{width:21px;height:21px}
.cursor-ring.lg{width:90px;height:90px;border-color:rgba(181,166,255,.7);background:rgba(181,166,255,.05)}
.cursor.hide,.cursor-ring.hide{opacity:0}
@media (hover:none){.cursor,.cursor-ring{display:none}}

/* ============================================================
   PAGE-LOAD INTRO
   ============================================================ */
.intro{
  position:fixed;inset:0;z-index:200;background:var(--bg);
  display:grid;place-items:center;
  transition:opacity .8s var(--ease), visibility .8s;
}
.intro.gone{opacity:0;visibility:hidden;pointer-events:none}
.intro-mark{
  display:flex;align-items:center;gap:14px;
  font-family:'Onest',sans-serif;font-weight:500;font-size:clamp(28px,5vw,52px);letter-spacing:-0.04em;
}
.intro-mark .o{
  width:.85em;height:.85em;border-radius:50%;background:var(--grad);
  position:relative;animation:spin 1.2s linear infinite;
}
.intro-mark .o::after{
  content:'';position:absolute;inset:18%;background:var(--bg);border-radius:50%;
}
@keyframes spin{to{transform:rotate(360deg)}}
.intro-bar{
  position:absolute;left:0;bottom:0;height:2px;background:var(--grad);width:0;
  animation:fill 1.6s var(--ease) forwards;
}
@keyframes fill{to{width:100%}}
.intro em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;background:var(--grad-text);background-clip:text;-webkit-background-clip:text;color:transparent}

/* ============================================================
   GLOBAL UTILS
   ============================================================ */
.glass{
  background:var(--glass);
  border:1px solid var(--bd);
  backdrop-filter:blur(18px) saturate(160%);
  -webkit-backdrop-filter:blur(18px) saturate(160%);
  border-radius:var(--r);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06), 0 12px 40px -10px rgba(0,0,0,.5);
}
.pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;border-radius:99px;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.02em;
  background:var(--glass);border:1px solid var(--bd);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  color:var(--ink-2);
}
.pill .live{width:6px;height:6px;border-radius:50%;background:#62E394;box-shadow:0 0 0 3px rgba(98,227,148,.18);animation:pulse 2s infinite}
@keyframes pulse{50%{box-shadow:0 0 0 6px rgba(98,227,148,0)}}

.label{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.06em;color:var(--mute);text-transform:uppercase}
.label .n{
  background:var(--grad-text);background-clip:text;-webkit-background-clip:text;color:transparent;
  font-weight:500;
}

em.grad{
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;
  background:var(--grad-text);background-clip:text;-webkit-background-clip:text;color:transparent;
  padding:0 .04em;
}

/* button base */
.btn{
  position:relative;overflow:hidden;
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;border-radius:99px;
  font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.04em;text-transform:uppercase;
  background:var(--glass-strong);
  border:1px solid var(--bd-hi);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  color:var(--ink);
  cursor:none;
  transition:border-color .35s var(--ease), transform .35s var(--ease);
}
@media (max-width:980px){ .btn{cursor:pointer} }
.btn::before{
  content:'';position:absolute;inset:0;border-radius:99px;
  background:var(--grad);opacity:0;transition:opacity .4s var(--ease);z-index:-1;
}
.btn:hover{border-color:transparent;color:#fff}
.btn:hover::before{opacity:1}
.btn .arrow{width:18px;height:18px;border-radius:50%;background:var(--ink);color:var(--bg);display:grid;place-items:center;font-size:11px;transition:background .35s var(--ease)}
.btn:hover .arrow{background:#fff;color:#000}
.btn.primary{background:var(--grad);border-color:transparent;color:#fff}
.btn.primary::before{opacity:0}
.btn.primary:hover{transform:translateY(-2px);box-shadow:0 18px 50px -12px rgba(139,123,255,.55)}
.btn.primary:disabled{opacity:0.45;pointer-events:none}
.btn.primary .arrow{background:rgba(0,0,0,.25);color:#fff}
.btn.ghost{background:transparent;border-color:var(--bd-hi);color:var(--ink-2)}
.btn.ghost:hover{border-color:var(--violet);color:var(--ink);background:rgba(139,123,255,.06)}
.btn.ghost .arrow{background:var(--mute);color:#fff}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin:clamp(28px,3.5vw,44px) 0 0}

/* reveal helpers */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 1s var(--ease), transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}
.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}

/* word reveal for hero */
.word{display:inline-block;vertical-align:bottom;padding-right:.05em}
.word > span{display:inline-block;transform:translateY(70%);opacity:0;filter:blur(8px);transition:transform 1.2s var(--ease), opacity 1.2s var(--ease), filter 1s var(--ease);will-change:transform,opacity}
.word.in > span{transform:translateY(0);opacity:1;filter:blur(0)}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:60;
  display:flex;align-items:center;gap:28px;
  padding:10px 14px;
  border-radius:99px;
  background:rgba(7,7,12,.55);
  border:1px solid var(--bd);
  backdrop-filter:blur(22px) saturate(160%);
  -webkit-backdrop-filter:blur(22px) saturate(160%);
  font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.04em;
  transition:transform .5s var(--ease), background .35s var(--ease);
  max-width:calc(100% - 24px);
}
.brand{
  display:flex;align-items:center;gap:10px;font-weight:500;letter-spacing:0;font-size:14px;
  padding:0 12px;
}
.brand .o{
  width:18px;height:18px;border-radius:50%;background:var(--grad);position:relative;
  box-shadow:0 0 18px rgba(139,123,255,.55);
}
.brand .o::after{content:'';position:absolute;inset:5px;border-radius:50%;background:var(--bg)}
.brand span{font-family:'Onest',sans-serif;font-weight:500}
.brand em{font-family:'Instrument Serif',serif;font-style:italic;color:var(--mute);font-weight:400}
.nav-mid{display:flex;gap:6px}
.nav-mid a{
  position:relative;padding:8px 14px;border-radius:99px;color:var(--ink-2);
  transition:color .25s, background .25s;
}
.nav-mid a:hover{color:var(--ink);background:var(--glass-strong)}
.nav-end{display:flex;gap:8px;align-items:center}

/* ===========================================================
   MOBILE TOGGLE + FULL-SCREEN OVERLAY MENU
   =========================================================== */
.nav-toggle{
  display:none;
  width:38px;height:38px;border-radius:50%;
  background:var(--glass-strong);
  border:1px solid var(--bd-hi);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  place-items:center;
  cursor:none;
  transition:background .3s var(--ease), border-color .3s var(--ease);
}
@media (hover:none){.nav-toggle{cursor:pointer}}
.nav-toggle > span{
  width:14px;height:10px;position:relative;
  display:flex;flex-direction:column;justify-content:space-between;align-items:stretch;
}
.nav-toggle > span > span{
  display:block;height:1.5px;background:var(--ink);border-radius:2px;
  transition:transform .45s var(--ease), width .35s var(--ease);
  transform-origin:center;
}
.nav-toggle > span > span:first-child{width:100%}
.nav-toggle > span > span:last-child{width:60%;margin-left:auto}
.nav-toggle.open{background:var(--grad);border-color:transparent}
.nav-toggle.open > span > span{width:100%;background:#fff}
.nav-toggle.open > span > span:first-child{transform:translateY(4.5px) rotate(45deg)}
.nav-toggle.open > span > span:last-child{transform:translateY(-4.5px) rotate(-45deg)}

.nav-overlay{
  position:fixed;inset:0;z-index:80;
  opacity:0;visibility:hidden;
  transition:opacity .5s var(--ease), visibility .5s;
  display:flex;flex-direction:column;
  padding: 90px var(--pad) 32px;
  overflow-y:auto;
}
.nav-overlay.open{opacity:1;visibility:visible}
.nav-overlay-bg{
  position:fixed;inset:0;z-index:-1;
  background:rgba(7,7,12,.78);
  backdrop-filter:blur(28px) saturate(140%);
  -webkit-backdrop-filter:blur(28px) saturate(140%);
}
.nav-overlay-bg::before{
  content:'';position:absolute;top:-100px;left:-100px;width:400px;height:400px;border-radius:50%;
  background:var(--grad);opacity:.18;filter:blur(80px);
}
.nav-overlay-bg::after{
  content:'';position:absolute;bottom:-150px;right:-100px;width:380px;height:380px;border-radius:50%;
  background:radial-gradient(circle, #C77DFF, transparent 70%);opacity:.18;filter:blur(80px);
}

.nav-overlay-close{
  position:absolute;
  top:20px;right:var(--pad);
  width:46px;height:46px;border-radius:50%;
  background:rgba(255,255,255,.04);
  border:1px solid var(--bd-hi);
  color:var(--ink);
  display:grid;place-items:center;
  cursor:none;z-index:5;
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  transition:all .35s var(--ease);
  opacity:0;transform:scale(.8) rotate(-90deg);
}
@media (hover:none){.nav-overlay-close{cursor:pointer}}
.nav-overlay.open .nav-overlay-close{
  opacity:1;transform:scale(1) rotate(0);
  transition-delay:.15s;
}
.nav-overlay-close > span{
  font-family:'Onest',sans-serif;font-weight:300;font-size:28px;line-height:1;
  display:block;margin-top:-2px;
  transition:transform .4s var(--ease);
}
.nav-overlay-close:hover{
  background:var(--grad);border-color:transparent;
  box-shadow:0 0 24px rgba(139,123,255,.5);
}
.nav-overlay-close:hover > span{transform:rotate(90deg);color:#fff}

.nav-overlay-inner{
  flex:1;display:flex;flex-direction:column;
  max-width:560px;width:100%;margin:0 auto;
}
.nav-overlay-head{
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  margin-bottom:28px;flex-wrap:wrap;
  opacity:0;transform:translateY(-12px);
  transition:opacity .5s var(--ease) .1s, transform .5s var(--ease) .1s;
}
.nav-overlay.open .nav-overlay-head{opacity:1;transform:none}

.nav-overlay-list{display:flex;flex-direction:column;border-top:1px solid var(--bd)}
.nav-overlay-item{
  display:grid;grid-template-columns: auto 1fr auto;gap:16px;align-items:center;
  padding:20px 4px;border-bottom:1px solid var(--bd);
  font-family:'Onest',sans-serif;font-weight:300;
  font-size:clamp(28px,8vw,44px);letter-spacing:-0.03em;line-height:1;
  color:var(--ink);
  opacity:0;transform:translateX(-24px);
  transition:opacity .6s var(--ease), transform .6s var(--ease), color .3s var(--ease);
  position:relative;
}
.nav-overlay.open .nav-overlay-item{opacity:1;transform:none}
.nav-overlay.open .nav-overlay-item:nth-child(1){transition-delay:.18s, .18s, 0s}
.nav-overlay.open .nav-overlay-item:nth-child(2){transition-delay:.24s, .24s, 0s}
.nav-overlay.open .nav-overlay-item:nth-child(3){transition-delay:.30s, .30s, 0s}
.nav-overlay.open .nav-overlay-item:nth-child(4){transition-delay:.36s, .36s, 0s}
.nav-overlay.open .nav-overlay-item:nth-child(5){transition-delay:.42s, .42s, 0s}
.nav-overlay.open .nav-overlay-item:nth-child(6){transition-delay:.48s, .48s, 0s}
.nav-overlay.open .nav-overlay-item:nth-child(7){transition-delay:.54s, .54s, 0s}

.nav-overlay-item .num{
  font-family:'JetBrains Mono',monospace;font-size:11px;
  color:var(--mute);text-transform:uppercase;letter-spacing:.08em;
  padding-top:6px;align-self:flex-start;
}
.nav-overlay-item .lbl{flex:1;transition:transform .35s var(--ease)}
.nav-overlay-item em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.nav-overlay-item .arrow{
  width:36px;height:36px;border-radius:50%;
  border:1px solid var(--bd);
  display:grid;place-items:center;
  font-size:14px;color:var(--mute);
  transition:all .35s var(--ease);
}
.nav-overlay-item:active .lbl,
.nav-overlay-item:hover .lbl{transform:translateX(6px)}
.nav-overlay-item:active .arrow,
.nav-overlay-item:hover .arrow{background:var(--grad);border-color:transparent;color:#fff;box-shadow:0 0 18px rgba(139,123,255,.5)}

.nav-overlay-item.cta .lbl{
  background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;
}

.nav-overlay-foot{
  margin-top:auto;padding-top:36px;
  display:flex;flex-direction:column;gap:10px;
  opacity:0;transform:translateY(20px);
  transition:opacity .6s var(--ease) .55s, transform .6s var(--ease) .55s;
}
.nav-overlay.open .nav-overlay-foot{opacity:1;transform:none}
.nav-overlay-mail{
  font-family:'Onest',sans-serif;font-size:18px;font-weight:400;color:var(--ink);
  background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.nav-overlay-loc{
  font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--mute);
  text-transform:uppercase;letter-spacing:.06em;
}

@media (max-width:860px){
  .nav-mid{display:none}
  .nav{gap:8px}
  .nav-toggle{display:grid}
  .btn-nav{display:none}
}
.btn-nav{
  padding:0 6px 0 14px;
  height:30px;
  border-radius:99px;
  background:transparent;
  color:var(--ink-2);
  border:1px solid var(--bd);
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.04em;text-transform:uppercase;
  cursor:none;
  display:inline-flex;align-items:center;gap:8px;
  transition:all .3s var(--ease);
  white-space:nowrap;
}
@media (hover:none){ .btn-nav{cursor:pointer} }
.btn-nav .ic{
  width:20px;height:20px;border-radius:50%;
  background:var(--grad);
  display:grid;place-items:center;
  font-size:10px;color:#fff;line-height:1;
  box-shadow:0 0 8px rgba(139,123,255,.35);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
  flex-shrink:0;
}
.btn-nav:hover{
  color:var(--ink);
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.18);
}
.btn-nav:hover .ic{transform:translate(2px,-2px);box-shadow:0 0 14px rgba(139,123,255,.55)}
/* icon-on-left variant (back button inside portal): pad left, invert hover motion */
.btn-nav:has(> .ic:first-child){padding:0 14px 0 6px}
.btn-nav:hover > .ic:first-child{transform:translate(-2px,-2px)}
@media (max-width:860px){ .nav{gap:12px} }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:100vh;
  padding: 140px var(--pad) 40px;
  display:flex;flex-direction:column;justify-content:flex-end;
  overflow:hidden;
}
.hero-top{
  position:absolute;top:120px;left:var(--pad);right:var(--pad);
  display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;
}
.hero h1{
  font-family:'Onest',sans-serif;
  font-weight:400;
  font-size: clamp(56px, 11vw, 180px);
  line-height:.95;
  letter-spacing:-0.04em;
  margin-bottom:auto;
  position:relative;
  max-width:14ch;
}
.hero h1 .row{display:block;overflow:visible}
.hero h1 em{
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;
  background:var(--grad-text);background-clip:text;-webkit-background-clip:text;color:transparent;
  letter-spacing:-0.02em;
}
.hero-foot{
  display:grid;grid-template-columns: 1fr auto auto;align-items:end;gap:32px;
  margin-top: 60px;padding-top:32px;border-top:1px solid var(--bd);
}
.hero-foot p{
  max-width:38ch;color:var(--ink-2);line-height:1.55;font-size:16px;
}
.hero-stats{display:flex;gap:32px;font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--mute)}
.hero-stats div b{display:block;font-family:'Onest',sans-serif;font-weight:500;font-size:28px;letter-spacing:-0.02em;color:var(--ink);background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:2px}
.scroll-cue{display:flex;flex-direction:column;align-items:center;gap:10px;font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--mute)}
.scroll-cue .line{width:1px;height:36px;background:linear-gradient(180deg,var(--violet),transparent);transform-origin:top;animation:scroll-dash 2.4s var(--ease) infinite}
@keyframes scroll-dash{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* marquee */
.marquee{
  overflow:hidden;white-space:nowrap;
  padding:32px 0;
  border-block:1px solid var(--bd);
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.02), transparent);
}
.marquee-track{display:inline-flex;gap:48px;animation:slide 32s linear infinite;will-change:transform;font-family:'Onest',sans-serif;font-weight:300;font-size:clamp(28px,4.4vw,68px);line-height:1;letter-spacing:-0.03em;color:var(--ink-2)}
.marquee-track > span{display:inline-flex;align-items:center;gap:48px}
.marquee em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.marquee .star{
  width:18px;height:18px;border-radius:50%;background:var(--grad);
  box-shadow:0 0 16px rgba(139,123,255,.6);
  flex-shrink:0;
}
@keyframes slide{to{transform:translateX(-50%)}}

/* Form steps — number + label split so we can hide labels on small screens */
.step-num{font-weight:500}
.step-lbl{font-weight:400;opacity:.85}
.step-lbl::before{content:' / ';opacity:.5}

/* ============================================================
   SECTIONS / HEADERS
   ============================================================ */
.section{padding: clamp(80px,12vh,160px) var(--pad);position:relative}
.sec-head{
  display:grid;grid-template-columns: 280px 1fr;gap: var(--gutter);
  align-items:start;margin-bottom:72px;
}
.sec-head h2{
  font-family:'Onest',sans-serif;font-weight:400;
  font-size: clamp(40px,5.8vw,88px);
  line-height:1;letter-spacing:-0.04em;max-width:18ch;
}
.sec-head h2 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;background:var(--grad-text);background-clip:text;-webkit-background-clip:text;color:transparent}
.sec-head p{
  color:var(--mute);max-width:48ch;margin-top:16px;font-size:15px;line-height:1.55;
}
@media (max-width:860px){
  .sec-head{grid-template-columns:1fr;gap:18px}
}

/* ============================================================
   MANIFESTO
   ============================================================ */
.manifesto{
  display:grid;grid-template-columns: 1.3fr 1fr;gap: clamp(40px,6vw,100px);align-items:end;
}
.manifesto-text{font-size:clamp(22px,2.4vw,32px);font-weight:300;line-height:1.3;letter-spacing:-0.015em;color:var(--ink-2);max-width:30ch}
.manifesto-text em{font-family:'Instrument Serif',serif;font-style:italic;color:var(--ink);background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.metrics{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.metric{
  background:var(--glass);border:1px solid var(--bd);border-radius:var(--r);
  padding:24px;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  position:relative;overflow:hidden;
}
.metric::before{
  content:'';position:absolute;top:-50%;right:-30%;width:200px;height:200px;
  background:var(--grad);opacity:.05;filter:blur(40px);border-radius:50%;
}
.metric b{
  display:block;font-family:'Onest',sans-serif;font-weight:400;
  font-size:clamp(36px,4.4vw,56px);letter-spacing:-0.03em;line-height:1;
  background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;
  margin-bottom:8px;
}
.metric span{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--mute)}
@media (max-width:860px){ .manifesto{grid-template-columns:1fr} }

/* ============================================================
   SERVICES
   ============================================================ */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gutter)}
@media (max-width:1100px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:700px){.svc-grid{grid-template-columns:1fr}}
.svc{
  position:relative;
  background:var(--glass);
  border:1px solid var(--bd);
  border-radius:var(--r-lg);
  padding:32px 28px;
  overflow:hidden;
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  transition:transform .5s var(--ease), border-color .5s var(--ease), background .5s var(--ease);
}
.svc::before{
  content:'';position:absolute;inset:-1px;border-radius:inherit;padding:1px;
  background:var(--grad);opacity:0;
  -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  transition:opacity .5s var(--ease);
  pointer-events:none;
}
.svc::after{
  content:'';position:absolute;top:-50%;right:-30%;width:80%;height:120%;
  background:var(--grad);opacity:0;filter:blur(60px);
  transition:opacity .6s var(--ease);pointer-events:none;
}
.svc:hover{transform:translateY(-6px);background:rgba(255,255,255,.05)}
.svc:hover::before{opacity:1}
.svc:hover::after{opacity:.15}
.svc-n{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.06em;color:var(--mute);margin-bottom:60px;display:flex;justify-content:space-between;align-items:center}
.svc-n .arrow{width:30px;height:30px;border-radius:50%;border:1px solid var(--bd);display:grid;place-items:center;color:var(--ink-2);transition:all .4s var(--ease)}
.svc:hover .svc-n .arrow{background:var(--grad);color:#fff;border-color:transparent;transform:rotate(45deg)}
.svc h3{font-family:'Onest',sans-serif;font-weight:400;font-size:clamp(24px,2.6vw,32px);letter-spacing:-0.025em;line-height:1.1;margin-bottom:10px}
.svc h3 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.svc p{color:var(--mute);font-size:14px;line-height:1.55;max-width:32ch}
.svc-tags{margin-top:18px;display:flex;flex-wrap:wrap;gap:6px;font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--mute-2)}
.svc-tags span{padding:4px 8px;border-radius:99px;background:rgba(255,255,255,.03);border:1px solid var(--bd);color:var(--mute);position:relative;z-index:1}

/* ============================================================
   WORK GRID
   ============================================================ */
.work{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--gutter)}
.work-item{
  position:relative;overflow:hidden;border-radius:var(--r-lg);
  background:var(--glass);border:1px solid var(--bd);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  cursor:none;
  transition:transform .6s var(--ease);
}
@media (max-width:980px){ .work-item{cursor:pointer} }
.work-item:nth-child(1){grid-column:1/8;aspect-ratio:16/10}
.work-item:nth-child(2){grid-column:8/13;aspect-ratio:5/6;margin-top:80px}
.work-item:nth-child(3){grid-column:1/6;aspect-ratio:5/6}
.work-item:nth-child(4){grid-column:6/13;aspect-ratio:16/10;margin-top:60px}
.work-item:nth-child(5){grid-column:1/13;aspect-ratio:21/8}
/* 3-item layout */
.work-item:nth-child(3):last-child{grid-column:1/13;aspect-ratio:21/8;margin-top:0}
@media (max-width:900px){
  .work-item{grid-column:1/-1!important;margin-top:0!important;aspect-ratio:4/3}
}
.work-visual{position:absolute;inset:0;transition:transform 1s var(--ease)}
.work-item:hover .work-visual{transform:scale(1.06)}
.work-visual.has-thumb{overflow:hidden}
.work-visual.has-thumb img{position:absolute;inset:0;width:100%!important;height:100%!important;max-width:none;object-fit:cover;object-position:top center;display:block}

/* visual variants — each a unique gradient/scene */
.v1{
  background:
    radial-gradient(circle at 30% 60%, rgba(199,125,255,.6), transparent 50%),
    radial-gradient(circle at 70% 30%, rgba(79,195,220,.5), transparent 50%),
    linear-gradient(135deg,#1A0F33 0%,#0A0820 100%);
}
.v1::before{
  content:'';position:absolute;inset:24%;border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.18) 0%, transparent 70%);
  filter:blur(20px);
}
.v1::after{
  content:'HALCYON';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  font-family:'Onest',sans-serif;font-weight:300;font-size:clamp(28px,5vw,68px);letter-spacing:-0.04em;
  color:rgba(255,255,255,.92);text-shadow:0 0 40px rgba(255,255,255,.5);
}
.v2{
  background:linear-gradient(160deg,#0F1E3A 0%,#06091A 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:32px;
}
.v2-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:80%;max-width:240px}
.v2-grid div{aspect-ratio:1;border-radius:8px;background:rgba(255,255,255,.06);border:1px solid var(--bd)}
.v2-grid div:nth-child(2){background:var(--grad)}
.v2-grid div:nth-child(5){background:rgba(255,255,255,.16)}
.v2-grid div:nth-child(7){background:rgba(216,197,142,.4)}
.v2-cap{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--mute);text-transform:uppercase;letter-spacing:.1em}
.v3{
  background:linear-gradient(180deg,#1A1430 0%,#0A0820 100%);
  display:grid;place-items:center;
}
.v3::before{
  content:'';position:absolute;width:70%;aspect-ratio:1;border-radius:50%;
  background:conic-gradient(from 0deg, transparent, var(--violet), transparent 60%);
  animation:spin 14s linear infinite;filter:blur(8px);opacity:.5;
}
.v3::after{
  content:'';position:absolute;width:50%;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle, var(--bg) 60%, rgba(255,255,255,.1));
  border:1px solid var(--bd);
}
.v3 .v3-mid{
  position:relative;z-index:2;width:34%;aspect-ratio:1;border-radius:50%;
  background:var(--grad);box-shadow:0 0 60px rgba(139,123,255,.55), inset 0 0 30px rgba(255,255,255,.3);
}
.v4{
  background:radial-gradient(circle at 20% 30%,rgba(216,197,142,.4),transparent 50%), linear-gradient(180deg,#1F1A0A 0%,#0A0805 100%);
  display:flex;align-items:center;justify-content:center;padding:36px;
  font-family:'Instrument Serif',serif;font-style:italic;
  color:rgba(255,255,255,.95);font-size:clamp(36px,6vw,84px);line-height:.95;letter-spacing:-0.01em;
  text-align:center;
  transition:opacity .5s var(--ease), transform 1s var(--ease);
}
.work-item:hover .v4{opacity:.35}
.v4::before{
  content:'';position:absolute;top:24px;right:24px;width:40px;height:40px;border-radius:50%;
  background:var(--gold);box-shadow:0 0 30px rgba(216,197,142,.6);
}
.v5{
  background:
    radial-gradient(ellipse at 80% 50%, rgba(79,195,220,.35), transparent 50%),
    radial-gradient(ellipse at 20% 50%, rgba(139,123,255,.25), transparent 50%),
    linear-gradient(180deg,#0A1428 0%,#020610 100%);
  display:flex;align-items:center;justify-content:center;gap:40px;padding:0 6vw;
}
.v5 .big{
  font-family:'Onest',sans-serif;font-weight:300;
  font-size:clamp(40px,9vw,140px);letter-spacing:-0.04em;line-height:.9;color:rgba(255,255,255,.95);
}
.v5 .big em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}

.work-tag{
  position:absolute;top:20px;left:20px;z-index:3;
  display:inline-flex;align-items:center;gap:8px;
  font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.08em;
  background:rgba(7,7,12,.6);border:1px solid var(--bd);padding:6px 10px;border-radius:99px;
  backdrop-filter:blur(12px);
}
.work-tag .live{width:6px;height:6px;border-radius:50%;background:#62E394;box-shadow:0 0 8px #62E394}
.work-info{
  position:absolute;left:0;right:0;bottom:0;z-index:3;
  padding:24px;
  background:linear-gradient(180deg, transparent, rgba(7,7,12,.85));
  display:flex;justify-content:space-between;align-items:flex-end;gap:16px;
  opacity:0;transform:translateY(20px);
  transition:opacity .5s var(--ease), transform .5s var(--ease);
}
.work-item:hover .work-info{opacity:1;transform:translateY(0)}
.work-info h3{font-family:'Onest',sans-serif;font-weight:500;font-size:clamp(20px,2.4vw,30px);letter-spacing:-0.02em;line-height:1;margin-bottom:6px}
.work-info h3 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.work-info .meta{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--mute);text-transform:uppercase;letter-spacing:.06em}
.work-info .view{
  width:48px;height:48px;border-radius:50%;background:var(--grad);
  display:grid;place-items:center;color:#fff;font-size:18px;
  box-shadow:0 12px 30px -6px rgba(139,123,255,.5);
}

/* ============================================================
   PROCESS — sticky scroll
   =========================================================== */
.process{display:grid;grid-template-columns: 360px 1fr;gap: clamp(40px,5vw,80px);align-items:start}
.process-track{position:sticky;top:130px;align-self:start}
.process-track-inner{
  background:var(--glass);border:1px solid var(--bd);border-radius:var(--r-lg);
  padding:28px 24px;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  display:grid;gap:14px;
  position:relative;overflow:hidden;
}
.process-track-inner::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad);opacity:.5;
}
.track-title{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--mute);margin-bottom:6px}
.track-item{
  display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;
  padding:14px;border-radius:14px;cursor:none;
  transition:background .3s var(--ease);
}
@media (max-width:980px){ .track-item{cursor:pointer} }
.track-item:hover{background:rgba(255,255,255,.03)}
.track-item.active{background:rgba(255,255,255,.05)}
.track-n{
  width:34px;height:34px;border-radius:50%;
  background:rgba(255,255,255,.04);border:1px solid var(--bd);
  display:grid;place-items:center;
  font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--mute);
  transition:all .4s var(--ease);
}
.track-item.active .track-n{background:var(--grad);color:#fff;border-color:transparent;box-shadow:0 0 24px rgba(139,123,255,.4)}
.track-item b{display:block;font-family:'Onest',sans-serif;font-weight:500;font-size:14px;color:var(--ink-2);letter-spacing:-0.005em;line-height:1.2;margin-bottom:2px}
.track-item.active b{color:var(--ink)}
.track-item small{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--mute);text-transform:uppercase;letter-spacing:.06em}
.track-item .dur{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--mute);text-transform:uppercase;letter-spacing:.06em}

.stages{display:grid;gap:18px}
.stage{
  position:relative;
  background:var(--glass);border:1px solid var(--bd);border-radius:var(--r-lg);
  padding:36px;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  display:grid;grid-template-columns: 50px 1fr auto;gap:24px;align-items:start;
  overflow:hidden;
  transition:border-color .4s var(--ease), background .4s var(--ease);
}
.stage::before{
  content:'';position:absolute;top:-100px;right:-100px;width:260px;height:260px;border-radius:50%;
  background:var(--grad);opacity:0;filter:blur(60px);
  transition:opacity .6s var(--ease);
}
.stage:hover{background:rgba(255,255,255,.04);border-color:var(--bd-hi)}
.stage:hover::before{opacity:.18}
.stage-n{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--mute);letter-spacing:.04em}
.stage h3{font-family:'Onest',sans-serif;font-weight:400;font-size:clamp(24px,3vw,38px);letter-spacing:-0.025em;line-height:1.05;margin-bottom:12px}
.stage h3 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.stage p{color:var(--ink-2);font-size:15px;line-height:1.55;max-width:54ch}
.stage-deliv{margin-top:18px;display:flex;flex-wrap:wrap;gap:6px;font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.06em}
.stage-deliv span{padding:4px 10px;border-radius:99px;background:rgba(255,255,255,.04);border:1px solid var(--bd);color:var(--mute)}
.stage-week{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--mute);text-transform:uppercase;letter-spacing:.06em;text-align:right;white-space:nowrap}
.stage-week b{display:block;font-family:'Onest',sans-serif;font-weight:500;font-size:24px;color:var(--ink);background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:2px;letter-spacing:-0.02em}

@media (max-width:980px){
  .process{grid-template-columns:1fr}
  .process-track{position:static}
  .stage{grid-template-columns:auto 1fr;gap:16px;padding:24px}
  .stage-week{grid-column:1/-1}
}

/* ============================================================
   PRICING
   ============================================================ */
.pricing{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gutter)}
@media (max-width:1200px){.pricing{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.pricing{grid-template-columns:1fr}}
.tier{
  position:relative;
  background:var(--glass);border:1px solid var(--bd);border-radius:var(--r-lg);
  padding:30px 26px;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  display:flex;flex-direction:column;gap:18px;overflow:hidden;
  transition:transform .5s var(--ease), border-color .5s var(--ease);
}
.tier:hover{transform:translateY(-4px);border-color:var(--bd-hi)}
.tier.featured{
  border-color:transparent;
  background:
    linear-gradient(180deg, rgba(139,123,255,.10), rgba(79,195,220,.05)),
    rgba(255,255,255,.04);
}
.tier.featured::before{
  content:'';position:absolute;inset:-1px;border-radius:inherit;padding:1px;
  background:var(--grad);
  -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  pointer-events:none;
}
.tier.featured::after{
  content:'';position:absolute;top:-100px;right:-50px;width:300px;height:300px;border-radius:50%;
  background:var(--grad);opacity:.12;filter:blur(60px);pointer-events:none;
}
.tier-head{display:flex;justify-content:space-between;align-items:center;font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--mute)}
.tier-head .pill-pop{background:var(--grad);color:#fff;padding:4px 10px;border-radius:99px;font-size:10px;letter-spacing:.06em}
.tier h3{font-family:'Onest',sans-serif;font-weight:400;font-size:clamp(22px,2.2vw,30px);letter-spacing:-0.03em;line-height:1.05}
.tier h3 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.tier-price{
  display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;
  font-family:'Onest',sans-serif;font-weight:400;font-size:24px;letter-spacing:-0.02em;
  padding-bottom:16px;border-bottom:1px solid var(--bd);
}
.tier-price small{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--mute);font-weight:400}
.tier ul{list-style:none;display:grid;gap:12px}
.tier ul li{font-size:14px;color:var(--ink-2);display:flex;gap:10px;align-items:flex-start;line-height:1.45}
.tier ul li::before{
  content:'';width:14px;height:14px;border-radius:50%;background:var(--grad);flex-shrink:0;margin-top:3px;
  box-shadow:inset 0 0 0 3px var(--bg);
}
.tier-cta{margin-top:auto}

.price-note{
  margin-top:28px;
  background:var(--glass);border:1px solid var(--bd);border-radius:var(--r);
  padding:18px 26px;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  display:grid;grid-template-columns:auto 1fr 1fr 1fr;gap:28px;align-items:center;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.04em;
  color:var(--mute-2);text-transform:uppercase;
}
.price-note .lbl{
  background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;
  font-weight:500;letter-spacing:.06em;display:flex;align-items:center;gap:8px;
}
.price-note .lbl::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--grad);box-shadow:0 0 8px rgba(139,123,255,.6)}
.price-note span{color:var(--ink-2)}
@media (max-width:980px){
  .price-note{grid-template-columns:1fr;gap:12px;padding:18px 22px}
}

/* ============================================================
   CLIENT LOGOS STRIP
   ============================================================ */
.logos{
  padding: 28px var(--pad);
  border-block:1px solid var(--bd);
  background:rgba(255,255,255,.012);
  display:flex;flex-direction:column;gap:18px;align-items:center;
  position:relative;overflow:hidden;
}
.logos-label{
  font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.1em;
  color:var(--mute);
}
.logos-row{
  display:flex;align-items:center;justify-content:center;flex-wrap:wrap;
  gap:18px 36px;
  font-family:'Onest',sans-serif;font-weight:500;font-size:clamp(15px,1.6vw,20px);letter-spacing:.04em;
  color:var(--ink-2);text-transform:uppercase;
  filter:grayscale(.4);opacity:.85;
}
.logos-row em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;letter-spacing:0;text-transform:none;color:var(--ink-2)}
.logos-row .sep{
  font-family:'Instrument Serif',serif;font-style:italic;color:var(--violet);font-size:14px;opacity:.6;
}

/* ============================================================
   FOUNDERS
   ============================================================ */
.founders{
  display:grid;grid-template-columns:1fr 1fr;gap:var(--gutter);
  margin-top:64px;padding-top:48px;border-top:1px solid var(--bd);
}
@media (max-width:780px){.founders{grid-template-columns:1fr;gap:18px}}
.founder{
  display:flex;gap:18px;align-items:flex-start;
  background:var(--glass);border:1px solid var(--bd);
  border-radius:var(--r);padding:22px;
  backdrop-filter:blur(14px);
  transition:border-color .35s var(--ease), transform .35s var(--ease);
}
.founder:hover{border-color:var(--bd-hi);transform:translateY(-3px)}
.founder-avatar{
  width:62px;height:62px;border-radius:50%;flex-shrink:0;
  position:relative;overflow:hidden;
  box-shadow:0 8px 22px -6px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.15);
}
.founder-avatar::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 30% 35%, rgba(255,255,255,.25), transparent 50%);
}
.founder-1{
  background:
    radial-gradient(circle at 30% 30%, #C77DFF, transparent 60%),
    linear-gradient(135deg, #6B3FA0, #2E1A4C);
}
.founder-2{
  background:
    radial-gradient(circle at 70% 30%, #4FC3DC, transparent 60%),
    linear-gradient(135deg, #1A4A6B, #0A2538);
}
.founder b{
  display:block;font-family:'Onest',sans-serif;font-weight:500;
  font-size:18px;letter-spacing:-0.01em;line-height:1.1;margin-bottom:2px;
}
.founder span{
  display:block;font-family:'JetBrains Mono',monospace;font-size:11px;
  color:var(--mute);text-transform:uppercase;letter-spacing:.04em;margin-bottom:10px;
}
.founder span em{font-family:'Instrument Serif',serif;font-style:italic;text-transform:none;letter-spacing:0;background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.founder p{font-size:14px;line-height:1.5;color:var(--ink-2)}

/* ============================================================
   FAQ ACCORDION
   ============================================================ */
.faq-list{display:grid;gap:8px;max-width:920px;margin:0 auto}
.faq-item{
  background:var(--glass);border:1px solid var(--bd);
  border-radius:var(--r);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  overflow:hidden;
  transition:border-color .3s var(--ease), background .3s var(--ease);
}
.faq-item[open]{
  background:rgba(255,255,255,.04);
  border-color:var(--bd-hi);
}
.faq-item summary{
  list-style:none;cursor:pointer;
  padding:22px 26px;
  display:flex;justify-content:space-between;align-items:center;gap:18px;
  font-family:'Onest',sans-serif;font-weight:400;
  font-size:clamp(16px,1.6vw,19px);letter-spacing:-0.01em;line-height:1.3;
  color:var(--ink);
  transition:color .25s var(--ease);
  user-select:none;
}
@media (hover:none){.faq-item summary{cursor:pointer}}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:'+';
  width:34px;height:34px;border-radius:50%;
  border:1px solid var(--bd);
  display:grid;place-items:center;
  font-family:'JetBrains Mono',monospace;font-size:20px;font-weight:300;line-height:1;
  color:var(--mute);
  transition:transform .4s var(--ease), background .35s var(--ease), border-color .35s var(--ease), color .35s var(--ease), box-shadow .35s var(--ease);
  flex-shrink:0;
}
.faq-item:hover summary{color:var(--ink)}
.faq-item:hover summary::after{border-color:var(--bd-hi);color:var(--ink)}
.faq-item[open] summary::after{
  background:var(--grad);color:#fff;border-color:transparent;transform:rotate(45deg);
  box-shadow:0 0 18px rgba(139,123,255,.45);
}
.faq-item.closing summary::after{
  transform:rotate(0deg);
  background:transparent;color:var(--mute);border-color:var(--bd);box-shadow:none;
}
.faq-item[open] summary{color:var(--ink)}
.faq-body-wrap{
  display:grid;
  grid-template-rows:0fr;
  transition:grid-template-rows .42s var(--ease);
}
.faq-item[open] .faq-body-wrap{grid-template-rows:1fr}
.faq-item.closing .faq-body-wrap{grid-template-rows:0fr}
.faq-body{
  min-height:0;overflow:hidden;
  padding:0 26px 22px;
  color:var(--ink-2);font-size:15px;line-height:1.6;max-width:72ch;
  opacity:0;transform:translateY(-6px);
  transition:opacity .3s var(--ease) .12s, transform .3s var(--ease) .12s;
}
.faq-item[open] .faq-body{opacity:1;transform:translateY(0)}
.faq-item.closing .faq-body{opacity:0;transform:translateY(-4px);transition-delay:0s}

/* Investment / approach section (no specific prices) ----- */
.invest-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gutter);margin-bottom:28px}
@media (max-width:980px){.invest-grid{grid-template-columns:1fr}}

.invest-card{
  position:relative;
  background:var(--glass);border:1px solid var(--bd);border-radius:var(--r-lg);
  padding:32px 28px;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  display:flex;flex-direction:column;gap:14px;
  overflow:hidden;
  transition:transform .5s var(--ease), border-color .5s var(--ease);
}
.invest-card:hover{transform:translateY(-4px);border-color:var(--bd-hi)}
.invest-card::before{
  content:'';position:absolute;top:-60%;right:-30%;width:80%;height:140%;
  background:var(--grad);opacity:0;filter:blur(70px);
  transition:opacity .6s var(--ease);pointer-events:none;
}
.invest-card:hover::before{opacity:.14}
.invest-icon{
  width:46px;height:46px;border-radius:14px;
  background:var(--grad);
  display:grid;place-items:center;
  font-family:'Onest',sans-serif;font-weight:400;font-size:22px;color:#fff;line-height:1;
  box-shadow:0 10px 26px -6px rgba(139,123,255,.4), inset 0 1px 0 rgba(255,255,255,.2);
}
.invest-card h3{font-family:'Onest',sans-serif;font-weight:400;font-size:clamp(22px,2.4vw,28px);letter-spacing:-0.025em;line-height:1.1;margin-top:6px}
.invest-card h3 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.invest-card p{color:var(--mute);font-size:14px;line-height:1.55;max-width:36ch}

.invest-cta{
  background:var(--glass);border:1px solid var(--bd);border-radius:var(--r-lg);
  padding:clamp(28px,3vw,40px);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap;
  position:relative;overflow:hidden;
}
.invest-cta::before{
  content:'';position:absolute;top:-150px;right:-100px;width:340px;height:340px;border-radius:50%;
  background:var(--grad);opacity:.14;filter:blur(70px);pointer-events:none;
}
.invest-cta::after{
  content:'';position:absolute;bottom:-100px;left:-80px;width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle, #C77DFF, transparent 70%);opacity:.10;filter:blur(60px);pointer-events:none;
}
.invest-cta-text{position:relative;max-width:46ch}
.invest-cta h3{font-family:'Onest',sans-serif;font-weight:400;font-size:clamp(22px,2.6vw,30px);letter-spacing:-0.025em;line-height:1.15;margin-bottom:8px}
.invest-cta h3 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.invest-cta p{color:var(--mute);font-size:14px;line-height:1.55}
.invest-cta .btn{position:relative;flex-shrink:0}

/* ============================================================
   START / SIGNUP FORM
   ============================================================ */
.start-wrap{
  display:grid;grid-template-columns: 380px 1fr;gap: clamp(32px,5vw,80px);
  align-items:stretch;
}
.start-side{
  display:flex;flex-direction:column;gap:18px;
}
.side-card{
  background:var(--glass);border:1px solid var(--bd);border-radius:var(--r);
  padding:22px;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
}
.side-card b{display:block;font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--mute);margin-bottom:8px;font-weight:500}
.side-card div{font-size:15px;color:var(--ink-2);line-height:1.5}
.side-card div em{font-family:'Instrument Serif',serif;font-style:italic;color:var(--ink);background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.start-flow{display:grid;gap:14px;font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--mute);text-transform:uppercase;letter-spacing:.06em}
.start-flow div{display:flex;gap:12px;align-items:flex-start}
.start-flow div::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--grad);margin-top:6px;flex-shrink:0;box-shadow:0 0 10px rgba(139,123,255,.6)}

/* the last side card grows to match the form's height */
.side-card-grow{
  flex:1;display:flex;flex-direction:column;
}
.side-card-grow .start-flow{
  flex:1;justify-content:space-between;
}

.form{
  background:var(--glass);border:1px solid var(--bd);border-radius:var(--r-lg);
  padding:clamp(28px,3.6vw,48px);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  position:relative;
}
.form::before{
  content:'';position:absolute;top:-200px;right:-200px;width:400px;height:400px;border-radius:50%;
  background:var(--grad);opacity:.08;filter:blur(80px);pointer-events:none;
}
.steps{display:flex;gap:8px;margin-bottom:36px;position:relative;z-index:1}
.step{
  flex:1;padding:12px 14px;border-radius:99px;
  font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.08em;
  background:rgba(255,255,255,.03);border:1px solid var(--bd);color:var(--mute);
  transition:all .4s var(--ease);
  display:flex;align-items:center;gap:8px;
}
.step.active{background:var(--grad);color:#fff;border-color:transparent;box-shadow:0 8px 24px -6px rgba(139,123,255,.5)}
.step.done{background:rgba(98,227,148,.08);border-color:rgba(98,227,148,.3);color:#62E394}
.step .dot{width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.7}

.pane{display:none;animation:fadeUp .6s var(--ease)}
.pane.active{display:grid;gap:22px;position:relative;z-index:1}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}}

.field{display:grid;gap:8px}
.field label{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--mute)}
.field input, .field select, .field textarea{
  background:rgba(255,255,255,.025);
  border:1px solid var(--bd);
  border-radius:12px;
  padding:14px 16px;
  color:var(--ink);font-family:'Onest',sans-serif;font-size:16px;
  outline:none;transition:border-color .3s var(--ease), background .3s var(--ease);
}
.field input:focus, .field textarea:focus, .field select:focus{border-color:var(--violet);background:rgba(139,123,255,.06)}
.field input::placeholder, .field textarea::placeholder{color:var(--mute-2)}
.field textarea{resize:vertical;min-height:100px;font-family:'Onest',sans-serif}
.field select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='%237E7E9C' viewBox='0 0 16 16'><path d='M3 6l5 5 5-5z'/></svg>");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.field select option{background:var(--bg);color:var(--ink)}

/* Custom glass dropdown ----------------------------------- */
.select{position:relative}
.select-trigger{
  width:100%;
  background:rgba(255,255,255,.025);
  border:1px solid var(--bd);
  border-radius:12px;
  padding:14px 16px;
  color:var(--ink);
  font-family:'Onest',sans-serif;font-size:16px;
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  cursor:none;text-align:left;
  transition:border-color .3s var(--ease), background .3s var(--ease);
}
@media (hover:none){.select-trigger{cursor:pointer}}
.select-trigger:hover{border-color:var(--bd-hi)}
.select.open .select-trigger{border-color:var(--violet);background:rgba(139,123,255,.06)}
.select-value{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.select-value.placeholder{color:var(--mute-2)}
.select-arrow{
  font-size:11px;color:var(--mute);
  font-family:'JetBrains Mono',monospace;
  transition:transform .35s var(--ease), color .35s var(--ease);
  flex-shrink:0;
}
.select.open .select-arrow{transform:rotate(180deg);color:var(--ink)}

.select-menu{
  position:absolute;top:calc(100% + 8px);left:0;right:0;
  background:rgba(14,14,24,.85);
  border:1px solid var(--bd-hi);
  border-radius:14px;
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  padding:6px;z-index:30;
  opacity:0;visibility:hidden;
  transform:translateY(-8px) scale(.98);transform-origin:top center;
  transition:opacity .25s var(--ease), transform .3s var(--ease), visibility .25s;
  box-shadow:
    0 24px 50px -16px rgba(0,0,0,.7),
    0 0 0 1px rgba(139,123,255,.08),
    inset 0 1px 0 rgba(255,255,255,.06);
  max-height:260px;overflow-y:auto;
}
.select.open .select-menu{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
/* gradient top accent */
.select-menu::before{
  content:'';position:sticky;top:-6px;display:block;height:1px;margin:-6px -6px 6px;
  background:var(--grad);opacity:.4;
}
.select-opt{
  padding:11px 14px;border-radius:8px;
  font-family:'Onest',sans-serif;font-size:14px;color:var(--ink-2);
  cursor:none;
  transition:background .2s var(--ease), color .2s var(--ease), padding .25s var(--ease);
  display:flex;justify-content:space-between;align-items:center;gap:10px;
}
@media (hover:none){.select-opt{cursor:pointer}}
.select-opt:hover{background:rgba(255,255,255,.05);color:var(--ink);padding-left:18px}
.select-opt.selected{background:rgba(139,123,255,.12);color:var(--ink)}
.select-opt.selected::after{
  content:'✓';font-family:'JetBrains Mono',monospace;font-size:11px;
  background:var(--grad);color:#fff;
  width:18px;height:18px;border-radius:50%;
  display:grid;place-items:center;
  box-shadow:0 0 10px rgba(139,123,255,.5);
}
/* nice scrollbar inside menu */
.select-menu::-webkit-scrollbar{width:6px}
.select-menu::-webkit-scrollbar-track{background:transparent}
.select-menu::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:99px}
.select-menu::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.2)}

.fields-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}

/* "Other" reveal — slides in below the select when Other/Something else is picked */
.field-other{
  display:none;
}
.field-other.show{
  display:block;
  animation:fadeUp .35s var(--ease);
  margin-top:10px;
}
.field-other input{
  width:100%;
  background:rgba(255,255,255,.025);
  border:1px solid var(--bd-hi);
  border-radius:12px;
  padding:13px 16px;
  color:var(--ink);font-family:'Onest',sans-serif;font-size:15px;
  outline:none;
  transition:border-color .3s var(--ease), background .3s var(--ease);
}
.field-other input:focus{border-color:var(--violet);background:rgba(139,123,255,.06)}
.field-other input::placeholder{color:var(--mute-2)}

/* invalid-field state: red glow on bad inputs */
.field input.invalid,
.field textarea.invalid,
.select.invalid .select-trigger,
.field-other input.invalid{
  border-color:rgba(255,120,120,.55) !important;
  background:rgba(255,90,90,.05) !important;
}

/* inline form error bar (lead form) */
.form-error{
  display:none;
  font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.04em;
  color:#FF8888;padding:11px 14px;border-radius:10px;
  background:rgba(255,90,90,.07);border:1px solid rgba(255,90,90,.22);
  margin-bottom:20px;align-items:center;gap:8px;
}
.form-error.show{display:flex;animation:errShake .4s var(--ease)}
.form-error::before{content:'⚠';font-size:14px}
@media (max-width:680px){.fields-row{grid-template-columns:1fr}}

.choice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
@media (max-width:680px){.choice-grid{grid-template-columns:1fr 1fr}}
.choice{
  position:relative;
  padding:14px 16px;border-radius:12px;
  background:rgba(255,255,255,.03);border:1px solid var(--bd);
  font-size:14px;color:var(--ink-2);
  display:flex;justify-content:space-between;align-items:center;gap:8px;
  cursor:none;transition:all .3s var(--ease);
}
@media (max-width:980px){.choice{cursor:pointer}}
.choice:hover{border-color:var(--bd-hi);color:var(--ink)}
.choice .tick{width:14px;height:14px;border-radius:50%;border:1px solid var(--bd);transition:all .3s var(--ease)}
.choice.selected{background:rgba(139,123,255,.08);border-color:var(--violet);color:var(--ink)}
.choice.selected .tick{background:var(--grad);border-color:transparent;box-shadow:0 0 10px rgba(139,123,255,.6)}
.choice:has(.choice-desc){flex-wrap:wrap;align-items:flex-start}
.choice-label{flex:1;min-width:0}
.choice-desc{width:100%;font-size:11px;opacity:0.5;line-height:1.4;font-weight:400;margin-top:4px;order:3}
.field-note{font-weight:400;opacity:0.5;font-size:12px;margin-left:4px}

.dropzone{
  border:1.5px dashed var(--bd-hi);border-radius:14px;
  padding:32px;text-align:center;
  background:rgba(255,255,255,.02);
  cursor:none;transition:all .3s var(--ease);
}
@media (max-width:980px){.dropzone{cursor:pointer}}
.dropzone:hover, .dropzone.over{border-color:var(--violet);background:rgba(139,123,255,.06)}
.dropzone .ic{width:44px;height:44px;margin:0 auto 12px;border-radius:50%;background:var(--grad);display:grid;place-items:center;color:#fff;font-size:22px;box-shadow:0 10px 30px -6px rgba(139,123,255,.5)}
.dropzone b{display:block;font-family:'Onest',sans-serif;font-weight:500;font-size:16px;color:var(--ink);margin-bottom:4px}
.dropzone span{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--mute)}
.dropzone input{display:none}
.file-list{display:grid;gap:6px;margin-top:12px}
.file-row{
  display:grid;grid-template-columns:auto 1fr auto auto;gap:10px;align-items:center;
  padding:10px 12px;border-radius:10px;
  background:rgba(255,255,255,.03);border:1px solid var(--bd);
  font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-2);
}
.file-row .ic{width:24px;height:24px;border-radius:6px;background:var(--grad);display:grid;place-items:center;color:#fff;font-size:11px}
.file-row .sz{color:var(--mute);font-size:10px}
.file-row .x{cursor:none;color:var(--mute);transition:color .2s}
@media (max-width:980px){.file-row .x{cursor:pointer}}
.file-row .x:hover{color:var(--ink)}

.form-actions{display:flex;justify-content:space-between;align-items:center;margin-top:32px;padding-top:24px;border-top:1px solid var(--bd)}
.btn-ghost{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--mute);cursor:none}
@media (max-width:980px){.btn-ghost{cursor:pointer}}
.btn-ghost:hover{color:var(--ink)}

@media (max-width:980px){.start-wrap{grid-template-columns:1fr}}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{padding: 80px var(--pad) 32px;position:relative;overflow:hidden}
.footer::before{
  content:'';position:absolute;top:-200px;left:50%;transform:translateX(-50%);
  width:90%;height:400px;border-radius:50%;
  background:var(--grad);opacity:.06;filter:blur(80px);pointer-events:none;
}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr;gap:32px;margin-bottom:60px;align-items:end;position:relative}
@media (max-width:860px){.footer-top{grid-template-columns:1fr}}
.footer-top h2{
  font-family:'Onest',sans-serif;font-weight:400;
  font-size:clamp(40px,6vw,90px);line-height:.95;letter-spacing:-0.04em;
}
.footer-top h2 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.luma-mark{
  font-family:'Onest',sans-serif;font-weight:400;
  font-size: clamp(120px,30vw,460px);line-height:.78;letter-spacing:-0.06em;
  border-block:1px solid var(--bd);
  margin: 24px 0 40px;padding:24px 0;
  position:relative;text-align:center;
  background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;
  text-shadow:0 0 80px rgba(139,123,255,.15);
  overflow:hidden;
}
.luma-mark::after{
  content:'';position:absolute;left:0;top:50%;width:100%;height:1px;background:var(--bd);transform:translateY(-50%);z-index:-1;
}
.footer-cols{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
@media (max-width:780px){.footer-cols{grid-template-columns:repeat(2,1fr)}}
.footer-cols b{display:block;font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--mute);margin-bottom:14px;font-weight:500}
.footer-cols a{display:block;margin-bottom:8px;color:var(--ink-2);font-size:14px;transition:color .25s}
.footer-cols a:hover{color:var(--ink)}
.footer-bot{
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:10px 40px;
  margin-top:48px;padding-top:24px;
  border-top:1px solid var(--bd);
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.04em;line-height:1.5;
  color:var(--mute);text-transform:uppercase;
}
.footer-bot > *{flex-shrink:0}
@media (max-width:640px){
  .footer-bot{flex-direction:column;align-items:flex-start;gap:10px;padding-top:20px;margin-top:36px}
}

/* ============================================================
   PORTAL — full-screen glass dashboard
   ============================================================ */
.portal{
  position:fixed;inset:0;z-index:120;background:var(--bg);
  display:none;flex-direction:column;
  animation:portalIn .8s var(--ease);
}
.portal.open{display:flex}
@keyframes portalIn{
  from{clip-path:circle(0% at 50% 50%);opacity:0}
  to{clip-path:circle(150% at 50% 50%);opacity:1}
}
.portal::before{
  content:'';position:absolute;inset:0;background:
    radial-gradient(ellipse at 90% 0%, rgba(139,123,255,.12), transparent 50%),
    radial-gradient(ellipse at 0% 100%, rgba(79,195,220,.10), transparent 50%);
  pointer-events:none;
}

.portal-nav{
  position:relative;z-index:2;
  display:flex;justify-content:space-between;align-items:center;
  padding:18px var(--pad);
  border-bottom:1px solid var(--bd);
  background:rgba(7,7,12,.5);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.04em;
}
.portal-nav-mid{display:flex;align-items:center;gap:14px;text-transform:uppercase;color:var(--ink-2)}
.portal-nav-mid .sep{width:4px;height:4px;background:var(--mute);border-radius:50%}

.portal-body{flex:1;display:grid;grid-template-columns: 340px 1fr;overflow:hidden;position:relative;z-index:1}
.portal-side{
  border-right:1px solid var(--bd);
  padding:28px var(--pad);
  display:flex;flex-direction:column;gap:24px;
  overflow-y:auto;
  background:rgba(7,7,12,.4);
}
.portal-side h3{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--mute);margin-bottom:10px;font-weight:500}
.proj-card{
  background:var(--glass);border:1px solid var(--bd);border-radius:var(--r);
  padding:22px;position:relative;overflow:hidden;
  backdrop-filter:blur(12px);
}
.proj-card::before{
  content:'';position:absolute;top:-50px;right:-50px;width:160px;height:160px;border-radius:50%;
  background:var(--grad);opacity:.18;filter:blur(40px);
}
.proj-card .proj-id{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--mute);margin-bottom:8px;position:relative}
.proj-card h4{font-family:'Onest',sans-serif;font-weight:500;font-size:22px;letter-spacing:-0.02em;line-height:1.1;margin-bottom:18px;position:relative}
.proj-meta{display:grid;gap:4px;position:relative}
.proj-meta div{display:flex;flex-direction:column;gap:2px;font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.04em;padding:8px 0;border-bottom:1px solid var(--bd);color:var(--ink)}
.proj-meta div:last-child{border-bottom:none}
.proj-meta div span:first-child{font-size:9px;letter-spacing:.08em;color:var(--mute)}

.side-list{display:grid;gap:2px}
.side-list a{
  display:flex;justify-content:space-between;align-items:center;
  padding:10px 12px;border-radius:10px;
  font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.04em;
  color:var(--ink-2);transition:background .25s, color .25s;
}
.side-list a:hover{background:rgba(255,255,255,.03);color:var(--ink)}
.side-list a span:last-child{color:var(--mute)}

.portal-main{padding:32px var(--pad) 60px;overflow-y:auto;position:relative}

/* Tracker */
.tracker{margin-bottom:48px}
.tracker-head{display:flex;justify-content:space-between;align-items:end;margin-bottom:24px;gap:24px;flex-wrap:wrap}
.tracker-head h2{font-family:'Onest',sans-serif;font-weight:400;font-size:clamp(28px,3.6vw,48px);letter-spacing:-0.035em;line-height:1}
.tracker-head h2 em{font-family:'Instrument Serif',serif;font-style:italic;background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.tracker-head .meta{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--mute);text-align:right}
.tracker-head .meta b{display:block;font-family:'Onest',sans-serif;font-weight:500;font-size:32px;letter-spacing:-0.02em;background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:2px}

.tracker-bar{
  position:relative;
  display:flex;
  background:var(--glass);border:1px solid var(--bd);border-radius:var(--r);
  overflow:hidden;backdrop-filter:blur(12px);
}
.tracker-bar::before{
  content:'';position:absolute;top:0;bottom:0;left:0;
  width:var(--prog,20%);
  background:var(--grad);opacity:.18;
  transition:width .6s var(--ease);
  pointer-events:none;z-index:0;
}
.t-stage{
  flex:1;position:relative;border-right:1px solid var(--bd);padding:18px 20px;
  display:flex;flex-direction:column;gap:6px;
  cursor:none;transition:background .3s var(--ease);
  z-index:1;
}
@media (max-width:980px){.t-stage{cursor:pointer}}
.t-stage:last-child{border-right:none}
.t-stage:hover{background:rgba(255,255,255,.04)}
.t-stage .t-n{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--mute)}
.t-stage .t-name{font-family:'Onest',sans-serif;font-weight:500;font-size:15px;color:var(--ink-2);letter-spacing:-0.005em}
.t-stage.done .t-n{color:#62E394}
.t-stage.done .t-name{color:var(--ink)}
.t-stage.done .t-n::before{content:'✓ ';color:#62E394}
.t-stage.current{background:rgba(139,123,255,.08)}
.t-stage.current .t-n{background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;font-weight:500}
.t-stage.current .t-name{color:var(--ink)}
.t-stage.current::after{
  content:'';position:absolute;left:0;right:0;bottom:0;height:2px;
  background:var(--grad);box-shadow:0 0 12px rgba(139,123,255,.6);
}

/* Upload grid */
/* UPLOADS SECTION */
.uploads-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:28px}
.uploads-head h2{font-family:'Onest',sans-serif;font-weight:400;font-size:clamp(28px,3.6vw,44px);letter-spacing:-0.03em;line-height:1.05}
.uploads-head h2 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.uploads-count{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.uploads-count .lbl{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--mute)}
.uploads-count .val{font-family:'Onest',sans-serif;font-size:26px;font-weight:400;letter-spacing:-0.02em;background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.upload-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:1100px){.upload-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:700px){.upload-grid{grid-template-columns:1fr}.portal-body{grid-template-columns:1fr}.portal-side{border-right:none;border-bottom:1px solid var(--bd)}}
.upload-card{background:var(--glass);border:1px solid var(--bd);border-radius:var(--r-lg);padding:22px;display:flex;flex-direction:column;gap:14px;position:relative;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);transition:border-color .35s var(--ease),background .35s var(--ease),transform .35s var(--ease);min-height:200px;cursor:pointer;text-align:left;appearance:none;font:inherit;color:inherit;width:100%}
.upload-card:hover{border-color:var(--bd-hi);background:rgba(255,255,255,.025);transform:translateY(-2px)}
.upload-card .arrow{position:absolute;top:22px;right:22px;color:var(--mute);transition:transform .35s var(--ease),color .35s var(--ease);display:flex}
.upload-card:hover .arrow{color:var(--violet-lo);transform:translate(2px,-2px)}
.uc-icon{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:rgba(139,123,255,.12);border:1px solid rgba(181,166,255,.25);flex-shrink:0}
.uc-title{display:flex;align-items:center;gap:10px;font-family:'Onest',sans-serif;font-weight:400;font-size:18px;letter-spacing:-0.015em}
.uc-n{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--mute);letter-spacing:.06em}
.uc-tags{display:flex;flex-wrap:wrap;gap:6px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--mute)}
.uc-tags span{padding:4px 8px;border-radius:99px;background:rgba(255,255,255,.025);border:1px solid var(--bd)}
.uc-progress{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:12px;padding-top:14px;border-top:1px solid var(--bd)}
.uc-progress-bar{flex:1;height:4px;background:rgba(255,255,255,.04);border-radius:99px;overflow:hidden}
.uc-progress-fill{height:100%;width:0%;background:var(--grad);border-radius:99px;transition:width .5s var(--ease)}
.uc-progress-text{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--mute);white-space:nowrap}
.uc-progress-text.complete{color:var(--green)}
/* FORM DRAWER */
.bf{position:fixed;inset:0;z-index:200;pointer-events:none;display:flex;justify-content:flex-end}
.bf-bg{position:absolute;inset:0;background:rgba(7,7,12,.6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);opacity:0;transition:opacity .4s var(--ease)}
.bf.open{pointer-events:auto}
.bf.open .bf-bg{opacity:1}
.bf-panel{position:relative;width:min(560px,100%);height:100%;background:linear-gradient(180deg,rgba(11,11,20,.97),rgba(7,7,12,.97));border-left:1px solid var(--bd-hi);box-shadow:-30px 0 80px -10px rgba(0,0,0,.6);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);transform:translateX(100%);transition:transform .5s var(--ease);display:flex;flex-direction:column;overflow:hidden}
.bf.open .bf-panel{transform:translateX(0)}
.bf-header{flex-shrink:0;padding:22px 28px 18px;border-bottom:1px solid var(--bd);display:flex;justify-content:space-between;align-items:flex-start;gap:16px;position:relative}
.bf-header::after{content:'';position:absolute;bottom:-1px;left:28px;right:28px;height:1px;background:linear-gradient(90deg,transparent,var(--violet),transparent);opacity:.4}
.bf-title-row{display:flex;align-items:center;gap:14px;flex:1}
.bf-icon{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;flex-shrink:0;background:rgba(139,123,255,.12);border:1px solid rgba(181,166,255,.3)}
.bf-lbl{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--mute);margin-bottom:2px}
.bf-title{font-family:'Onest',sans-serif;font-weight:400;font-size:22px;letter-spacing:-0.02em;line-height:1.1}
.bf-close{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.04);border:1px solid var(--bd);color:var(--mute);display:grid;place-items:center;transition:all .3s var(--ease);flex-shrink:0}
.bf-close:hover{background:rgba(255,255,255,.08);color:var(--ink);border-color:var(--bd-hi);transform:rotate(90deg)}
.bf-body{flex:1;min-height:0;overflow-y:auto;padding:22px 28px 8px;display:flex;flex-direction:column;gap:22px}
.bf-body::-webkit-scrollbar{width:8px}
.bf-body::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:4px}
.bf-body::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.14)}
.bf-intro{color:var(--ink-2);font-size:14px;line-height:1.55;padding:14px 16px;border-radius:12px;background:rgba(255,255,255,.02);border:1px solid var(--bd)}
.bf-actions{flex-shrink:0;padding:16px 28px;border-top:1px solid var(--bd);background:rgba(7,7,12,.6);display:flex;gap:10px}
.bf-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:12px 18px;border-radius:12px;font-family:'Onest',sans-serif;font-weight:500;font-size:14px;cursor:pointer;transition:all .3s var(--ease)}
.bf-btn.primary{background:var(--grad);color:#fff;box-shadow:0 12px 28px -10px rgba(139,123,255,.7)}
.bf-btn.primary:hover{transform:translateY(-2px);box-shadow:0 18px 36px -10px rgba(139,123,255,.85)}
.bf-btn.ghost{background:rgba(255,255,255,.03);border:1px solid var(--bd);color:var(--ink-2);flex:0 0 auto}
.bf-btn.ghost:hover{background:rgba(255,255,255,.06);color:var(--ink)}
/* FORM FIELDS */
.ff{display:flex;flex-direction:column;gap:8px;animation:ffIn .35s var(--ease)}
@keyframes ffIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.ff-label{display:flex;align-items:center;gap:8px;font-family:'Onest',sans-serif;font-weight:500;font-size:14px;color:var(--ink)}
.ff-label .opt{font-family:'JetBrains Mono',monospace;font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:var(--mute-2);padding:2px 6px;border-radius:99px;background:rgba(255,255,255,.025);border:1px solid var(--bd);font-weight:400}
.ff-label .check{width:16px;height:16px;border-radius:50%;background:var(--green);color:#07070C;display:grid;place-items:center}
.ff-helper{font-size:12.5px;color:var(--mute);line-height:1.45}
.ff-text,.ff-textarea{background:rgba(255,255,255,.025);border:1px solid var(--bd);border-radius:10px;padding:11px 14px;color:var(--ink);font-family:inherit;font-size:14px;outline:none;width:100%;transition:border-color .25s var(--ease),background .25s var(--ease)}
.ff-textarea{resize:vertical;min-height:72px;line-height:1.5}
.ff-text:focus,.ff-textarea:focus{border-color:var(--violet);background:rgba(139,123,255,.06)}
.ff-text::placeholder,.ff-textarea::placeholder{color:var(--mute-2)}
.ff-file-input{display:none}
.ff-file-drop{display:flex;flex-direction:column;align-items:center;gap:8px;padding:22px 18px;border:1.5px dashed var(--bd-hi);border-radius:12px;background:rgba(255,255,255,.012);cursor:pointer;transition:all .3s var(--ease);text-align:center;width:100%}
.ff-file-drop:hover,.ff-file-drop.dragging{border-color:var(--violet-lo);background:rgba(139,123,255,.04)}
.ff-file-drop .plus{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;background:var(--grad);color:#fff;box-shadow:0 6px 18px -4px rgba(139,123,255,.5);transition:transform .3s var(--ease)}
.ff-file-drop:hover .plus{transform:rotate(90deg)}
.ff-file-drop .prompt{font-family:'Onest',sans-serif;font-size:13px;color:var(--ink-2)}
.ff-file-drop .formats{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--mute-2)}
.ff-file-list{display:flex;flex-direction:column;gap:6px}
.ff-file-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;background:rgba(255,255,255,.025);border:1px solid var(--bd);font-size:13px;animation:ffIn .3s var(--ease)}
.ff-file-item .ic{width:24px;height:24px;border-radius:6px;display:grid;place-items:center;flex-shrink:0;background:var(--grad);color:#fff}
.ff-file-item .name{flex:1;min-width:0;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;text-decoration:none;color:inherit}
.ff-file-item .size{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--mute);white-space:nowrap}
.ff-file-item .rm{color:var(--mute);padding:4px 6px;transition:color .25s;display:flex;align-items:center}
.ff-file-item .rm:hover{color:#FF8888}
.ff-colors{display:flex;flex-direction:column;gap:8px}
.ff-color-row{display:flex;align-items:center;gap:8px;padding:6px;border-radius:10px;background:rgba(255,255,255,.025);border:1px solid var(--bd);transition:border-color .25s}
.ff-color-row:focus-within{border-color:var(--violet)}
.ff-color-swatch{width:36px;height:36px;border-radius:8px;flex-shrink:0;border:1px solid rgba(255,255,255,.1);box-shadow:inset 0 0 0 1px rgba(0,0,0,.2);cursor:pointer;position:relative;overflow:hidden}
.ff-color-swatch input[type="color"]{position:absolute;inset:-10px;opacity:0;cursor:pointer;width:calc(100% + 20px);height:calc(100% + 20px)}
.ff-color-hex{flex:1;background:transparent;border:none;outline:none;font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--ink);letter-spacing:.04em;text-transform:uppercase;padding:6px 0}
.ff-color-hex::placeholder{color:var(--mute-2)}
.ff-color-rm,.ff-rep-rm{color:var(--mute);padding:6px 8px;transition:color .25s;display:flex;align-items:center}
.ff-color-rm:hover,.ff-rep-rm:hover{color:#FF8888}
.ff-add-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;border-radius:99px;background:rgba(255,255,255,.03);border:1px dashed var(--bd-hi);font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-2);transition:all .25s var(--ease);align-self:flex-start}
.ff-add-btn:hover{background:rgba(139,123,255,.06);border-color:rgba(181,166,255,.4);color:var(--ink)}
.ff-repeater{display:flex;flex-direction:column;gap:8px}
.ff-rep-row{display:flex;gap:8px;align-items:center}
.ff-rep-row .ff-text{flex:1}
.ff-urls{display:flex;flex-direction:column;gap:10px}
.ff-url-row{display:flex;flex-direction:column;gap:6px;padding:10px;border-radius:10px;background:rgba(255,255,255,.015);border:1px solid var(--bd)}
.ff-url-row:focus-within{border-color:var(--bd-hi)}
.ff-url-top{display:flex;gap:8px;align-items:center}
.ff-url-top .ff-text{flex:1}
.ff-checklist{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}
@media(max-width:480px){.ff-checklist{grid-template-columns:1fr}}
.ff-check{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;background:rgba(255,255,255,.02);border:1px solid var(--bd);cursor:pointer;font-size:13.5px;transition:all .25s var(--ease)}
.ff-check:hover{background:rgba(255,255,255,.04);border-color:var(--bd-hi)}
.ff-check input{position:absolute;opacity:0;pointer-events:none}
.ff-check .box{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--bd-hi);display:grid;place-items:center;flex-shrink:0;transition:all .25s var(--ease);position:relative}
.ff-check .box::after{content:'';width:8px;height:5px;border-left:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(-45deg) scale(0);transition:transform .3s var(--ease);margin-top:-2px}
.ff-check input:checked + .box{background:var(--grad);border-color:transparent;box-shadow:0 4px 12px -2px rgba(139,123,255,.4)}
.ff-check input:checked + .box::after{transform:rotate(-45deg) scale(1)}
.ff-check input:checked ~ .lbl{color:var(--ink)}
.ff-check .lbl{color:var(--ink-2)}
.ff-divider{height:1px;background:var(--bd);margin:4px -28px}
@media(max-width:700px){.bf-panel{width:100%}}

/* Activity / next steps */
.activity{margin-top:48px;display:grid;grid-template-columns:1.4fr 1fr;gap:var(--gutter)}
@media (max-width:980px){.activity{grid-template-columns:1fr}}
.act{
  background:var(--glass);border:1px solid var(--bd);border-radius:var(--r);
  padding:26px;backdrop-filter:blur(12px);
}
.act h3{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--mute);margin-bottom:18px;display:flex;justify-content:space-between;align-items:center;font-weight:500}
.act h3 a{color:var(--ink-2);text-decoration:none}
.act h3 a:hover{color:var(--ink)}
.feed{display:grid;gap:0}
.feed-row{display:grid;grid-template-columns:80px 1fr auto;gap:14px;padding:14px 0;border-top:1px solid var(--bd);font-size:14px;align-items:center;line-height:1.4;color:var(--ink-2)}
.feed-row:first-child{border-top:none}
.feed-row .when{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--mute)}
.feed-row .who{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--mute);background:rgba(255,255,255,.04);padding:3px 8px;border-radius:99px;border:1px solid var(--bd)}
.feed-row b{font-weight:500;color:var(--ink)}
.feed-row em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--ink)}

.next{display:grid;gap:8px;list-style:none}
.next li{
  position:relative;padding:14px 14px 14px 42px;border-radius:10px;
  background:rgba(255,255,255,.03);border:1px solid var(--bd);
  font-size:14px;color:var(--ink-2);
}
.next li::before{
  content:'';position:absolute;left:14px;top:50%;transform:translateY(-50%);
  width:16px;height:16px;border-radius:50%;border:1px solid var(--bd);
}
.next li.done::before{background:var(--grad);border-color:transparent;box-shadow:0 0 12px rgba(139,123,255,.6)}
.next li.done::after{content:'✓';position:absolute;left:18px;top:50%;transform:translateY(-50%);color:#fff;font-size:10px;font-family:'JetBrains Mono',monospace}
.next li.done{color:var(--mute);text-decoration:line-through}

/* toast */
.toast{
  position:fixed;bottom:24px;right:24px;z-index:300;
  padding:14px 18px;border-radius:12px;
  background:rgba(7,7,12,.85);border:1px solid var(--bd-hi);
  backdrop-filter:blur(18px);
  font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.06em;
  color:var(--ink);
  display:flex;align-items:center;gap:10px;
  transform:translateY(20px);opacity:0;transition:all .4s var(--ease);
}
.toast.show{transform:translateY(0);opacity:1}
.toast::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--grad);box-shadow:0 0 10px rgba(139,123,255,.7)}
/* ============================================================
   AUTH / SIGN-IN MODAL
   ============================================================ */
.auth{
  position:fixed;inset:0;z-index:210;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  opacity:0;visibility:hidden;
  transition:opacity .4s var(--ease), visibility .4s;
}
.auth.open{opacity:1;visibility:visible}
.auth-bg{
  position:fixed;inset:0;z-index:-1;
  background:rgba(7,7,12,.78);
  backdrop-filter:blur(22px) saturate(140%);
  -webkit-backdrop-filter:blur(22px) saturate(140%);
}
.auth-panel{
  position:relative;
  width:100%;max-width:420px;
  background:var(--glass);
  border:1px solid var(--bd-hi);
  border-radius:24px;
  padding:clamp(28px,3.4vw,42px) clamp(24px,3vw,36px);
  backdrop-filter:blur(28px) saturate(180%);
  -webkit-backdrop-filter:blur(28px) saturate(180%);
  box-shadow:
    0 40px 80px -16px rgba(0,0,0,.7),
    0 0 0 1px rgba(139,123,255,.10),
    inset 0 1px 0 rgba(255,255,255,.06);
  overflow:hidden;
  transform:scale(.94) translateY(20px);
  transition:transform .5s var(--ease);
}
.auth.open .auth-panel{transform:scale(1) translateY(0)}
.auth-panel::before{
  content:'';position:absolute;top:-120px;right:-60px;width:280px;height:280px;border-radius:50%;
  background:var(--grad);opacity:.18;filter:blur(70px);pointer-events:none;
}
.auth-panel::after{
  content:'';position:absolute;bottom:-120px;left:-60px;width:260px;height:260px;border-radius:50%;
  background:radial-gradient(circle, #C77DFF, transparent 70%);opacity:.12;filter:blur(70px);pointer-events:none;
}

.auth-close{
  position:absolute;top:16px;right:16px;
  width:32px;height:32px;border-radius:50%;
  background:transparent;border:1px solid var(--bd);
  color:var(--mute);font-size:20px;line-height:1;
  display:grid;place-items:center;
  cursor:none;z-index:3;
  transition:all .25s var(--ease);
}
@media (hover:none){.auth-close{cursor:pointer}}
.auth-close:hover{background:rgba(255,255,255,.05);color:var(--ink);border-color:var(--bd-hi);transform:rotate(90deg)}

.auth-head{text-align:center;margin-bottom:28px;position:relative;z-index:1}
.auth-mark{
  width:52px;height:52px;border-radius:50%;
  background:var(--grad);
  margin:0 auto 18px;position:relative;
  box-shadow:0 14px 32px -6px rgba(139,123,255,.55), inset 0 1px 0 rgba(255,255,255,.2);
}
.auth-mark::after{content:'';position:absolute;inset:14px;background:var(--bg);border-radius:50%}
.auth-head h3{
  font-family:'Onest',sans-serif;font-weight:400;font-size:26px;
  letter-spacing:-0.02em;line-height:1;margin-bottom:8px;
}
.auth-head p{color:var(--mute);font-size:14px}

.auth-form{display:grid;gap:16px;position:relative;z-index:1}
#authSigninView,#authSetpwView,#authForgotView{display:grid;gap:16px}
.auth-form .field{gap:6px}
.auth-form .field label{display:flex;justify-content:space-between;align-items:center}
.auth-forgot{
  font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.06em;
  color:var(--ink-2);
}
.auth-forgot:hover{
  background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;
}

.auth-check{
  display:flex;align-items:center;gap:10px;
  font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.04em;
  color:var(--mute);cursor:none;user-select:none;
}
@media (hover:none){.auth-check{cursor:pointer}}
.auth-check input{position:absolute;opacity:0;pointer-events:none}
.auth-check .check-box{
  width:16px;height:16px;border-radius:4px;
  border:1px solid var(--bd-hi);background:rgba(255,255,255,.02);
  position:relative;transition:all .25s var(--ease);flex-shrink:0;
}
.auth-check input:checked + .check-box{background:var(--grad);border-color:transparent;box-shadow:0 0 12px rgba(139,123,255,.4)}
.auth-check input:checked + .check-box::after{
  content:'';position:absolute;left:5px;top:1px;width:4px;height:9px;
  border:solid #fff;border-width:0 1.5px 1.5px 0;transform:rotate(45deg);
}

.auth-submit{width:100%;justify-content:center;margin-top:4px;padding:14px 22px}

.auth-divider{
  display:flex;align-items:center;gap:14px;
  font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--mute-2);
  margin:4px 0;
}
.auth-divider::before,.auth-divider::after{
  content:'';flex:1;height:1px;background:var(--bd);
}

.auth-sso{
  width:100%;justify-content:center;padding:13px 18px;
  background:rgba(255,255,255,.025);border:1px solid var(--bd);color:var(--ink-2);
}
.auth-sso::before{display:none}
.auth-sso:hover{background:rgba(255,255,255,.05);border-color:var(--bd-hi);color:var(--ink)}
.sso-ic{
  width:18px;height:18px;border-radius:50%;
  background:#fff;color:#222;
  display:grid;place-items:center;font-size:11px;font-weight:600;
  font-family:'Onest',sans-serif;
}

.auth-bottom{
  text-align:center;font-size:13px;color:var(--mute);margin-top:4px;
}
#authSetpwView .auth-bottom,
#authForgotView .auth-bottom{margin-top:20px}
.auth-bottom a{
  font-weight:500;
  background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;
}

.auth-demo{
  text-align:center;font-family:'JetBrains Mono',monospace;font-size:10px;
  color:var(--mute-2);text-transform:uppercase;letter-spacing:.06em;
  margin-top:10px;padding-top:14px;border-top:1px solid var(--bd);
  display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;
}

.auth-error{
  display:none;
  font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.04em;
  color:#FF8888;padding:11px 14px;border-radius:10px;
  background:rgba(255,90,90,.07);border:1px solid rgba(255,90,90,.2);
  margin-bottom:4px;
}
.auth-error.show{display:flex;align-items:center;gap:8px;animation:errShake .4s var(--ease)}
.auth-error::before{content:'⚠';font-size:14px}
@keyframes errShake{
  0%,100%{transform:translateX(0)}
  20%{transform:translateX(-4px)}
  40%{transform:translateX(4px)}
  60%{transform:translateX(-2px)}
  80%{transform:translateX(2px)}
}

@media (max-width:480px){
  .auth{padding:14px}
  .auth-panel{padding:28px 22px;border-radius:20px}
  .auth-head h3{font-size:24px}
}

/* ============================================================
   CONTACT MODAL
   ============================================================ */
/* ── Thank-you modal ────────────────────────────────────────── */
.thankyou{
  position:fixed;inset:0;z-index:120;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  opacity:0;visibility:hidden;
  transition:opacity .4s var(--ease),visibility .4s;
}
.thankyou.open{opacity:1;visibility:visible}
.thankyou-bg{
  position:fixed;inset:0;z-index:-1;
  background:rgba(7,7,12,.82);
  backdrop-filter:blur(24px) saturate(140%);
  -webkit-backdrop-filter:blur(24px) saturate(140%);
}
.thankyou-panel{
  position:relative;
  width:100%;max-width:520px;
  background:var(--bg-2);
  border:1px solid var(--bd-hi);
  border-radius:24px;
  padding:clamp(32px,5vw,52px);
  text-align:center;
  box-shadow:0 40px 80px -16px rgba(0,0,0,.7),inset 0 1px 0 rgba(255,255,255,.06);
  transform:scale(.94) translateY(24px);
  transition:transform .5s var(--ease);
}
.thankyou.open .thankyou-panel{transform:scale(1) translateY(0)}
.thankyou-close{
  position:absolute;top:16px;right:16px;
  width:32px;height:32px;border-radius:50%;
  background:rgba(7,7,12,.5);border:1px solid var(--bd);
  color:var(--mute);font-size:20px;line-height:1;
  display:grid;place-items:center;cursor:none;
  transition:all .25s var(--ease);
}
@media(hover:none){.thankyou-close{cursor:pointer}}
.thankyou-close:hover{background:rgba(255,255,255,.08);color:var(--ink);border-color:var(--bd-hi);transform:rotate(90deg)}
.thankyou-icon{font-size:32px;margin-bottom:20px;opacity:.6}
.thankyou-panel h2{font-size:clamp(22px,3.5vw,32px);font-weight:500;letter-spacing:-.02em;margin-bottom:14px;line-height:1.15}
.thankyou-panel h2 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.thankyou-panel p{color:var(--ink-2);font-size:15px;line-height:1.65;margin-bottom:28px}
.thankyou-panel p strong{color:var(--ink)}
.thankyou-meta{
  display:flex;justify-content:center;gap:32px;
  margin-bottom:32px;padding:20px;
  background:var(--glass);border:1px solid var(--bd);border-radius:14px;
}
.thankyou-meta div{display:flex;flex-direction:column;gap:4px;text-align:center}
.thankyou-meta span{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--mute)}
.thankyou-meta b{font-size:14px;font-weight:500;color:var(--ink)}

.contact{
  position:fixed;inset:0;z-index:210;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  opacity:0;visibility:hidden;
  transition:opacity .4s var(--ease), visibility .4s;
}
.contact.open{opacity:1;visibility:visible}
.contact-bg{
  position:fixed;inset:0;z-index:-1;
  background:rgba(7,7,12,.78);
  backdrop-filter:blur(22px) saturate(140%);
  -webkit-backdrop-filter:blur(22px) saturate(140%);
}
.contact-panel{
  position:relative;
  width:100%;max-width:880px;max-height:92vh;
  background:var(--glass);
  border:1px solid var(--bd-hi);
  border-radius:24px;
  backdrop-filter:blur(28px) saturate(180%);
  -webkit-backdrop-filter:blur(28px) saturate(180%);
  box-shadow:
    0 40px 80px -16px rgba(0,0,0,.7),
    0 0 0 1px rgba(139,123,255,.10),
    inset 0 1px 0 rgba(255,255,255,.06);
  overflow:hidden;
  transform:scale(.94) translateY(20px);
  transition:transform .5s var(--ease);
}
.contact.open .contact-panel{transform:scale(1) translateY(0)}

.contact-close{
  position:absolute;top:16px;right:16px;
  width:32px;height:32px;border-radius:50%;
  background:rgba(7,7,12,.5);border:1px solid var(--bd);
  color:var(--mute);font-size:20px;line-height:1;
  display:grid;place-items:center;
  cursor:none;z-index:5;
  backdrop-filter:blur(10px);
  transition:all .25s var(--ease);
}
@media (hover:none){.contact-close{cursor:pointer}}
.contact-close:hover{background:rgba(255,255,255,.08);color:var(--ink);border-color:var(--bd-hi);transform:rotate(90deg)}

.contact-grid{
  display:grid;grid-template-columns:1fr 1.2fr;
  max-height:92vh;
}

.contact-side{
  position:relative;overflow:hidden;
  padding:clamp(28px,3vw,40px);
  background:rgba(255,255,255,.02);
  border-right:1px solid var(--bd);
  display:flex;flex-direction:column;gap:22px;
}
.contact-side::before{
  content:'';position:absolute;top:-150px;left:-80px;width:320px;height:320px;border-radius:50%;
  background:var(--grad);opacity:.16;filter:blur(70px);pointer-events:none;
}
.contact-side::after{
  content:'';position:absolute;bottom:-100px;right:-50px;width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle, #C77DFF, transparent 70%);opacity:.12;filter:blur(60px);pointer-events:none;
}
.contact-mark{
  width:48px;height:48px;border-radius:50%;
  background:var(--grad);position:relative;
  box-shadow:0 12px 30px -6px rgba(139,123,255,.55), inset 0 1px 0 rgba(255,255,255,.2);
}
.contact-mark::after{content:'';position:absolute;inset:14px;background:var(--bg);border-radius:50%}
.contact-side h3{
  font-family:'Onest',sans-serif;font-weight:400;font-size:clamp(26px,3vw,34px);
  letter-spacing:-0.025em;line-height:1.05;position:relative;
}
.contact-side h3 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.contact-side > p{color:var(--mute);font-size:14px;line-height:1.55;position:relative}

.contact-methods{display:flex;flex-direction:column;gap:8px;position:relative}
.contact-method{
  display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;
  padding:14px;border-radius:12px;
  background:rgba(255,255,255,.025);border:1px solid var(--bd);
  transition:all .3s var(--ease);
}
.contact-method:hover{background:rgba(255,255,255,.05);border-color:var(--bd-hi)}
.cm-ic{
  width:36px;height:36px;border-radius:10px;
  background:var(--grad);color:#fff;
  display:grid;place-items:center;
  font-family:'Onest',sans-serif;font-weight:500;font-size:18px;line-height:1;
  box-shadow:0 6px 16px -4px rgba(139,123,255,.4), inset 0 1px 0 rgba(255,255,255,.2);
}
.contact-method > div{display:flex;flex-direction:column;gap:2px;min-width:0}
.contact-method b{font-family:'Onest',sans-serif;font-weight:500;font-size:14px;color:var(--ink)}
.contact-method span{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--mute);letter-spacing:.02em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cm-arrow{color:var(--mute);font-size:14px;transition:transform .3s var(--ease), color .3s var(--ease)}
.contact-method:hover .cm-arrow{color:var(--ink);transform:translate(2px,-2px)}

.contact-foot{margin-top:auto;display:flex;flex-direction:column;gap:8px;position:relative}
.contact-hours{
  font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--mute);
  text-transform:uppercase;letter-spacing:.06em;
}

.contact-form{
  padding:clamp(28px,3vw,40px);
  display:flex;flex-direction:column;gap:16px;overflow-y:auto;
  position:relative;
}
.contact-form .fields-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:520px){.contact-form .fields-row{grid-template-columns:1fr}}
.contact-form .select-menu{max-height:200px}
.contact-submit{width:100%;justify-content:center;margin-top:4px}

.contact-error{
  display:none;
  font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.04em;
  color:#FF8888;padding:11px 14px;border-radius:10px;
  background:rgba(255,90,90,.07);border:1px solid rgba(255,90,90,.2);
}
.contact-error.show{display:flex;align-items:center;gap:8px;animation:errShake .4s var(--ease)}
.contact-error::before{content:'⚠';font-size:14px}

.contact-bottom{
  text-align:center;font-size:13px;color:var(--mute);margin-top:6px;
}
.contact-bottom a{
  font-weight:500;
  background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;
}

/* success state overlays the form */
.contact-success{
  display:none;
  position:absolute;inset:0;z-index:4;
  background:rgba(7,7,12,.92);
  backdrop-filter:blur(14px);
  flex-direction:column;align-items:center;justify-content:center;
  padding:40px;text-align:center;gap:14px;
}
.contact-success.show{display:flex;animation:fadeUp .5s var(--ease)}
.contact-success .check-circle{
  width:64px;height:64px;border-radius:50%;
  background:var(--grad);
  display:grid;place-items:center;color:#fff;font-size:30px;line-height:1;
  box-shadow:0 12px 30px -6px rgba(139,123,255,.5), inset 0 1px 0 rgba(255,255,255,.2);
  margin-bottom:6px;
}
.contact-success h3{font-family:'Onest',sans-serif;font-weight:400;font-size:28px;letter-spacing:-0.025em;line-height:1}
.contact-success h3 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.contact-success p{color:var(--mute);font-size:14px;max-width:38ch;line-height:1.5}

@media (max-width:780px){
  .contact{padding:12px}
  .contact-panel{max-height:96vh;border-radius:20px}
  .contact-grid{grid-template-columns:1fr;max-height:96vh}
  .contact-side{
    padding:22px 22px 18px;border-right:none;border-bottom:1px solid var(--bd);gap:14px;
  }
  .contact-side h3{font-size:22px}
  .contact-side > p{display:none}
  .contact-methods{flex-direction:row;gap:8px}
  .contact-method{flex:1;padding:10px;min-width:0}
  .contact-method .cm-arrow{display:none}
  .contact-method b{font-size:12px}
  .contact-method span{font-size:10px}
  .cm-ic{width:30px;height:30px;font-size:14px}
  .contact-foot{display:none}
  .contact-form{padding:22px;gap:14px}
}



/* Touch / no-hover devices: hide the custom cursor (no mousemove = stuck) */
/* ============================================================
   JOURNAL CARDS
   ============================================================ */
.journal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gutter)}
@media (max-width:980px){.journal-grid{grid-template-columns:1fr;gap:18px}}
.journal-card{
  background:var(--glass);border:1px solid var(--bd);
  border-radius:var(--r-lg);
  overflow:hidden;
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  display:flex;flex-direction:column;
  transition:transform .5s var(--ease), border-color .5s var(--ease);
}
.journal-card:hover{transform:translateY(-6px);border-color:var(--bd-hi)}
.journal-cover{
  position:relative;aspect-ratio:16/10;overflow:hidden;
}
.journal-cover::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 40%, rgba(7,7,12,.4));
}
.j-1{background:radial-gradient(ellipse at 30% 30%, rgba(199,125,255,.55), transparent 55%), linear-gradient(135deg, #1a0f33, #06091a)}
.j-2{background:radial-gradient(ellipse at 70% 60%, rgba(79,195,220,.45), transparent 55%), linear-gradient(135deg, #06091a, #0a1428)}
.j-3{background:radial-gradient(ellipse at 50% 30%, rgba(216,197,142,.45), transparent 55%), linear-gradient(135deg, #1f1a0a, #06091a)}
.journal-tag{
  position:absolute;top:18px;left:18px;z-index:2;
  font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.08em;
  background:rgba(7,7,12,.6);border:1px solid var(--bd);padding:5px 10px;border-radius:99px;
  color:var(--ink);backdrop-filter:blur(10px);
}
.journal-card > .journal-meta{
  padding:18px 22px 0;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.04em;color:var(--mute);text-transform:uppercase;
  display:flex;align-items:center;gap:8px;
}
.journal-card > .journal-meta .dot{color:var(--mute-2)}
.journal-card h3{
  padding:6px 22px 0;
  font-family:'Onest',sans-serif;font-weight:400;font-size:22px;letter-spacing:-0.025em;line-height:1.2;
}
.journal-card h3 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.journal-card p{padding:8px 22px 0;color:var(--ink-2);font-size:14px;line-height:1.55}
.journal-link{
  margin-top:auto;padding:18px 22px;border-top:1px solid var(--bd);
  display:flex;justify-content:space-between;align-items:center;
  font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-2);
  transition:color .25s, background .25s;
}
.journal-link:hover{background:rgba(255,255,255,.03);color:var(--ink)}
.journal-link span{font-size:14px;transition:transform .3s var(--ease)}
.journal-link:hover span{transform:translate(2px,-2px)}
.journal-all{
  display:inline-flex;align-items:center;gap:10px;
  margin-top:32px;padding:14px 22px;border-radius:99px;
  font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.06em;
  background:var(--glass);border:1px solid var(--bd);color:var(--ink-2);
  transition:all .3s var(--ease);
}
.journal-all:hover{background:rgba(255,255,255,.05);border-color:var(--bd-hi);color:var(--ink)}

/* ============================================================
   CASE STUDY OVERLAY
   ============================================================ */
.case{
  position:fixed;inset:0;z-index:115;
  display:flex;align-items:flex-start;justify-content:center;
  padding:32px 24px;
  opacity:0;visibility:hidden;overflow-y:auto;
  transition:opacity .4s var(--ease), visibility .4s;
}
.case.open{opacity:1;visibility:visible}
.case-bg{
  position:fixed;inset:0;z-index:-1;
  background:rgba(7,7,12,.82);
  backdrop-filter:blur(22px) saturate(140%);
  -webkit-backdrop-filter:blur(22px) saturate(140%);
}
.case-panel{
  position:relative;width:100%;max-width:880px;
  background:var(--glass);border:1px solid var(--bd-hi);
  border-radius:24px;
  backdrop-filter:blur(28px) saturate(160%);
  -webkit-backdrop-filter:blur(28px) saturate(160%);
  box-shadow:0 50px 100px -20px rgba(0,0,0,.7), inset 0 1px 0 rgba(255,255,255,.06);
  overflow:hidden;
  transform:scale(.96) translateY(20px);
  transition:transform .55s var(--ease);
  margin:auto 0;
}
.case.open .case-panel{transform:scale(1) translateY(0)}

.case-close{
  position:absolute;top:18px;right:18px;z-index:5;
  width:38px;height:38px;border-radius:50%;
  background:rgba(7,7,12,.6);border:1px solid var(--bd-hi);
  color:var(--ink);font-size:22px;line-height:1;
  display:grid;place-items:center;
  cursor:none;backdrop-filter:blur(10px);
  transition:all .3s var(--ease);
}
@media (hover:none){.case-close{cursor:pointer}}
.case-close:hover{background:var(--grad);border-color:transparent;transform:rotate(90deg)}

.case-cover{
  position:relative;aspect-ratio:21/9;
  background:linear-gradient(135deg, #1a0f33, #06091a);
  border-bottom:1px solid var(--bd);
  overflow:hidden;
}
.case-cover::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(7,7,12,.85));
}

.case-head{padding:36px 40px 24px;position:relative}
.case-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px}
.case-tag{
  font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.06em;
  background:rgba(255,255,255,.04);border:1px solid var(--bd);padding:5px 10px;border-radius:99px;
  color:var(--ink-2);
}
.case-head h2{
  font-family:'Onest',sans-serif;font-weight:400;
  font-size:clamp(28px,3.6vw,44px);letter-spacing:-0.03em;line-height:1.1;
  margin-bottom:12px;
}
.case-head h2 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.case-lede{color:var(--ink-2);font-size:17px;line-height:1.5;max-width:50ch}

.case-body{padding:0 40px 32px;display:flex;flex-direction:column;gap:32px}
.case-block{}
.case-label{
  font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.08em;
  color:var(--mute);margin-bottom:10px;
}
.case-block p{color:var(--ink-2);font-size:15px;line-height:1.65;max-width:65ch}
.case-block p em{font-family:'Instrument Serif',serif;font-style:italic;color:var(--ink);background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}

.case-results .case-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
}
@media (max-width:780px){.case-results .case-stats{grid-template-columns:repeat(2,1fr)}}
.case-stat{
  background:rgba(255,255,255,.03);border:1px solid var(--bd);
  border-radius:14px;padding:18px;
  position:relative;overflow:hidden;
}
.case-stat::before{
  content:'';position:absolute;top:-30px;right:-30px;width:100px;height:100px;border-radius:50%;
  background:var(--grad);opacity:.10;filter:blur(30px);pointer-events:none;
}
.case-stat .stat{
  font-family:'Onest',sans-serif;font-weight:400;font-size:clamp(24px,2.4vw,30px);
  letter-spacing:-0.02em;line-height:1;
  background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;
  margin-bottom:6px;
}
.case-stat .label{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--mute);text-transform:uppercase;letter-spacing:.06em;line-height:1.4}

.case-chips{display:flex;flex-wrap:wrap;gap:6px}
.case-chip{
  font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.04em;
  background:rgba(255,255,255,.03);border:1px solid var(--bd);padding:7px 12px;border-radius:99px;color:var(--ink-2);
}

.case-quote{
  background:rgba(255,255,255,.025);border:1px solid var(--bd);border-radius:18px;
  padding:24px 28px;position:relative;overflow:hidden;
}
.case-quote::before{
  content:'';position:absolute;top:-40px;right:-40px;width:160px;height:160px;border-radius:50%;
  background:var(--grad);opacity:.10;filter:blur(50px);
}
.case-qmark{
  font-family:'Instrument Serif',serif;font-style:italic;font-size:56px;line-height:.6;
  background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;
  height:22px;
}
.case-quote blockquote{
  font-family:'Onest',sans-serif;font-weight:300;font-size:18px;line-height:1.45;color:var(--ink);
  margin:8px 0 14px;letter-spacing:-0.005em;
}
.case-quote cite{
  font-family:'JetBrains Mono',monospace;font-style:normal;font-size:11px;
  color:var(--mute);text-transform:uppercase;letter-spacing:.06em;
}

.case-foot{
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  padding:22px 40px;border-top:1px solid var(--bd);background:rgba(255,255,255,.02);
}

@media (max-width:680px){
  .case{padding:14px}
  .case-panel{border-radius:18px}
  .case-head{padding:26px 22px 18px}
  .case-body{padding:0 22px 24px;gap:24px}
  .case-foot{padding:18px 22px;flex-direction:column-reverse;gap:10px;align-items:stretch}
  .case-foot .btn{justify-content:center}
}

/* ============================================================
   LEGAL OVERLAY (Privacy · Terms · Cookies)
   ============================================================ */
.legal{
  position:fixed;inset:0;z-index:115;
  display:flex;align-items:flex-start;justify-content:center;
  padding:32px 24px;
  opacity:0;visibility:hidden;overflow-y:auto;
  transition:opacity .4s var(--ease), visibility .4s;
}
.legal.open{opacity:1;visibility:visible}
.legal-bg{
  position:fixed;inset:0;z-index:-1;
  background:rgba(7,7,12,.82);
  backdrop-filter:blur(22px) saturate(140%);
  -webkit-backdrop-filter:blur(22px) saturate(140%);
}
.legal-panel{
  position:relative;width:100%;max-width:780px;
  background:var(--glass);border:1px solid var(--bd-hi);
  border-radius:24px;
  backdrop-filter:blur(28px) saturate(160%);
  -webkit-backdrop-filter:blur(28px) saturate(160%);
  box-shadow:0 50px 100px -20px rgba(0,0,0,.7);
  padding:clamp(28px,3vw,44px);
  transform:scale(.96) translateY(20px);
  transition:transform .5s var(--ease);
  margin:auto 0;
}
.legal.open .legal-panel{transform:scale(1) translateY(0)}
.legal-close{
  position:absolute;top:16px;right:16px;z-index:5;
  width:36px;height:36px;border-radius:50%;
  background:transparent;border:1px solid var(--bd);color:var(--mute);
  font-size:20px;line-height:1;display:grid;place-items:center;cursor:none;
  transition:all .3s var(--ease);
}
@media (hover:none){.legal-close{cursor:pointer}}
.legal-close:hover{background:rgba(255,255,255,.05);color:var(--ink);border-color:var(--bd-hi);transform:rotate(90deg)}
.legal-tabs{
  display:flex;gap:4px;margin-bottom:18px;padding:4px;
  background:rgba(255,255,255,.025);border:1px solid var(--bd);border-radius:99px;width:fit-content;
}
.legal-tab{
  padding:8px 16px;border-radius:99px;
  font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.04em;
  color:var(--mute);background:transparent;cursor:none;transition:all .3s var(--ease);
}
@media (hover:none){.legal-tab{cursor:pointer}}
.legal-tab:hover{color:var(--ink)}
.legal-tab.active{background:var(--grad);color:#fff;box-shadow:0 6px 18px -4px rgba(139,123,255,.5)}
.legal-meta{display:flex;gap:8px;margin-bottom:18px}
.legal-panel h2{
  font-family:'Onest',sans-serif;font-weight:400;font-size:clamp(26px,3vw,34px);letter-spacing:-0.025em;line-height:1;
  margin-bottom:20px;
}
.legal-body{color:var(--ink-2);font-size:14.5px;line-height:1.65;max-width:64ch;animation:fadeUp .35s var(--ease)}
.legal-body h3{
  font-family:'Onest',sans-serif;font-weight:500;font-size:16px;color:var(--ink);
  margin:22px 0 8px;letter-spacing:-0.01em;
}
.legal-body h3:first-child{margin-top:0}
.legal-body p{margin-bottom:12px}
.legal-body ul{padding-left:18px;margin-bottom:12px;display:grid;gap:6px}
.legal-body a{
  background:var(--grad-text);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;font-weight:500;
}

.footer-legal{display:flex;align-items:center;gap:10px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.06em;color:var(--mute);text-transform:uppercase}
.footer-legal a{color:var(--ink-2);transition:color .25s}
.footer-legal a:hover{color:var(--ink)}
.footer-legal span{color:var(--mute-2)}

/* Respect users who don't want motion: kill ambient + slow long transitions */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .15s !important;
    scroll-behavior: auto !important;
  }
  .orb, .marquee-track, .intro-mark .o{animation:none !important}
  .reveal{opacity:1 !important; transform:none !important}
  .word > span{transform:none !important; opacity:1 !important; filter:none !important}
}

@media (hover:none), (pointer:coarse){
  .cursor, .cursor-ring, .spot{display:none !important}
  body{cursor:auto !important}
  .btn, .btn-nav, .choice, .dropzone, .file-row .x,
  .upload-card, .ff-file-drop, .ff-file-item .rm, .t-stage, .track-item, .btn-ghost,
  .svc, .work-item, .tier, .stage{cursor:pointer !important}
}

@media (max-width:780px){
  /* tighten vertical rhythm everywhere */
  .section{padding: clamp(48px,7vh,72px) var(--pad)}
  .sec-head{margin-bottom:48px}

  /* HERO */
  .hero{padding: 110px var(--pad) 28px;justify-content:flex-start;min-height:auto}
  .hero-top{
    position:static;flex-direction:column;align-items:flex-start;
    gap:10px;margin-bottom:32px;
  }
  .hero h1{font-size:clamp(42px,12vw,80px);max-width:none;letter-spacing:-0.03em}
  .hero-foot{grid-template-columns:1fr;gap:22px;margin-top:36px;padding-top:22px}
  .hero-foot p{font-size:15px;max-width:none}
  .hero-stats{flex-wrap:wrap;gap:18px 32px}
  .hero-stats div b{font-size:24px}
  .scroll-cue{display:none}

  /* MARQUEE */
  .marquee{padding:22px 0}
  .marquee-track{gap:32px;font-size:clamp(24px,8vw,40px)}
  .marquee-track > span{gap:32px}
  .marquee .star{width:12px;height:12px}

  /* WORK CARDS — tighten and reduce gap below the last full-width tile */
  .work-item{margin-top:0 !important;aspect-ratio:4/3}
  .work-item:last-child{aspect-ratio:16/10}
  .work-info{padding:16px;opacity:1;transform:none;background:linear-gradient(180deg,transparent 30%,rgba(7,7,12,.9))}
  .work-info h3{font-size:18px}
  .work-info .view{width:38px;height:38px;font-size:14px}

  /* v1-v5 work visuals */
  .v1::after{font-size:clamp(28px,8vw,48px)}
  .v2 .v2-grid{max-width:160px}
  .v3 .v3-mid{width:30%}
  .v4{font-size:clamp(36px,9vw,52px);padding:22px;text-align:center}
  .v4::before{width:26px;height:26px;top:16px;right:16px}
  .v5{padding:0 6vw;gap:12px}
  .v5 .big{font-size:clamp(26px,8vw,40px);text-align:center}

  /* FORM */
  .form{padding:24px 20px;border-radius:22px}
  .steps{gap:6px;margin-bottom:28px}
  .step{
    padding:10px 8px;font-size:10px;letter-spacing:.04em;
    text-align:center;justify-content:center;
    flex-direction:column;gap:2px;line-height:1;
  }
  .step .dot{display:none}
  .step-lbl{display:none}
  .step-num{font-size:11px}

  /* PROCESS / STAGES */
  .stage-week{text-align:left;margin-top:6px}
  .stage-week b{font-size:20px}

  /* PORTAL collapse */
  .portal-body{grid-template-columns:1fr}
  .portal-side{border-right:none;border-bottom:1px solid var(--bd);padding:24px var(--pad)}

  /* FOOTER */
  .luma-mark{font-size:clamp(96px,30vw,200px);margin:18px 0 28px}
}

@media (max-width:480px){
  /* NAV — keep brand + Portal button readable */
  .nav{gap:8px;padding:8px 10px}
  .brand{padding:0 6px;font-size:13px}
  .brand .o{width:16px;height:16px}
  .btn-nav{padding:7px 12px;font-size:10px}
  .pill{font-size:10px;padding:5px 10px}

  /* HERO */
  .hero h1{font-size:clamp(40px,13vw,68px)}
  .hero-stats{gap:14px 28px}
  .hero-stats div b{font-size:22px}

  /* MANIFESTO metrics */
  .metrics{grid-template-columns:1fr;gap:12px}
  .metric{padding:20px}
  .metric b{font-size:clamp(32px,9vw,44px)}

  /* SECTION headings */
  .sec-head h2{font-size:clamp(34px,9vw,52px)}

  /* STAGE */
  .stage{padding:22px}
  .stage h3{font-size:clamp(22px,6vw,28px)}

  /* WORK visuals — even tighter Northbound and Field Notes */
  .v4{font-size:clamp(32px,9vw,44px)}
  .v5 .big{font-size:clamp(24px,7.5vw,36px)}

  /* FOOTER hero CTA */
  .footer-top h2{font-size:clamp(32px,9vw,52px)}
}

/* ============================================================
   PORTAL CONTRACT GATE — AGREEMENT LAYOUT
   ============================================================ */
.portal-gate[hidden],
.portal-side[hidden],
.portal-main[hidden]{ display:none !important }

.portal-gate{
  grid-column:1/-1;
  overflow-y:auto;
  padding:40px var(--pad) 80px;
}

.agree-progress{
  max-width:1180px;margin:0 auto 40px;
  display:flex;flex-direction:column;gap:10px;
}
.agree-progress-bar{
  height:2px;background:rgba(255,255,255,.06);
  border-radius:99px;overflow:hidden;
}
.agree-progress-fill{
  height:100%;width:75%;
  background:var(--grad);border-radius:99px;
  box-shadow:0 0 16px rgba(139,123,255,.5);
}
.agree-progress-meta{
  display:flex;align-items:center;gap:10px;
  font-family:'JetBrains Mono',monospace;font-size:11px;
  text-transform:uppercase;letter-spacing:.04em;color:var(--mute);
  flex-wrap:wrap;
}
.agree-progress-meta .step-num b{color:var(--ink);font-weight:400}
.agree-progress-meta .dot{color:var(--mute-2)}
.agree-progress-meta .step-after{color:var(--mute-2)}

.agree-header{
  max-width:780px;margin:0 auto 56px;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:18px;
}
.agree-seal{
  width:96px;height:96px;border-radius:50%;
  display:grid;place-items:center;
  background:radial-gradient(circle at 30% 30%,rgba(181,166,255,.18),transparent 70%),rgba(255,255,255,.025);
  border:1px solid var(--bd-hi);
  box-shadow:0 20px 60px -20px rgba(139,123,255,.4),inset 0 1px 0 rgba(255,255,255,.06);
  animation:sealPulse 4s var(--ease) infinite;
}
@keyframes sealPulse{
  0%,100%{box-shadow:0 20px 60px -20px rgba(139,123,255,.3),inset 0 1px 0 rgba(255,255,255,.06)}
  50%{box-shadow:0 20px 80px -16px rgba(139,123,255,.6),inset 0 1px 0 rgba(255,255,255,.1)}
}
.agree-header h1{
  font-family:'Onest',sans-serif;font-weight:400;
  font-size:clamp(34px,4.6vw,56px);
  letter-spacing:-0.035em;line-height:1.04;max-width:18ch;
}
.agree-header h1 em{
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;
  background:var(--grad-text);background-clip:text;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.agree-sub{font-size:16px;line-height:1.55;color:var(--ink-2);max-width:58ch}
.agree-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:8px}
.agree-chip{
  display:flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:99px;
  background:rgba(255,255,255,.03);border:1px solid var(--bd);font-size:13px;
}
.agree-chip .lbl{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  text-transform:uppercase;letter-spacing:.06em;color:var(--mute);
}
.agree-chip .val{color:var(--ink)}

.agree-layout{
  max-width:1180px;margin:0 auto;
  display:grid;grid-template-columns:1fr 420px;gap:32px;align-items:start;
}

.agree-doc{
  background:var(--glass);border:1px solid var(--bd-hi);border-radius:20px;
  padding:44px clamp(28px,3.5vw,56px);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  box-shadow:0 20px 60px -30px rgba(0,0,0,.6),inset 0 1px 0 rgba(255,255,255,.04);
  position:relative;
}
.agree-doc::before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:60%;height:1px;
  background:linear-gradient(90deg,transparent,var(--violet),transparent);opacity:.4;
}
.doc-head{border-bottom:1px solid var(--bd);padding-bottom:22px;margin-bottom:28px}
.doc-tag{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  text-transform:uppercase;letter-spacing:.1em;color:var(--mute);margin-bottom:14px;
}
.doc-head h2{
  font-family:'Onest',sans-serif;font-weight:400;
  font-size:clamp(24px,2.6vw,32px);letter-spacing:-0.025em;line-height:1.1;margin-bottom:10px;
}
.doc-intro{color:var(--ink-2);font-size:14.5px;line-height:1.55}
.doc-intro strong{color:var(--ink);font-weight:500}

.gate-contract{margin-bottom:28px}

.doc-sections{display:flex;flex-direction:column;gap:24px;list-style:none;padding:0;margin:0}
.doc-sections > li{display:grid;grid-template-columns:48px 1fr;gap:18px}
.doc-n{
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:.06em;color:var(--mute);padding-top:4px;
}
.doc-sections h3{
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink);font-weight:500;margin-bottom:6px;
}
.doc-sections p{color:var(--ink-2);font-size:14.5px;line-height:1.65;max-width:60ch;margin:0 0 10px}
.doc-sections p:last-child{margin-bottom:0}
.doc-sections p strong{color:var(--ink);font-weight:500}
.doc-sections ul{color:var(--ink-2);font-size:14.5px;line-height:1.65;padding-left:18px;margin:6px 0 0;list-style:disc}
.doc-sections li{margin-bottom:4px}

.doc-accept{margin-top:24px;padding-top:24px;border-top:1px solid var(--bd)}
.doc-accept-lbl{
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink);font-weight:500;margin-bottom:6px;
}
.doc-accept-body{color:var(--ink-2);font-size:14.5px;line-height:1.65;margin-bottom:18px}

.sig-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}
.sig-party-name{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  text-transform:uppercase;letter-spacing:.08em;color:var(--mute);margin-bottom:10px;
}
.sig-card{
  background:rgba(255,255,255,.02);border:1px solid var(--bd);border-radius:12px;
  padding:18px 18px 14px;display:flex;flex-direction:column;gap:10px;
  position:relative;overflow:hidden;
  transition:border-color .35s var(--ease),background .35s var(--ease);
}
.sig-card.signed{
  background:linear-gradient(135deg,rgba(181,166,255,.04),rgba(79,195,220,.04));
  border-color:rgba(181,166,255,.25);
}
.sig-card::before{
  content:'';position:absolute;top:-30px;right:-30px;
  width:110px;height:110px;border-radius:50%;
  background:var(--grad);opacity:0;filter:blur(34px);
  transition:opacity .5s var(--ease);
}
.sig-card.signed::before,.sig-card.just-signed::before{opacity:.18}
.sig-mark{
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;
  font-size:30px;line-height:1.05;min-height:36px;
  background:var(--grad-text);background-clip:text;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.sig-mark.placeholder{
  font-family:'JetBrains Mono',monospace;font-style:normal;
  font-size:12px;text-transform:uppercase;letter-spacing:.06em;
  background:none;-webkit-text-fill-color:var(--mute);
}
.sig-line{height:1px;background:var(--bd);width:100%}
.sig-card.signed .sig-line{
  background:linear-gradient(90deg,transparent,var(--violet),transparent);opacity:.6;
}
.sig-meta{
  display:flex;justify-content:space-between;gap:8px;
  font-family:'JetBrains Mono',monospace;font-size:10px;
  text-transform:uppercase;letter-spacing:.06em;color:var(--mute);
}
.sig-meta .check{color:#62E394}
.sig-meta .pending{color:var(--mute)}
.sig-card.just-signed{animation:signedFlash 1.2s var(--ease)}
@keyframes signedFlash{
  0%{border-color:var(--bd);background:rgba(255,255,255,.02)}
  35%{border-color:rgba(181,166,255,.8);background:rgba(139,123,255,.08)}
  100%{border-color:rgba(181,166,255,.25);background:linear-gradient(135deg,rgba(181,166,255,.04),rgba(79,195,220,.04))}
}
.doc-foot{
  margin-top:36px;padding-top:18px;border-top:1px dashed var(--bd);
  display:flex;justify-content:space-between;
  font-family:'JetBrains Mono',monospace;font-size:10px;
  text-transform:uppercase;letter-spacing:.06em;color:var(--mute);
}

.agree-pad{
  position:sticky;top:104px;
  background:var(--glass);border:1px solid var(--bd-hi);border-radius:20px;
  padding:28px;
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  box-shadow:0 30px 80px -30px rgba(0,0,0,.6),inset 0 1px 0 rgba(255,255,255,.06);
  display:flex;flex-direction:column;gap:18px;
}
.agree-pad::before{
  content:'';position:absolute;top:-1px;left:24px;right:24px;height:1px;
  background:linear-gradient(90deg,transparent,var(--violet),var(--cyan),transparent);opacity:.5;
}
.pad-tag{
  align-self:flex-start;
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;border-radius:99px;
  background:rgba(98,227,148,.08);border:1px solid rgba(98,227,148,.25);
  font-family:'JetBrains Mono',monospace;font-size:10px;
  text-transform:uppercase;letter-spacing:.06em;color:#62E394;
}
.pad-tag-dot{
  width:6px;height:6px;border-radius:50%;
  background:#62E394;animation:pulse 2s var(--ease) infinite;
}
@keyframes pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.5;transform:scale(1.3)}
}
.agree-pad h2{
  font-family:'Onest',sans-serif;font-weight:400;font-size:24px;
  letter-spacing:-0.02em;line-height:1.15;
}
.pad-sub{color:var(--ink-2);font-size:13.5px;line-height:1.5}

.pad-check{
  display:flex;align-items:flex-start;gap:12px;cursor:pointer;
  padding:14px;border-radius:12px;
  background:rgba(255,255,255,.02);border:1px solid var(--bd);
  transition:border-color .25s,background .25s;
}
.pad-check:hover{border-color:var(--bd-hi);background:rgba(255,255,255,.035)}
.pad-check input{position:absolute;opacity:0;pointer-events:none}
.pad-check .check-box{
  flex-shrink:0;width:20px;height:20px;border-radius:6px;
  border:1.5px solid var(--bd-hi);
  display:grid;place-items:center;
  transition:all .25s var(--ease);
  position:relative;margin-top:1px;
}
.pad-check .check-box::after{
  content:'';width:10px;height:6px;
  border-left:2px solid #fff;border-bottom:2px solid #fff;
  transform:rotate(-45deg) scale(0);
  transition:transform .3s var(--ease);
  margin-top:-2px;
}
.pad-check input:checked + .check-box{
  background:var(--grad);border-color:transparent;
  box-shadow:0 4px 16px -2px rgba(139,123,255,.5);
}
.pad-check input:checked + .check-box::after{transform:rotate(-45deg) scale(1)}
.check-label{font-size:13.5px;line-height:1.5;color:var(--ink-2)}

.pad-field{display:flex;flex-direction:column;gap:6px}
.pad-field label{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  text-transform:uppercase;letter-spacing:.06em;color:var(--mute);
}
.pad-field input{
  background:rgba(255,255,255,.025);border:1px solid var(--bd);border-radius:12px;
  padding:14px 16px;color:var(--ink);
  font-family:'Onest',sans-serif;font-size:15px;outline:none;
  transition:border-color .3s var(--ease),background .3s var(--ease);
}
.pad-field input:focus{border-color:var(--violet);background:rgba(139,123,255,.06)}
.pad-field input::placeholder{color:var(--mute-2)}
.pad-field-helper{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  text-transform:uppercase;letter-spacing:.05em;color:var(--mute-2);margin-top:2px;
}

.pad-preview{
  background:rgba(255,255,255,.02);border:1px dashed var(--bd-hi);border-radius:12px;
  padding:18px;display:flex;flex-direction:column;gap:8px;
  position:relative;overflow:hidden;
}
.pad-preview::before{
  content:'';position:absolute;top:0;left:0;width:100%;height:100%;
  background:radial-gradient(circle at 0% 100%,rgba(181,166,255,.08),transparent 60%);
  pointer-events:none;
}
.pad-preview-lbl{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  text-transform:uppercase;letter-spacing:.06em;color:var(--mute);
  position:relative;z-index:1;
}
.pad-preview-sig{
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;
  font-size:30px;line-height:1.05;
  background:var(--grad-text);background-clip:text;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  min-height:36px;position:relative;z-index:1;
  transition:opacity .25s var(--ease);
}
.pad-preview-sig.placeholder{
  font-family:'JetBrains Mono',monospace;font-style:normal;font-size:12px;
  text-transform:uppercase;letter-spacing:.06em;
  background:none;-webkit-text-fill-color:var(--mute-2);
}
.pad-preview-line{
  height:1px;opacity:.5;position:relative;z-index:1;
  background:linear-gradient(90deg,transparent,var(--violet),var(--cyan),transparent);
}
.pad-preview-meta{
  display:flex;justify-content:space-between;gap:8px;
  font-family:'JetBrains Mono',monospace;font-size:10px;
  text-transform:uppercase;letter-spacing:.06em;color:var(--mute);
  position:relative;z-index:1;
}
.pad-preview-meta b{color:var(--ink-2);font-weight:400}

.pad-submit{width:100%;justify-content:center;padding:16px 24px;font-size:14px;position:relative}
.pad-submit:disabled{opacity:.45;pointer-events:none;filter:grayscale(.6)}
.pad-submit .arrow{transition:transform .35s var(--ease)}
.pad-submit:hover:not(:disabled) .arrow{transform:translateX(4px)}
.pad-note{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  text-transform:uppercase;letter-spacing:.05em;line-height:1.5;color:var(--mute-2);
}

.gate-error{
  display:none;
  font-family:'JetBrains Mono',monospace;font-size:11px;
  text-transform:uppercase;letter-spacing:.04em;color:#FF8888;
  padding:10px 14px;border-radius:10px;
  background:rgba(255,90,90,.07);border:1px solid rgba(255,90,90,.22);
}

.gate-success{
  display:none;position:fixed;inset:0;z-index:200;
  background:rgba(7,7,12,.85);
  backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);
  align-items:center;justify-content:center;flex-direction:column;gap:18px;
  text-align:center;padding:24px;
}
.gate-success.show{display:flex;animation:fadeUp .5s var(--ease)}
@keyframes fadeUp{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:translateY(0)}
}
.seal-big{
  width:120px;height:120px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,var(--violet-lo),var(--violet) 60%,var(--cyan) 110%);
  display:grid;place-items:center;
  font-size:48px;color:#fff;
  box-shadow:0 30px 80px -10px rgba(139,123,255,.7);
  animation:sealPulse 3s var(--ease) infinite;
}
.gate-success h2{
  font-family:'Onest',sans-serif;font-weight:400;
  font-size:clamp(28px,3.4vw,40px);letter-spacing:-0.025em;
}
.gate-success h2 em{
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;
  background:var(--grad-text);background-clip:text;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.gate-success p{color:var(--ink-2);max-width:48ch}

@media(max-width:980px){
  .agree-layout{grid-template-columns:1fr;gap:24px}
  .agree-pad{position:static}
  .portal-gate{padding:28px var(--pad) 60px}
  .agree-header{margin-bottom:36px}
}
@media(max-width:700px){.sig-row{grid-template-columns:1fr}}
@media(max-width:560px){
  .agree-doc{padding:28px 22px}
  .agree-chips{gap:6px}
  .agree-chip{padding:6px 10px;font-size:12px}
  .agree-pad{padding:22px}
  .doc-sections > li{grid-template-columns:1fr;gap:6px}
  .doc-n{padding-top:0}
}

/* ============================================================
   AUTH MODAL — set-password / forgot additions
   ============================================================ */
.auth-setpw-intro{
  font-size:14px;color:var(--ink-2);line-height:1.55;margin-bottom:20px;
}

/* Password show/hide + strength */
.pw-wrap{position:relative;display:block}
.pw-wrap input{width:100%;box-sizing:border-box;padding-right:44px}
.pw-toggle{
  position:absolute;right:12px;top:50%;transform:translateY(-50%);
  background:none;border:none;padding:4px;cursor:pointer;
  color:var(--mute);line-height:0;transition:color .2s;z-index:1;
}
.pw-toggle:hover{color:var(--ink)}
.pw-toggle svg{display:block}

.pw-strength{display:none;align-items:center;gap:8px;margin-top:8px}
.pw-strength.show{display:flex}
.pw-strength-bar{display:flex;gap:3px;flex:1}
.pw-strength-bar span{
  flex:1;height:3px;border-radius:2px;
  background:rgba(255,255,255,.08);transition:background .25s;
}
.pw-strength-label{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  text-transform:uppercase;letter-spacing:.06em;
  color:var(--mute);min-width:42px;text-align:right;transition:color .25s;
}
.pw-strength[data-level="1"] .pw-strength-bar span:nth-child(1){background:#ef4444}
.pw-strength[data-level="2"] .pw-strength-bar span:nth-child(-n+2){background:#f97316}
.pw-strength[data-level="3"] .pw-strength-bar span:nth-child(-n+3){background:#eab308}
.pw-strength[data-level="4"] .pw-strength-bar span:nth-child(-n+4){background:#22c55e}
.pw-strength[data-level="1"] .pw-strength-label{color:#ef4444}
.pw-strength[data-level="2"] .pw-strength-label{color:#f97316}
.pw-strength[data-level="3"] .pw-strength-label{color:#eab308}
.pw-strength[data-level="4"] .pw-strength-label{color:#22c55e}

.pw-reqs{
  display:none;list-style:none;margin:8px 0 0;padding:0;
  flex-wrap:wrap;gap:6px;
}
.pw-reqs.show{display:flex}
.pw-reqs li{
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.04em;
  color:var(--mute-2);
  padding:3px 8px;border-radius:20px;border:1px solid rgba(255,255,255,.08);
  transition:color .2s,border-color .2s;
}
.pw-reqs li::before{content:'✗ ';opacity:.4}
.pw-reqs li.met{color:#22c55e;border-color:rgba(34,197,94,.25)}
.pw-reqs li.met::before{content:'✓ ';opacity:1}

/* ── Messages section ────────────────────────────────── */
#messages{display:grid;gap:20px}
.msgs-head{display:flex;align-items:center;gap:12px}
.msgs-head h2{margin:0}
.msgs-badge{background:var(--violet);color:#fff;font-size:11px;font-family:'JetBrains Mono',monospace;padding:2px 8px;border-radius:20px;min-width:20px;text-align:center}
.msgs-thread{background:rgba(255,255,255,.02);border:1px solid var(--bd);border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:12px;min-height:120px;max-height:420px;overflow-y:auto}
.msgs-empty{color:var(--mute);font-size:13px;text-align:center;padding:24px 0;align-self:center}
.msg-bubble{max-width:72%;padding:12px 16px;border-radius:12px;display:flex;flex-direction:column;gap:4px}
.msg-bubble.msg-admin{align-self:flex-start;background:rgba(139,123,255,.12);border:1px solid rgba(139,123,255,.2)}
.msg-bubble.msg-client{align-self:flex-end;background:rgba(255,255,255,.06);border:1px solid var(--bd)}
.msg-text{font-size:14px;color:var(--ink);line-height:1.55}
.msg-meta{font-size:11px;color:var(--mute);font-family:'JetBrains Mono',monospace}
.msgs-compose{display:grid;gap:10px}
.msgs-input{background:rgba(255,255,255,.03);border:1px solid var(--bd);border-radius:10px;padding:12px 14px;color:var(--ink);font-size:14px;resize:vertical;transition:border-color .2s}
.msgs-input:focus{outline:none;border-color:var(--violet)}
.msgs-send{justify-self:end}
@media (max-width:680px){.msg-bubble{max-width:90%}}

/* ── Stepper ──────────────────────────────────────────── */
.fields-row:has(.stepper){align-items:end}
.stepper{display:inline-flex;align-items:center;justify-self:start;border:1px solid var(--bd);border-radius:8px;overflow:hidden}
.stepper-dec,.stepper-inc{background:transparent;border:none;color:var(--mute);font-size:18px;line-height:1;width:42px;padding:8px 0;text-align:center;cursor:none;transition:color .2s,background .2s}
@media (hover:none){.stepper-dec,.stepper-inc{cursor:pointer}}
@media (max-width:980px){.stepper-dec,.stepper-inc{cursor:pointer}}
.stepper-dec:hover,.stepper-inc:hover{color:var(--ink);background:rgba(255,255,255,.04)}
.stepper-val{min-width:36px;text-align:center;font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--ink)}

/* ── Price tag inside a chip ──────────────────────────── */
.price-tag{font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--mute);margin-left:auto;padding-left:8px;white-space:nowrap;flex-shrink:0}

/* ── Multi-select (addons) selected state ─────────────── */
.choice-grid[data-multi] .choice.selected .tick{background:var(--grad);border-color:transparent;box-shadow:0 0 10px rgba(139,123,255,.6)}

/* ── Estimate card ────────────────────────────────────── */
.estimate-card{background:rgba(139,123,255,.07);border:1px solid rgba(139,123,255,.25);border-radius:12px;padding:20px 22px;display:grid;gap:10px;margin-top:8px}
.estimate-total{font-size:28px;font-weight:700;letter-spacing:-.02em;color:var(--ink)}
.estimate-breakdown{list-style:none;margin:0;padding:0;display:grid;gap:4px}
.estimate-breakdown li{display:flex;justify-content:space-between;font-size:12px;color:var(--mute)}
.estimate-breakdown li span:last-child{font-family:'JetBrains Mono',monospace;color:var(--ink)}

/* ── Requirements form overlay ─────────────────────────── */
.rfp{position:fixed;inset:0;z-index:220;overflow-y:auto;background:rgba(7,7,12,.92);backdrop-filter:blur(20px) saturate(130%);-webkit-backdrop-filter:blur(20px) saturate(130%)}
.rfp-wrap{min-height:100%;display:flex;align-items:flex-start;justify-content:center;padding:clamp(48px,8vh,80px) 24px}
.rfp-panel{width:100%;max-width:600px;background:var(--glass);border:1px solid var(--bd-hi);border-radius:24px;padding:clamp(36px,5vw,56px) clamp(28px,4vw,48px);backdrop-filter:blur(28px) saturate(180%);-webkit-backdrop-filter:blur(28px) saturate(180%);box-shadow:0 40px 80px -16px rgba(0,0,0,.7),0 0 0 1px rgba(139,123,255,.10),inset 0 1px 0 rgba(255,255,255,.06)}
.rfp-head{margin-bottom:36px}
.rfp-badge{display:inline-block;padding:4px 12px;border-radius:99px;background:rgba(139,123,255,.12);border:1px solid rgba(139,123,255,.25);font-size:11px;font-family:'JetBrains Mono',monospace;letter-spacing:.06em;text-transform:uppercase;color:var(--violet);margin-bottom:16px}
.rfp-head h2{font-size:clamp(24px,3.2vw,36px);font-weight:600;letter-spacing:-.02em;line-height:1.1;margin-bottom:12px}
.rfp-head h2 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--violet)}
.rfp-head p{color:var(--ink-2);font-size:15px;line-height:1.6;max-width:52ch}
.rfp-mark{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;font-size:22px;margin-bottom:20px}
.rfp-success{background:rgba(98,227,148,.12);border:1px solid rgba(98,227,148,.3);color:#62E394}
.rfp-error{background:rgba(255,80,80,.08);border:1px solid rgba(255,80,80,.25);border-radius:10px;padding:12px 16px;font-size:13px;color:#FF5050;margin-bottom:20px}
.rfp-field{margin-bottom:28px}
.rfp-label{font-size:15px;font-weight:500;color:var(--ink);margin-bottom:6px}
.rfp-req{color:var(--violet);margin-left:2px}
.rfp-desc{font-size:13px;color:var(--mute);line-height:1.55;margin-bottom:10px;font-style:italic}
.rfp-radios{display:flex;flex-wrap:wrap;gap:10px;margin-top:4px}
.rfp-radio{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:10px;border:1px solid var(--bd);cursor:none;transition:border-color .2s,background .2s;font-size:14px;color:var(--ink-2)}
@media (hover:none),(max-width:980px){.rfp-radio{cursor:pointer}}
.rfp-radio input[type=radio]{display:none}
.rfp-radio:has(input:checked){border-color:var(--violet);background:rgba(139,123,255,.08);color:var(--ink)}
.rfp-input{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--bd);border-radius:10px;padding:12px 14px;color:var(--ink);font-size:14px;font-family:inherit;transition:border-color .2s;box-sizing:border-box}
.rfp-input:focus{outline:none;border-color:var(--violet)}
.rfp-textarea{resize:vertical;min-height:80px}
.rfp-foot{margin-top:32px;display:grid;gap:12px}
.rfp-disclaimer{font-size:12px;color:var(--mute);text-align:center;line-height:1.5}
.rfp-table{border:1px solid rgba(255,255,255,.08);border-radius:12px 12px 0 0;overflow:hidden}
.rfp-price-row{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.06)}
.rfp-price-row:last-child{border-bottom:none}
.rfp-price-label{font-size:14px;color:var(--ink-2);line-height:1.4}
.rfp-price-label span{display:block;font-size:12px;color:var(--mute);margin-top:2px}
.rfp-price-val{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--ink);white-space:nowrap;flex-shrink:0}
.rfp-total{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-top:none;border-radius:0 0 12px 12px;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--mute);font-family:'JetBrains Mono',monospace;margin-bottom:20px}
.rfp-total-val{font-size:20px;font-weight:600;color:var(--violet);text-transform:none;letter-spacing:-.01em}
.rfp-note{font-size:13px;color:var(--mute);line-height:1.5}
@media (max-width:600px){.rfp-panel{border-radius:16px}.rfp-radios{flex-direction:column}}

