/* ==============================================================
   VIBECRAFT — "EVENT HORIZON"
   Dark cosmic-cyberpunk. Black holes, wormholes, deep space.
   Accretion amber + ice-blue rim + crimson. No purple. No neon soup.
   ============================================================== */

:root{
  --void:#04060b;
  --void-2:#070a12;
  --ink:#0b0f1a;
  --line:rgba(150,180,230,.12);
  --line-2:rgba(150,180,230,.22);

  --text:#EAF0FF;
  --muted:#8C99B5;
  --faint:#56607a;

  /* accretion disk spectrum (lead) */
  --amber:#FF8A1E;
  --amber-soft:#FFB45A;
  --gold:#FFD66B;
  --hot:#FF4326;          /* crimson plasma, sparing */
  /* event-horizon rim (sparing cold accent) */
  --ice:#49B6FF;

  --display:'Unbounded',system-ui,sans-serif;
  --tech:'Chakra Petch',monospace;
  --body:'Space Grotesk','Inter',system-ui,sans-serif;
  --ease:cubic-bezier(.19,1,.22,1);
  --maxw:1280px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}   /* clips off-canvas fixed drawer -> no sideways shift on mobile */
body{
  background:
    radial-gradient(1200px 700px at 78% 8%, rgba(255,138,30,.10), transparent 60%),
    radial-gradient(900px 600px at 12% 80%, rgba(73,182,255,.07), transparent 60%),
    var(--void);
  color:var(--text);
  font-family:var(--body);
  line-height:1.7;
  overflow-x:hidden;
  width:100%;
  position:relative;
  cursor:none;
  -webkit-font-smoothing:antialiased;
}
body.locked{overflow:hidden;height:100vh}
html.no-scroll{overflow:hidden}   /* lock background scroll while an overlay is open */
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:none}
img,svg{display:block;max-width:100%}
::selection{background:var(--amber);color:var(--void)}

/* faint scanlines + grain for cyberpunk texture (very subtle) */
body::after{
  content:"";position:fixed;inset:0;z-index:60;pointer-events:none;opacity:.5;
  background:repeating-linear-gradient(0deg,rgba(0,0,0,.16) 0 1px,transparent 1px 3px);
  mix-blend-mode:multiply;
}

/* ==============================================================
   LAYERS: WebGL scene canvas (behind), content (above)
   ============================================================== */
#gl{position:fixed;inset:0;z-index:0;display:block;opacity:.5}   /* dimmed so it never overpowers content */
.gl-fallback{position:fixed;inset:0;z-index:-1;
  background:radial-gradient(700px 700px at 75% 30%,rgba(255,138,30,.12),transparent 60%),var(--void)}
/* darkening layer over the 3D — more opaque so all content reads clearly */
.vignette{position:fixed;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(rgba(4,6,11,.55),rgba(4,6,11,.55)),radial-gradient(ellipse at 50% 45%,transparent 16%,rgba(2,3,7,.92) 100%)}
main{position:relative;z-index:2}

/* ==============================================================
   CURSOR
   ============================================================== */
.cur{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;transform:translate(-50%,-50%);
  width:36px;height:36px;transition:width .35s var(--ease),height .35s var(--ease),opacity .3s}
.cur::before,.cur::after{content:"";position:absolute;inset:0}
.cur::before{border:1px solid rgba(255,138,30,.7);border-radius:50%;
  clip-path:polygon(0 0,30% 0,30% 6%,6% 6%,6% 30%,0 30%, 0 0, 100% 0,100% 30%,94% 30%,94% 6%,70% 6%,70% 0, 100% 100%,70% 100%,70% 94%,94% 94%,94% 70%,100% 70%, 0 100%,0 70%,6% 70%,6% 94%,30% 94%,30% 100%)}
.cur i{position:absolute;left:50%;top:50%;width:4px;height:4px;background:var(--gold);border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 8px var(--gold)}
.cur.hot{width:64px;height:64px}
.cur.hot::before{border-color:var(--gold);box-shadow:0 0 18px rgba(255,214,107,.5)}
@media (hover:none),(pointer:coarse){body{cursor:auto}.cur{display:none}}

/* ==============================================================
   LOADER — collapse into the singularity
   ============================================================== */
#boot{position:fixed;inset:0;z-index:10000;background:#020308;display:grid;place-items:center;overflow:hidden;
  transition:opacity 1s var(--ease),visibility 1s}
#boot.gone{opacity:0;visibility:hidden;pointer-events:none}
.boot-core{position:relative;display:flex;flex-direction:column;align-items:center;gap:26px;z-index:2;text-align:center}
.singularity{width:0;height:0;border-radius:50%;background:#fff;
  box-shadow:0 0 60px 20px rgba(255,214,107,.7),0 0 140px 60px rgba(255,138,30,.45),0 0 240px 120px rgba(255,67,38,.25);
  animation:collapse 3.6s var(--ease) forwards}
@keyframes collapse{
  0%{width:0;height:0;opacity:0}
  25%{width:120px;height:120px;opacity:1}
  60%{width:140px;height:140px}
  100%{width:18px;height:18px;box-shadow:0 0 30px 10px rgba(255,214,107,.9),0 0 90px 40px rgba(255,138,30,.5)}
}
.boot-word{font-family:var(--display);font-weight:800;font-size:clamp(2rem,8vw,5rem);letter-spacing:.04em;line-height:1;
  display:flex;gap:.02em}
.boot-word span{display:inline-block;opacity:0;transform:translateY(40px) rotateX(-90deg);transform-origin:bottom;
  background:linear-gradient(180deg,#fff,var(--gold));-webkit-background-clip:text;background-clip:text;color:transparent;
  animation:bootIn .7s var(--ease) forwards}
@keyframes bootIn{to{opacity:1;transform:none}}
.boot-status{font-family:var(--tech);font-size:.72rem;letter-spacing:.42em;text-transform:uppercase;color:var(--muted);
  opacity:0;animation:fade .8s ease 2.4s forwards}
.boot-bar{width:200px;height:2px;background:rgba(255,255,255,.1);overflow:hidden;opacity:0;animation:fade .6s ease 2.4s forwards}
.boot-bar i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--amber),var(--gold));animation:load 1.4s var(--ease) 2.5s forwards}
@keyframes load{to{width:100%}}
.boot-skip{position:absolute;bottom:32px;right:34px;font-family:var(--tech);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--faint);transition:.3s;opacity:0;animation:fade .6s ease 3s forwards}
.boot-skip:hover{color:var(--gold)}
@keyframes fade{to{opacity:1}}

/* ==============================================================
   HUD FRAME (fixed overlay corner brackets + status)
   ============================================================== */
.hud{position:fixed;top:118px;left:18px;right:18px;bottom:18px;z-index:50;pointer-events:none;opacity:0;animation:fade 1.2s ease 1s forwards}
.hud .corner{position:absolute;width:26px;height:26px;border:1px solid var(--line-2)}
.hud .tl{top:0;left:0;border-right:0;border-bottom:0}
.hud .tr{top:0;right:0;border-left:0;border-bottom:0}
.hud .bl{bottom:0;left:0;border-right:0;border-top:0}
.hud .br{bottom:0;right:0;border-left:0;border-top:0}
.hud .readout{position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  font-family:var(--tech);font-size:.62rem;letter-spacing:.34em;text-transform:uppercase;color:var(--faint)}

