/* ============================================================
   GYSHO: website styles
   Brand: pink #FF007E on black · Montserrat 800 + Roboto · hex motif
   Evolves the deck language into a scroll-driven web experience.
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --black:#000000;
  --bg:#050507;
  --bg-elevated:#0c0c14;
  --bg-card:#0f0f17;
  --pink:#FF007E;
  --pink-dim:rgba(255,0,126,.6);
  --pink-tint:rgba(255,0,126,.10);
  --pink-glow:rgba(255,0,126,.35);
  --magenta:#C2126B;
  --ok:#3ddc97;
  --err:#ff6b6b;
  --text:#FAFAFA;
  --text-dim:rgba(255,255,255,.66);
  --text-muted:rgba(255,255,255,.42);
  --hairline:rgba(255,255,255,.12);
  --hairline-soft:rgba(255,255,255,.06);

  --font-display:'Montserrat',sans-serif;
  --font-body:'Roboto',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-mono:'Roboto Mono',ui-monospace,monospace;

  --maxw:1320px;
  --pad:clamp(20px,5vw,80px);
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-expo:cubic-bezier(.19,1,.22,1);
  --ease-spring:cubic-bezier(.2,1.22,.32,1);
}

/* ---------- Self-hosted fonts (no external calls) ----------
   Drop the matching .woff2 files into /fonts (see fonts/README.md). */
