/* ============================================================================
   Waxe — "The Waxe Keynote" single-page film
   Drenched-dark navy · blue→violet volumetric light · molten-wax accent.
   A pinned cinematic stage (desktop, motion-OK) where story beats cross-dissolve
   like scrubbing a video; degrades to a flowing, fully-readable document
   (mobile / reduced-motion / no-JS). No cards. No boxes. Type + light + motion.
   ========================================================================== */

/* ---------- Fonts (self-hosted) ------------------------------------------- */
@font-face{font-family:"Chakra Petch";src:url("../fonts/chakra-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Chakra Petch";src:url("../fonts/chakra-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Satoshi";src:url("../fonts/satoshi-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Satoshi";src:url("../fonts/satoshi-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Satoshi";src:url("../fonts/satoshi-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"JetBrains Mono";src:url("../fonts/jetbrains-mono-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"JetBrains Mono";src:url("../fonts/jetbrains-mono-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}

/* ---------- Tokens -------------------------------------------------------- */
:root{
  --bg:#04060e;
  --bg-2:#070f24;
  --surface:#0b1430;
  --surface-2:#101a3d;
  --line:rgba(150,170,255,.14);
  --line-strong:rgba(150,170,255,.26);
  --ink:#eef2ff;
  --ink-soft:#b7c1e3;
  --ink-mid:#8e9bc6;
  --ink-mute:#79849f;
  --primary:#0d61ff;
  --primary-bright:#3d83ff;
  --primary-soft:#7ea8ff;
  --violet:#7a3cff;
  --violet-deep:#4b15b6;
  --wax:#ff9d2e;
  --wax-hi:#ffce8a;

  --font-display:"Chakra Petch",-apple-system,Segoe UI,Roboto,sans-serif;
  --font-body:"Satoshi",-apple-system,Segoe UI,Roboto,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  --t-xs:clamp(.72rem,.69rem + .12vw,.8rem);
  --t-sm:clamp(.86rem,.82rem + .2vw,.98rem);
  --t-base:clamp(1.05rem,1rem + .3vw,1.22rem);
  --t-lead:clamp(1.18rem,1.06rem + .6vw,1.5rem);
  --t-h3:clamp(1.35rem,1.1rem + 1.1vw,2rem);
  --t-h2:clamp(2rem,1.3rem + 2.6vw,3.15rem);
  --t-h1:clamp(3rem,1.7rem + 5.6vw,5.8rem);

  --gut:clamp(1.2rem,5vw,4rem);
  --maxw:1240px;

  --r:14px; --r-lg:22px; --r-pill:999px;
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);

  --z-bg:0; --z-rays:1; --z-figure:2; --z-beat:3; --z-stagehud:5;
  --z-grain:6; --z-hud:40; --z-cursor:80; --z-skip:90;
}

/* ---------- Reset / base ------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  font-size:var(--t-base);
  line-height:1.62;
  color:var(--ink-soft);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,canvas,video{display:block;max-width:100%}
a{color:var(--primary-bright);text-decoration:none}
a:hover{color:#fff}
::selection{background:rgba(13,97,255,.34);color:#fff}
:focus-visible{outline:2px solid var(--primary-soft);outline-offset:3px;border-radius:4px}
b,strong{color:var(--ink);font-weight:700}

h1,h2,h3{font-family:var(--font-display);color:var(--ink);line-height:1.06;font-weight:500;letter-spacing:-.005em;text-wrap:balance}
h2{font-size:var(--t-h2)}
h3{font-size:var(--t-h3);letter-spacing:0}
p{text-wrap:pretty}

.mono{font-family:var(--font-mono)}
.measure{max-width:60ch}

/* ---------- Skip link ---------------------------------------------------- */
.skip-link{
  position:fixed;top:.6rem;left:.6rem;z-index:var(--z-skip);
  background:var(--primary);color:#fff;padding:.6rem 1rem;border-radius:10px;font-weight:600;
  transform:translateY(-160%);transition:transform .2s var(--ease)
}
.skip-link:focus{transform:none;color:#fff}

/* ---------- Ambient background (fixed, decorative) ---------------------- */
.bg-field{position:fixed;inset:0;z-index:var(--z-bg);pointer-events:none;overflow:hidden}
.bg-glow{position:absolute;inset:-20% -10%;
  background:
    radial-gradient(60% 45% at 50% -8%,rgba(13,97,255,.30),transparent 70%),
    radial-gradient(46% 40% at 88% 14%,rgba(122,60,255,.22),transparent 72%),
    radial-gradient(52% 52% at 8% 92%,rgba(75,21,182,.20),transparent 75%);
  filter:saturate(118%);
}
.bg-grid{position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(rgba(120,160,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(120,160,255,.045) 1px,transparent 1px);
  background-size:64px 64px;animation:gridpan 30s linear infinite;
  -webkit-mask:radial-gradient(130% 90% at 50% 30%,#000,transparent 78%);mask:radial-gradient(130% 90% at 50% 30%,#000,transparent 78%)}
@keyframes gridpan{to{background-position:64px 64px,64px 64px}}
.orb{position:absolute;border-radius:50%;filter:blur(70px);opacity:.5;mix-blend-mode:screen;will-change:transform}
.orb--1{width:460px;height:460px;top:18%;left:-8%;background:radial-gradient(circle,rgba(13,97,255,.5),transparent 70%);animation:floatA 30s ease-in-out infinite}
.orb--2{width:400px;height:400px;top:60%;right:-6%;background:radial-gradient(circle,rgba(122,60,255,.42),transparent 70%);animation:floatB 34s ease-in-out infinite}
.orb--3{width:320px;height:320px;top:34%;left:54%;background:radial-gradient(circle,rgba(255,157,46,.12),transparent 70%);animation:floatC 38s ease-in-out infinite}
@keyframes floatA{50%{transform:translate(70px,-54px) scale(1.1)}}
@keyframes floatB{50%{transform:translate(-56px,46px) scale(1.08)}}
@keyframes floatC{50%{transform:translate(46px,-64px) scale(1.12)}}
.grain{position:fixed;inset:0;z-index:var(--z-grain);pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ---------- Buttons / chips --------------------------------------------- */
.btn-row{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}
.btn{
  --bw:1px;display:inline-flex;align-items:center;gap:.6em;cursor:pointer;
  font-family:var(--font-body);font-weight:700;font-size:var(--t-sm);letter-spacing:.01em;
  padding:.95em 1.5em;border-radius:var(--r-pill);border:var(--bw) solid transparent;color:#fff;background:transparent;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease),border-color .25s var(--ease);
  text-align:center;line-height:1;
}
.btn svg{width:1.05em;height:1.05em;transition:transform .25s var(--ease)}
.btn--primary{background:var(--primary);box-shadow:0 10px 30px -10px rgba(13,97,255,.7),0 0 0 1px rgba(120,160,255,.25) inset}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 18px 46px -12px rgba(13,97,255,.9),0 0 0 1px rgba(170,200,255,.45) inset;color:#fff}
.btn--primary:hover svg{transform:translateX(3px)}
.btn--ghost{border-color:var(--line-strong);color:var(--ink);background:rgba(255,255,255,.02)}
.btn--ghost:hover{transform:translateY(-2px);border-color:var(--primary-bright);background:rgba(13,97,255,.10);color:#fff}
.btn--lg{font-size:var(--t-base);padding:1.05em 1.85em}

.chip{
  display:inline-flex;align-items:center;gap:.6em;font-family:var(--font-mono);font-size:var(--t-xs);font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);padding:.5em 1em;border-radius:var(--r-pill);
  border:1px solid var(--line);background:rgba(8,14,34,.5);backdrop-filter:blur(6px)
}
.chip .dot{width:.5em;height:.5em;border-radius:50%;background:#39d98a;box-shadow:0 0 10px #39d98a;animation:pulseDot 2.6s var(--ease) infinite}
@keyframes pulseDot{0%,100%{opacity:1}50%{opacity:.4}}

/* statement type used across beats (replaces eyebrows + cards) */
.kicker{font-family:var(--font-mono);font-size:var(--t-xs);font-weight:500;letter-spacing:.28em;text-transform:uppercase;color:var(--primary-soft);display:inline-flex;align-items:center;gap:.7em}
.kicker::before{content:"";width:1.8em;height:1px;background:linear-gradient(90deg,var(--primary-bright),transparent)}
.lead{font-size:var(--t-lead);color:var(--ink-soft);line-height:1.5;max-width:48ch}

/* ============================================================================
   FILM · STAGE · BEATS
   Default (this block) = flowing, fully-readable document. `.cinema` upgrades
   it to a pinned scrubbed film (added by JS on capable desktops).
   ========================================================================== */
.film{position:relative;z-index:var(--z-beat)}
.stage{position:relative}
.stage__rays{display:none}

/* The persistent atmosphere canvas sits behind everything, fixed. */
.core-canvas{position:fixed;inset:0;width:100%;height:100%;z-index:var(--z-rays);pointer-events:none}

/* Keyed Waxe — live canvas (cinema) is hidden until JS turns cinema on. */
.waxe-figure{display:none}
.waxe-still{display:block}

/* ---- Beats (flowing default) ---- */
.beat{position:relative;z-index:var(--z-beat);min-height:96svh;display:grid;align-content:center;
  padding-block:clamp(5rem,12vh,9rem);padding-inline:var(--gut)}
.beat__inner{width:100%;max-width:var(--maxw);margin-inline:auto}
.beat__head{display:flex;flex-direction:column;gap:1.2rem;max-width:24ch}
.beat__head--wide{max-width:32ch}
.beat__head h2{margin-top:.2rem}
.beat__body{margin-top:1.5rem;display:flex;flex-direction:column;gap:1.1rem;color:var(--ink-soft);max-width:52ch}
.beat__body b{color:#fff}

/* The line-by-line "film subtitle" wrapper (each child reveals in sequence) */
.seq>*{will-change:transform,opacity}

/* ---------- HERO beat ---------------------------------------------------- */
.beat--hero .beat__inner{display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:clamp(1.5rem,4vw,3rem)}
.hero__text{display:flex;flex-direction:column;align-items:flex-start;gap:1.5rem;position:relative}
.hero__title{font-size:var(--t-h1);font-weight:500;letter-spacing:-.01em;line-height:1.0;color:#fff;
  text-shadow:0 2px 50px rgba(4,6,14,.6)}
.hero__title .accent{color:var(--primary-soft)}
.hero__sub{font-family:var(--font-display);font-weight:500;color:var(--ink);font-size:clamp(1.25rem,.95rem + 1.5vw,2.1rem);
  line-height:1.14;letter-spacing:-.02em;max-width:20ch;text-shadow:0 1px 26px rgba(4,6,14,.7)}
.hero__sub b{font-weight:600;color:#fff;box-shadow:inset 0 -.5em 0 rgba(255,157,46,.26)}
.hero__lead{max-width:50ch;color:var(--ink-soft)}
.hero__trust{font-family:var(--font-mono);font-size:var(--t-xs);letter-spacing:.18em;color:var(--ink-mid);
  text-transform:uppercase;display:flex;flex-wrap:wrap;gap:.4em 1.1em}
.hero__trust span{white-space:nowrap}
.hero__trust b{color:var(--wax);font-weight:500}
.hero__stage{position:relative;display:grid;place-items:center;min-height:min(70svh,560px)}
/* poster fallback for Waxe (flowing/reduced/no-JS) */
.waxe-still{width:clamp(300px,40vw,540px);height:auto;filter:drop-shadow(0 26px 42px rgba(4,6,16,.5));
  -webkit-mask:linear-gradient(180deg,#000 80%,transparent);mask:linear-gradient(180deg,#000 80%,transparent)}

.scrollcue{position:absolute;left:50%;bottom:1.6rem;transform:translateX(-50%);z-index:var(--z-hud);
  display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--ink-mute);
  font-family:var(--font-mono);font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;pointer-events:none}
.scrollcue .rail{width:1px;height:42px;background:linear-gradient(var(--primary-bright),transparent);position:relative;overflow:hidden}
.scrollcue .rail::after{content:"";position:absolute;left:0;top:0;width:100%;height:40%;background:#fff;animation:cue 2.2s var(--ease) infinite}
@keyframes cue{0%{transform:translateY(-100%)}60%,100%{transform:translateY(260%)}}

/* ---------- MATH beat (time equivalence) -------------------------------- */
/* left column larger; the comparison bars become the one permitted card */
.beat--math .beat__inner{display:grid;grid-template-columns:1.32fr .88fr;gap:clamp(2rem,4.5vw,3.6rem);align-items:center}
.beat--math .beat__head{max-width:30ch}
.beat--math .beat__body{max-width:54ch}
.equiv{display:flex;flex-direction:column;gap:1.4rem;position:relative;overflow:visible;
  background:linear-gradient(158deg,rgba(17,27,63,.74),rgba(8,13,32,.62));
  border:1px solid var(--line-strong);border-radius:16px;
  padding:clamp(1.5rem,2.6vw,2.15rem);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  box-shadow:0 36px 80px -34px rgba(0,0,0,.72),inset 0 1px 0 rgba(160,180,255,.10)}
.equiv::before{content:"";position:absolute;inset:0;pointer-events:none;border-radius:inherit;
  background:radial-gradient(120% 80% at 88% -10%,rgba(122,60,255,.16),transparent 60%),radial-gradient(90% 70% at 6% 110%,rgba(13,97,255,.14),transparent 60%)}
.equiv>*{position:relative}
.equiv__row{display:flex;flex-direction:column;gap:.7rem}
.equiv__top{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--font-mono);font-size:var(--t-xs);
  letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mid)}
.equiv__top b{font-family:var(--font-display);font-size:clamp(1.4rem,1rem + 1.5vw,2.2rem);letter-spacing:-.02em}
.equiv__beam{height:10px;border-radius:var(--r-pill);position:relative;background:rgba(255,255,255,.05);overflow:hidden}
.equiv__beam i{position:absolute;inset:0 auto 0 0;width:var(--fill,8%);border-radius:inherit;transform-origin:left}
.equiv__row--waxe i{background:linear-gradient(90deg,var(--primary),var(--primary-bright));box-shadow:0 0 26px rgba(13,97,255,.7)}
.equiv__row--human i{background:linear-gradient(90deg,var(--violet-deep),var(--violet));box-shadow:0 0 26px rgba(122,60,255,.5)}
.equiv__row--waxe b{color:var(--primary-bright)}
.equiv__row--human b{color:var(--violet)}
.equiv__note{font-family:var(--font-mono);font-size:var(--t-xs);color:var(--ink-mute);letter-spacing:.05em}
.beat--math .beat__inner.proof{margin-top:clamp(1.4rem,3vw,2.4rem);display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,3vw,2.2rem);
  border-top:1px solid var(--line);padding-top:clamp(1.6rem,3.5vw,2.6rem)}
.proof__item{display:flex;flex-direction:column;gap:.5rem}
.proof__item .f{font-family:var(--font-mono);font-size:var(--t-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mid)}
.proof__item .t{font-family:var(--font-display);font-weight:600;font-size:clamp(1.3rem,1rem + 1.4vw,2rem);letter-spacing:-.02em;color:var(--ink);line-height:1.05}
.proof__item .t em{font-style:normal;color:var(--primary-bright)}
.proof__item .t em.wax{color:var(--wax)}

/* ---------- HIRE beat (frameless dossier) ------------------------------- */
.beat--hire .beat__inner{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.hire__copy{display:flex;flex-direction:column;gap:clamp(1.2rem,2.5vw,1.8rem)}
/* title + lead span the full copy column (not the default narrow head measure) */
.beat--hire .hire__copy .beat__head{max-width:none}
.hire__lead{color:var(--ink-soft);max-width:none}
.dossier{display:flex;flex-direction:column;gap:.2rem;position:relative;padding-left:1.4rem}
.dossier::before{content:"";position:absolute;left:0;top:.3rem;bottom:.3rem;width:1px;
  background:linear-gradient(180deg,transparent,var(--primary-bright),var(--violet),transparent)}
.dossier__id{display:flex;align-items:baseline;gap:.8rem;margin-bottom:1rem}
.dossier__id .n{font-family:var(--font-display);font-weight:600;font-size:clamp(1.8rem,1.3rem + 1.6vw,2.6rem);color:#fff;letter-spacing:-.02em;line-height:1}
.dossier__id .f{font-family:var(--font-mono);font-size:var(--t-xs);letter-spacing:.16em;text-transform:uppercase;color:var(--primary-soft)}
.dline{display:grid;grid-template-columns:11ch 1fr;gap:1rem;padding:.6rem 0;border-bottom:1px solid var(--line);align-items:baseline}
.dline:last-of-type{border-bottom:0}
.dline dt{font-family:var(--font-mono);font-size:var(--t-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mid)}
.dline dd{color:var(--ink);font-weight:500}
.dline dd .hl{color:var(--wax);font-weight:700}
.dossier__ticker{margin-top:1.2rem;font-family:var(--font-mono);font-size:var(--t-xs);letter-spacing:.1em;color:var(--ink-mid);
  display:flex;align-items:center;gap:.7em}
.dossier__bar{flex:1;height:5px;border-radius:var(--r-pill);background:rgba(255,255,255,.06);overflow:hidden}
.dossier__bar i{display:block;height:100%;width:var(--fill,0%);border-radius:inherit;background:linear-gradient(90deg,var(--primary),var(--violet))}
.beat--hire .hire__stage{position:relative;display:grid;place-items:center;min-height:min(64svh,520px)}

/* ---------- DELIVER beat (proposal artifact + orbiting types) ----------- */
.beat--deliver .beat__inner{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(2rem,5vw,4rem);align-items:center}
/* deliver title uses the full copy column */
.beat--deliver .deliver__copy .beat__head{max-width:none}
.beat--deliver .deliver__copy .beat__head h2{max-width:18ch}
.deliver__art{position:relative;display:grid;place-items:center;min-height:min(62svh,520px)}
/* the real on-brand proposal page (product proof, not a UI card) */
.proposal{width:min(72%,300px);aspect-ratio:210/297;background:#f7f8fc;color:#0b1430;border-radius:7px;
  padding:clamp(1rem,2.4vw,1.6rem) clamp(1rem,2.2vw,1.5rem);display:flex;flex-direction:column;
  box-shadow:0 50px 90px -36px rgba(0,0,0,.85),0 0 60px -28px rgba(61,131,255,.55);transform:rotate(-2deg)}
.proposal__top{display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid var(--primary);padding-bottom:.55rem}
.proposal__brand{font-family:var(--font-display);font-weight:700;font-size:1rem;letter-spacing:-.01em}
.proposal__tag{font-family:var(--font-mono);font-size:.52rem;letter-spacing:.12em;text-transform:uppercase;color:#5b6385}
.proposal h4{font-family:var(--font-display);font-weight:600;font-size:1.15rem;margin-top:.9rem;letter-spacing:-.01em;color:#0b1430}
.proposal__l{height:6px;border-radius:3px;background:#c9cee0;margin-top:.42rem}
.proposal__l.s{width:92%}.proposal__l.m{width:78%}.proposal__l.x{width:60%}
.proposal__sec{margin-top:.95rem}
.proposal__k{display:block;font-family:var(--font-mono);font-size:.5rem;letter-spacing:.14em;text-transform:uppercase;color:var(--primary);margin-bottom:.4rem;font-weight:500}
.proposal__bars{display:flex;gap:4px;margin-top:.2rem}
.proposal__bars i{height:8px;flex:1;border-radius:2px;background:linear-gradient(90deg,#bcd0ff,#7ea8ff)}
.proposal__bars i:nth-child(1){flex:2}.proposal__bars i:nth-child(3){flex:1.4}
.proposal__row{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:.8rem;border-top:1px solid #e6e8f2}
.proposal__price{font-family:var(--font-display);font-weight:700;color:var(--primary);font-size:1.15rem}
.proposal__send{font-family:var(--font-mono);font-size:.54rem;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:var(--primary);padding:.34rem .7rem;border-radius:99px}
.deliver__types{display:flex;flex-direction:column;gap:.2rem}
.dtype{display:flex;align-items:center;gap:.9rem;padding:.6rem 0;border-bottom:1px solid var(--line)}
.dtype:last-child{border-bottom:0}
.dtype__g{width:34px;height:34px;flex:none;display:grid;place-items:center;color:var(--primary-soft);transition:transform .28s var(--ease),color .28s var(--ease)}
.dtype__g svg{width:24px;height:24px}
/* row-hover affordance — transform/colour only, no box */
.dtype__txt{transition:transform .28s var(--ease)}
.dtype:hover .dtype__g,.dtype:hover .dtype__txt{transform:translateX(5px)}
.dtype:hover .dtype__g{color:#fff}
.dtype:hover .dtype__t{color:#fff}
.dtype__txt{display:flex;flex-direction:column;gap:.1rem}
.dtype__t{font-family:var(--font-display);font-weight:600;font-size:1.1rem;color:var(--ink);letter-spacing:-.01em;line-height:1.15}
.dtype__d{font-size:var(--t-sm);color:var(--ink-mid);line-height:1.4}
.deliver__band{margin-top:clamp(1rem,2vw,1.6rem)}
.deliver__band b{font-family:var(--font-display);font-weight:600;font-size:clamp(1.5rem,1.1rem + 1.6vw,2.2rem);color:#fff;letter-spacing:-.02em;display:block}
.deliver__band p{max-width:48ch;color:var(--ink-soft);margin-top:.6rem}

/* ---------- PROCESS beat (light path) ----------------------------------- */
.beat--process .beat__head{max-width:34ch;margin-inline:auto;text-align:center;align-items:center}
.path{margin-top:clamp(2.5rem,6vw,4rem);display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1rem,2vw,1.8rem);position:relative}
.path__line{position:absolute;left:6%;right:6%;top:34px;height:2px;background:var(--line);overflow:hidden}
.path__line i{position:absolute;inset:0;width:var(--prog,0%);background:linear-gradient(90deg,var(--primary),var(--violet));box-shadow:0 0 16px rgba(13,97,255,.7)}
.node{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;gap:.9rem}
.node__n{width:68px;height:68px;border-radius:50%;flex:none;display:grid;place-items:center;font-family:var(--font-display);
  font-weight:600;font-size:1.4rem;color:var(--ink-mute);background:rgba(8,14,34,.7);border:1px solid var(--line);transition:.45s var(--ease);position:relative;z-index:2}
.node.on .node__n{color:#fff;border-color:transparent;background:radial-gradient(circle at 38% 30%,var(--primary-bright),var(--violet-deep));box-shadow:0 0 36px -4px rgba(13,97,255,.9)}
.node h3{font-size:clamp(1.05rem,.95rem + .4vw,1.3rem)}
.node p{font-size:var(--t-sm);color:var(--ink-mid);max-width:22ch;transition:color .3s var(--ease)}
.node.on h3{color:#fff}
.node__n{cursor:default}
.node:hover .node__n{color:#fff;border-color:var(--primary-bright);box-shadow:0 0 30px -8px rgba(13,97,255,.75);transform:translateY(-3px)}
.node:hover h3{color:#fff}
.node:hover p{color:var(--ink-soft)}
.surgical{margin-top:clamp(2.5rem,5vw,3.5rem);display:grid;grid-template-columns:auto 1fr;gap:clamp(1rem,3vw,1.8rem);align-items:center;
  max-width:64ch;margin-inline:auto;padding-top:clamp(1.6rem,3vw,2.4rem);border-top:1px solid var(--line)}
.surgical__g{width:58px;height:58px;border-radius:50%;display:grid;place-items:center;flex:none;color:#2a1500;
  background:radial-gradient(circle at 36% 30%,var(--wax-hi),var(--wax));box-shadow:0 0 40px -6px rgba(255,157,46,.7)}
.surgical__g svg{width:30px;height:30px}
.surgical b{font-family:var(--font-display);font-weight:600;font-size:clamp(1.2rem,1rem + 1.1vw,1.7rem);color:#fff;letter-spacing:-.02em;display:block;margin-bottom:.35rem}
.surgical p{color:var(--ink-soft)}
.surgical em{font-style:normal;color:var(--wax-hi);font-family:var(--font-mono);font-size:.9em}

/* ---------- CHANNELS beat (per-app windows) ----------------------------- */
.beat--channels .beat__inner{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.chan__switch{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.8rem}
.chan__btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--font-body);font-weight:500;font-size:var(--t-sm);
  color:var(--ink-mid);padding:.6em 1.05em;border-radius:var(--r-pill);border:1px solid var(--line);background:rgba(8,14,34,.4);cursor:pointer;transition:.25s var(--ease)}
.chan__btn svg{width:1.15em;height:1.15em}
.chan__btn:hover{border-color:var(--line-strong);color:#fff;transform:translateY(-2px)}
.chan__btn[aria-selected="true"]{color:#fff;border-color:transparent;background:linear-gradient(120deg,var(--primary),var(--violet-deep));box-shadow:0 10px 30px -12px rgba(13,97,255,.8)}

.chan__stage{position:relative;min-height:min(62svh,476px);display:flex;align-items:center}

/* the window shell — shared chrome, themed per app via [data-app] */
.cwin{width:100%;max-width:452px;margin-inline:auto;border-radius:18px;overflow:visible;position:relative;flex-direction:column;
  border:1px solid var(--line-strong);background:var(--surface);
  box-shadow:0 46px 92px -38px rgba(0,3,14,.88),0 0 0 1px rgba(120,160,255,.05),0 0 64px -32px rgba(13,97,255,.4)}
/* overflow is visible (so the corner brackets sit on the border) → round the
   first/last rows instead, keeping the app content clipped to the window shape */
.cwin__bar{border-top-left-radius:17px;border-top-right-radius:17px}
.cwin__compose,.email__actions{border-bottom-left-radius:17px;border-bottom-right-radius:17px}
.cwin.chan__panel{display:none}
.cwin.chan__panel.on{display:flex}
@media (prefers-reduced-motion:no-preference){.cwin.chan__panel.on{animation:cwinIn .5s var(--ease-out)}}
@keyframes cwinIn{from{opacity:0;transform:translateY(12px) scale(.99)}to{opacity:1;transform:none}}

.cwin__bar{display:flex;align-items:center;gap:.7rem;padding:.8rem 1rem;border-bottom:1px solid var(--line);position:relative;z-index:2}
.cwin__ava{width:38px;height:38px;border-radius:50%;flex:none;display:grid;place-items:center;color:#fff}
.cwin__ava svg{width:20px;height:20px}
.cwin__meta{display:flex;flex-direction:column;gap:.12rem;line-height:1.12;margin-right:auto}
.cwin__name{font-family:var(--font-display);font-weight:600;font-size:1rem;color:#fff;letter-spacing:-.01em}
.cwin__status{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.06em;color:var(--ink-mid);font-style:normal;display:flex;align-items:center;gap:.45em;text-transform:none}
.cwin__live{width:.5em;height:.5em;border-radius:50%;background:#25d366;box-shadow:0 0 8px #25d366}
.cwin__chan{font-family:var(--font-display);font-weight:600;font-size:1rem;color:#fff;letter-spacing:-.01em;display:flex;align-items:center;gap:.18em;margin-right:auto}
.cwin__hash{color:var(--ink-mid);font-weight:500}
.cwin__sub{font-family:var(--font-mono);font-size:.56rem;letter-spacing:.08em;color:var(--ink-mute);text-transform:uppercase;display:flex;align-items:center;gap:.4em}
.cwin__sub svg{width:1.15em;height:1.15em}
.cwin__subject{font-family:var(--font-display);font-weight:600;font-size:.98rem;color:#fff;letter-spacing:-.01em}
.cwin__dots{display:flex;gap:4px;flex:none;align-self:center}
.cwin__dots i{width:4px;height:4px;border-radius:50%;background:var(--ink-mute)}
.cwin__body{display:flex;flex-direction:column;gap:.82rem;padding:1.1rem 1rem;position:relative;z-index:1;min-height:228px}
.cwin__compose{display:flex;align-items:center;gap:.55rem;padding:.65rem .75rem;border-top:1px solid var(--line)}
.cwin__field{flex:1;font-size:var(--t-sm);color:var(--ink-mute);padding:.52rem .9rem;border-radius:99px;background:rgba(255,255,255,.04);border:1px solid var(--line)}
.cwin__send{width:34px;height:34px;flex:none;border-radius:50%;display:grid;place-items:center;color:#fff;background:var(--primary)}
.cwin__send svg{width:16px;height:16px}

/* shared message + attachment primitives (themed per app below) */
.cwin__body .msg{max-width:100%;display:flex;flex-direction:column;gap:.3rem}
.msg .who{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute);display:flex;align-items:center;gap:.5em}
.msg__time{font-style:normal;font-size:.92em;opacity:.7;letter-spacing:.03em}
.msg__bot{font-family:var(--font-mono);font-size:.5rem;letter-spacing:.08em;background:rgba(150,170,255,.16);color:var(--ink-soft);padding:.06em .4em;border-radius:3px}
.msg .txt{font-size:var(--t-sm);line-height:1.46;color:var(--ink)}
.msg .txt .cmd{font-family:var(--font-mono);color:var(--primary-soft)}
.attach{display:flex;align-items:center;gap:.7rem;padding:.6rem .7rem;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.03)}
.attach__ic{width:32px;height:40px;border-radius:6px;flex:none;background:linear-gradient(160deg,#0d61ff,#4b15b6);position:relative;box-shadow:0 6px 14px -6px rgba(13,97,255,.7)}
.attach__ic::after{content:"PDF";position:absolute;left:0;right:0;bottom:5px;text-align:center;font-family:var(--font-mono);font-size:.42rem;letter-spacing:.06em;color:#fff}
.attach__meta{display:flex;flex-direction:column;gap:.15rem;min-width:0;margin-right:auto}
.attach__t{font-family:var(--font-display);font-weight:600;font-size:.92rem;color:#fff;letter-spacing:-.01em}
.attach__s{font-family:var(--font-mono);font-size:.58rem;color:var(--ink-mid);letter-spacing:.04em}
.attach__open{flex:none;font-family:var(--font-mono);font-size:.54rem;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:var(--primary);padding:.4rem .65rem;border-radius:99px;transition:.2s var(--ease)}
.attach:hover .attach__open{filter:brightness(1.15)}

/* ····· WhatsApp ····· */
.cwin[data-app="wa"]{background:#0b141a;border-color:rgba(255,255,255,.07)}
.cwin[data-app="wa"] .cwin__bar{background:#1f2c33;border-bottom-color:rgba(255,255,255,.05)}
.cwin[data-app="wa"] .cwin__ava{background:#25d366;color:#0b141a}
.cwin[data-app="wa"] .cwin__body{background:#0b141a;gap:.45rem}
.cwin[data-app="wa"] .cwin__body::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background:radial-gradient(120% 60% at 50% 0%,rgba(37,211,102,.05),transparent 60%)}
.cwin[data-app="wa"] .msg{max-width:84%}
.cwin[data-app="wa"] .msg .who{display:none}
.cwin[data-app="wa"] .msg .txt{padding:.45rem .65rem .5rem;border-radius:9px;color:#e9edef;font-family:var(--font-body);box-shadow:0 1px 1px rgba(0,0,0,.18)}
.cwin[data-app="wa"] .msg--you{align-self:flex-end}
.cwin[data-app="wa"] .msg--you .txt{background:#005c4b;border-top-right-radius:3px}
.cwin[data-app="wa"] .msg--waxe{align-self:flex-start}
.cwin[data-app="wa"] .msg--waxe .txt{background:#202c33;border-top-left-radius:3px}
.cwin[data-app="wa"] .msg__time{float:right;margin:.5em -.1em -.25em .7em;font-size:.6rem;color:rgba(233,237,239,.5)}
.cwin[data-app="wa"] .msg--file .attach{background:#202c33;border-color:transparent}
.cwin[data-app="wa"] .cwin__compose{background:#1f2c33;border-top-color:rgba(255,255,255,.04)}
.cwin[data-app="wa"] .cwin__field{background:#2a3942;border-color:transparent;color:#8696a0}
.cwin[data-app="wa"] .cwin__send{background:#25d366;color:#0b141a}

/* ····· Slack ····· */
.cwin[data-app="slack"]{background:#1a1d21;border-color:rgba(255,255,255,.08)}
.cwin[data-app="slack"] .cwin__bar{background:#350d36;border-bottom-color:rgba(255,255,255,.07)}
.cwin[data-app="slack"] .cwin__body{gap:1.05rem}
.cwin[data-app="slack"] .msg{display:grid;grid-template-columns:auto 1fr;grid-template-areas:"ava who" "ava txt" "ava react";column-gap:.65rem;row-gap:.15rem;align-items:start}
.cwin[data-app="slack"] .msg::before{content:"";grid-area:ava;width:36px;height:36px;border-radius:9px;flex:none}
.cwin[data-app="slack"] .msg--you::before{background:linear-gradient(135deg,#7a8cff,#4b15b6)}
.cwin[data-app="slack"] .msg--waxe::before{background:linear-gradient(135deg,#36c5f0,#2eb67d)}
.cwin[data-app="slack"] .msg .who{grid-area:who;font-family:var(--font-display);font-weight:700;font-size:.86rem;letter-spacing:0;text-transform:none;color:#fff}
.cwin[data-app="slack"] .msg .txt{grid-area:txt;color:#d1d2d3}
.cwin[data-app="slack"] .msg--file{grid-template-areas:"ava txt"}
.cwin[data-app="slack"] .msg--file::before{visibility:hidden}
.cwin[data-app="slack"] .cwin__send{background:#007a5a}

/* ····· Teams ····· */
.cwin[data-app="teams"]{background:#1f1f23;border-color:rgba(255,255,255,.08)}
.cwin[data-app="teams"] .cwin__bar{background:#2d2c34;border-bottom-color:rgba(98,100,167,.4)}
.cwin[data-app="teams"] .cwin__chan{color:#fff}
.cwin[data-app="teams"] .cwin__body{gap:.9rem}
.cwin[data-app="teams"] .msg{display:grid;grid-template-columns:auto 1fr;grid-template-areas:"ava bubble";column-gap:.6rem;align-items:start}
.cwin[data-app="teams"] .msg::before{content:"";grid-area:ava;width:34px;height:34px;border-radius:50%;flex:none;background:linear-gradient(135deg,#6264a7,#4b15b6)}
.cwin[data-app="teams"] .msg .who{grid-area:bubble;font-family:var(--font-display);font-weight:600;text-transform:none;letter-spacing:0;font-size:.84rem;color:#c8c8ff;margin-bottom:-.05rem}
.cwin[data-app="teams"] .msg .txt{grid-area:bubble;margin-top:1.25rem;padding:.55rem .75rem;border-radius:0 8px 8px 8px;background:#2d2c34;color:#e6e6ef}
.cwin[data-app="teams"] .msg--file{grid-template-areas:"ava bubble"}
.cwin[data-app="teams"] .msg--file::before{visibility:hidden}
.cwin[data-app="teams"] .msg--file .attach{margin-top:.1rem;background:#2d2c34;border-color:rgba(98,100,167,.3)}
.cwin[data-app="teams"] .cwin__send{background:#6264a7}

/* ····· Email ····· */
.cwin[data-app="email"]{background:#0c1426}
.cwin[data-app="email"] .cwin__bar{flex-direction:column;align-items:flex-start;gap:.35rem;background:linear-gradient(180deg,rgba(13,97,255,.10),transparent)}
.cwin[data-app="email"] .cwin__sub{color:var(--ink-mid)}
.cwin[data-app="email"] .cwin__sub svg{color:var(--primary-soft)}
.cwin[data-app="email"] .cwin__body{gap:0;padding-block:.4rem}
.cwin[data-app="email"] .msg{padding:.95rem 0;border-bottom:1px solid var(--line);gap:.45rem}
.cwin[data-app="email"] .msg:last-child{border-bottom:0}
.cwin[data-app="email"] .msg .who{font-size:.62rem;color:var(--primary-soft);letter-spacing:.08em}
.cwin[data-app="email"] .msg--you .who{color:var(--ink-mid)}
.cwin[data-app="email"] .msg .txt{color:var(--ink-soft)}
.cwin[data-app="email"] .cwin__compose--mail .cwin__field{text-align:left}

/* ········· enriched, app-accurate chrome ········· */
.cwin__ci{width:22px;height:22px;flex:none;color:var(--ink-mid)}

/* WhatsApp — header call/video, chat wallpaper, date pill, read receipt, icon composer */
.cwin[data-app="wa"] .wa__acts{display:flex;align-items:center;gap:.9rem;color:#aebac1}
.cwin[data-app="wa"] .wa__acts svg{width:19px;height:19px}
.cwin[data-app="wa"] .wa__acts .cwin__dots i{background:#aebac1}
.cwin[data-app="wa"] .cwin__body{
  background-color:#0b141a;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='84' height='84' viewBox='0 0 84 84'%3E%3Cg fill='none' stroke='%23ffffff' stroke-width='1.1' stroke-linecap='round' opacity='0.028'%3E%3Ccircle cx='18' cy='20' r='6'/%3E%3Cpath d='M54 13v13M47.5 19.5h13'/%3E%3Cpath d='M12 58c4-5 9-5 13 0'/%3E%3Crect x='52' y='52' width='12' height='12' rx='3'/%3E%3Cpath d='M70 30l5 5-5 5'/%3E%3C/g%3E%3C/svg%3E");
  background-size:84px;background-repeat:repeat}
.cwin[data-app="wa"] .wa__day{align-self:center;font-family:var(--font-mono);font-size:.52rem;letter-spacing:.1em;text-transform:uppercase;
  color:#8696a0;background:#182229;padding:.25rem .7rem;border-radius:7px;margin:.1rem 0 .35rem;box-shadow:0 1px 1px rgba(0,0,0,.25);position:relative;z-index:1}
.cwin[data-app="wa"] .msg__time{display:inline-flex;align-items:center;gap:.05em}
.cwin[data-app="wa"] .wa__rr{width:15px;height:11px;color:#53bdeb;margin-left:.15em}
.cwin[data-app="wa"] .cwin__compose{gap:.65rem}
.cwin[data-app="wa"] .cwin__ci{color:#8696a0;width:21px;height:21px}
.cwin[data-app="wa"] .cwin__send svg{width:18px;height:18px}

/* Slack — member chip, reactions, bordered composer with formatting bar */
.cwin[data-app="slack"] .cwin__bar{gap:.5rem}
.cwin[data-app="slack"] .slack__hdr{display:flex;align-items:center;gap:.7rem;color:#abadb0}
.cwin[data-app="slack"] .slack__hdr svg{width:15px;height:15px}
.cwin[data-app="slack"] .slack__members{display:inline-flex;align-items:center;gap:.35em;font-family:var(--font-mono);font-size:.62rem;color:#cfd0d2;
  border:1px solid rgba(255,255,255,.16);border-radius:6px;padding:.18rem .45rem .18rem .5rem}
.cwin[data-app="slack"] .slack__members i{width:13px;height:13px;border-radius:3px;margin-left:-5px;border:1px solid #350d36}
.cwin[data-app="slack"] .slack__members i:first-child{margin-left:0;background:#e8912d}
.cwin[data-app="slack"] .slack__members i:nth-child(2){background:#36c5f0}
.cwin[data-app="slack"] .slack__members i:nth-child(3){background:#2eb67d;margin-right:.3em}
.cwin[data-app="slack"] .slack__reacts{grid-area:react;display:flex;gap:.4rem;margin-top:.5rem}
.cwin[data-app="slack"] .react{display:inline-flex;align-items:center;gap:.3em;font-size:.7rem;color:#d1d2d3;
  background:rgba(29,155,209,.12);border:1px solid rgba(29,155,209,.35);border-radius:99px;padding:.1rem .5rem;line-height:1.4}
.cwin[data-app="slack"] .react--add{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.12);color:#abadb0}
.cwin[data-app="slack"] .slack__compose{flex-direction:column;align-items:stretch;gap:0;padding:0;margin:0 .9rem .85rem;
  border:1px solid rgba(255,255,255,.2);border-radius:8px;background:#222529}
.cwin[data-app="slack"] .slack__tools{display:flex;align-items:center;gap:.7rem;padding:.45rem .6rem;border-bottom:1px solid rgba(255,255,255,.08);color:#abadb0;font-size:.82rem}
.cwin[data-app="slack"] .slack__tools b,.cwin[data-app="slack"] .slack__tools i,.cwin[data-app="slack"] .slack__tools s{width:16px;text-align:center;color:#abadb0;font-style:normal}
.cwin[data-app="slack"] .slack__tools i{font-style:italic;font-family:Georgia,serif}
.cwin[data-app="slack"] .slack__sep{width:1px;height:14px;background:rgba(255,255,255,.14)}
.cwin[data-app="slack"] .slack__tools svg{width:16px;height:16px}
.cwin[data-app="slack"] .slack__inrow{display:flex;align-items:center;gap:.5rem;padding:.5rem .6rem}
.cwin[data-app="slack"] .slack__inrow .cwin__field{flex:1;background:none;border:0;padding:0;color:#9a9b9e}
.cwin[data-app="slack"] .slack__inrow .cwin__send{width:28px;height:28px;border-radius:6px}
.cwin[data-app="slack"] .slack__inrow .cwin__send svg{width:14px;height:14px}

/* Teams — Posts/Files tabs, message composer */
.cwin[data-app="teams"] .cwin__bar{flex-wrap:wrap;align-items:center;gap:.45rem .7rem;padding-bottom:.5rem}
.cwin[data-app="teams"] .teams__tabs{display:flex;align-items:center;gap:1.1rem;width:100%;font-family:var(--font-body);font-size:.78rem;color:#a6a6c2;
  border-top:1px solid rgba(255,255,255,.07);padding-top:.55rem;margin-top:.15rem}
.cwin[data-app="teams"] .teams__tabs .on{color:#fff;font-weight:600;position:relative}
.cwin[data-app="teams"] .teams__tabs .on::after{content:"";position:absolute;left:0;right:0;bottom:-.55rem;height:2px;border-radius:2px;background:#6264a7}
.cwin[data-app="teams"] .teams__add{margin-left:auto;display:grid;place-items:center;color:#a6a6c2}
.cwin[data-app="teams"] .teams__add svg{width:15px;height:15px}
.cwin[data-app="teams"] .teams__compose{gap:.6rem}
.cwin[data-app="teams"] .teams__compose .cwin__field{flex:1;border-radius:8px}
.cwin[data-app="teams"] .teams__send{display:flex;align-items:center;gap:.65rem;color:#a6a6c2}
.cwin[data-app="teams"] .teams__send .cwin__ci{width:20px;height:20px}
.cwin[data-app="teams"] .teams__send .cwin__send{width:30px;height:30px}
.cwin[data-app="teams"] .teams__send .cwin__send svg{width:15px;height:15px}

/* Email — Gmail-style sender row, quoted original, reply/forward actions */
.cwin[data-app="email"] .cwin__bar{flex-direction:row;align-items:center;gap:.7rem}
.cwin[data-app="email"] .cwin__subject{margin-right:auto}
.cwin[data-app="email"] .email__hdr{display:flex;align-items:center;gap:.6rem}
.cwin[data-app="email"] .email__label{font-family:var(--font-mono);font-size:.5rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mid);border:1px solid var(--line);border-radius:5px;padding:.18rem .42rem}
.cwin[data-app="email"] .email__star{width:18px;height:18px;color:#f4c150}
.cwin[data-app="email"] .cwin__body{gap:.55rem;padding-block:.9rem}
.cwin[data-app="email"] .email__sender{display:flex;align-items:center;gap:.6rem;padding-bottom:.5rem;border-bottom:1px solid var(--line)}
.cwin[data-app="email"] .email__ava{width:34px;height:34px;border-radius:50%;flex:none;display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:.95rem;color:#fff;background:linear-gradient(135deg,var(--primary),var(--violet))}
.cwin[data-app="email"] .email__id{display:flex;flex-direction:column;gap:.05rem;margin-right:auto;line-height:1.25}
.cwin[data-app="email"] .email__id b{font-size:.92rem;color:#fff}
.cwin[data-app="email"] .email__id i{font-style:normal;font-family:var(--font-mono);font-size:.56rem;color:var(--ink-mid)}
.cwin[data-app="email"] .email__time{font-family:var(--font-mono);font-size:.58rem;color:var(--ink-mute)}
.cwin[data-app="email"] .msg{padding:.3rem 0;border-bottom:0;gap:.3rem}
.cwin[data-app="email"] .msg .who{font-size:.6rem;color:var(--ink-mute);letter-spacing:.06em;text-transform:none}
.cwin[data-app="email"] .email__quote{border-left:2px solid var(--line-strong);padding:.15rem 0 .15rem .8rem;margin-top:.3rem}
.cwin[data-app="email"] .email__quote .txt{color:var(--ink-mid);font-size:.82rem}
.email__actions{display:flex;gap:.6rem;padding:.7rem .85rem;border-top:1px solid var(--line)}
.email__btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-body);font-weight:600;font-size:.8rem;color:var(--ink-soft);
  border:1px solid var(--line-strong);border-radius:99px;padding:.42rem .95rem;background:rgba(255,255,255,.03);cursor:pointer;transition:.2s var(--ease)}
.email__btn:hover{color:#fff;border-color:var(--primary-bright);background:rgba(13,97,255,.1)}
.email__btn svg{width:15px;height:15px}

/* Email window → Gmail light mode (only this window; others stay dark).
   The blue corner brackets stay — they belong to our window frame, not Gmail. */
.cwin[data-app="email"]{background:#fff;border-color:#dadce0;
  box-shadow:0 46px 92px -38px rgba(0,3,14,.7),0 0 0 1px rgba(0,0,0,.05),0 0 60px -30px rgba(13,97,255,.28)}
.cwin[data-app="email"] .cwin__bar{background:#fff;border-bottom-color:#e8eaed}
.cwin[data-app="email"] .cwin__subject{color:#202124}
.cwin[data-app="email"] .email__label{color:#5f6368;border-color:#dadce0;background:#f1f3f4}
.cwin[data-app="email"] .email__star{color:#f4b400}
.cwin[data-app="email"] .cwin__body{background:#fff}
.cwin[data-app="email"] .email__sender{border-bottom-color:#e8eaed}
.cwin[data-app="email"] .email__ava{background:#1a73e8;color:#fff}
.cwin[data-app="email"] .email__id b{color:#202124}
.cwin[data-app="email"] .email__id i{color:#5f6368}
.cwin[data-app="email"] .email__time{color:#5f6368}
.cwin[data-app="email"] .msg .who{color:#5f6368}
.cwin[data-app="email"] .msg .txt{color:#3c4043}
.cwin[data-app="email"] .email__quote{border-left-color:#dadce0}
.cwin[data-app="email"] .email__quote .txt{color:#5f6368}
.cwin[data-app="email"] .attach{background:#f8f9fa;border-color:#dadce0}
.cwin[data-app="email"] .attach__t{color:#202124}
.cwin[data-app="email"] .attach__s{color:#5f6368}
.cwin[data-app="email"] .attach__open{background:#1a73e8;color:#fff}
.cwin[data-app="email"] .email__actions{background:#fff;border-top-color:#e8eaed}
.cwin[data-app="email"] .email__btn{color:#3c4043;border-color:#dadce0;background:#fff}
.cwin[data-app="email"] .email__btn:hover{color:#1a73e8;border-color:#1a73e8;background:#f6faff}
.cwin[data-app="email"] .email__btn svg{color:#1a73e8}

/* ---------- ECONOMICS beat (light balance) ------------------------------ */
/* tighter columns so the graphic sits closer to the copy (no dead middle gap) */
.beat--economics .beat__inner{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(1.2rem,2.2vw,2rem);align-items:center}
.ptags{margin-top:1.8rem;display:flex;flex-wrap:wrap;gap:.6rem}
.ptag{font-family:var(--font-mono);font-size:var(--t-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);
  border:1px solid var(--line);border-radius:var(--r-pill);padding:.5em .9em;transition:.25s var(--ease)}
.ptag:hover{color:#fff;border-color:var(--primary-bright);background:rgba(13,97,255,.10);transform:translateY(-2px)}
/* the balance — weighs a senior's 2 days against Waxe's 5 minutes */
.balance{position:relative;display:grid;place-items:center start;min-height:392px;width:100%}
.scale{position:relative;width:min(100%,500px);height:352px;margin-inline:0}
.scale::before{content:"";position:absolute;left:50%;top:30px;width:310px;height:310px;transform:translateX(-50%);
  border-radius:50%;border:1px dashed rgba(150,170,255,.13);
  -webkit-mask:linear-gradient(180deg,#000,transparent 60%);mask:linear-gradient(180deg,#000,transparent 60%);opacity:.55}
.scale::after{content:"";position:absolute;left:50%;bottom:30px;width:216px;height:26px;transform:translateX(-50%);
  border-radius:50%;background:radial-gradient(closest-side,rgba(13,97,255,.42),transparent 72%);filter:blur(5px)}
.scale__pillar{position:absolute;left:50%;bottom:44px;width:6px;height:170px;transform:translateX(-50%);border-radius:4px;
  background:linear-gradient(180deg,var(--primary-soft),rgba(120,160,255,.10));box-shadow:0 0 22px rgba(13,97,255,.35)}
.scale__fulcrum{position:absolute;left:50%;top:98px;width:22px;height:22px;transform:translate(-50%,-50%) rotate(45deg);z-index:3;border-radius:5px;
  background:radial-gradient(circle at 34% 28%,#fff,var(--primary));box-shadow:0 0 30px rgba(13,97,255,.95)}
.scale__beam{position:absolute;left:50%;top:98px;width:84%;height:9px;transform:translateX(-50%) rotate(var(--tip,0deg));transform-origin:center;
  transition:transform .7s var(--ease);border-radius:99px;z-index:2;
  background:linear-gradient(90deg,var(--violet),var(--primary-bright));box-shadow:0 0 28px rgba(13,97,255,.6),inset 0 1px 0 rgba(255,255,255,.45)}
.scale__beam::before,.scale__beam::after{content:"";position:absolute;top:50%;width:12px;height:12px;border-radius:50%;transform:translateY(-50%);
  background:radial-gradient(circle at 35% 30%,#fff,var(--primary-soft));box-shadow:0 0 14px rgba(150,180,255,.9)}
.scale__beam::before{left:-4px}.scale__beam::after{right:-4px}
.pan{position:absolute;top:4px;width:152px;margin-left:-76px;display:flex;flex-direction:column;align-items:center;
  transform:rotate(calc(-1 * var(--tip,0deg)));transform-origin:top center;transition:transform .7s var(--ease)}
.pan--human{left:0}.pan--waxe{left:100%}
.pan__cord{width:1px;height:44px;background:linear-gradient(180deg,var(--line-strong),transparent)}
.pan__plate{position:relative;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.85rem 1.1rem;border-radius:14px;
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(8,13,32,.55));border:1px solid var(--line);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}
.pan__v{font-family:var(--font-display);font-weight:700;font-size:2rem;letter-spacing:-.02em;line-height:1}
.pan__l{font-family:var(--font-mono);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mid);text-align:center}
.pan--human .pan__v{color:var(--violet)}
.pan--waxe .pan__v{color:var(--primary-bright)}
.pan--human .pan__plate{box-shadow:0 16px 34px -18px rgba(122,60,255,.75),inset 0 0 0 1px rgba(122,60,255,.16)}
.pan--waxe .pan__plate{box-shadow:0 16px 34px -18px rgba(13,97,255,.85),inset 0 0 0 1px rgba(13,97,255,.22)}

/* ---------- CLOSE beat -------------------------------------------------- */
.beat--close .beat__inner{text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.4rem;max-width:60ch}
.beat--close .hero__title{font-size:clamp(2.6rem,1.6rem + 4.4vw,5rem)}
.close__mark{width:66px;filter:drop-shadow(0 0 30px rgba(13,97,255,.85)) drop-shadow(0 0 9px rgba(61,131,255,.6))}
.beat--close .lead{margin-inline:auto}
.beat--close .btn-row{justify-content:center}
.reassure{margin-top:.8rem;font-family:var(--font-mono);font-size:var(--t-xs);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mid)}

/* ============================================================================
   HUD — progress + chapter scrubber + custom cursor
   ========================================================================== */
.hud-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:var(--z-hud);pointer-events:none;background:rgba(150,170,255,.07)}
.hud-progress i{display:block;height:100%;width:100%;transform:scaleX(0);transform-origin:left;
  background:linear-gradient(90deg,var(--primary),var(--violet),var(--wax));box-shadow:0 0 14px rgba(13,97,255,.85)}
.chapters{position:fixed;right:clamp(.8rem,2vw,1.6rem);top:50%;transform:translateY(-50%);z-index:var(--z-hud);
  display:flex;flex-direction:column;gap:.85rem;align-items:flex-end}
.chapters button{display:flex;align-items:center;gap:.7rem;background:none;border:0;cursor:pointer;color:var(--ink-mute);
  font-family:var(--font-mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;transition:color .3s var(--ease)}
.chapters .lbl{opacity:0;transform:translateX(6px);transition:opacity .3s var(--ease),transform .3s var(--ease);white-space:nowrap}
.chapters .tick{width:40px;height:2px;border-radius:2px;background:currentColor;opacity:.5;transform:scaleX(.55);transform-origin:right center;transition:transform .3s var(--ease),opacity .3s var(--ease),background .3s var(--ease)}
.chapters button:hover{color:var(--ink-soft)}
.chapters button:hover .lbl{opacity:1;transform:none}
.chapters button[aria-current="true"]{color:#fff}
.chapters button[aria-current="true"] .tick{transform:scaleX(1);opacity:1;background:linear-gradient(90deg,var(--primary-bright),var(--violet))}
.chapters button[aria-current="true"] .lbl{opacity:1;transform:none}

.cursor,.cursor-dot{position:fixed;top:0;left:0;pointer-events:none;z-index:var(--z-cursor);opacity:0;mix-blend-mode:screen;transform:translate(-50%,-50%);will-change:transform,opacity}
.cursor{width:34px;height:34px;border:1px solid rgba(130,175,255,.6);border-radius:50%;transition:opacity .3s,width .25s var(--ease),height .25s var(--ease),background .25s,border-color .25s}
.cursor-dot{width:6px;height:6px;border-radius:50%;background:var(--primary-bright);box-shadow:0 0 12px var(--primary-bright)}
.cursor.is-on,.cursor-dot.is-on{opacity:1}
.cursor.is-hover{width:58px;height:58px;background:rgba(13,97,255,.12);border-color:rgba(150,180,255,.9)}

/* ---------- FOOTER ------------------------------------------------------- */
.foot{position:relative;z-index:var(--z-beat);border-top:1px solid var(--line);padding-block:clamp(3rem,6vw,4.5rem) 2.5rem;padding-inline:var(--gut);background:linear-gradient(180deg,transparent,rgba(7,15,36,.5))}
.foot__wrap{max-width:var(--maxw);margin-inline:auto}
.foot__top{display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between;align-items:flex-start}
.foot__brand{display:flex;flex-direction:column;gap:1rem;max-width:46ch}
.foot__mark{display:flex;align-items:center;gap:.7rem}
.foot__mark svg{width:34px}
.foot__mark b{font-family:var(--font-display);font-weight:600;font-size:1.3rem;color:#fff;letter-spacing:-.01em}
.foot__brand p{font-size:var(--t-sm);color:var(--ink-mid)}
.foot__brand p b{color:var(--ink-soft)}
.foot__cols{display:flex;gap:clamp(2rem,5vw,4rem);flex-wrap:wrap}
.foot__col{display:flex;flex-direction:column;gap:.7rem}
.foot__col .h{font-family:var(--font-mono);font-size:var(--t-xs);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:.3rem}
.foot__col a{color:var(--ink-soft);font-size:var(--t-sm)}
.foot__col a:hover{color:#fff}
.foot__bottom{margin-top:clamp(2.5rem,5vw,3.5rem);padding-top:1.6rem;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;font-family:var(--font-mono);font-size:var(--t-xs);letter-spacing:.08em;color:var(--ink-mute)}
.foot__channels{display:flex;gap:.6rem}
.foot__channels a{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;border:1px solid var(--line);color:var(--ink-soft);background:rgba(8,14,34,.4);transition:.25s var(--ease)}
.foot__channels a:hover{color:#fff;border-color:var(--primary-bright);background:rgba(13,97,255,.12);transform:translateY(-2px)}
.foot__channels svg{width:18px;height:18px}

/* ---------- Hero: single long H1 ---------------------------------------- */
.beat--hero .hero__title{font-size:clamp(1.9rem,1.1rem + 3.1vw,3.5rem);line-height:1.12;letter-spacing:-.005em;max-width:21ch}
.beat--hero .hero__title .accent{color:var(--primary-soft)}

/* ---------- Footer logo -------------------------------------------------- */
.foot__logo{display:inline-flex;width:fit-content}
.foot__logo img{height:30px;width:auto;display:block}

/* ============================================================================
   Corner brackets — the video-modal frame accent, reused on the math card
   and the channel chat windows. Inset just enough to clear rounded corners.
   ========================================================================== */
.brackets{position:absolute;inset:0;pointer-events:none;z-index:6;border-radius:inherit}
.brackets i{position:absolute;width:18px;height:18px;border:2px solid var(--primary-bright);opacity:.85}
.brackets i:nth-child(1){top:-1px;left:-1px;border-right:0;border-bottom:0;border-top-left-radius:14px}
.brackets i:nth-child(2){top:-1px;right:-1px;border-left:0;border-bottom:0;border-top-right-radius:14px}
.brackets i:nth-child(3){bottom:-1px;left:-1px;border-right:0;border-top:0;border-bottom-left-radius:14px}
.brackets i:nth-child(4){bottom:-1px;right:-1px;border-left:0;border-top:0;border-bottom-right-radius:14px}

/* ============================================================================
   "WATCH WAXE WORK" — futuristic video modal
   ========================================================================== */
.vmodal{border:0;padding:0;margin:auto;background:transparent;color:var(--ink);max-width:min(92vw,1040px);width:100%;overflow:visible}
.vmodal::backdrop{background:rgba(2,4,12,.74);backdrop-filter:blur(8px)}
.vmodal[open]{animation:vmodalIn .42s var(--ease-out)}
@keyframes vmodalIn{from{opacity:0;transform:translateY(14px) scale(.985)}to{opacity:1;transform:none}}
.vmodal__frame{position:relative;border-radius:16px;padding:clamp(.5rem,1.1vw,.85rem);
  background:linear-gradient(150deg,rgba(13,22,52,.96),rgba(6,11,28,.97));border:1px solid var(--line-strong);
  box-shadow:0 50px 120px -30px rgba(0,0,0,.85),0 0 90px -34px rgba(13,97,255,.65),0 0 0 1px rgba(120,160,255,.08) inset}
.vmodal__edge{position:absolute;inset:0;border-radius:16px;pointer-events:none;
  background:radial-gradient(120% 80% at 50% 0%,rgba(13,97,255,.18),transparent 58%)}
.vmodal__cnr{position:absolute;width:18px;height:18px;border:2px solid var(--primary-bright);opacity:.85;pointer-events:none}
.vmodal__cnr.tl{top:-1px;left:-1px;border-right:0;border-bottom:0;border-top-left-radius:14px}
.vmodal__cnr.tr{top:-1px;right:-1px;border-left:0;border-bottom:0;border-top-right-radius:14px}
.vmodal__cnr.bl{bottom:-1px;left:-1px;border-right:0;border-top:0;border-bottom-left-radius:14px}
.vmodal__cnr.br{bottom:-1px;right:-1px;border-left:0;border-top:0;border-bottom-right-radius:14px}
.vmodal__bar{display:flex;align-items:center;justify-content:space-between;padding:.35rem .6rem .65rem}
.vmodal__sig{font-family:var(--font-mono);font-size:var(--t-xs);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);display:inline-flex;align-items:center;gap:.6em}
.vmodal__sig .dot{width:.5em;height:.5em;border-radius:50%;background:#39d98a;box-shadow:0 0 10px #39d98a;animation:pulseDot 2.6s var(--ease) infinite}
.vmodal__close{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;cursor:pointer;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--ink-soft);transition:.2s var(--ease)}
.vmodal__close:hover{color:#fff;border-color:var(--primary-bright);background:rgba(13,97,255,.12)}
.vmodal__close svg{width:18px;height:18px}
.vmodal__screen{position:relative;border-radius:10px;overflow:hidden;background:#02040c;aspect-ratio:16/9;border:1px solid var(--line)}
.vmodal__video{width:100%;height:100%;display:block;object-fit:contain;background:#02040c}
.vmodal__scan{position:absolute;inset:0;pointer-events:none;mix-blend-mode:overlay;opacity:.4;background:repeating-linear-gradient(180deg,transparent 0 2px,rgba(120,160,255,.07) 2px 3px)}
@media (prefers-reduced-motion:reduce){.vmodal[open]{animation:none}.vmodal__sig .dot{animation:none}}
/* Mobile portrait: rotate the player to landscape so the video fills the screen
   (no need to physically turn the phone). The close bar stays upright + fixed. */
@media (max-width:768px) and (orientation:portrait){
  .vmodal{max-width:100svw;width:100svw;max-height:100svh;height:100svh;overflow:hidden}
  .vmodal__frame{position:fixed;inset:0;width:100svw;height:100svh;padding:0;border:0;border-radius:0;
    background:#02040c;overflow:hidden;box-shadow:none}
  .vmodal__edge,.vmodal__cnr{display:none}
  .vmodal__bar{position:fixed;top:0;left:0;right:0;z-index:6;margin:0;padding:.7rem 1rem;
    background:linear-gradient(180deg,rgba(2,4,12,.82),transparent)}
  /* rotate to landscape; absolute transform-centre handles the oversized rotated box */
  .vmodal__screen{position:absolute;top:50%;left:50%;--short:min(96svw,54svh);
    width:calc(var(--short) * 16 / 9);height:var(--short);max-width:none;aspect-ratio:auto;border-radius:10px;
    transform:translate(-50%,-50%) rotate(90deg)}
}

/* ============================================================================
   CINEMA MODE — pinned, scrubbed film (added by JS on capable desktops)
   Beats become absolutely-stacked layers; JS owns opacity/transform.
   ========================================================================== */
.cinema .stage{height:100svh;overflow:hidden}
.cinema .beat{position:absolute;inset:0;min-height:0;z-index:var(--z-beat);
  padding-block:clamp(1.4rem,4.5vh,3.2rem);align-content:center;opacity:0;visibility:hidden;will-change:opacity}
.cinema .beat__inner{max-height:100%}
.cinema .waxe-still{display:none}
.cinema .waxe-figure{display:block;position:absolute;z-index:var(--z-figure);width:clamp(320px,34vw,560px);height:auto;aspect-ratio:1/1;
  top:50%;left:50%;pointer-events:none;
  filter:drop-shadow(0 26px 44px rgba(4,6,16,.55));
  -webkit-mask:linear-gradient(180deg,#000 82%,transparent);mask:linear-gradient(180deg,#000 82%,transparent)}
.cinema .stage__rays{display:block;position:absolute;inset:0;z-index:var(--z-rays);pointer-events:none;opacity:.6;mix-blend-mode:screen;
  background:conic-gradient(from var(--rot,0deg) at var(--rx,50%) var(--ry,42%),transparent 0deg,rgba(120,160,255,.16) 8deg,transparent 16deg,transparent 40deg,rgba(122,60,255,.12) 48deg,transparent 56deg);
  -webkit-mask:radial-gradient(closest-side,#000,transparent 75%);mask:radial-gradient(closest-side,#000,transparent 75%)}
/* in cinema, beats centre their own grid within the stage */
.cinema .beat--hero .beat__inner,.cinema .beat--math .beat__inner,.cinema .beat--hire .beat__inner,
.cinema .beat--deliver .beat__inner,.cinema .beat--channels .beat__inner,.cinema .beat--economics .beat__inner{align-items:center}
.cinema .scrollcue{position:fixed}
/* hero text needs no second figure column in cinema (Waxe is the shared canvas) */
.cinema .beat--hero .hero__stage,.cinema .beat--hire .hire__stage{visibility:hidden;pointer-events:none}
.cinema .beat--hero .beat__inner{grid-template-columns:1.1fr .9fr}

/* ============================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width:980px){
  .beat--hero .beat__inner,.beat--math .beat__inner,.beat--hire .beat__inner,
  .beat--deliver .beat__inner,.beat--channels .beat__inner,.beat--economics .beat__inner{grid-template-columns:1fr;gap:clamp(2rem,7vw,3.5rem)}
  .beat--hire .hire__stage,.beat--hero .hero__stage{order:-1}
  .hero__text{align-items:center;text-align:center}
  .hero__text .btn-row{justify-content:center;width:100%}
  .hero__sub{max-width:24ch}
  .path{grid-template-columns:repeat(2,1fr);gap:2.2rem 1.4rem}
  .path__line{display:none}
  .deliver__art{order:-1}
  /* stacked: re-centre the balance graphic in the full-width column */
  .balance{place-items:center}
  .scale{margin-inline:auto}
}
@media (max-width:620px){
  .beat{min-height:auto;padding-block:clamp(4rem,11vh,6rem)}
  .beat--math .beat__inner.proof{grid-template-columns:1fr;gap:1.4rem}
  .path{grid-template-columns:1fr}
  .surgical{grid-template-columns:1fr;text-align:left;gap:1rem}
  .chapters{display:none}
  .dline{grid-template-columns:9ch 1fr;gap:.7rem}
  .msg{max-width:100%}
  /* shrink the balance so its overhanging pans never clip on phones */
  .balance{overflow:hidden;min-height:300px}
  .scale{transform:scale(.74);transform-origin:center}
}

/* ---------- Short cinema viewports (laptops) — keep beats inside the stage */
@media (min-width:1024px) and (max-height:860px){
  .cinema .beat{padding-block:clamp(.5rem,1.5vh,1.2rem)}
  .cinema .beat__head{gap:.7rem;max-width:30ch}
  .cinema h2{font-size:clamp(1.7rem,1.1rem + 1.7vw,2.5rem)}
  .cinema .beat__body{margin-top:.8rem;gap:.55rem}
  .cinema .lead{font-size:1rem}
  .cinema .hire__copy{gap:.8rem}
  .cinema .hire__lead{font-size:.95rem}
  .cinema .dline{padding:.42rem 0}
  .cinema .dtype{padding:.42rem 0}
  .cinema .deliver__band{margin-top:.7rem}
  .cinema .deliver__band p{font-size:var(--t-sm)}
  .cinema .proof{margin-top:1rem;padding-top:1rem}
  .cinema .surgical{margin-top:1.2rem;padding-top:1.2rem}
  .cinema .path{margin-top:1.6rem}
}

/* ============================================================================
   REDUCED MOTION — silence all motion, force visible
   ========================================================================== */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .scrollcue{display:none}
  .bg-grid,.orb{animation:none}
  .cursor,.cursor-dot{display:none!important}
}
@media (hover:none){.cursor,.cursor-dot{display:none}}