/* sticky solid header */
.site-header{position:fixed;top:0;left:0;right:0;z-index:78;height:clamp(72px,11vw,104px);
  display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 clamp(16px,4vw,44px);
  background:rgba(7,10,18,.97);backdrop-filter:blur(14px);border-bottom:1px solid var(--line-2);
  box-shadow:0 10px 30px -20px rgba(0,0,0,.8);opacity:0;animation:fade 1s ease .2s forwards}
.brand{display:inline-flex;align-items:center;gap:12px;font-family:var(--display);font-weight:800;font-size:1.05rem;letter-spacing:.02em}
/* logo (trimmed wide lockup vibecrafts-logo.png) — sized by height, responsive */
.brand img{height:clamp(52px,8vw,80px);width:auto;object-fit:contain;filter:drop-shadow(0 0 12px rgba(255,138,30,.32))}
.brand .bf{color:var(--text)}.brand .bf b{color:var(--amber);font-weight:800}

/* header — centered status chip (live clock) + CTA */
.header-status{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:flex;align-items:center;gap:11px;
  white-space:nowrap;padding:7px 16px;border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.008));
  clip-path:polygon(9px 0,100% 0,100% calc(100% - 9px),calc(100% - 9px) 100%,0 100%,0 9px)}
.header-status .dot{width:8px;height:8px;border-radius:50%;background:#3dffa8;box-shadow:0 0 10px #3dffa8;animation:blink 2s infinite;flex:0 0 auto}
.header-status .hs-label{font-family:var(--tech);font-size:.6rem;font-weight:500;letter-spacing:.24em;text-transform:uppercase;color:var(--muted)}
.header-status .hs-sep{width:1px;height:15px;background:var(--line-2)}
.header-status .hs-clock{font-family:var(--tech);font-weight:600;font-size:.95rem;letter-spacing:.16em;color:var(--gold);
  font-variant-numeric:tabular-nums;text-shadow:0 0 14px rgba(255,214,107,.5)}
.header-status .hs-zone{font-family:var(--tech);font-size:.54rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);align-self:flex-start;margin-top:3px}
.header-cta{font-size:.8rem;padding:13px 22px;flex:0 0 auto}
.header-cta .cta-short{display:none}
.header-cta .arr{display:inline-block;transition:transform .3s var(--ease)}
.header-cta:hover .arr{transform:translateX(4px)}
/* keep the clock on tablets (hide only on phones where there's no room) */
@media(max-width:600px){
  .header-status{display:none}
  .header-cta{padding:9px 15px;font-size:.72rem}
  .header-cta .cta-full{display:none}
  .header-cta .cta-short{display:inline-block;line-height:1.06;text-align:center}
}

/* side nav — vertical ticks */
.spine{position:fixed;top:50%;right:30px;transform:translateY(-50%);z-index:70;display:flex;flex-direction:column;gap:20px;
  opacity:0;animation:fade 1.2s ease 1.3s forwards}
.tick{display:flex;align-items:center;gap:12px;justify-content:flex-end;color:var(--faint);transition:.4s var(--ease)}
.tick .lbl{font-family:var(--tech);font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;opacity:0;transform:translateX(8px);transition:.4s var(--ease)}
.tick .bar{width:22px;height:1px;background:currentColor;transition:.4s var(--ease)}
.tick:hover,.tick.on{color:var(--gold)}
.tick:hover .lbl,.tick.on .lbl{opacity:1;transform:none}
.tick.on .bar{width:40px;box-shadow:0 0 10px var(--gold)}
@media(max-width:820px){.spine,.hud .readout{display:none}}

/* progress line top */
#prog{position:fixed;top:0;left:0;height:2px;width:0;z-index:80;background:linear-gradient(90deg,var(--amber),var(--gold),var(--ice))}

/* ==============================================================
   SHARED — sections / typography
   ============================================================== */
.sec{position:relative;padding:clamp(90px,13vh,170px) clamp(24px,6vw,90px);max-width:var(--maxw);margin:0 auto}
.tag{display:inline-flex;align-items:center;gap:10px;font-family:var(--tech);font-size:.7rem;font-weight:600;
  letter-spacing:.32em;text-transform:uppercase;color:var(--amber);margin-bottom:26px}
.tag::before{content:"";width:30px;height:1px;background:var(--amber);box-shadow:0 0 8px var(--amber)}
.tag .idx{color:var(--faint)}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.02;letter-spacing:-.01em}
.title{font-size:clamp(2rem,6vw,4.4rem);font-weight:800;margin-bottom:20px}
.title .glow{color:transparent;background:linear-gradient(120deg,var(--amber),var(--gold) 60%,#fff);-webkit-background-clip:text;background-clip:text;
  filter:drop-shadow(0 0 22px rgba(255,138,30,.4))}
.lead-p{color:var(--muted);font-size:clamp(1rem,1.5vw,1.18rem);max-width:60ch;font-weight:300}

/* glow button / link */
.cta{display:inline-flex;align-items:center;gap:12px;font-family:var(--tech);font-weight:600;font-size:.84rem;
  letter-spacing:.16em;text-transform:uppercase;padding:15px 28px;position:relative;color:var(--void);
  background:linear-gradient(120deg,var(--amber),var(--gold));
  clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
  transition:.4s var(--ease);box-shadow:0 0 0 rgba(255,138,30,0)}
.cta:hover{transform:translateY(-3px);box-shadow:0 14px 40px -10px rgba(255,138,30,.7)}
.cta.ghost{background:transparent;color:var(--text);border:1px solid var(--line-2)}
.cta.ghost:hover{border-color:var(--amber);color:var(--gold);box-shadow:0 14px 40px -16px rgba(255,138,30,.5)}

/* ==============================================================
   HERO
   ============================================================== */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;
  padding:140px clamp(24px,6vw,90px) 90px;max-width:var(--maxw);margin:0 auto}
.hero .coords{font-family:var(--tech);font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:var(--faint);margin-bottom:30px;display:flex;gap:24px;flex-wrap:wrap}
.hero .coords b{color:var(--ice);font-weight:500}
.hero h1{font-family:var(--display);font-weight:800;font-size:clamp(2.8rem,9.5vw,8rem);line-height:.92;letter-spacing:-.02em;max-width:14ch}
.hero h1 .l{display:block;overflow:hidden}
.hero h1 .l>span{display:inline-block;transform:translateY(110%);transition:transform 1.1s var(--ease)}
.hero h1.in .l>span{transform:none}
.hero h1 .grad{color:transparent;background:linear-gradient(120deg,var(--amber),var(--gold) 55%,#fff);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 0 30px rgba(255,138,30,.45))}
.hero .sub{color:var(--muted);font-weight:300;font-size:clamp(1.05rem,1.8vw,1.4rem);max-width:50ch;margin-top:34px}
.hero .acts{display:flex;gap:18px;margin-top:46px;flex-wrap:wrap;align-items:center}
.hero .scan{margin-top:64px;display:flex;gap:40px;flex-wrap:wrap;font-family:var(--tech)}
.hero .scan .s b{font-family:var(--display);font-weight:800;font-size:clamp(1.6rem,3vw,2.4rem);display:block;color:var(--gold)}
.hero .scan .s span{font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--faint)}

/* ==============================================================
   ABOUT
   ============================================================== */
.about{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.about .lead-q{font-family:var(--display);font-weight:700;font-size:clamp(1.5rem,3.4vw,2.6rem);line-height:1.2;margin-bottom:26px}
.about .lead-q em{font-style:normal;color:var(--amber)}
.about p{color:var(--muted);font-weight:300;margin-bottom:16px;max-width:52ch}
.pillars{display:grid;gap:14px}
.pillar{position:relative;padding:22px 24px;border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.02),transparent);
  clip-path:polygon(0 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%);transition:.4s var(--ease)}