@font-face{font-family:'Montserrat';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/montserrat-500.woff2') format('woff2')}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/montserrat-700.woff2') format('woff2')}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:800;font-display:swap;src:url('fonts/montserrat-800.woff2') format('woff2')}
@font-face{font-family:'Montserrat';font-style:italic;font-weight:500;font-display:swap;src:url('fonts/montserrat-500-italic.woff2') format('woff2')}
@font-face{font-family:'Roboto';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/roboto-300.woff2') format('woff2')} /* 300 file serving as regular: 400 wasn't available */
@font-face{font-family:'Roboto';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/roboto-500.woff2') format('woff2')}
@font-face{font-family:'Roboto';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/roboto-700.woff2') format('woff2')}
@font-face{font-family:'Roboto Mono';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/roboto-mono-300.woff2') format('woff2')} /* 300 file serving as regular: 400 wasn't available */
@font-face{font-family:'Roboto Mono';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/roboto-mono-500.woff2') format('woff2')}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  font-size:clamp(15px,1.05vw,18px);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
/* Skip to main content: first focusable element, visible on keyboard focus */
.skip-link{position:absolute;left:.5rem;top:-4rem;z-index:1000;background:var(--pink);color:#fff;padding:.7rem 1.2rem;border-radius:0 0 8px 8px;font-family:var(--font-display);font-weight:700;font-size:.95rem;min-height:44px;display:inline-flex;align-items:center;transition:top .2s var(--ease)}
.skip-link:focus{top:0;outline:2px solid #fff;outline-offset:2px}
h1,h2,h3{font-family:var(--font-display);font-weight:800;line-height:1.02;letter-spacing:-.02em;margin:0}
/* Main headings: section h2s and sub-page hero titles: set in all caps. */
h2,.subhero__title{text-transform:uppercase;letter-spacing:0;line-height:1.12}
em{font-style:italic;color:var(--pink)}
.accent{color:var(--pink)}

/* ---------- Atmosphere ---------- */
.grain{
  position:fixed;inset:-10%;z-index:1;pointer-events:none;opacity:.04;mix-blend-mode:screen;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 8s steps(5) infinite;
}
@keyframes grain{0%,100%{transform:translate(0,0)}20%{transform:translate(-4%,3%)}40%{transform:translate(3%,-5%)}60%{transform:translate(-2%,4%)}80%{transform:translate(5%,-2%)}}
.mesh{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.mesh__blob{position:absolute;border-radius:50%;opacity:.5;mix-blend-mode:screen}
.mesh__blob--1{width:78vw;height:78vw;background:radial-gradient(circle,var(--pink) 0%,transparent 66%);top:-28vw;right:-22vw;animation:drift 22s var(--ease) infinite alternate}
.mesh__blob--2{width:66vw;height:66vw;background:radial-gradient(circle,var(--magenta) 0%,transparent 66%);bottom:-24vw;left:-20vw;opacity:.4;animation:drift2 28s var(--ease) infinite alternate}
.mesh__blob--3{width:56vw;height:56vw;background:radial-gradient(circle,#3a0a8c 0%,transparent 66%);top:34%;left:24%;opacity:.3;animation:drift 30s var(--ease) infinite alternate-reverse}
@keyframes drift{to{transform:translate(8%,12%) scale(1.15)}}
@keyframes drift2{to{transform:translate(-10%,-8%) scale(1.2)}}
@media (prefers-reduced-motion:reduce){.grain,.mesh__blob{animation:none}}

/* ---------- Scroll progress rail ---------- */
.scroll-rail{position:fixed;top:0;left:0;right:0;height:2px;z-index:60;background:transparent}
.scroll-rail__fill{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--magenta),var(--pink));box-shadow:0 0 12px var(--pink-glow)}

main,.nav,.marquee,.foot{position:relative;z-index:2}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--font-display);font-weight:700;font-size:.84rem;letter-spacing:.04em;
  padding:.95em 1.6em;border-radius:100px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .35s var(--ease),background .3s,color .3s,border-color .3s,box-shadow .3s;
  text-transform:uppercase;white-space:nowrap;
}
.btn--lg{font-size:.95rem;padding:1.15em 2em}
.btn--solid{background:var(--pink);color:#fff;box-shadow:0 8px 30px -8px var(--pink-glow)}
.btn--solid:hover{transform:translateY(-3px);box-shadow:0 16px 42px -10px var(--pink-glow)}
.btn--ghost{border-color:var(--hairline);color:var(--text);background:rgba(255,255,255,.02);backdrop-filter:blur(6px)}
.btn--ghost:hover{border-color:var(--pink);color:var(--pink);transform:translateY(-3px)}
.btn__arr{transition:transform .35s var(--ease)}
.btn:hover .btn__arr{transform:translateX(5px)}

/* ---------- Section scaffolding ---------- */
section{padding:clamp(80px,11vw,160px) var(--pad);max-width:var(--maxw);margin-inline:auto}
.section-eyebrow{
  font-family:var(--font-mono);font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--text-muted);display:flex;align-items:center;gap:.9em;margin:0 0 1.4em;
}
.section-eyebrow .num{color:var(--pink);font-weight:500}
.section-eyebrow::after{content:"";flex:1;max-width:120px;height:1px;background:var(--hairline)}

/* ---------- NAV ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;gap:2rem;
  padding:1.1rem var(--pad);
  transition:background .4s,backdrop-filter .4s,border-color .4s,padding .4s;
  border-bottom:1px solid transparent;
}
.nav[data-scrolled]{background:rgba(5,5,7,.72);backdrop-filter:blur(16px) saturate(1.4);border-bottom-color:var(--hairline-soft);padding-top:.75rem;padding-bottom:.75rem}
.nav__brand{display:flex;align-items:center;gap:.55rem;margin-right:auto}
.nav__mark{width:26px;height:26px}
.nav__word{font-family:var(--font-display);font-weight:800;letter-spacing:-.01em;font-size:1.1rem}
.nav__links{display:flex;gap:1.7rem}
.nav__links a{
  font-size:.86rem;font-weight:500;color:var(--text-dim);position:relative;padding:.3em 0;letter-spacing:.01em;
  transition:color .25s;
}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--pink);transition:width .3s var(--ease)}
.nav__links a:hover{color:var(--text)}
.nav__links a:hover::after{width:100%}
.nav__cta{padding:.7em 1.25em;font-size:.74rem}
.nav__burger{display:none;flex-direction:column;align-items:center;justify-content:center;gap:5px;background:none;border:0;cursor:pointer;padding:8px;min-width:44px;min-height:44px}
.nav__burger span{width:24px;height:2px;background:var(--text);transition:.3s}

/* ---------- HERO ---------- */
.hero{min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding-top:clamp(120px,16vh,200px);max-width:var(--maxw);position:relative}
.hero__inner,.hero__ticker{position:relative;z-index:2}
.hero__grid{
  position:absolute;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background-image:linear-gradient(var(--hairline-soft) 1px,transparent 1px),linear-gradient(90deg,var(--hairline-soft) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 80% 60% at 30% 40%,#000 30%,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 30% 40%,#000 30%,transparent 80%);
}
.hero__eyebrow{font-family:var(--font-mono);font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim);display:flex;align-items:center;gap:.7em;margin:0 0 1.8rem}
.hero__eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--pink);box-shadow:0 0 0 4px var(--pink-tint);animation:pulse 2.4s var(--ease) infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 4px var(--pink-tint)}50%{box-shadow:0 0 0 8px transparent}}
.hero__title{font-size:clamp(2.4rem,8.5vw,7rem);letter-spacing:-.01em;line-height:1.04;text-transform:uppercase;margin:0 0 1.4rem}
.hero__title .line{display:block;overflow:hidden}
.hero__title .line>span{display:block;transform:translateY(110%);animation:riseIn 1s var(--ease-expo) forwards}
.hero__title .line:nth-child(1)>span{animation-delay:.1s}
.hero__title .line:nth-child(2)>span{animation-delay:.22s}
.hero__title .line:nth-child(3)>span{animation-delay:.34s}
.hero__title .line:nth-child(4)>span{animation-delay:.46s}
.hero__title .line--accent>span{color:var(--pink)}
@keyframes riseIn{to{transform:translateY(0)}}
/* "off-the-shelf": letters rest on a magenta shelf, tumble off and spring back on hover */
.hero__title .line--accent .ots{position:relative;display:inline-block}
.line--accent.ots-ready{overflow:visible}
.ots__l{display:inline-block;white-space:pre;will-change:transform}
.ots.is-tumbling .ots__l{animation:otsTumble .9s both;animation-delay:calc(var(--i,0) * 55ms)}
@keyframes otsTumble{
  0%{transform:translateY(0) rotate(0);animation-timing-function:cubic-bezier(.55,0,.85,.4)}
  34%{transform:translateY(var(--fall,32px)) rotate(var(--rot,12deg));animation-timing-function:cubic-bezier(.2,1.32,.34,1)}
  100%{transform:translateY(0) rotate(0)}
}
@media (prefers-reduced-motion:reduce){
  .line--accent{overflow:visible}
  .ots.is-tumbling .ots__l{animation:none}
}
.hero__lede{max-width:46ch;font-size:clamp(1.05rem,1.5vw,1.35rem);color:var(--text-dim);margin:0 0 2.4rem}
.hero__actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.3rem}
.hero__cta-note{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.03em;color:var(--text-muted);margin:0 0 2.6rem;max-width:48ch}
.hero__terminal{font-family:var(--font-mono);font-size:.9rem;color:var(--text-dim);display:flex;align-items:center;gap:.5em}
.hero__prompt{color:var(--pink)}
.caret{color:var(--pink);animation:blink 1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}

.hero__ticker{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;margin:clamp(3rem,7vh,6rem) 0 0;padding:0;background:var(--hairline-soft);border:1px solid var(--hairline-soft);border-radius:16px;overflow:hidden}
.hero__ticker li{background:rgba(10,10,16,.6);padding:1.5rem 1.4rem;display:flex;flex-direction:column;gap:.35rem}
.hero__ticker strong{font-family:var(--font-display);font-weight:800;font-size:clamp(1.8rem,3.4vw,2.8rem);letter-spacing:-.03em;line-height:1}
.hero__ticker span{font-size:.82rem;color:var(--text-muted)}
.hero__scroll{position:absolute;top:calc(100svh - 5rem);bottom:auto;right:var(--pad);font-family:var(--font-mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);display:flex;flex-direction:column;align-items:center;gap:.8rem}
.hero__scroll span{width:1px;height:48px;background:linear-gradient(var(--pink),transparent);position:relative;overflow:hidden}
.hero__scroll span::after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;background:var(--pink);animation:scrolldot 1.8s var(--ease) infinite}
@keyframes scrolldot{0%{transform:translateY(-100%)}100%{transform:translateY(250%)}}

/* ---------- MARQUEE ---------- */
.marquee{max-width:none;margin:0;padding:1.4rem 0;border-block:1px solid var(--hairline-soft);overflow:hidden;background:rgba(255,0,126,.03)}
.marquee__track{display:flex;align-items:center;gap:2.5rem;width:max-content;animation:marq 32s linear infinite}
.marquee__track span{font-family:var(--font-display);font-weight:800;font-size:clamp(1.3rem,2.6vw,2.2rem);letter-spacing:-.01em;text-transform:uppercase;color:transparent;-webkit-text-stroke:1px var(--text-muted)}
.marquee__track i{color:var(--pink);font-style:normal;font-size:1.1rem}
@keyframes marq{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee__track{animation:none}}

/* ---------- WHO ---------- */
.who{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.who__head{font-size:clamp(2rem,4.4vw,3.6rem);margin:0 0 1.6rem}
.who p{color:var(--text-dim);margin:0 0 1.2rem;max-width:52ch}
.who p strong{color:var(--text)}
.who__quote{margin:1.8rem 0;padding-left:1.4rem;border-left:2px solid var(--pink);font-family:var(--font-display);font-weight:500;font-style:italic;font-size:clamp(1.15rem,1.9vw,1.55rem);line-height:1.35;color:var(--text)}
.who__pithy{font-family:var(--font-mono);font-weight:500;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);line-height:1.5;margin:1.9rem 0 0}
.who__col--media{position:relative}
.who__photo{margin:0;position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--hairline)}
.who__photo img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/4.4;filter:grayscale(.2) contrast(1.05)}
/* "Clean sheet → assembled": blueprint grid + modular blocks that snap in on scroll */
.who__build{margin:0;position:relative;aspect-ratio:4/4.4;border-radius:18px;overflow:hidden;border:1px solid var(--hairline);background:radial-gradient(120% 110% at 32% 22%,#0e0e17,var(--black) 72%)}
.who__build-grid{position:absolute;inset:0;pointer-events:none;opacity:.55;
  background-image:linear-gradient(var(--hairline-soft) 1px,transparent 1px),linear-gradient(90deg,var(--hairline-soft) 1px,transparent 1px);
  background-size:8.333% 8.333%;
  -webkit-mask:radial-gradient(circle at 38% 30%,#000 32%,transparent 88%);mask:radial-gradient(circle at 38% 30%,#000 32%,transparent 88%)}
.who__build-glow{position:absolute;inset:0;pointer-events:none;opacity:0;transition:opacity 1s var(--ease) .25s;
  background:radial-gradient(58% 48% at 36% 36%,rgba(255,0,126,.18),transparent 70%)}
.who__build-blocks{position:absolute;inset:clamp(16px,6%,28px)}
/* Blocks are positioned/sized by main.js and re-assembled on a loop; left/top/w/h transition so they glide */
.who__build-blocks i{position:absolute;left:50%;top:50%;width:2%;height:2%;opacity:0;border-radius:3px;
  background:var(--pink);box-shadow:0 0 0 1px rgba(255,0,126,.18);
  transition:left .9s var(--ease-spring),top .9s var(--ease-spring),width .9s var(--ease-spring),height .9s var(--ease-spring),opacity .55s var(--ease)}
.who__col--media.in .who__build-glow,.who__build.reveal.in .who__build-glow{opacity:1}
@media (prefers-reduced-motion:reduce){
  .who__build-blocks i{transition:none}
  .who__build-glow{opacity:1;transition:none}
}
.who__stat{position:absolute;left:1.2rem;bottom:1.2rem;right:1.2rem;background:rgba(5,5,7,.82);backdrop-filter:blur(10px);border:1px solid var(--hairline);border-radius:12px;padding:1.1rem 1.3rem;display:flex;align-items:baseline;gap:.9rem}
.who__stat-num{font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,4vw,3rem);color:var(--pink);line-height:1}
.who__stat-label{font-size:.84rem;color:var(--text-dim)}
.who__badge{position:absolute;top:-14px;right:14px;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;background:var(--pink);color:#fff;padding:.5em 1em;border-radius:100px;box-shadow:0 8px 24px -8px var(--pink-glow);transform:rotate(2deg)}

/* ---------- PLATFORM ---------- */
.platform__head{max-width:760px;margin-bottom:clamp(3rem,5vw,4.5rem)}
.platform__head h2{font-size:clamp(2rem,4.6vw,3.8rem)}
.platform__sub{color:var(--text-dim);margin-top:1.2rem;font-size:1.1rem}
.platform__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--hairline-soft);border:1px solid var(--hairline-soft);border-radius:20px;overflow:hidden}
.platform__cta{display:flex;justify-content:center;margin-top:clamp(2rem,4vw,3rem)}
.pcard{background:var(--bg-card);padding:clamp(1.6rem,2.4vw,2.4rem);min-height:280px;display:flex;flex-direction:column;position:relative;transition:background .4s}
.pcard:hover{background:#13131d}
.pcard--wide{grid-column:span 1;grid-row:span 1}
.pcard__tag{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--pink);margin-bottom:auto}
.pcard h3{font-size:clamp(1.2rem,1.8vw,1.6rem);margin:1.6rem 0 .7rem;letter-spacing:-.01em}
.pcard p{color:var(--text-dim);font-size:.96rem;margin:0}
.pcard--accent{background:linear-gradient(160deg,rgba(255,0,126,.14),var(--bg-card) 70%)}
.pcard--accent:hover{background:linear-gradient(160deg,rgba(255,0,126,.2),var(--bg-card) 70%)}
.pcard__blocks{display:grid;grid-template-columns:repeat(6,1fr);gap:5px;margin:1.4rem 0 0;max-width:160px}
.pcard__blocks i{aspect-ratio:1;background:var(--pink);opacity:.25;border-radius:2px;transition:opacity .4s}
.pcard--wide:hover .pcard__blocks i{opacity:.85}
.pcard__route{display:flex;gap:.5rem;margin-top:1.2rem}
.pcard__route span{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.1em;padding:.35em .7em;border:1px solid var(--pink-dim);border-radius:6px;color:var(--text-dim)}
.pcard__spark{margin-top:1.2rem;height:40px}
.pcard__spark svg{width:100%;height:100%}
.pcard__spark polyline{fill:none;stroke:var(--pink);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 4px var(--pink-glow))}

/* ---- Platform cards come alive: ambient pulse + animated visuals + hover reward ---- */
.pcard{transition:background .4s,box-shadow .45s var(--ease)}
.pcard::after{content:"";position:absolute;left:0;top:0;right:0;height:2px;background:linear-gradient(90deg,var(--pink),transparent 75%);transform:scaleX(0);transform-origin:left;transition:transform .55s var(--ease-spring);pointer-events:none}
.pcard:hover{box-shadow:inset 0 0 0 1px rgba(255,0,126,.16)}
.pcard:hover::after{transform:scaleX(1)}
/* a quiet heartbeat on every card's tag: staggered so they breathe out of sync */
.pcard__tag{display:flex;align-items:center;gap:.6em}
.pcard__tag::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--pink);flex:none;animation:liveDot 2.8s var(--ease) infinite}
.pcard:nth-child(2) .pcard__tag::before{animation-delay:.5s}
.pcard:nth-child(3) .pcard__tag::before{animation-delay:1s}
.pcard:nth-child(4) .pcard__tag::before{animation-delay:1.5s}
.pcard:nth-child(5) .pcard__tag::before{animation-delay:.8s}
.pcard:nth-child(6) .pcard__tag::before{animation-delay:1.3s}
@keyframes liveDot{0%,100%{box-shadow:0 0 0 0 rgba(255,0,126,.55);opacity:.85}50%{box-shadow:0 0 0 5px rgba(255,0,126,0);opacity:1}}
/* composable squares: gentle twinkle in a column wave; brighten on hover */
.pcard__blocks i{animation:twinkle 4.5s var(--ease) infinite}
.pcard__blocks i:nth-child(6n+2){animation-delay:.3s}
.pcard__blocks i:nth-child(6n+3){animation-delay:.6s}
.pcard__blocks i:nth-child(6n+4){animation-delay:.9s}
.pcard__blocks i:nth-child(6n+5){animation-delay:1.2s}
.pcard__blocks i:nth-child(6n){animation-delay:1.5s}
@keyframes twinkle{0%,100%{opacity:.16}50%{opacity:.42}}
.pcard--wide:hover .pcard__blocks i{animation:none;opacity:.9}
/* LLM Balancer: the active route hops across CLOUD → LOCAL → ON-PREM */
.pcard__route span{animation:route 3.6s var(--ease) infinite}
.pcard__route span:nth-child(2){animation-delay:1.2s}
.pcard__route span:nth-child(3){animation-delay:2.4s}
@keyframes route{0%,40%,100%{border-color:var(--pink-dim);color:var(--text-dim);background:transparent}12%,28%{border-color:var(--pink);color:#fff;background:rgba(255,0,126,.16)}}
/* Observability: sparkline flows like live telemetry */
.pcard__spark polyline{stroke-dasharray:4 7;animation:spark 1.1s linear infinite}
@keyframes spark{to{stroke-dashoffset:-11}}
@media (prefers-reduced-motion:reduce){
  .pcard__tag::before,.pcard__blocks i,.pcard__route span,.pcard__spark polyline{animation:none}
  .pcard__spark polyline{stroke-dasharray:none}
  .pcard::after{transition:none}
}

/* ---------- WORK ---------- */
.work__head{margin-bottom:clamp(2.5rem,4vw,4rem)}
.work__head h2{font-size:clamp(2rem,4.6vw,3.8rem)}
.work__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.wcard{background:var(--bg-card);border:1px solid var(--hairline-soft);border-radius:16px;padding:1.8rem;transition:transform .4s var(--ease),border-color .4s}
.wcard:hover{transform:translateY(-5px);border-color:var(--pink-dim)}
.wcard__sector{display:block;font-family:var(--font-display);font-weight:700;font-size:1.05rem;margin-bottom:.8rem;letter-spacing:-.01em}
.wcard p{color:var(--text-dim);font-size:.95rem;margin:0}
.wcard--accent{grid-column:1/-1;border-color:transparent;position:relative;overflow:hidden;
  display:flex;align-items:center;gap:1.4rem 2.4rem;flex-wrap:wrap;
  background:linear-gradient(120deg,var(--pink),var(--magenta) 55%,var(--pink));background-size:220% 100%;background-repeat:no-repeat;
  animation:speedGlow 7s ease-in-out infinite}
@keyframes speedGlow{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
/* a light streak rockets across: the "speed" flash */
.wcard--accent::after{content:"";position:absolute;top:-25%;bottom:-25%;left:0;width:42%;pointer-events:none;
  background:linear-gradient(105deg,transparent,rgba(255,255,255,.42),transparent);
  transform:translateX(-200%) skewX(-20deg);animation:speedSweep 3.4s infinite}
@keyframes speedSweep{0%,80%{transform:translateX(-200%) skewX(-20deg);animation-timing-function:cubic-bezier(.5,0,.3,1)}100%{transform:translateX(380%) skewX(-20deg)}}
.wcard--accent .wcard__sector{color:rgba(255,255,255,.82);text-transform:uppercase;font-family:var(--font-mono);font-size:.74rem;letter-spacing:.14em;margin:0;white-space:nowrap;position:relative;z-index:1}
.wcard__big{font-family:var(--font-display);font-weight:800;font-size:clamp(1.4rem,2.6vw,2.1rem);line-height:1.12;color:#fff;flex:1;min-width:min(100%,18ch);position:relative;z-index:1}
.wcard__big span{display:inline-block;border-bottom:3px solid rgba(255,255,255,.6);animation:speedNum 2.6s ease-in-out infinite}
@keyframes speedNum{0%,100%{text-shadow:0 0 0 transparent}50%{text-shadow:0 0 18px rgba(255,255,255,.6)}}
@media (prefers-reduced-motion:reduce){.wcard--accent,.wcard--accent::after,.wcard__big span{animation:none}}
/* CTA card: the conversion prompt, with a gradient border that flows around it */
@property --ctaA{syntax:"<angle>";inherits:false;initial-value:0deg}
.wcard--cta{position:relative;display:flex;flex-direction:column;background:var(--bg-card);border-color:transparent;text-decoration:none;color:inherit}
.wcard--cta::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1.5px;pointer-events:none;
  background:conic-gradient(from var(--ctaA),transparent 0deg,var(--pink) 55deg,transparent 130deg,transparent 235deg,var(--magenta) 305deg,transparent 360deg);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;
  mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask-composite:exclude;
  animation:ctaBorder 6s linear infinite}
@keyframes ctaBorder{to{--ctaA:360deg}}
.wcard--cta:hover{background:#13131d}
.wcard--cta .wcard__sector{color:var(--pink)}
.wcard--cta p{margin-bottom:1.4rem}
.wcard__go{margin-top:auto;font-family:var(--font-mono);font-size:.8rem;letter-spacing:.04em;color:var(--pink);display:inline-flex;align-items:center;gap:.45em}
.wcard--cta:hover .wcard__go .btn__arr{transform:translateX(4px)}
@media (prefers-reduced-motion:reduce){.wcard--cta::before{animation:none}}
.work__regions{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:2.5rem}
.work__regions span{font-family:var(--font-mono);font-size:.8rem;letter-spacing:.08em;color:var(--text-muted);border:1px solid var(--hairline);border-radius:100px;padding:.5em 1.1em}

/* ---------- Globe: regions delivered ---------- */
.globe{position:relative;width:100%;max-width:740px;margin:3.5rem auto 0;aspect-ratio:1 / .82}
.globe__sphere{position:absolute;inset:0}
/* Dot-field masked into a soft disc: the "globe" face */
.globe__dots{position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.18) 1.1px,transparent 1.7px);
  background-size:23px 23px;background-position:center;
  -webkit-mask:radial-gradient(circle closest-side at 50% 50%,#000 42%,rgba(0,0,0,.45) 72%,transparent 97%);
  mask:radial-gradient(circle closest-side at 50% 50%,#000 42%,rgba(0,0,0,.45) 72%,transparent 97%);
  animation:globeBreathe 6s var(--ease) infinite}
/* A pink light that orbits the globe, grazing the dots */
.globe__scan{position:absolute;inset:0;border-radius:50%;
  background:radial-gradient(circle at 72% 50%,rgba(255,0,126,.16),transparent 34%);
  -webkit-mask:radial-gradient(circle closest-side at 50% 50%,#000 30%,transparent 72%);
  mask:radial-gradient(circle closest-side at 50% 50%,#000 30%,transparent 72%);
  mix-blend-mode:screen;animation:globeSpin 16s linear infinite}
/* Breathing core glow */
.globe__glow{position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 50% 50%,rgba(255,0,126,.30) 0%,rgba(194,18,107,.13) 22%,transparent 50%);
  animation:globeGlow 6s var(--ease) infinite}
@keyframes globeBreathe{0%,100%{opacity:.72}50%{opacity:1}}
@keyframes globeSpin{to{transform:rotate(360deg)}}
@keyframes globeGlow{0%,100%{opacity:.7;transform:scale(.97)}50%{opacity:1;transform:scale(1.05)}}

/* Location pins: drop in staggered (--pd) once the globe reveals */
.globe__pin{position:absolute;left:var(--x);top:var(--y);width:0;height:0;
  opacity:0;transform:translate(-50%,-50%) scale(.3);
  transition:opacity .55s var(--ease),transform .7s var(--ease-spring)}
.globe.in .globe__pin{opacity:1;transform:translate(-50%,-50%) scale(1);transition-delay:var(--pd,0s)}
.globe__pin i{position:absolute;left:0;top:0;width:13px;height:13px;border-radius:50%;
  transform:translate(-50%,-50%);background:var(--pink);
  box-shadow:0 0 0 4px var(--pink-tint),0 0 16px var(--pink-glow)}
.globe__pin i::after{content:"";position:absolute;inset:0;border-radius:50%;border:1.5px solid var(--pink);
  opacity:0;animation:globePing 2.8s var(--ease) infinite}
.globe.in .globe__pin i::after{animation-delay:var(--pd,0s)}
@keyframes globePing{0%{transform:scale(1);opacity:.75}70%,100%{transform:scale(3.4);opacity:0}}
.globe__pin b{position:absolute;white-space:nowrap;font-family:var(--font-mono);font-weight:500;
  font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text);
  text-shadow:0 1px 10px rgba(0,0,0,.85)}
.globe__pin--l b{right:14px;top:50%;transform:translateY(-50%)}
.globe__pin--r b{left:14px;top:50%;transform:translateY(-50%)}
.globe__pin--t b{bottom:14px;left:50%;transform:translateX(-50%)}

/* Origin callout: rises in last */
.globe__origin{position:absolute;right:0;bottom:1%;text-align:right;
  opacity:0;transform:translateY(14px);
  transition:opacity .7s var(--ease),transform .7s var(--ease-spring);transition-delay:.62s}
.globe.in .globe__origin{opacity:1;transform:none}
.globe__origin-label{display:block;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--text-muted)}
.globe__origin-place{display:block;font-family:var(--font-display);font-weight:800;letter-spacing:-.01em;color:var(--pink);font-size:clamp(1.3rem,2.4vw,1.9rem);margin-top:.3rem}

@media (max-width:560px){
  .globe__pin b{font-size:.6rem;letter-spacing:.08em}
  .globe__pin i{width:10px;height:10px}
  .globe__pin--l b{right:11px}.globe__pin--r b{left:11px}
}
@media (prefers-reduced-motion:reduce){
  .globe__dots,.globe__scan,.globe__glow{animation:none}
  .globe__pin{opacity:1;transform:translate(-50%,-50%) scale(1);transition:none}
  .globe__pin i::after{animation:none;opacity:0}
  .globe__origin{opacity:1;transform:none;transition:none}
}

/* Globe as hero backdrop: sits behind the headline, right-biased, left edge faded for legibility */
.globe--hero{position:absolute;top:clamp(-24px,1.5vh,24px);right:-3%;
  width:min(56%,660px);max-width:none;height:auto;margin:0;z-index:0;opacity:0;pointer-events:none;
  -webkit-mask:linear-gradient(90deg,transparent,#000 26%);mask:linear-gradient(90deg,transparent,#000 26%);
  transition:opacity 1.2s var(--ease)}
.globe--hero.in{opacity:.85}
.globe--hero .globe__origin{bottom:5%}
.globe--hero .globe__origin-place{font-size:clamp(1.1rem,2vw,1.55rem)}
/* At the tablet layout switch there's no room beside the poster headline: hide the decorative globe (regions are stated in the eyebrow + ticker) */
@media (max-width:980px){.globe--hero{display:none}}
@media (prefers-reduced-motion:reduce){.globe--hero{transition:none}}

/* First-visit intro: dots fly from the pointer and hop onto the pins */
.globe-fly{position:fixed;top:0;left:0;width:13px;height:13px;border-radius:50%;
  background:var(--pink);box-shadow:0 0 0 4px var(--pink-tint),0 0 16px var(--pink-glow);
  pointer-events:none;z-index:9996;transform:translate(-50%,-50%)}
.globe--intro.in .globe__pin{opacity:0;transform:translate(-50%,-50%) scale(.3)}
.globe--intro .globe__pin.is-landed{opacity:1;animation:pinLand .5s var(--ease-spring) forwards}
@keyframes pinLand{0%{transform:translate(-50%,-50%) scale(1.6)}60%{transform:translate(-50%,-50%) scale(.92)}100%{transform:translate(-50%,-50%) scale(1)}}
@media (hover:none),(pointer:coarse){.globe-fly{display:none}}

/* ---------- DEMOS ---------- */
.demos__head{max-width:680px;margin-bottom:clamp(2.5rem,4vw,4rem)}
.demos__head h2{font-size:clamp(2.6rem,6vw,5rem)}
.demos__sub{color:var(--text-dim);margin-top:1rem;font-size:1.1rem}
.demos__sub strong{color:var(--pink)}
.demos__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
.demo-tile{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--hairline);padding:1.6rem;min-height:300px;display:flex;flex-direction:column;justify-content:flex-end;isolation:isolate;transition:transform .5s var(--ease),border-color .4s}
.demo-tile__poster{position:absolute;inset:0;z-index:-2;transition:transform .8s var(--ease);
  background:radial-gradient(70% 75% at var(--gx,80%) var(--gy,20%),rgba(255,0,126,.4),rgba(194,18,107,.1) 40%,transparent 66%),linear-gradient(155deg,#170a14,#07070b 72%)}
.demo-tile::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(to top,rgba(5,5,7,.96) 12%,rgba(5,5,7,.5) 55%,rgba(5,5,7,.25))}
.demo-tile:hover{transform:translateY(-6px);border-color:var(--pink)}
.demo-tile:hover .demo-tile__poster{transform:scale(1.07)}
.demo-tile__live{position:absolute;top:1.2rem;left:1.2rem;display:flex;align-items:center;gap:.5em;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;background:rgba(5,5,7,.6);backdrop-filter:blur(6px);border:1px solid var(--hairline);padding:.4em .8em;border-radius:100px}
.demo-tile__live i{width:7px;height:7px;border-radius:50%;background:#37d67a;box-shadow:0 0 8px #37d67a;animation:pulse 2s infinite}
.demo-tile__name{font-family:var(--font-display);font-weight:800;font-size:1.5rem;letter-spacing:-.02em}
.demo-tile__sub{color:var(--text-dim);font-size:.92rem;margin-top:.3rem}
.demo-tile__cta{font-family:var(--font-mono);font-size:.78rem;color:var(--pink);margin-top:1rem;letter-spacing:.04em;transition:transform .35s var(--ease)}
.demo-tile:hover .demo-tile__cta{transform:translateX(5px)}
/* Brand-built demo posters: pink glow + composable square-grid + a floating module tile */
.demo-tile__poster::after{content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:30px 30px;
  -webkit-mask:radial-gradient(120% 120% at var(--gx,80%) var(--gy,20%),#000 6%,transparent 72%);
  mask:radial-gradient(120% 120% at var(--gx,80%) var(--gy,20%),#000 6%,transparent 72%)}
.demo-tile__poster::before{content:"";position:absolute;left:var(--gx,80%);top:var(--gy,20%);transform:translate(-50%,-50%) rotate(var(--rot,-8deg));
  width:clamp(64px,24%,118px);aspect-ratio:1;border-radius:16px;
  background:linear-gradient(150deg,rgba(255,0,126,.34),rgba(255,0,126,.05));
  box-shadow:inset 0 0 0 1px rgba(255,0,126,.3),0 16px 40px -16px var(--pink-glow)}
.demos__grid .demo-tile:nth-child(1) .demo-tile__poster{--gx:24%;--gy:26%;--rot:-9deg}
.demos__grid .demo-tile:nth-child(2) .demo-tile__poster{--gx:80%;--gy:22%;--rot:7deg}
.demos__grid .demo-tile:nth-child(3) .demo-tile__poster{--gx:26%;--gy:24%;--rot:6deg}
.demos__grid .demo-tile:nth-child(4) .demo-tile__poster{--gx:82%;--gy:28%;--rot:-7deg}

/* ---------- APPROACH ---------- */
.approach__head{max-width:720px;margin-bottom:clamp(3rem,5vw,4.5rem)}
.approach__head h2{font-size:clamp(2rem,4.6vw,3.8rem)}
.approach__sub{color:var(--text-dim);margin-top:1.2rem;font-size:1.1rem}
.timeline{list-style:none;margin:0 0 3rem;padding:0;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--hairline-soft);border:1px solid var(--hairline-soft);border-radius:18px;overflow:hidden;counter-reset:t}
.timeline__step{background:var(--bg-card);padding:2rem 1.6rem;position:relative;transition:background .4s}
.timeline__step::before{content:"";position:absolute;top:0;left:0;height:3px;width:0;background:var(--pink);transition:width .8s var(--ease)}
.timeline__step.in::before{width:100%}
.timeline__step:hover{background:#13131d}
.timeline__num{font-family:var(--font-mono);font-size:.8rem;color:var(--pink);letter-spacing:.1em}
.timeline__step h3{font-size:1.45rem;margin:.8rem 0 .3rem}
.timeline__weeks{font-family:var(--font-mono);font-size:.78rem;color:var(--text-muted);display:block;margin-bottom:.9rem}
.timeline__step p{color:var(--text-dim);font-size:.92rem;margin:0}
.timeline__step--ongoing{background:linear-gradient(160deg,rgba(255,0,126,.1),var(--bg-card) 70%)}
/* The timeline unfolds as a journey: line + content reveal step-by-step, numbers flare at each checkpoint */
.timeline__step.in::before{transition-delay:calc(var(--ri,0) * .12s)}
.timeline__step > *{opacity:0;transform:translateY(8px);transition:opacity .55s var(--ease),transform .6s var(--ease-spring)}
.timeline__step.in > *{opacity:1;transform:none;transition-delay:calc(var(--ri,0) * .12s + .12s)}
.timeline__step.in .timeline__num{animation:numFlare .9s var(--ease) both;animation-delay:calc(var(--ri,0) * .12s + .22s)}
.timeline__step:hover .timeline__num{text-shadow:0 0 14px var(--pink-glow)}
/* "Operate" is ongoing: a quiet heartbeat beside its number says it never stops */
.timeline__step--ongoing .timeline__num{position:relative}
.timeline__step--ongoing.in .timeline__num::after{content:"";position:absolute;top:50%;right:-15px;transform:translateY(-50%);width:7px;height:7px;border-radius:50%;background:var(--pink);animation:liveDot 2.4s var(--ease) infinite;animation-delay:1.2s}
@media (prefers-reduced-motion:reduce){
  .timeline__step > *{opacity:1;transform:none;transition:none}
  .timeline__step.in .timeline__num{animation:none}
  .timeline__step--ongoing.in .timeline__num::after{animation:none}
}
/* Choreographed signal: 01→02→03 each give two pulses, 2s apart; Operate ends on one big pulse. Loops every 8s. */
.timeline__step{animation:stepPulse 8s linear infinite}
.timeline__step:nth-child(2){animation-delay:2s}
.timeline__step:nth-child(3){animation-delay:4s}
.timeline__step--ongoing{animation:stepPulseBig 8s linear infinite;animation-delay:6s}
@keyframes stepPulse{
  0%,4%{box-shadow:inset 0 0 0 0 rgba(255,0,126,0)}
  11%{box-shadow:inset 0 0 70px -12px rgba(255,0,126,.45)}
  22%,100%{box-shadow:inset 0 0 0 0 rgba(255,0,126,0)}
}
@keyframes stepPulseBig{
  0%,3%{box-shadow:inset 0 0 0 0 rgba(255,0,126,0)}
  14%{box-shadow:inset 0 0 120px -6px rgba(255,0,126,.7)}
  34%{box-shadow:inset 0 0 120px -6px rgba(255,0,126,.7)}
  60%,100%{box-shadow:inset 0 0 0 0 rgba(255,0,126,0)}
}
@media (prefers-reduced-motion:reduce){.timeline__step,.timeline__step--ongoing{animation:none}}
.approach__models{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.approach__models--three{grid-template-columns:repeat(3,1fr)}
.model{position:relative;overflow:hidden;display:block;text-decoration:none;color:inherit;border:1px solid var(--hairline);border-radius:16px;padding:1.8rem;background:rgba(255,255,255,.015);transition:transform .4s var(--ease),border-color .4s,box-shadow .45s var(--ease),background .4s}
.model::before{content:"";position:absolute;left:0;top:0;right:0;height:2px;background:linear-gradient(90deg,var(--pink),transparent 75%);transform:scaleX(0);transform-origin:left;transition:transform .55s var(--ease-spring)}
.model:hover{transform:translateY(-5px);border-color:var(--pink-dim);background:rgba(255,255,255,.03);box-shadow:0 24px 54px -28px var(--pink-glow)}
.model:hover::before{transform:scaleX(1)}
.model strong{font-family:var(--font-display);font-weight:700;font-size:1.2rem;display:block;margin-bottom:.6rem}
.model p{color:var(--text-dim);font-size:.95rem;margin:0}
.model__cta{display:inline-flex;align-items:center;gap:.45em;margin-top:1.3rem;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.04em;color:var(--pink);opacity:0;transform:translateY(6px);transition:opacity .35s var(--ease),transform .4s var(--ease-spring)}
.model:hover .model__cta{opacity:1;transform:none}
.model:hover .model__cta .btn__arr{transform:translateX(4px)}

/* ---------- WHY ---------- */
.why__head{margin-bottom:clamp(2.5rem,4vw,4rem)}
.why__head h2{font-size:clamp(2rem,4.6vw,3.8rem)}
.why__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.pillar{border:1px solid var(--hairline-soft);border-radius:16px;padding:1.8rem;background:var(--bg-card);transition:transform .4s var(--ease),border-color .4s}
.pillar:hover{transform:translateY(-5px);border-color:var(--pink-dim)}
.pillar__num{font-family:var(--font-display);font-weight:800;font-size:2.4rem;color:transparent;-webkit-text-stroke:1.5px var(--pink-dim);display:block;margin-bottom:1.2rem;line-height:1}
.pillar h3{font-size:1.25rem;margin-bottom:.7rem;letter-spacing:-.01em}
.pillar p{color:var(--text-dim);font-size:.93rem;margin:0}
.pillar--accent{background:linear-gradient(165deg,rgba(255,0,126,.16),var(--bg-card) 75%)}
.pillar--accent .pillar__num{color:var(--pink);-webkit-text-stroke:0}

/* ---------- TEAM ---------- */
.team__head{margin-bottom:clamp(2.5rem,4vw,4rem)}
.team__head h2{font-size:clamp(2rem,4.6vw,3.8rem)}
.team__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.person{margin:0;position:relative;border-radius:16px;overflow:hidden;background:var(--bg-elevated);border:1px solid var(--hairline-soft)}
.person img{width:100%;aspect-ratio:1;object-fit:cover;filter:grayscale(1) contrast(1.05);transition:filter .5s,transform .6s var(--ease)}
.person:hover img{filter:grayscale(0);transform:scale(1.04)}
.person figcaption{position:absolute;left:0;right:0;bottom:0;padding:1.1rem 1.2rem;background:linear-gradient(to top,rgba(5,5,7,.95),transparent)}
.person strong{font-family:var(--font-display);font-weight:700;font-size:1.02rem;display:block}
.person span{font-size:.8rem;color:var(--text-dim)}

/* ---------- CONTACT ---------- */
.contact{position:relative;max-width:none;text-align:center;padding-block:clamp(100px,14vw,200px);overflow:hidden}
.contact__bg{position:absolute;inset:0;z-index:0;background:radial-gradient(ellipse 60% 80% at 50% 120%,var(--pink-tint),transparent 70%)}
.contact__bg::before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--hairline-soft) 1px,transparent 1px),linear-gradient(90deg,var(--hairline-soft) 1px,transparent 1px);background-size:54px 54px;mask-image:radial-gradient(ellipse 50% 60% at 50% 60%,#000,transparent 75%);-webkit-mask-image:radial-gradient(ellipse 50% 60% at 50% 60%,#000,transparent 75%);opacity:.6}
.contact__inner{position:relative;z-index:1;max-width:var(--maxw);margin-inline:auto;display:flex;flex-direction:column;align-items:center}
.contact .section-eyebrow{justify-content:center}
.contact .section-eyebrow::after{display:none}
.contact__title{font-size:clamp(3rem,11vw,9rem);letter-spacing:.01em;margin:0 0 1.6rem}
.contact__quote{max-width:46ch;color:var(--text-dim);font-size:clamp(1.1rem,1.8vw,1.4rem);font-style:italic;margin:0 0 2.6rem}
.contact__actions{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}
.contact__note{font-family:var(--font-mono);font-size:.82rem;letter-spacing:.03em;color:var(--text-dim);margin:1.6rem 0 0}

/* ---------- FOOTER ---------- */
.foot{position:relative;overflow:hidden;max-width:var(--maxw);margin:0 auto;padding:clamp(3rem,5vw,4.5rem) var(--pad) 2.4rem;border-top:1px solid var(--hairline-soft)}
.foot__grid{position:absolute;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background-image:linear-gradient(var(--hairline-soft) 1px,transparent 1px),linear-gradient(90deg,var(--hairline-soft) 1px,transparent 1px);
  background-size:54px 54px;
  -webkit-mask:radial-gradient(ellipse 85% 95% at 50% 135%,#000,transparent 72%);mask:radial-gradient(ellipse 85% 95% at 50% 135%,#000,transparent 72%)}
.foot__top{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;align-items:flex-start}
.foot__logo{height:30px;width:auto;margin-bottom:1rem}
.foot__brand p{color:var(--text-muted);font-size:.9rem;margin:0;max-width:30ch}
.foot__links{display:flex;flex-wrap:wrap;gap:.4rem 1.6rem;justify-content:flex-end}
.foot__links a{font-size:.88rem;color:var(--text-dim);transition:color .25s}
.foot__links a:hover{color:var(--pink)}
/* Giant brand sign-off: a shimmering wordmark that doubles as back-to-top */
.foot__word{display:block;text-align:center;text-decoration:none;text-transform:uppercase;
  font-family:var(--font-display);font-weight:900;letter-spacing:-.03em;line-height:.78;
  font-size:clamp(4rem,23vw,19rem);margin:clamp(2rem,4vw,3.4rem) 0 1.5rem;
  color:transparent;-webkit-background-clip:text;background-clip:text;
  background-image:linear-gradient(100deg,rgba(255,255,255,.1),var(--pink) 50%,rgba(255,255,255,.1));
  background-size:220% 100%;background-position:0% 50%;background-repeat:no-repeat;
  animation:footWord 9s ease-in-out infinite;transition:filter .4s var(--ease)}
@keyframes footWord{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.foot__word:hover{filter:drop-shadow(0 0 34px var(--pink-glow))}
.foot__bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;border-top:1px solid var(--hairline-soft);padding-top:1.5rem}
.foot__legal{font-family:var(--font-mono);font-size:.74rem;color:var(--text-muted);letter-spacing:.04em;margin:0}
.foot__totop{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-dim);text-decoration:none;display:inline-flex;align-items:center;gap:.5em;transition:color .25s}
.foot__totop span{transition:transform .3s var(--ease-spring)}
.foot__totop:hover{color:var(--pink)}
.foot__totop:hover span{transform:translateY(-4px)}
@media (prefers-reduced-motion:reduce){.foot__word{animation:none}}

/* ---------- Scroll reveal ---------- */
/* Spring settle + staggered cascade (--ri set per-sibling in main.js). */
.reveal{
  opacity:0;
  transform:translateY(30px) scale(.985);
  filter:blur(6px);
  transition:opacity .7s var(--ease),transform .9s var(--ease-spring),filter .7s var(--ease);
  transition-delay:calc(var(--ri,0) * 70ms);
}
.reveal.in{opacity:1;transform:none;filter:none}

/* Reward: accent words draw an underline as the heading lands. */
h2 .accent{position:relative;z-index:0;display:inline-block}
h2 .accent::after{
  content:"";position:absolute;left:-.04em;right:-.04em;bottom:-.08em;height:.08em;z-index:-1;
  background:var(--pink);border-radius:3px;transform:scaleX(0);transform-origin:left;opacity:.6;
  transition:transform .7s var(--ease-spring),height .2s var(--ease),bottom .2s var(--ease),opacity .2s var(--ease);
  transition-delay:calc(var(--ri,0) * 70ms + .32s),0s,0s,0s;
}
h2.reveal.in .accent::after{transform:scaleX(1)}

/* Spanky: hover slides the word's own colours open from the centre like airlock doors:
   a black-on-pink copy (.accent__reveal, injected in main.js) is unveiled via a centre-out clip. */
.accent__reveal{position:absolute;inset:0;z-index:2;pointer-events:none;white-space:pre;
  background:var(--pink);color:#000;border-radius:3px;
  clip-path:inset(0 50% 0 50%);-webkit-clip-path:inset(0 50% 0 50%);
  transition:clip-path .5s var(--ease),-webkit-clip-path .5s var(--ease)}
h2 .accent:hover .accent__reveal{clip-path:inset(0 0 0 0);-webkit-clip-path:inset(0 0 0 0)}
@media (prefers-reduced-motion:reduce){.accent__reveal{transition:none}}

/* Reward: section number flares as its eyebrow reveals. */
.section-eyebrow.reveal.in .num{animation:numFlare .9s var(--ease) both}
@keyframes numFlare{0%{text-shadow:0 0 0 transparent}35%{text-shadow:0 0 16px var(--pink-glow)}100%{text-shadow:0 0 0 transparent}}

/* Reward: counted numbers pop on landing (class added in main.js). */
[data-count].is-counted{animation:countPop .55s var(--ease-spring)}
@keyframes countPop{0%{transform:scale(1)}45%{transform:scale(1.13)}100%{transform:scale(1)}}

@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;filter:none;transition:none}
  .hero__title .line>span{animation:none;transform:none}
  h2 .accent::after{transform:scaleX(1);transition:none}
  .section-eyebrow.reveal.in .num,[data-count].is-counted{animation:none}
}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:flex}
  .nav[data-open] .nav__links{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:rgba(5,5,7,.96);backdrop-filter:blur(16px);padding:1rem var(--pad);border-bottom:1px solid var(--hairline)}
  .nav[data-open] .nav__links a{padding:.9em 0;border-bottom:1px solid var(--hairline-soft)}
  .who{grid-template-columns:1fr}
  .platform__grid,.work__grid,.why__grid,.team__grid{grid-template-columns:repeat(2,1fr)}
  .timeline,.demos__grid,.approach__models,.hero__ticker{grid-template-columns:1fr 1fr}
  .foot__top{flex-direction:column}
  .foot__links{justify-content:flex-start}
}
@media (max-width:560px){
  .hero__ticker,.platform__grid,.work__grid,.why__grid,.team__grid,.timeline,.demos__grid,.approach__models{grid-template-columns:1fr}
  .hero__title{font-size:clamp(2rem,9vw,3.4rem)}
  .hero__actions .btn,.contact__actions .btn{width:100%;justify-content:center}
}

/* ============================================================
   SUBPAGES: Platform · Work · About · Contact
   ============================================================ */

/* Active nav state */
.nav__links a[aria-current="page"]{color:var(--text)}
.nav__links a[aria-current="page"]::after{width:100%}

/* ---------- Subpage hero ---------- */
.subhero{min-height:var(--subhero-h,62svh);display:flex;flex-direction:column;justify-content:flex-end;padding-top:clamp(140px,18vh,220px);position:relative;overflow:hidden}
/* Atmospheric subhero: faint grid (matches the homepage hero) over the global mesh/grain */
.subhero::before{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;opacity:.45;
  background-image:linear-gradient(var(--hairline-soft) 1px,transparent 1px),linear-gradient(90deg,var(--hairline-soft) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(ellipse 75% 70% at 68% 32%,#000 18%,transparent 75%);
  mask-image:radial-gradient(ellipse 75% 70% at 68% 32%,#000 18%,transparent 75%)}
.subhero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(to top,var(--bg) 4%,rgba(5,5,7,.35) 34%,transparent 68%)}
.crumb{font-family:var(--font-mono);font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);display:flex;gap:.6em;align-items:center;margin:0 0 1.4rem}
.crumb a{color:var(--text-muted);transition:color .25s}
.crumb a:hover{color:var(--pink)}
.crumb span{color:var(--pink)}
.subhero__title{font-size:clamp(2.6rem,7.5vw,6.6rem);letter-spacing:-.035em;margin:0 0 1.2rem}
.subhero__lede{max-width:54ch;font-size:clamp(1.05rem,1.5vw,1.35rem);color:var(--text-dim);margin:0 0 .5rem}
.subpage{padding-top:clamp(60px,8vw,110px)}

/* ---------- Platform: layered stack ---------- */
.layers{display:flex;flex-direction:column;gap:1px;background:var(--hairline-soft);border:1px solid var(--hairline-soft);border-radius:18px;overflow:hidden;position:relative}
.layer{background:var(--bg-card);padding:clamp(1.5rem,3vw,2.4rem);display:grid;grid-template-columns:auto 1fr;gap:1.6rem;align-items:center;transition:background .4s}
.layer:hover{background:#13131d}
.layer__idx{font-family:var(--font-mono);font-size:.8rem;color:var(--pink);letter-spacing:.1em}
.layer__body h3{font-size:clamp(1.2rem,1.9vw,1.7rem);margin-bottom:.4rem;letter-spacing:-.01em}
.layer__body p{color:var(--text-dim);font-size:.98rem;margin:0;max-width:62ch}
.layer--perimeter{background:linear-gradient(120deg,rgba(255,0,126,.16),var(--bg-card) 60%)}
.layer--perimeter:hover{background:linear-gradient(120deg,rgba(255,0,126,.22),var(--bg-card) 60%)}
@media (max-width:680px){.layer{gap:1rem}}

/* Two-column feature rows */
.feature-rows{display:grid;gap:clamp(2rem,4vw,3.5rem)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,4rem);align-items:center;padding:clamp(1.5rem,3vw,2.5rem) 0;border-top:1px solid var(--hairline-soft)}
.frow:nth-child(even) .frow__visual{order:-1}
.frow__kicker{font-family:var(--font-mono);font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:var(--pink);margin:0 0 .8rem}
.frow h3{font-size:clamp(1.6rem,2.8vw,2.4rem);margin-bottom:1rem}
.frow p{color:var(--text-dim);margin:0 0 1rem;max-width:52ch}
.frow__list{list-style:none;margin:1rem 0 0;padding:0;display:flex;flex-direction:column;gap:.7rem}
.frow__list li{display:flex;gap:.7em;align-items:flex-start;color:var(--text-dim);font-size:.96rem}
.frow__list li::before{content:"";flex:0 0 8px;width:8px;height:8px;margin-top:.5em;background:var(--pink);clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%)}
.frow__visual{border:1px solid var(--hairline);border-radius:18px;background:radial-gradient(120% 120% at 70% 0,rgba(255,0,126,.1),var(--bg-card) 60%);min-height:280px;display:flex;align-items:center;justify-content:center;padding:2rem;overflow:hidden}
.frow__visual img{max-width:78%;height:auto}
/* Brand-built agentic mesh: a core orchestrator dispatching across a ring of agents */
.mesh-viz{width:100%;max-width:340px;height:auto;display:block;overflow:visible}
.mesh-viz__ring line{stroke:var(--hairline-soft);stroke-width:1}
.mesh-viz__spokes line{stroke:var(--pink);stroke-width:1;opacity:.26;stroke-dasharray:2 6;animation:meshFlow 2.4s linear infinite}
@keyframes meshFlow{to{stroke-dashoffset:-16}}
/* heartbeat ring radiating from the orchestrator */
.mesh-viz__wave{fill:none;stroke:var(--pink);stroke-width:1;opacity:0;transform-box:fill-box;transform-origin:center;animation:meshWave 2.4s ease-out infinite}
.mesh-viz__wave--2{animation-delay:1.2s}
@keyframes meshWave{0%{transform:scale(.4);opacity:.5}70%{opacity:.1}100%{transform:scale(5.6);opacity:0}}
/* agent nodes flash as their packet lands (delay synced to the matching packet) */
.mesh-viz__agents circle{fill:var(--bg-card);stroke:var(--pink);stroke-width:1.6;transform-box:fill-box;transform-origin:center;animation:meshNode 2.4s ease-in-out infinite;animation-delay:var(--nd,0s)}
@keyframes meshNode{0%,100%{transform:scale(1.32);fill:var(--pink);stroke-width:2.3}24%,76%{transform:scale(1);fill:var(--bg-card);stroke-width:1.6}}
/* data packets dispatched along each spoke, core -> node */
.mesh-viz__packets circle{fill:var(--pink);opacity:0;filter:drop-shadow(0 0 4px var(--pink-glow));animation:meshPacket 2.4s linear infinite;animation-delay:var(--d,0s)}
@keyframes meshPacket{0%{transform:translate(0,0);opacity:0}14%{opacity:1}82%{opacity:1}100%{transform:translate(var(--dx,0),var(--dy,0));opacity:0}}
.mesh-viz__core{fill:var(--pink);transform-box:fill-box;transform-origin:center;filter:drop-shadow(0 0 10px var(--pink-glow));animation:meshCore 2.4s ease-in-out infinite}
@keyframes meshCore{0%,100%{transform:scale(1)}50%{transform:scale(1.13)}}
@media (prefers-reduced-motion:reduce){.mesh-viz__spokes line,.mesh-viz__agents circle,.mesh-viz__core,.mesh-viz__wave,.mesh-viz__packets circle{animation:none}}
@media (max-width:760px){.frow{grid-template-columns:1fr}.frow:nth-child(even) .frow__visual{order:0}}

/* Stat strip (reusable banded numbers) */
.statstrip{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--hairline-soft);border:1px solid var(--hairline-soft);border-radius:16px;overflow:hidden;margin-top:clamp(2.5rem,4vw,3.5rem)}
.statstrip>div{background:var(--bg-card);padding:1.6rem 1.4rem}
.statstrip strong{display:block;font-family:var(--font-display);font-weight:800;font-size:clamp(1.8rem,3.4vw,2.8rem);letter-spacing:-.03em;line-height:1}
.statstrip span{font-size:.84rem;color:var(--text-muted)}
@media (max-width:680px){.statstrip{grid-template-columns:1fr 1fr}}

/* ---------- Work: case cards ---------- */
.filters{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2.5rem}
.filter{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.06em;color:var(--text-dim);border:1px solid var(--hairline);background:rgba(255,255,255,.015);border-radius:100px;padding:.55em 1.1em;cursor:pointer;transition:.25s}
.filter:hover{border-color:var(--pink-dim);color:var(--text)}
.filter[aria-pressed="true"]{background:var(--pink);border-color:var(--pink);color:#fff}
.cases{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.case{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--hairline);background:var(--bg-card);display:flex;flex-direction:column;transition:transform .45s var(--ease),border-color .4s,box-shadow .45s var(--ease)}
.case:hover{transform:translateY(-6px);border-color:var(--pink-dim);box-shadow:0 24px 54px -30px var(--pink-glow)}
/* Brand-built sector poster: glow + composable square-grid + a floating module (swap to a real screenshot per card later) */
.case__img{aspect-ratio:16/10;position:relative;overflow:hidden;--gx:78%;--gy:22%;--rot:-8deg;
  background:linear-gradient(to top,var(--bg-card),transparent 52%),radial-gradient(72% 78% at var(--gx) var(--gy),rgba(255,0,126,.36),rgba(194,18,107,.08) 44%,transparent 70%),linear-gradient(155deg,#170a14,#07070b 74%)}
.case__img::before{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:28px 28px;
  -webkit-mask:radial-gradient(120% 120% at var(--gx) var(--gy),#000 6%,transparent 70%);mask:radial-gradient(120% 120% at var(--gx) var(--gy),#000 6%,transparent 70%)}
.case__img::after{content:"";position:absolute;left:var(--gx);top:var(--gy);transform:translate(-50%,-50%) rotate(var(--rot));pointer-events:none;
  width:clamp(54px,26%,98px);aspect-ratio:1;border-radius:14px;
  background:linear-gradient(150deg,rgba(255,0,126,.32),rgba(255,0,126,.05));box-shadow:inset 0 0 0 1px rgba(255,0,126,.3),0 14px 38px -16px var(--pink-glow);
  transition:transform .8s var(--ease)}
.case:hover .case__img::after{transform:translate(-50%,-50%) rotate(var(--rot)) scale(1.09)}
.case__sector{position:absolute;top:1rem;left:1rem;z-index:1;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;background:rgba(5,5,7,.6);backdrop-filter:blur(6px);border:1px solid var(--hairline);color:var(--pink);padding:.4em .8em;border-radius:100px}
.case__body{padding:1.4rem;display:flex;flex-direction:column;gap:.6rem;flex:1}
.case__body h3{font-size:1.18rem;letter-spacing:-.01em;line-height:1.2}
.case__body p{color:var(--text-dim);font-size:.92rem;margin:0}
.case__tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:auto;padding-top:.6rem}
.case__tags span{font-family:var(--font-mono);font-size:.68rem;color:var(--text-muted);border:1px solid var(--hairline-soft);border-radius:6px;padding:.25em .6em}
.case.is-hidden{display:none}
/* per-card poster variety so no two read alike */
.cases .case:nth-child(2) .case__img{--gx:24%;--gy:26%;--rot:7deg}
.cases .case:nth-child(3) .case__img{--gx:30%;--gy:70%;--rot:6deg}
.cases .case:nth-child(4) .case__img{--gx:82%;--gy:66%;--rot:-7deg}
.cases .case:nth-child(5) .case__img{--gx:50%;--gy:18%;--rot:9deg}
.cases .case:nth-child(6) .case__img{--gx:76%;--gy:48%;--rot:-6deg}
.cases .case:nth-child(7) .case__img{--gx:22%;--gy:48%;--rot:8deg}
.cases .case:nth-child(8) .case__img{--gx:80%;--gy:26%;--rot:-9deg}
.cases .case:nth-child(9) .case__img{--gx:28%;--gy:30%;--rot:6deg}
/* filter: matched cards animate back in */
.case--enter{animation:caseEnter .45s var(--ease-spring)}
@keyframes caseEnter{0%{opacity:0;transform:translateY(12px) scale(.985)}100%{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.case--enter{animation:none}}
@media (max-width:920px){.cases{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.cases{grid-template-columns:1fr}}

/* ---------- About: mission/vision/values ---------- */
.mvv{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.mvv__card{position:relative;overflow:hidden;border:1px solid var(--hairline-soft);border-radius:18px;background:var(--bg-card);padding:2.2rem 1.8rem;text-align:center;transition:transform .4s var(--ease),border-color .4s,box-shadow .4s}
.mvv__card::before{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:linear-gradient(90deg,transparent,var(--pink),transparent);transform:scaleX(0);transition:transform .55s var(--ease)}
.mvv__card:hover{transform:translateY(-6px);border-color:var(--pink-dim);box-shadow:0 22px 50px -28px var(--pink-glow)}
.mvv__card:hover::before{transform:scaleX(1)}
.mvv__num{position:absolute;top:.9rem;right:1.2rem;font-family:var(--font-display);font-weight:800;font-size:2.6rem;line-height:1;color:var(--text);opacity:.06;transition:opacity .4s,color .4s}
.mvv__card:hover .mvv__num{opacity:.18;color:var(--pink)}
.mvv__icon{position:relative;width:72px;height:72px;margin:0 auto 1.3rem;display:grid;place-items:center}
.mvv__icon::after{content:"";position:absolute;inset:-10px;border-radius:50%;background:radial-gradient(circle,var(--pink-tint),transparent 68%);opacity:.45;transition:opacity .45s,transform .45s var(--ease-spring)}
.mvv__card:hover .mvv__icon::after{opacity:1;transform:scale(1.2)}
.mvv__glyph{position:relative;z-index:1;width:60px;height:60px;display:block;color:var(--pink);transform-origin:center;animation:mvvBreath 4.2s ease-in-out infinite}
.mvv__card:nth-child(2) .mvv__glyph{animation-delay:.7s}
.mvv__card:nth-child(3) .mvv__glyph{animation-delay:1.4s}
.mvv__glyph .hex{fill:none;stroke:currentColor;stroke-width:2;opacity:.7;transform-box:fill-box;transform-origin:center;stroke-dasharray:162;stroke-dashoffset:162;transition:stroke-dashoffset .9s var(--ease) calc(var(--ri,0) * 70ms + .15s),transform .6s var(--ease-spring),fill .4s}
.mvv__card.in .mvv__glyph .hex{stroke-dashoffset:0}
.mvv__card:hover .mvv__glyph .hex{transform:rotate(60deg);fill:var(--pink-tint);opacity:1}
.mvv__glyph .sym{fill:none;stroke:currentColor;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;transform-box:fill-box;transform-origin:center}
.mvv__glyph .dot{fill:currentColor;transform-box:fill-box;transform-origin:center}
/* per-pillar hover micro-motion: Mission dot pulses, Vision arrow lifts, Values shield steadies */
.mvv__card:nth-child(1):hover .mvv__glyph .dot{animation:mvvDot 1s ease-in-out infinite}
.mvv__card:nth-child(2):hover .mvv__glyph .sym{animation:mvvArrow 1.1s ease-in-out infinite}
.mvv__card:nth-child(3):hover .mvv__glyph .sym{animation:mvvShield 1.3s ease-in-out infinite}
@keyframes mvvBreath{0%,100%{transform:scale(1)}50%{transform:scale(1.045)}}
@keyframes mvvDot{0%,100%{transform:scale(1)}50%{transform:scale(1.55)}}
@keyframes mvvArrow{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
@keyframes mvvShield{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
.mvv__card h3{font-size:1.3rem;margin-bottom:.7rem}
.mvv__card p{position:relative;z-index:1;color:var(--text-dim);font-size:.96rem;margin:0}
@media (max-width:760px){.mvv{grid-template-columns:1fr}}
@media (prefers-reduced-motion:reduce){.mvv__glyph,.mvv__glyph .sym,.mvv__glyph .dot{animation:none}.mvv__glyph .hex{stroke-dashoffset:0;transition:none}.mvv__card:hover .mvv__glyph .hex{transform:none}.mvv__card::before{display:none}}

/* Beliefs grid */
.beliefs{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
.belief{border:1px solid var(--hairline-soft);border-radius:16px;background:var(--bg-card);padding:1.8rem;transition:border-color .4s}
.belief:hover{border-color:var(--pink-dim)}
.belief__label{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--pink)}
.belief h3{font-size:1.25rem;margin:.7rem 0 .6rem;letter-spacing:-.01em}
.belief p{color:var(--text-dim);font-size:.94rem;margin:0}
.belief em{color:var(--text);font-style:italic}
@media (max-width:680px){.beliefs{grid-template-columns:1fr}}

/* Story two-column */
.story{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.story h2{font-size:clamp(2rem,4vw,3.2rem);margin-bottom:1.4rem}
.story p{color:var(--text-dim);margin:0 0 1.1rem;max-width:54ch}
.story p strong{color:var(--text)}
.story__quote{margin:1.6rem 0;padding-left:1.4rem;border-left:2px solid var(--pink);font-family:var(--font-display);font-weight:500;font-style:italic;font-size:clamp(1.15rem,1.8vw,1.5rem);line-height:1.35;color:var(--text)}
.story__media{border-radius:18px;overflow:hidden;border:1px solid var(--hairline)}
.story__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/4.4;filter:grayscale(.2) contrast(1.05)}
@media (max-width:760px){.story{grid-template-columns:1fr}}

/* ---------- Contact page ---------- */
.contact-wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.contact-form{display:flex;flex-direction:column;gap:1.2rem}
.field{display:flex;flex-direction:column;gap:.5rem}
.field label{font-family:var(--font-mono);font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim)}
.field input,.field textarea,.field select{
  background:var(--bg-card);border:1px solid var(--hairline);border-radius:12px;color:var(--text);
  font-family:var(--font-body);font-size:1rem;padding:.9em 1em;transition:border-color .25s,box-shadow .25s;resize:vertical;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--pink);box-shadow:0 0 0 3px var(--pink-tint)}
.field--row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.contact-aside{display:flex;flex-direction:column;gap:1.6rem}
.contact-aside__block{border:1px solid var(--hairline-soft);border-radius:16px;background:var(--bg-card);padding:1.6rem}
.contact-aside__block h3{font-size:1.05rem;margin-bottom:.4rem}
.contact-aside__block a{color:var(--pink)}
.contact-aside__block p{color:var(--text-dim);font-size:.94rem;margin:.2rem 0 0}
.contact-aside__big{font-family:var(--font-display);font-weight:800;font-size:clamp(1.4rem,2.4vw,2rem);letter-spacing:-.02em;line-height:1.1}
@media (max-width:820px){.contact-wrap{grid-template-columns:1fr}.field--row{grid-template-columns:1fr}}

/* CTA band (reusable footer-of-page call to action) */
.ctaband{max-width:none;margin:0;padding:clamp(70px,9vw,120px) var(--pad);position:relative;overflow:hidden;text-align:center}
.ctaband__bg{position:absolute;inset:0;z-index:0;background:radial-gradient(ellipse 60% 90% at 50% 120%,var(--pink-tint),transparent 70%)}
.ctaband__inner{position:relative;z-index:1;max-width:var(--maxw);margin-inline:auto;display:flex;flex-direction:column;align-items:center}
.ctaband h2{font-size:clamp(2.2rem,5vw,4rem);letter-spacing:-.03em;margin:0 0 1.4rem}
.ctaband p{color:var(--text-dim);max-width:46ch;margin:0 0 2rem;font-size:1.1rem}

/* ---------- Pink cursor follower ---------- */
/* Dotted sweep: small pink dots dropped along the pointer's path, fading as they trail */
.cursor-trail{
  position:fixed;top:0;left:0;width:7px;height:7px;border-radius:50%;
  background:var(--pink);box-shadow:0 0 8px var(--pink-glow);
  pointer-events:none;z-index:9997;opacity:0;transform:translate(-50%,-50%);
  will-change:transform,opacity}
@media (hover:none),(pointer:coarse){.cursor-trail{display:none}}

/* CTA "win" burst: dot explosion + shockwave ring on hover */
.cta-spark{position:fixed;top:0;left:0;width:6px;height:6px;border-radius:50%;
  background:var(--pink);box-shadow:0 0 8px var(--pink-glow);
  pointer-events:none;z-index:9998;opacity:0;will-change:transform,opacity}
.cta-ring{position:fixed;top:0;left:0;width:48px;height:48px;border-radius:50%;
  border:2px solid var(--pink);box-shadow:0 0 14px var(--pink-glow);
  pointer-events:none;z-index:9998;opacity:0;will-change:transform,opacity}
@media (hover:none),(pointer:coarse){.cta-spark,.cta-ring{display:none}}

/* Profile name "fireworks": letters that erupt from a portrait on hover */
.name-confetti{position:fixed;top:0;left:0;
  font-family:var(--font-display);font-weight:800;font-size:clamp(1.1rem,1.6vw,1.6rem);
  line-height:1;color:var(--pink);text-shadow:0 0 14px var(--pink-glow);
  pointer-events:none;z-index:9998;opacity:0;white-space:pre;will-change:transform,opacity}
@media (hover:none),(pointer:coarse){.name-confetti{display:none}}

/* Rocket follower: homage to our space-exploration origins; trail above = its exhaust */
.cursor{
  position:fixed;top:0;left:0;width:22px;height:33px;
  pointer-events:none;z-index:9999;opacity:0;
  filter:drop-shadow(0 0 5px var(--pink-glow));
  transition:opacity .35s var(--ease);will-change:transform}
.cursor.is-active{opacity:1}
.cursor.is-idle{opacity:0}   /* fade off the text when the pointer rests */
.cursor svg{display:block;width:100%;height:100%;transition:transform .2s var(--ease-spring)}
.cursor.is-hover svg{transform:scale(1.35)}   /* boost over interactive elements */
.cursor.is-down svg{transform:scale(.82)}      /* recoil on click */
.cursor .rk-flame{transform-box:fill-box;transform-origin:50% 0;animation:rkFlame .26s steps(2,end) infinite}
@keyframes rkFlame{0%{transform:scaleY(.6);opacity:.6}100%{transform:scaleY(1.12);opacity:1}}
@media (hover:none),(pointer:coarse){.cursor{display:none}}
@media (prefers-reduced-motion:reduce){.cursor .rk-flame{animation:none}}

/* ===================== BLOG ===================== */
/* Listing */
.bloglist{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem;max-width:var(--maxw);margin-inline:auto}
.bpost{position:relative;display:flex;flex-direction:column;border:1px solid var(--hairline);border-radius:18px;background:var(--bg-card);padding:1.9rem;text-decoration:none;color:inherit;overflow:hidden;transition:transform .4s var(--ease),border-color .4s,box-shadow .45s var(--ease)}
.bpost::before{content:"";position:absolute;left:0;top:0;right:0;height:2px;background:linear-gradient(90deg,var(--pink),transparent 75%);transform:scaleX(0);transform-origin:left;transition:transform .55s var(--ease-spring)}
.bpost:hover{transform:translateY(-5px);border-color:var(--pink-dim);box-shadow:0 24px 54px -30px var(--pink-glow)}
.bpost:hover::before{transform:scaleX(1)}
.bpost__meta{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--pink);display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:.9rem}
.bpost__meta span:not(:first-child){color:var(--text-muted)}
.bpost h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.3rem,2.2vw,1.7rem);line-height:1.2;letter-spacing:-.01em;margin:0 0 .6rem}
.bpost p{color:var(--text-dim);font-size:.96rem;margin:0}
.bpost__more{margin-top:auto;padding-top:1.3rem;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.04em;color:var(--pink);display:inline-flex;align-items:center;gap:.45em}
.bpost:hover .bpost__more .btn__arr{transform:translateX(4px)}
@media (max-width:760px){.bloglist{grid-template-columns:1fr}}
/* Article */
.post{max-width:760px;margin-inline:auto;padding:clamp(2rem,5vw,3.5rem) var(--pad) 0}
.post__back{font-family:var(--font-mono);font-size:.76rem;letter-spacing:.04em;color:var(--text-dim);text-decoration:none;display:inline-flex;gap:.45em;align-items:center;margin-bottom:1.8rem}
.post__back:hover{color:var(--pink)}
.post__meta{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--pink);display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.1rem}
.post__meta span:not(:first-child){color:var(--text-muted)}
.post__title{font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,5vw,3.4rem);line-height:1.08;letter-spacing:-.02em;margin:0 0 1.1rem}
.post__lede{font-size:clamp(1.1rem,1.8vw,1.32rem);color:var(--text-dim);line-height:1.5;margin:0 0 2.6rem;max-width:62ch}
.prose{max-width:68ch;margin-inline:auto;color:var(--text-dim);font-size:1.05rem;line-height:1.75}
.prose>*+*{margin-top:1.4rem}
.prose h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.4rem,2.6vw,1.9rem);letter-spacing:-.01em;line-height:1.2;color:var(--text);margin-top:2.8rem}
.prose h3{font-family:var(--font-display);font-weight:700;font-size:1.25rem;color:var(--text);margin-top:2rem}
.prose strong{color:var(--text)}
.prose a{color:var(--pink);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.prose ul,.prose ol{padding-left:1.3rem}
.prose li{margin-top:.55rem}
.prose li::marker{color:var(--pink)}
.prose blockquote{margin:2.2rem 0;padding-left:1.5rem;border-left:2px solid var(--pink);font-family:var(--font-display);font-weight:500;font-style:italic;font-size:clamp(1.2rem,2vw,1.5rem);line-height:1.4;color:var(--text)}
.prose hr{border:0;border-top:1px solid var(--hairline);margin:2.6rem 0}
.post__foot{max-width:68ch;margin:3.5rem auto 0;padding-top:2.8rem;border-top:1px solid var(--hairline);display:flex;flex-wrap:wrap;gap:1.5rem;align-items:center;justify-content:space-between}

/* ===================== CASE STUDY ===================== */
.cs{max-width:var(--maxw);margin-inline:auto;padding:calc(4.5rem + 0.5vw) var(--pad) clamp(3.5rem,7vw,6rem)}
.cs__grid{display:grid;grid-template-columns:1fr clamp(220px,24vw,300px);gap:clamp(2rem,5vw,4rem);align-items:start;margin-top:clamp(1.5rem,3vw,2.5rem)}
.cs__main{max-width:68ch}
.cs__aside{position:sticky;top:100px;display:flex;flex-direction:column;gap:1.8rem;border-left:1px solid var(--hairline-soft);padding-left:clamp(1.2rem,2vw,2rem)}
.cs__label{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);margin:0 0 .85rem}
.cs__chips{display:flex;flex-wrap:wrap;gap:.5rem}
.cs__chips span{font-family:var(--font-mono);font-size:.74rem;color:var(--text-dim);border:1px solid var(--hairline);border-radius:8px;padding:.45em .8em;background:rgba(255,255,255,.015)}
.cs__chips .is-industry{color:var(--pink);border-color:var(--pink-dim);background:var(--pink-tint)}
.cs__related{display:flex;flex-direction:column}
.cs__related .cs__label{margin-bottom:.2rem}
.cs__rel{text-decoration:none;color:inherit;display:block;padding:.85rem 0;border-top:1px solid var(--hairline-soft)}
.cs__rel:last-child{padding-bottom:0}
.cs__rel-cat{display:block;font-family:var(--font-mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:var(--pink);margin-bottom:.3rem}
.cs__rel-title{display:block;font-size:.9rem;line-height:1.32;color:var(--text-dim);transition:color .25s}
.cs__rel:hover .cs__rel-title{color:var(--text)}
.cs__share{display:flex;flex-direction:column;gap:.75rem}
.cs__share-row{display:flex;gap:.55rem;flex-wrap:wrap}
.cs__share-btn{width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--hairline);border-radius:10px;background:rgba(255,255,255,.015);color:var(--text-dim);cursor:pointer;padding:0;-webkit-appearance:none;appearance:none;transition:color .25s,border-color .25s,background .25s,transform .25s var(--ease-spring)}
.cs__share-btn svg{width:18px;height:18px;display:block}
.cs__share-btn:hover{color:var(--pink);border-color:var(--pink-dim);background:var(--pink-tint);transform:translateY(-2px)}
.cs__share-btn[data-copied]{color:var(--pink);border-color:var(--pink-dim);background:var(--pink-tint)}
.cs__author{display:inline-flex;align-items:center;gap:.7rem;cursor:default}
.cs__author-img{width:40px;height:40px;border-radius:50%;object-fit:cover;object-position:center top;border:1.5px solid var(--hairline);filter:grayscale(1) contrast(.95) brightness(.95);transition:filter .45s var(--ease),transform .5s var(--ease-spring),border-color .4s,box-shadow .4s}
.cs__author-name{font-family:var(--font-display);font-weight:600;font-size:.92rem;color:var(--text-dim);transition:color .3s}
.cs__author:hover .cs__author-img{filter:grayscale(0) contrast(1) brightness(1);transform:scale(1.16);border-color:var(--pink);box-shadow:0 0 0 3px var(--pink-tint),0 10px 24px -10px var(--pink-glow)}
.cs__author:hover .cs__author-name{color:var(--pink)}
@media (prefers-reduced-motion:reduce){.cs__author-img{transition:filter .3s}.cs__author:hover .cs__author-img{transform:none}}
.cs__note{max-width:var(--maxw);margin:1rem auto 0;font-family:var(--font-mono);font-size:.74rem;color:var(--text-muted);text-align:center}
@media (max-width:820px){.cs__grid{grid-template-columns:1fr}.cs__aside{position:static;border-left:0;border-top:1px solid var(--hairline-soft);padding-left:0;padding-top:1.8rem;flex-direction:row;flex-wrap:wrap;gap:2rem}.cs__related,.cs__share{flex-basis:100%}}
@media (max-width:560px){.cs__aside{flex-direction:column;gap:1.6rem}.cs__aside>div,.cs__related,.cs__share{flex-basis:auto;width:100%}}
/* Work cards link into their case pages */
.case{text-decoration:none;color:inherit}
.case__view{margin-top:1rem;font-family:var(--font-mono);font-size:.74rem;letter-spacing:.04em;color:var(--pink);display:inline-flex;align-items:center;gap:.4em}
.case:hover .case__view .btn__arr{transform:translateX(3px)}

/* ---------- Utilities (replace token-based inline styles; no raw values) ---------- */
/* Screen-reader-only: present in the a11y tree, removed from visual layout */
.u-visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.u-container{max-width:var(--maxw);margin-inline:auto;width:100%;padding-inline:var(--pad)}
.u-text-center{text-align:center}
.u-muted{color:var(--text-muted)}
.u-pink{color:var(--pink)}
.u-mt-sm{margin-top:.8rem}
.u-mb-sm{margin-bottom:.8rem}
.u-mt-fluid{margin-top:clamp(2.5rem,5vw,4rem)}
.form-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.form-note{font-family:var(--font-mono);font-size:.82rem;color:var(--text-dim)}
.form-note--ok{color:var(--ok);font-weight:500}
.form-note--error{color:var(--err);font-weight:500}
.hero__actions--center{justify-content:center}
.pcard__route--center{flex-wrap:wrap;justify-content:center;gap:.8rem}
.subhero--46{--subhero-h:46svh}
.subhero--42{--subhero-h:42svh}