.pillar:hover{border-color:var(--line-2);transform:translateX(8px)}
.pillar h4{font-family:var(--tech);font-weight:600;font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;margin-bottom:8px}
.pillar.m h4{color:var(--amber)}.pillar.v h4{color:var(--ice)}.pillar.p h4{color:var(--gold)}
.pillar p{margin:0;font-size:.95rem;color:var(--muted)}

/* ==============================================================
   SERVICES — HUD modules (3D tilt)
   ============================================================== */
.grid-svc{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;perspective:1400px}
.mod{position:relative;padding:30px 26px;border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,.005));
  clip-path:polygon(0 0,calc(100% - 16px) 0,100% 16px,100% 100%,16px 100%,0 calc(100% - 16px));
  transition:transform .4s var(--ease),border-color .4s,box-shadow .4s;transform-style:preserve-3d;cursor:none;overflow:hidden}
.mod::before{content:"";position:absolute;top:0;left:-60%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,214,107,.08),transparent);transition:.6s var(--ease)}
.mod:hover{border-color:rgba(255,138,30,.5);box-shadow:0 24px 60px -30px rgba(255,138,30,.5),inset 0 0 30px rgba(255,138,30,.04)}
.mod:hover::before{left:120%}
.mod .no{font-family:var(--tech);font-size:.72rem;letter-spacing:.2em;color:var(--amber);margin-bottom:18px;display:block;transform:translateZ(30px)}
.mod h3{font-size:1.18rem;font-weight:700;margin-bottom:10px;transform:translateZ(24px)}
.mod p{color:var(--muted);font-size:.92rem;font-weight:300;transform:translateZ(16px)}
.mod .dot{position:absolute;top:26px;right:26px;width:7px;height:7px;border-radius:50%;background:var(--amber);box-shadow:0 0 10px var(--amber)}
@media(max-width:900px){.grid-svc{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.grid-svc{grid-template-columns:1fr}}

/* ==============================================================
   PROCESS — flight path
   ============================================================== */
.flight{display:grid;grid-template-columns:repeat(7,1fr);gap:0;margin-top:50px;position:relative}
.flight::before{content:"";position:absolute;left:0;right:0;top:18px;height:1px;background:linear-gradient(90deg,transparent,var(--amber),var(--ice),transparent);opacity:.5}
.leg{position:relative;text-align:center;padding:0 8px}
.leg .node{position:relative;z-index:1;width:14px;height:14px;border-radius:50%;margin:12px auto 22px;background:var(--void);border:1px solid var(--amber);box-shadow:0 0 12px rgba(255,138,30,.6);transition:.4s}
.leg:hover .node{background:var(--gold);box-shadow:0 0 22px var(--gold)}
.leg h5{font-family:var(--display);font-weight:700;font-size:1rem;margin-bottom:6px}
.leg p{font-family:var(--tech);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--faint)}
/* curvy connector line (JS-drawn through the dots) — mobile only */
.flight-path{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;overflow:visible;display:none}
.flight-path path{fill:none;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 6px rgba(255,138,30,.6))}
@media(max-width:820px){.flight{grid-template-columns:repeat(2,1fr);gap:34px 20px}.flight::before{display:none}.flight-path{display:block}}
@media(max-width:600px){.flight{gap:30px 16px}}

/* ==============================================================
   WORK — monolith shards (3D), dimensional tear retained
   ============================================================== */
.shards{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;perspective:1600px}
.shard{position:relative;min-height:300px;display:flex;flex-direction:column;justify-content:flex-end;
  padding:32px;border:1px solid var(--line);overflow:hidden;cursor:none;transform-style:preserve-3d;
  transition:transform .5s var(--ease),border-color .4s;
  clip-path:polygon(0 0,100% 0,100% calc(100% - 22px),calc(100% - 22px) 100%,0 100%)}
.shard .bg{position:absolute;inset:0;z-index:0;opacity:.5;transition:.6s var(--ease)}
.shard::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,transparent 30%,rgba(4,6,11,.92))}
.shard>*{position:relative;z-index:2}
.shard:hover{border-color:rgba(255,138,30,.5)}
.shard:hover .bg{opacity:.8;transform:scale(1.05)}
.shard .k{font-family:var(--tech);font-size:.64rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.shard h3{font-size:1.7rem;font-weight:800;margin-bottom:8px}
.shard p{color:var(--muted);font-weight:300;font-size:.95rem;max-width:40ch}
.shard .open{margin-top:16px;font-family:var(--tech);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--amber)}
.shard.tall{min-height:360px}
@media(max-width:760px){.shards{grid-template-columns:1fr}}

/* dimensional tear */
#tear{position:fixed;inset:0;z-index:900;pointer-events:none;opacity:0;visibility:hidden;transition:opacity .5s;
  background:rgba(4,6,11,.975);backdrop-filter:blur(16px)}   /* solid backdrop — no bleed-through */
#tear.open{opacity:1;visibility:visible;pointer-events:auto}
.tear-bg{position:absolute;inset:0;background:rgba(2,3,8,.9);backdrop-filter:blur(10px);
  clip-path:polygon(50% 50%,50% 50%,50% 50%,50% 50%);transition:clip-path .7s var(--ease)}
#tear.open .tear-bg{clip-path:polygon(0 0,100% 0,100% 40%,58% 50%,100% 60%,100% 100%,0 100%,0 62%,42% 50%,0 38%)}
.tear-in{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;
  text-align:center;overflow-y:auto;padding:8vh 5vw;opacity:0;transition:opacity .5s .3s}
#tear.open .tear-in{opacity:1}
.tear-close{font-family:var(--tech);font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);transition:.3s}
.tear-close:hover{color:var(--gold);letter-spacing:.4em}

/* ---------- rich case study (inside the tear) ---------- */
.case{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(24px,4vw,50px);align-items:center;
  width:min(1020px,94vw);text-align:left}
.c-kind{font-family:var(--tech);font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;color:var(--ac,var(--gold));margin-bottom:14px}
.c-back{font-family:var(--tech);font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);
  margin-bottom:18px;transition:.3s var(--ease);display:inline-flex;align-items:center;gap:6px}
.c-back:hover{color:var(--gold);gap:10px}
.case h3{font-family:var(--display);font-weight:800;font-size:clamp(2rem,6vw,3.6rem);line-height:1;margin-bottom:20px}
.c-problem,.c-build{color:var(--muted);font-weight:300;font-size:.98rem;margin-bottom:12px;max-width:48ch}
.c-problem b,.c-build b{color:var(--text);font-weight:500;font-family:var(--tech);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;display:block;margin-bottom:3px}
.c-metrics{display:grid;grid-template-columns:repeat(3,auto);gap:18px 30px;margin:24px 0}
.metric b{font-family:var(--display);font-weight:800;font-size:clamp(1.5rem,3.4vw,2.2rem);color:var(--gold);display:block;line-height:1}
.metric span{font-family:var(--tech);font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;color:var(--faint)}
.c-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:26px}
.chip{font-family:var(--tech);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);
  border:1px solid var(--line);padding:6px 11px;background:rgba(255,255,255,.02);
  clip-path:polygon(0 0,100% 0,100% calc(100% - 5px),calc(100% - 5px) 100%,0 100%)}
.c-cta{display:inline-flex}

/* case visuals */
.c-visual{display:grid;place-items:center}
.mock-browser{width:100%;max-width:460px;border:1px solid var(--line-2);background:#05070d;
  box-shadow:0 30px 70px -30px rgba(255,138,30,.45);clip-path:polygon(0 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%)}
.mb-bar{display:flex;align-items:center;gap:8px;padding:9px 12px;border-bottom:1px solid var(--line);font-family:var(--tech);font-size:.58rem;color:var(--faint)}
.mb-lock{width:11px;height:11px;color:var(--amber);flex:0 0 auto;opacity:.9}
.mb-url{flex:1;letter-spacing:.08em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mb-live{width:7px;height:7px;border-radius:50%;background:#3dffa8;box-shadow:0 0 8px #3dffa8;animation:blink 2s infinite;flex:0 0 auto}
.mb-soon{color:var(--amber);letter-spacing:.12em}
.mb-shot{position:relative;aspect-ratio:16/11;overflow:hidden;background:#070a12;display:grid;place-items:center}
.mb-shot img{width:100%;height:100%;object-fit:cover;object-position:top}
.mb-shot .mb-ph{display:none;font-family:var(--display);font-weight:800;font-size:1.2rem;color:var(--muted)}
.mb-shot.noshot img{display:none}.mb-shot.noshot .mb-ph{display:block}
.mb-corner{position:absolute;width:15px;height:15px;z-index:3;pointer-events:none;border:1px solid rgba(255,138,30,.65);opacity:0;transition:.4s var(--ease)}
.mb-corner.tl{top:8px;left:8px;border-right:0;border-bottom:0}
.mb-corner.br{bottom:8px;right:8px;border-left:0;border-top:0}
.mock-browser:hover .mb-corner{opacity:1}
.mock-dash{width:100%;max-width:430px;border:1px solid var(--line-2);background:#070a12;padding:18px;
  box-shadow:0 30px 70px -30px rgba(255,214,107,.4);clip-path:polygon(0 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%)}
.md-top{font-family:var(--tech);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);display:flex;align-items:center;gap:8px;margin-bottom:14px}
.md-dot{width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 8px var(--gold)}
.md-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.md-tile{border:1px solid var(--line);padding:10px}
.md-tile b{font-family:var(--display);font-weight:800;font-size:1.05rem;color:var(--text);display:block}
.md-tile span{font-family:var(--tech);font-size:.5rem;letter-spacing:.08em;text-transform:uppercase;color:var(--faint)}
.md-chart{display:flex;align-items:flex-end;gap:6px;height:78px;margin-bottom:14px}
.md-chart i{flex:1;background:linear-gradient(180deg,var(--amber),rgba(255,138,30,.15));animation:barGrow .9s var(--ease) both}
@keyframes barGrow{from{transform:scaleY(0);transform-origin:bottom}}
.md-rows div{height:9px;background:var(--line);margin-bottom:7px;border-radius:2px}
.md-rows div:nth-child(2){width:82%}.md-rows div:nth-child(3){width:58%}
.mock-status{width:100%;max-width:400px;border:1px solid var(--line-2);background:#070a12;padding:22px;
  box-shadow:0 30px 70px -30px rgba(73,182,255,.4);clip-path:polygon(0 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%)}
.ms-row{display:flex;align-items:center;gap:10px;font-family:var(--tech);font-size:.74rem;color:var(--text);padding:9px 0;border-bottom:1px solid var(--line)}
.ms-dot{width:9px;height:9px;border-radius:50%;background:#3dffa8;box-shadow:0 0 8px #3dffa8;animation:blink 2s infinite}
@keyframes blink{50%{opacity:.35}}
.ms-heart{margin:16px 0 10px}
.ms-heart svg{width:100%;height:38px;display:block}
.ms-heart polyline{fill:none;stroke:var(--amber);stroke-width:2;filter:drop-shadow(0 0 4px var(--amber));
  stroke-dasharray:300;stroke-dashoffset:300;animation:heart 2.6s linear infinite}
@keyframes heart{to{stroke-dashoffset:-300}}
.ms-up{font-family:var(--tech);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.mock-soon{width:100%;max-width:360px;aspect-ratio:1.2;display:grid;place-items:center;position:relative}
.beacon-pulse{width:58px;height:58px;border-radius:50%;background:radial-gradient(circle,#fff,var(--gold) 40%,var(--amber));
  box-shadow:0 0 45px var(--amber);animation:beaconGlow 2s ease-in-out infinite}
.beacon-pulse::before,.beacon-pulse::after{content:"";position:absolute;top:50%;left:50%;width:58px;height:58px;margin:-29px;border-radius:50%;border:1px solid var(--amber);animation:beaconRing 2.6s ease-out infinite}
.beacon-pulse::after{animation-delay:1.3s}
@keyframes beaconGlow{50%{transform:scale(1.14)}}
@keyframes beaconRing{0%{transform:scale(1);opacity:.8}100%{transform:scale(3.4);opacity:0}}
.mock-soon .ms-label{position:absolute;bottom:22%;font-family:var(--display);font-weight:800;font-size:1.3rem;color:var(--text)}
.mock-soon .ms-sub{position:absolute;bottom:14%;font-family:var(--tech);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--faint)}

@media(max-width:820px){
  .case{grid-template-columns:1fr;gap:24px;text-align:center}
  .c-problem,.c-build{max-width:100%}
  .c-metrics{grid-template-columns:repeat(3,1fr);justify-items:center;gap:14px}
  .c-chips{justify-content:center}
  .c-visual{order:-1}
  .tear-in{justify-content:flex-start;padding:74px 20px 40px}
}

/* ---------- chambers (category view inside the tear) ---------- */
.chamber{width:min(1060px,94vw);display:flex;flex-direction:column;align-items:center;gap:clamp(22px,3vw,32px);text-align:center}
.ch-head{max-width:58ch}
.ch-head h3{font-family:var(--display);font-weight:800;font-size:clamp(1.9rem,5vw,3.2rem);line-height:1;margin:8px 0 12px}
.ch-tag{color:var(--muted);font-weight:300;font-size:1rem;max-width:52ch;margin:0 auto}
.ch-projects{display:flex;flex-wrap:wrap;justify-content:center;gap:16px;width:100%}
.pj{flex:1 1 262px;max-width:342px;display:flex;flex-direction:column;text-align:left;overflow:hidden;position:relative;
  border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.03),transparent);
  transition:.45s var(--ease);animation:pjIn .6s var(--ease) backwards;
  clip-path:polygon(0 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%)}
.pj::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;z-index:5;
  background:linear-gradient(90deg,var(--amber),var(--gold));transform:scaleX(0);transform-origin:left;transition:.55s var(--ease)}
.pj:hover{border-color:rgba(255,138,30,.6);transform:translateY(-8px);box-shadow:0 32px 64px -26px rgba(255,138,30,.6)}
.pj:hover::before{transform:scaleX(1)}
.pj .mock-browser{max-width:none;border:none;box-shadow:none;clip-path:none;background:transparent;border-bottom:1px solid var(--line)}
.pj .mb-shot{aspect-ratio:16/10}
.pj .mb-shot img{transition:object-position 4.5s var(--ease)}
.pj:hover .mb-shot img{object-position:bottom}   /* slowly pan through the live site */
.pj .mb-shot::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;opacity:0;transition:.4s var(--ease);
  background:linear-gradient(180deg,transparent 55%,rgba(255,138,30,.08))}
.pj:hover .mb-shot::after{opacity:1}
@keyframes pjIn{from{opacity:0;filter:blur(7px)}to{opacity:1;filter:blur(0)}}
.pj:nth-child(2){animation-delay:.09s}.pj:nth-child(3){animation-delay:.18s}
.pj-info{padding:15px 17px;display:flex;flex-direction:column;gap:3px}
.pj-info b{font-family:var(--display);font-weight:700;font-size:1.02rem;display:flex;align-items:center;gap:8px;flex-wrap:wrap;color:var(--text)}
.pj-info>span{font-family:var(--tech);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}
.pj-info em{font-family:var(--tech);font-style:normal;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--amber);margin-top:8px}
.pj-badge{font-family:var(--tech);font-size:.52rem;letter-spacing:.1em;text-transform:uppercase;color:#3dffa8;border:1px solid rgba(61,255,168,.4);padding:2px 7px}
.ch-empty{display:flex;flex-direction:column;align-items:center;gap:16px;padding:6px 0}
.ch-empty .mock-soon{aspect-ratio:auto;width:auto;min-height:110px;place-items:center}
.ch-empty-txt p{color:var(--muted);font-weight:300;max-width:46ch;margin:0 auto 4px}
.ch-empty-txt p:first-child{font-family:var(--display);font-weight:700;color:var(--text);font-size:1.2rem;margin-bottom:8px}
.ch-cta{margin-top:4px}
@media(max-width:600px){.pj{flex:1 1 100%;max-width:360px}}

/* ---------- SHOWCASE — featured live preview + selector ---------- */
.showcase{width:min(1140px,94vw);display:flex;flex-direction:column;gap:28px}
.sc-main{display:grid;grid-template-columns:1.25fr .92fr;gap:clamp(28px,4vw,50px);align-items:center;text-align:left}
.sc-view{position:relative}
.sc-view .sc-glow{position:absolute;inset:-12% -8%;z-index:-1;filter:blur(26px);
  background:radial-gradient(circle at 50% 45%,color-mix(in srgb,var(--ac,var(--amber)) 30%,transparent),transparent 62%)}
.sc-view .mock-browser{max-width:none;border:1px solid var(--line-2);box-shadow:0 46px 100px -46px color-mix(in srgb,var(--ac,var(--amber)) 70%,transparent)}
.sc-view .mb-shot{aspect-ratio:16/10}
.sc-view .mb-shot img{animation:kenPan 22s ease-in-out infinite}
@keyframes kenPan{0%,100%{object-position:top}50%{object-position:bottom}}
.sc-info{position:relative;min-width:0}
.sc-index{position:absolute;top:-46px;right:-4px;font-family:var(--display);font-weight:800;font-size:clamp(4rem,9vw,7rem);line-height:1;
  color:transparent;-webkit-text-stroke:1px color-mix(in srgb,var(--ac,var(--amber)) 40%,transparent);opacity:.55;z-index:0;pointer-events:none;user-select:none}
.sc-info>*{position:relative;z-index:1}
.sc-title{font-family:var(--display);font-weight:800;font-size:clamp(1.7rem,3.4vw,2.7rem);line-height:1;margin:6px 0 16px}
.sc-info .c-problem{font-size:.96rem;margin-bottom:12px}
.sc-info .c-build{color:var(--text);font-size:1.04rem;margin-bottom:20px}
.sc-info .c-metrics{margin:0 0 20px}
.sc-info .cta{margin-top:4px}
.sc-fade{animation:scFade .5s var(--ease)}
@keyframes scFade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.sc-tabs{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;border-top:1px solid var(--line);padding-top:22px}
.sc-tab{display:flex;align-items:center;gap:10px;padding:12px 18px;border:1px solid var(--line);background:rgba(255,255,255,.02);cursor:none;transition:.35s var(--ease);
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px)}
.sc-tab .t-idx{font-family:var(--tech);font-size:.68rem;color:var(--faint)}
.sc-tab .t-name{font-family:var(--tech);font-size:.82rem;letter-spacing:.04em;color:var(--muted)}
.sc-tab:hover{border-color:var(--line-2);transform:translateY(-2px)}
.sc-tab.active{border-color:transparent;background:linear-gradient(120deg,var(--amber),var(--gold))}
.sc-tab.active .t-idx,.sc-tab.active .t-name{color:var(--void)}
@media(max-width:820px){
  .sc-main{grid-template-columns:1fr;gap:22px}
  .sc-index{font-size:3.4rem;top:-24px}
  .sc-tabs{overflow-x:auto;flex-wrap:nowrap;justify-content:flex-start;-webkit-overflow-scrolling:touch}
  .sc-tab{flex:0 0 auto}
}

/* ==============================================================
   FOUNDERS
   ============================================================== */
.crew{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.member{position:relative;padding:40px;border:1px solid var(--line);text-align:center;transition:.5s var(--ease);
  background:linear-gradient(180deg,rgba(255,255,255,.02),transparent);
  clip-path:polygon(0 0,100% 0,100% calc(100% - 18px),calc(100% - 18px) 100%,0 100%)}
.member:hover{border-color:rgba(255,138,30,.45);transform:translateY(-6px)}
.member .orb{width:120px;height:120px;margin:0 auto 22px;border-radius:50%;position:relative;display:grid;place-items:center;
  font-family:var(--display);font-weight:800;font-size:1.9rem;color:var(--text)}
.member .orb::before{content:"";position:absolute;inset:0;border-radius:50%;border:1px solid var(--amber);
  box-shadow:0 0 30px rgba(255,138,30,.4),inset 0 0 30px rgba(255,138,30,.18);animation:rot 10s linear infinite}
.member .orb::after{content:"";position:absolute;inset:6px;border-radius:50%;border-top:1px solid var(--ice);animation:rot 6s linear infinite reverse}
@keyframes rot{to{transform:rotate(360deg)}}
.member h4{font-size:1.4rem;font-weight:800}
.member .role{font-family:var(--tech);font-size:.64rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin:4px 0 14px}
.member p{color:var(--muted);font-weight:300;font-size:.94rem;max-width:34ch;margin:0 auto}
.member-social{display:flex;gap:10px;justify-content:center;margin-top:22px}
.member-social a{width:42px;height:42px;display:grid;place-items:center;color:var(--muted);cursor:none;
  border:1px solid var(--line);background:rgba(255,255,255,.02);transition:.3s var(--ease);
  clip-path:polygon(9px 0,100% 0,100% calc(100% - 9px),calc(100% - 9px) 100%,0 100%,0 9px)}
.member-social a:hover{color:var(--void);background:linear-gradient(120deg,var(--amber),var(--gold));border-color:transparent;
  transform:translateY(-4px);box-shadow:0 12px 26px -10px rgba(255,138,30,.7)}
.member-social svg{width:19px;height:19px;display:block}
@media(max-width:700px){.crew{grid-template-columns:1fr}}

/* ==============================================================
   TESTIMONIALS marquee
   ============================================================== */
.echoes{overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.echo-row{display:flex;gap:18px;width:max-content;padding:6px 0}
.echo-row.a{animation:slide 46s linear infinite}
.echo-row.b{animation:slide 40s linear infinite reverse;margin-top:18px}
.echoes:hover .echo-row{animation-play-state:paused}
@keyframes slide{to{transform:translateX(-50%)}}
.echo{flex:0 0 380px;padding:26px;border:1px solid var(--line);background:rgba(255,255,255,.015);
  clip-path:polygon(0 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%)}
.echo .q{font-weight:300;margin-bottom:16px}
.echo .by{font-family:var(--tech);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}

/* ==============================================================
   CONTACT — terminal
   ============================================================== */
.contact{display:grid;grid-template-columns:.9fr 1.1fr;gap:54px;align-items:start}
.contact .lead-p{margin-bottom:30px}
.chan{display:grid;gap:12px;margin-bottom:26px}
.chan-block{display:flex;align-items:flex-start;gap:14px;padding:13px 15px;border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(255,255,255,.02),transparent);transition:.35s var(--ease);
  clip-path:polygon(0 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%)}
.chan-block:hover{border-color:var(--line-2);transform:translateX(5px)}
.chan-ic{width:44px;height:44px;flex:0 0 auto;display:grid;place-items:center;color:var(--void);transition:.35s var(--ease);
  clip-path:polygon(9px 0,100% 0,100% calc(100% - 9px),calc(100% - 9px) 100%,0 100%,0 9px)}
.chan-ic:hover{transform:translateY(-3px) scale(1.06)}
.chan-ic svg{width:20px;height:20px}
.chan-ic.email{background:linear-gradient(135deg,#FF8A1E,#FFB45A);box-shadow:0 8px 20px -10px rgba(255,138,30,.8)}
.chan-ic.phone{background:linear-gradient(135deg,#FFD66B,#FF8A1E);box-shadow:0 8px 20px -10px rgba(255,214,107,.8)}
.chan-ic.linkedin{background:linear-gradient(135deg,#49B6FF,#2b6fbf);box-shadow:0 8px 20px -10px rgba(73,182,255,.8)}
.chan-ic.insta{background:linear-gradient(135deg,#FF7A6B,#FF8A1E 55%,#FFD66B);box-shadow:0 8px 20px -10px rgba(255,122,107,.8)}
.chan-vals{display:flex;flex-direction:column;gap:5px;min-width:0;padding-top:1px}
.chan-vals .chan-k{font-family:var(--tech);font-size:.55rem;letter-spacing:.22em;text-transform:uppercase;color:var(--faint);margin-bottom:1px}
.chan-vals a{font-family:var(--tech);font-size:.85rem;letter-spacing:.02em;color:var(--text);transition:.25s;word-break:break-word;width:fit-content}
.chan-vals a:hover{color:var(--gold)}
.chan-note{display:flex;align-items:center;gap:10px;font-family:var(--tech);font-size:.74rem;letter-spacing:.08em;color:var(--muted);padding:6px 2px}
.chan-note .ic{color:var(--amber)}

/* floating WhatsApp (themed, not green) */
.wa{position:fixed;right:24px;bottom:24px;z-index:79;width:56px;height:56px;display:grid;place-items:center;color:var(--void);
  background:linear-gradient(135deg,var(--amber),var(--gold));cursor:none;
  clip-path:polygon(14px 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%,0 14px);
  box-shadow:0 12px 36px -10px rgba(255,138,30,.75);transition:.4s var(--ease)}
.wa:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 18px 50px -12px rgba(255,214,107,.9)}
.wa svg{width:28px;height:28px}
.wa .wa-ping{position:absolute;inset:0;clip-path:inherit;border:1px solid var(--gold);animation:waPing 2.6s var(--ease) infinite}
@keyframes waPing{0%{opacity:.7;transform:scale(1)}100%{opacity:0;transform:scale(1.5)}}
.wa .wa-tip{position:absolute;right:70px;white-space:nowrap;font-family:var(--tech);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);
  background:rgba(7,10,18,.9);border:1px solid var(--line);padding:8px 12px;opacity:0;transform:translateX(8px);transition:.3s var(--ease);pointer-events:none;
  clip-path:polygon(0 0,100% 0,100% calc(100% - 6px),calc(100% - 6px) 100%,0 100%)}
.wa:hover .wa-tip{opacity:1;transform:none}
.to-top{bottom:92px}   /* sit above the WhatsApp float */
@media(max-width:600px){.wa{width:52px;height:52px;right:16px;bottom:16px}.wa .wa-tip{display:none}.to-top{bottom:80px;right:16px}}
.term{position:relative;border:1px solid var(--line-2);background:rgba(7,10,18,.6);backdrop-filter:blur(6px);overflow:hidden;
  clip-path:polygon(0 0,100% 0,100% calc(100% - 20px),calc(100% - 20px) 100%,0 100%)}
.term-bar{display:flex;align-items:center;gap:12px;padding:15px 20px;border-bottom:1px solid var(--line);font-family:var(--tech);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);flex-wrap:wrap;min-width:0}
.term-prompt{color:var(--amber);font-weight:700;font-size:.95rem;letter-spacing:.02em}
.term-prompt .cur{animation:caret 1.1s steps(1) infinite}
@keyframes caret{50%{opacity:0}}
.term-path{color:var(--text);letter-spacing:.1em}
.term-path b{color:var(--amber);font-weight:600}
.term-live{margin-left:auto;display:inline-flex;align-items:center;gap:8px;color:var(--gold);letter-spacing:.22em}
.term-live::before{content:"";width:8px;height:8px;border-radius:50%;background:#3dffa8;box-shadow:0 0 9px #3dffa8;animation:blink 2s infinite}
.term::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;z-index:3;pointer-events:none;
  background:linear-gradient(90deg,transparent,var(--amber),var(--gold),var(--amber),transparent);background-size:200% 100%;animation:termSweep 5s linear infinite}
@keyframes termSweep{to{background-position:200% 0}}
.term-body{position:relative;padding:28px 26px}
.term-body::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;opacity:.6;
  background-image:radial-gradient(rgba(150,180,230,.05) 1px,transparent 1px);background-size:22px 22px}
.term-body>*{position:relative;z-index:1}
.f{margin-bottom:18px;position:relative}
.f label{display:flex;align-items:center;gap:7px;font-family:var(--tech);font-size:.66rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--amber);margin-bottom:9px;transition:color .3s}
.f label::before{content:">";color:var(--faint);font-weight:700}
.f:focus-within label,.f:focus-within label::before{color:var(--gold)}
.f input,.f textarea,.f select{width:100%;background:rgba(0,0,0,.32);border:1px solid var(--line);color:var(--text);
  font-family:var(--body);font-size:.98rem;padding:13px 15px;transition:.3s var(--ease);cursor:none}
.f input::placeholder,.f textarea::placeholder{color:var(--faint)}
.f input:focus,.f textarea:focus{outline:none;border-color:var(--amber);background:rgba(255,138,30,.04);box-shadow:0 0 0 2px rgba(255,138,30,.15),0 10px 26px -16px rgba(255,138,30,.7)}
.f select{appearance:none;-webkit-appearance:none;padding-right:36px;
  background:rgba(0,0,0,.32) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23FF8A1E' stroke-width='1.6' fill='none'/%3E%3C/svg%3E") no-repeat right 14px center}
.f select:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 2px rgba(255,138,30,.15)}
.f select option{background:var(--ink)}
.f::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;z-index:2;pointer-events:none;
  background:linear-gradient(90deg,var(--amber),var(--gold));box-shadow:0 0 8px var(--amber);transition:width .35s var(--ease)}
.f:focus-within::after{width:100%}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.term-msg{margin-top:14px;font-family:var(--tech);font-size:.78rem;color:var(--ice);opacity:0;transition:.3s}
.term-msg.show{opacity:1}

/* ---- signal console: live carrier waveform + lock meter ---- */
.sig-strip{display:flex;align-items:center;gap:12px;margin-bottom:18px;padding:7px 12px;border:1px solid var(--line);background:rgba(0,0,0,.28);
  clip-path:polygon(0 0,100% 0,100% calc(100% - 6px),calc(100% - 6px) 100%,0 100%)}
.sig-label{font-family:var(--tech);font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;color:var(--faint);white-space:nowrap}
.sig-wave{flex:1 1 0;min-width:0;height:32px;display:block}
.sig-lock{font-family:var(--tech);font-size:.6rem;letter-spacing:.12em;color:var(--gold);white-space:nowrap;font-variant-numeric:tabular-nums}

/* ---- transmission cinematic overlay ---- */
.tx-overlay{position:absolute;inset:0;z-index:6;display:none;place-items:center;background:rgba(3,5,10,0);backdrop-filter:blur(0);overflow:hidden;transition:background .5s var(--ease),backdrop-filter .5s var(--ease)}
.tx-overlay.show{display:grid}
.tx-overlay.solid{background:rgba(3,5,10,.9);backdrop-filter:blur(6px)}
.tx-canvas{position:absolute;inset:0;z-index:1}
.tx-inner{position:relative;z-index:2;text-align:center;width:min(88%,440px);opacity:0;transition:opacity .4s var(--ease)}
.tx-overlay.solid .tx-inner{opacity:1}

/* ---- quantum letter framing ---- */
.letter-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:16px 20px;border-bottom:1px dashed var(--line-2)}
.lh-addr{font-family:var(--tech);display:flex;align-items:baseline;gap:9px;flex-wrap:wrap;padding-top:8px;min-width:0}
.lh-addr .lh-k{font-size:.58rem;letter-spacing:.24em;text-transform:uppercase;color:var(--faint)}
.lh-addr b{font-family:var(--display);font-weight:700;font-size:1rem;color:var(--text);letter-spacing:.02em}
.lh-addr .lh-id{font-size:.56rem;letter-spacing:.16em;text-transform:uppercase;color:var(--amber)}
.stamp{position:relative;width:64px;height:64px;flex:0 0 auto;display:grid;place-items:center;text-align:center;transform:rotate(4deg);
  border:1px dashed rgba(255,138,30,.55);background:radial-gradient(circle at 50% 40%,rgba(255,138,30,.16),rgba(255,138,30,.03));box-shadow:0 0 22px -8px rgba(255,138,30,.6)}
.stamp::before{content:"";position:absolute;inset:4px;border:1px solid rgba(255,138,30,.22)}
.stamp-mark{font-family:var(--display);font-weight:800;font-size:1.05rem;color:var(--gold);line-height:1;text-shadow:0 0 10px rgba(255,214,107,.6)}
.stamp-txt{position:absolute;bottom:5px;left:0;right:0;font-family:var(--tech);font-size:.4rem;letter-spacing:.12em;text-transform:uppercase;color:var(--amber)}
.salut{font-family:Georgia,'Times New Roman',serif;font-style:italic;font-size:1.55rem;color:var(--text);margin-bottom:3px;letter-spacing:.01em}
.salut-sub{font-family:var(--tech);font-size:.63rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:22px}
.sign-off{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:2px}
.signed-by{font-family:Georgia,'Times New Roman',serif;font-style:italic;font-size:1.02rem;color:var(--muted)}
.seal-btn{gap:9px}
.seal-btn .seal-ic{filter:drop-shadow(0 0 6px rgba(255,214,107,.8))}
@media(max-width:520px){.sign-off{flex-direction:column;align-items:stretch}.seal-btn{width:100%;justify-content:center}}

/* ---- teleport (beam-up) ---- */
.beam{position:absolute;inset:0;z-index:5;opacity:0;pointer-events:none;mix-blend-mode:screen;
  background:repeating-linear-gradient(90deg,rgba(255,214,107,0) 0 7px,rgba(255,214,107,.16) 7px 8px)}
.term.teleporting .letter-head,.term.teleporting .term-body{animation:beamUp 1.3s var(--ease) forwards;transform-origin:center}
@keyframes beamUp{0%{opacity:1;filter:brightness(1)}35%{opacity:1;filter:brightness(1.9)}70%{opacity:.5;transform:scaleY(.95);filter:brightness(2.6)}100%{opacity:0;transform:scaleY(.02);filter:brightness(3.2)}}
.term.teleporting .beam{animation:beamFlash 1.3s var(--ease) forwards}
@keyframes beamFlash{0%{opacity:0}30%{opacity:.9}70%{opacity:.65}100%{opacity:0}}
.tx-title{font-family:var(--tech);letter-spacing:.42em;text-transform:uppercase;color:var(--gold);font-size:.78rem;margin-bottom:18px;text-shadow:0 0 16px rgba(255,214,107,.55)}
.tx-log{font-family:var(--tech);font-size:.72rem;line-height:1.95;color:var(--muted);text-align:left;min-height:118px}
.tx-log .ok{color:var(--gold)}
.tx-bar{height:3px;background:rgba(255,255,255,.12);margin:16px 0 14px;overflow:hidden}
.tx-bar i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--amber),var(--gold));box-shadow:0 0 12px var(--gold)}
.tx-status{font-family:var(--display);font-weight:700;font-size:1.1rem;opacity:0;transform:translateY(6px);transition:.4s var(--ease)}
.tx-status.show{opacity:1;transform:none}
.tx-status.ok{color:var(--gold)}.tx-status.err{color:var(--hot);font-size:.92rem}
.tx-status b{color:var(--gold)}
@media(max-width:820px){.contact{grid-template-columns:1fr}.f-row{grid-template-columns:1fr}}

/* ==============================================================
   FOOTER
   ============================================================== */
.footer{text-align:center;padding:90px 24px 50px;border-top:1px solid var(--line);margin-top:60px;position:relative;z-index:2;overflow:hidden}
/* giant footer wordmark — SVG stretches to full width, one line, never wraps */
.footer .big{display:block;width:100%;max-width:1820px;height:auto;margin:0 auto 2px;user-select:none}
.footer .big text{font-family:var(--display);font-weight:800;font-size:100px}
.footer .echo-line{font-family:var(--display);font-weight:700;color:var(--muted);margin-top:6px}
.footer .fine{font-family:var(--tech);font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:var(--faint);margin-top:34px}

/* ==============================================================
   REVEAL
   ============================================================== */
.rv{opacity:0;transform:translateY(40px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.rv.in{opacity:1;transform:none}
.rv.d1{transition-delay:.1s}.rv.d2{transition-delay:.2s}.rv.d3{transition-delay:.3s}.rv.d4{transition-delay:.4s}.rv.d5{transition-delay:.5s}.rv.d6{transition-delay:.6s}

.to-top{position:fixed;right:24px;bottom:24px;width:46px;height:46px;z-index:70;display:grid;place-items:center;
  border:1px solid var(--line-2);color:var(--gold);background:rgba(7,10,18,.6);backdrop-filter:blur(6px);
  clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
  opacity:0;transform:translateY(16px);transition:.4s var(--ease);cursor:none}
.to-top.show{opacity:1;transform:none}
.to-top:hover{border-color:var(--amber)}

/* ==============================================================
   MOBILE NAV — the "Beacon" (unique solution)
   Where the side rail sits on desktop, a glowing beacon appears on
   touch/small screens. Tap it → a HUD drawer of all destinations.
   ============================================================== */
.nav-beacon{display:none}
.nav-scrim{position:fixed;inset:0;z-index:73;background:rgba(2,3,8,.55);backdrop-filter:blur(2px);
  opacity:0;visibility:hidden;transition:.4s var(--ease)}
.nav-scrim.open{opacity:1;visibility:visible}
.nav-panel{position:fixed;top:0;right:0;bottom:0;z-index:74;width:min(80vw,320px);max-width:100vw;
  background:linear-gradient(200deg,rgba(9,12,20,.96),rgba(4,6,11,.98));backdrop-filter:blur(16px);
  border-left:1px solid var(--line-2);box-shadow:-30px 0 80px -30px rgba(255,138,30,.35);
  transform:translateX(100%);visibility:hidden;transition:transform .5s var(--ease),visibility .5s;
  display:flex;flex-direction:column;justify-content:center;gap:2px;padding:34px 30px}
.nav-panel::before{content:"";position:absolute;top:26px;left:30px;right:30px;height:1px;background:var(--line-2)}
.nav-panel::after{content:"";position:absolute;bottom:26px;left:30px;right:30px;height:1px;background:var(--line-2)}
.nav-panel.open{transform:none;visibility:visible}
.nav-panel .np-title{position:absolute;top:30px;left:30px;font-family:var(--tech);font-size:.62rem;
  letter-spacing:.32em;text-transform:uppercase;color:var(--amber)}
.nav-panel a{font-family:var(--display);font-weight:700;font-size:clamp(1.2rem,5.5vw,1.5rem);color:var(--text);
  padding:13px 0;display:flex;align-items:center;gap:16px;border-bottom:1px solid var(--line);transition:.3s var(--ease)}
.nav-panel a:last-of-type{border-bottom:0}
.nav-panel a i{font-family:var(--tech);font-style:normal;font-weight:500;font-size:.72rem;color:var(--amber);letter-spacing:.06em;min-width:22px}
.nav-panel a:active,.nav-panel a:hover{color:var(--gold);padding-left:10px}

@media(max-width:820px){
  .nav-beacon{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
    position:fixed;right:16px;top:50%;transform:translateY(-50%);z-index:75;width:48px;height:48px;
    border:1px solid var(--line-2);background:rgba(7,10,18,.6);backdrop-filter:blur(8px);cursor:pointer;
    clip-path:polygon(12px 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%,0 12px);
    box-shadow:0 0 22px -6px rgba(255,138,30,.6);animation:beaconPulse 3s ease-in-out infinite}
  .nav-beacon span{display:block;width:16px;height:2px;border-radius:2px;background:var(--gold);
    box-shadow:0 0 6px var(--gold);transition:.35s var(--ease)}
  .nav-beacon.open{animation:none}
  .nav-beacon.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
  .nav-beacon.open span:nth-child(2){opacity:0}
  .nav-beacon.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
}
@keyframes beaconPulse{0%,100%{box-shadow:0 0 18px -6px rgba(255,138,30,.5)}50%{box-shadow:0 0 30px -2px rgba(255,138,30,.85)}}
@media(min-width:821px){.nav-beacon,.nav-panel,.nav-scrim{display:none!important}}

/* ==============================================================
   RESPONSIVE — mobile-first polish (primary audience is mobile)
   ============================================================== */
/* tablets + phones: hero is content-driven (no full-height empty space) */
@media(max-width:1024px){
  .hero{min-height:auto;justify-content:flex-start}
  .sec{padding:clamp(70px,9vh,118px) clamp(24px,5vw,56px)}
}
/* tablet: nudge body copy up a touch for readability (kept balanced) */
@media(min-width:601px) and (max-width:1024px){
  .hero .sub{font-size:1.16rem}
  .lead-p{font-size:1.08rem}
  .about p,.pillar p,.member p,.shard p,.ch-tag{font-size:1.02rem}
  .echo .q{font-size:1.04rem}
}
@media(max-width:820px){
  .hud{top:100px;left:12px;right:12px;bottom:12px}
  .sec{padding:clamp(64px,10vh,110px) 22px}
  .hero{padding:124px 22px 90px}
  .about{grid-template-columns:1fr;gap:40px}   /* was staying 2-col on mobile */
}
@media(max-width:600px){
  body{line-height:1.6}
  .site-header{height:88px;padding:0 18px}      /* bigger logo on phones (desktop unchanged) */
  .brand img{height:64px}
  .hero{padding:120px 20px 72px}
  .hero .coords{gap:12px 18px;margin-bottom:22px;font-size:.58rem}
  .hero h1{font-size:clamp(2.1rem,12.5vw,3.6rem);line-height:.98;max-width:100%}
  .hero .sub{font-size:1.02rem;margin-top:26px}
  .hero .acts{gap:12px;margin-top:34px}
  .hero .acts .cta{width:100%;justify-content:center}
  .hero .scan{gap:22px 30px;margin-top:44px}
  .sec{padding:60px 20px}
  .tag{margin-bottom:20px;font-size:.64rem;letter-spacing:.26em}
  .title{font-size:clamp(1.9rem,8vw,2.6rem)}
  .about{gap:34px}
  .about .lead-q{font-size:clamp(1.35rem,6vw,1.8rem)}
  .echo{flex:0 0 82vw;padding:22px}
  .contact{gap:34px}
  .term-body{padding:20px}
  .term-bar{font-size:.56rem;letter-spacing:.1em}
  .to-top{right:16px;bottom:16px}
  .footer{padding:64px 20px 40px}
}
@media(max-width:380px){
  .hero h1{font-size:clamp(1.9rem,12vw,2.4rem)}
  .flight{grid-template-columns:1fr}
}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.01ms!important}
  .rv{opacity:1!important;transform:none!important}
  .hero h1 .l>span{transform:none!important}
}
