/* ---------- TOKENS (Agencux-mapped) ----------
   Variable NAMES are preserved so all existing rules + JS keep working.
   Semantics are remapped to the Agencux light system:
     --cream / --paper  = light page backgrounds (#fff / off-whites)
     --ink / --ink-2/3  = near-black text AND intentional dark "punch" sections
     --accent           = Agencux red  #f9452d
     --accent-lime      = Agencux lime #72ff13  (secondary pop)
   Dark sections (services, manifesto, team, contact, cta-strip, ticker) are
   painted with var(--ink) and therefore stay dark on the light site — the
   intended Agencux inverted-section rhythm. */
:root{
  /* dark scale — text + inverted sections */
  --ink:#000;
  --ink-2:#111;
  --ink-3:#1a1a1f;
  /* light scale — page + surfaces */
  --cream:#ffffff;
  --cream-2:#f3f3f3;
  --paper:#f9f9f9;
  /* neutrals */
  --muted:#555555;
  --muted-dark:#a2a2a2;
  --line:rgba(0,0,0,.12);
  --line-d:rgba(255,255,255,.14);
  /* accents */
  --accent:#f9452d;
  --accent-lime:#72ff13;
  --accent-2:#ffe2dc;
  --accent-ink:#ffffff;

  /* type: Zalando Sans Expanded (display) + DM Sans (body) */
  --f-display:"Zalando Sans Expanded","Zalando Sans Expanded Placeholder",sans-serif;
  /* label font — consolidated onto DM Sans (uppercase + letter-spacing kept on labels) */
  --f-mono:"DM Sans","DM Sans Placeholder",sans-serif;
  --f-body:"DM Sans","DM Sans Placeholder",system-ui,sans-serif;

  --max:1480px;
  --pad:clamp(1.25rem,4vw,4.5rem);
  --gap:clamp(1rem,2vw,2rem);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--cream);color:var(--ink);font-family:var(--f-body);font-weight:400;line-height:1.45;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
body{overscroll-behavior-y:none}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
input,textarea,select{font:inherit;color:inherit}
::selection{background:var(--accent);color:var(--accent-ink)}

/* ---------- UTIL ---------- */
.wrap{max-width:var(--max);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.label{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:500}
.label--light{color:var(--muted-dark)}
.hr{height:1px;background:var(--line);border:0;margin:0}
.hr--d{background:var(--line-d)}

.dot{display:inline-block;width:.45rem;height:.45rem;border-radius:50%;background:var(--accent-lime);box-shadow:0 0 0 0 rgba(114,255,19,.6);animation:pulse 2.2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(114,255,19,.55)}70%{box-shadow:0 0 0 .55rem rgba(114,255,19,0)}100%{box-shadow:0 0 0 0 rgba(114,255,19,0)}}

/* ---------- GRAIN + NOISE (subtle) ---------- */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:200;opacity:.045;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ---------- NAV ---------- */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem var(--pad);
  background:rgba(255,255,255,.72);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line);
  transition:transform .4s ease;
}
.nav.hide{transform:translateY(-110%)}
.nav__logo{display:flex;align-items:center;gap:.55rem;font-family:var(--f-display);font-weight:700;font-size:1.1rem;letter-spacing:-.02em}
.nav__logo svg{width:18px;height:18px}
.nav__menu{display:flex;align-items:center;gap:.25rem;font-family:var(--f-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.14em}
.nav__menu a{padding:.55rem .85rem;border-radius:99px;transition:background .2s,color .2s}
.nav__menu a:hover{background:var(--ink);color:var(--cream)}
.nav__cta{display:inline-flex;align-items:center;gap:.5rem;background:var(--ink);color:var(--cream);padding:.7rem 1.1rem;border-radius:99px;font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;transition:background .2s, color .2s, transform .2s}
.nav__cta:hover{background:var(--accent);color:var(--accent-ink);transform:translateY(-1px)}
.nav__cta .arr{display:inline-block;transition:transform .25s}
.nav__cta:hover .arr{transform:translate(2px,-2px)}
.nav__burger{display:none;width:42px;height:42px;border:1px solid var(--line);border-radius:99px;align-items:center;justify-content:center}
.nav__burger span{display:block;width:16px;height:1.5px;background:var(--ink);position:relative}
.nav__burger span::before,.nav__burger span::after{content:"";position:absolute;left:0;width:16px;height:1.5px;background:var(--ink)}
.nav__burger span::before{top:-5px}.nav__burger span::after{top:5px}

@media (max-width:880px){
  .nav__menu{display:none}
  .nav__burger{display:inline-flex}
}

/* ---------- HERO ---------- */
.hero{
  position:relative;padding-top:7.5rem;padding-bottom:3rem;
  background:var(--cream);
  overflow:hidden;
}
.hero__top{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:2rem}
.hero__avail{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink)}
.hero__meta{display:flex;gap:2rem;font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);text-align:right}
.hero__meta div b{display:block;color:var(--ink);font-weight:500;margin-bottom:.2rem}

.hero__type{position:relative;padding-block:1rem 1.5rem}
.hero__type h1{
  font-family:var(--f-display);
  font-weight:700;
  line-height:.86;
  letter-spacing:-.04em;
  font-size:clamp(4rem, 17vw, 17rem);
  
  color:var(--ink);
}
.hero__type .row{display:flex;align-items:baseline;gap:.5rem;flex-wrap:wrap}
.hero__type .reg{font-size:.4em;vertical-align:super;font-weight:500;color:var(--accent)}
.hero__type .paren{font-family:var(--f-mono);font-size:.18em;letter-spacing:.05em;color:var(--muted);font-weight:400;text-transform:none;align-self:center;transform:translateY(-.4em)}
.hero__type .year{font-family:var(--f-mono);font-size:.14em;color:var(--muted);font-weight:400;align-self:flex-end;padding-bottom:.6em}
.hero__type .accent{color:var(--accent);font-style:italic}

.hero__bottom{display:grid;grid-template-columns:1.2fr 1fr;gap:2rem;align-items:end;margin-top:1.5rem}
.hero__tag{font-family:var(--f-display);font-size:clamp(1.15rem,1.8vw,1.6rem);line-height:1.25;letter-spacing:-.01em;max-width:38ch;color:var(--ink)}
.hero__cta-wrap{display:flex;justify-content:flex-end;align-items:center;gap:1rem}
.btn-circle{
  width:148px;height:148px;border-radius:50%;
  background:var(--ink);color:var(--cream);
  display:inline-flex;align-items:center;justify-content:center;text-align:center;
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  position:relative;transition:transform .35s ease, background .25s;
}
.btn-circle:hover{background:var(--accent);color:var(--accent-ink);transform:rotate(10deg) scale(1.05)}
.btn-circle::after{content:"↗";position:absolute;font-size:1.5rem;opacity:.7}
.btn-circle span{display:block;max-width:90px;line-height:1.15;transform:translateY(-12px)}

@media (max-width:880px){
  .hero__bottom{grid-template-columns:1fr}
  .hero__cta-wrap{justify-content:flex-start}
  .btn-circle{width:120px;height:120px}
}

/* decorative side cards in hero */
.hero__deco{position:absolute;pointer-events:none;font-family:var(--f-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.hero__deco--l{top:7.5rem;left:var(--pad);writing-mode:vertical-rl;transform:rotate(180deg)}
.hero__deco--r{top:7.5rem;right:var(--pad);writing-mode:vertical-rl}

/* ---------- TICKER ---------- */
.ticker{
  background:var(--ink);color:var(--cream);
  padding:1.4rem 0;
  overflow:hidden;
  border-block:1px solid var(--ink);
}
.ticker__track{display:flex;gap:3rem;animation:scroll 38s linear infinite;width:max-content}
.ticker__track span{font-family:var(--f-display);font-size:clamp(2rem,4.5vw,3.6rem);font-weight:500;letter-spacing:-.02em;display:inline-flex;align-items:center;gap:3rem}
.ticker__track span::after{content:"★";color:var(--accent);font-size:.6em;margin-left:3rem}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

.ticker--logos{background:var(--cream-2);color:var(--ink);padding:1.8rem 0;border-block:1px solid var(--line)}
.ticker--logos .ticker__track{animation-duration:50s;gap:5rem}
.ticker--logos .ticker__track span{font-size:clamp(1.4rem,2.4vw,2rem);font-weight:600;opacity:.45;transition:opacity .3s}
.ticker--logos .ticker__track span:hover{opacity:1}
.ticker--logos .ticker__track span::after{content:"";margin-left:5rem;width:6px;height:6px;border-radius:50%;background:var(--ink);opacity:.4}

/* ---------- ABOUT INTRO ---------- */
.intro{padding:5rem var(--pad);background:var(--cream);border-bottom:1px solid var(--line)}
.intro__grid{display:grid;grid-template-columns:1fr 2fr auto;gap:3rem;align-items:end}
.intro__statement{font-family:var(--f-display);font-size:clamp(1.6rem,3vw,2.6rem);line-height:1.18;letter-spacing:-.02em;color:var(--ink);max-width:34ch}
.intro__statement em{font-style:italic;color:var(--accent)}
@media (max-width:880px){.intro__grid{grid-template-columns:1fr;gap:2rem}}

/* ---------- CHALLENGE ---------- */
.challenge{padding:6rem var(--pad);background:var(--paper);border-bottom:1px solid var(--line);position:relative}
.challenge__head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem;gap:2rem;flex-wrap:wrap}
.challenge h2{font-family:var(--f-display);font-size:clamp(2.4rem,6vw,5rem);font-weight:600;line-height:.95;letter-spacing:-.03em;max-width:14ch}
.challenge h2 .accent{color:var(--accent);font-style:italic}
.challenge__body{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.challenge__lede{font-family:var(--f-display);font-size:clamp(1.1rem,1.7vw,1.5rem);line-height:1.5;color:var(--ink);max-width:48ch}
.challenge__q{display:flex;flex-direction:column;gap:1.5rem}
.challenge__q .q{display:grid;grid-template-columns:auto 1fr;gap:1.5rem;padding-block:1.2rem;border-top:1px solid var(--line);align-items:start}
.challenge__q .q:last-child{border-bottom:1px solid var(--line)}
.challenge__q .num{font-family:var(--f-mono);font-size:.78rem;color:var(--accent);font-weight:500;padding-top:.25rem}
.challenge__q .text{font-family:var(--f-display);font-size:clamp(1.05rem,1.5vw,1.3rem);line-height:1.35;color:var(--ink)}
@media (max-width:880px){.challenge__body{grid-template-columns:1fr;gap:2.5rem}}

/* ---------- SERVICES ---------- */
.services{padding:6rem var(--pad);background:var(--ink);color:var(--cream);border-bottom:1px solid var(--ink)}
.services__head{display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:end;margin-bottom:3.5rem}
.services__head .label--light{color:var(--muted-dark)}
.services__head h2{font-family:var(--f-display);font-size:clamp(2.4rem,6vw,5.5rem);font-weight:600;line-height:.92;letter-spacing:-.03em;color:var(--cream)}
.services__head h2 em{font-style:italic;color:var(--accent)}
.services__head .sub{font-family:var(--f-mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted-dark);max-width:24ch;text-align:right}
.services__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.service{
  position:relative;background:var(--ink-2);border:1px solid var(--line-d);border-radius:18px;
  padding:2rem 1.75rem 1.75rem;min-height:380px;display:flex;flex-direction:column;justify-content:space-between;
  overflow:hidden;transition:background .35s, transform .35s, border-color .35s;
}
.service::before{
  content:"";position:absolute;inset:auto -40% -40% auto;width:80%;aspect-ratio:1;
  background:radial-gradient(circle at center, rgba(249,69,45,.18), transparent 60%);
  filter:blur(20px);opacity:0;transition:opacity .5s;
}
.service:hover{background:var(--ink-3);border-color:var(--accent);transform:translateY(-4px)}
.service:hover::before{opacity:1}
.service__top{display:flex;justify-content:space-between;align-items:flex-start}
.service__num{font-family:var(--f-mono);font-size:.78rem;color:var(--muted-dark);letter-spacing:.14em}
.service__icon{width:42px;height:42px;border:1px solid var(--line-d);border-radius:50%;display:grid;place-items:center;color:var(--accent)}
.service h3{font-family:var(--f-display);font-size:clamp(1.5rem,2.2vw,1.9rem);font-weight:600;line-height:1.05;letter-spacing:-.02em;margin-top:6rem}
.service p{margin-top:.85rem;color:var(--muted-dark);max-width:32ch;font-size:.97rem;line-height:1.55}
.service__more{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cream);margin-top:1.6rem;padding-top:1.2rem;border-top:1px solid var(--line-d);transition:color .25s}
.service__more .arr{display:inline-block;transition:transform .25s}
.service:hover .service__more{color:var(--accent)}
.service:hover .service__more .arr{transform:translate(4px,-4px)}
@media (max-width:980px){.services__grid{grid-template-columns:1fr}}

/* ---------- BIG BANNER ---------- */
.banner{padding:6rem var(--pad);background:var(--cream);overflow:hidden;border-bottom:1px solid var(--line)}
.banner__row{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:2rem}
.banner__row .word{font-family:var(--f-display);font-size:clamp(3rem,12vw,11rem);font-weight:600;line-height:.88;letter-spacing:-.04em;text-transform:uppercase}
.banner__row .l{text-align:right}
.banner__row .r{text-align:left;color:var(--accent);font-style:italic}
.banner__viz{width:clamp(120px,18vw,260px);aspect-ratio:1;border-radius:50%;background:radial-gradient(circle at 30% 30%, var(--accent), var(--ink) 70%);position:relative;overflow:hidden;box-shadow:0 30px 60px -25px rgba(0,0,0,.4)}
.banner__viz::before,.banner__viz::after{content:"";position:absolute;inset:8%;border-radius:50%;border:1px dashed rgba(255,255,255,.35);animation:spin 22s linear infinite}
.banner__viz::after{inset:22%;border-style:dotted;animation-duration:14s;animation-direction:reverse}
@keyframes spin{to{transform:rotate(360deg)}}
@media (max-width:880px){
  .banner__row{grid-template-columns:1fr;text-align:center}
  .banner__row .l,.banner__row .r{text-align:center}
  .banner__viz{margin:0 auto}
}

/* ---------- STACK / RECOGNITION ---------- */
.stack{padding:6rem var(--pad);background:var(--paper);border-bottom:1px solid var(--line)}
.stack__head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem;gap:2rem;flex-wrap:wrap}
.stack h2{font-family:var(--f-display);font-size:clamp(2rem,4vw,3.4rem);font-weight:600;letter-spacing:-.025em;line-height:1}
.stack__list{display:grid;grid-template-columns:repeat(5,1fr);gap:0;border-top:1px solid var(--line)}
.stack__item{padding:2rem 1.25rem;border-right:1px solid var(--line);border-bottom:1px solid var(--line);min-height:200px;display:flex;flex-direction:column;justify-content:space-between;transition:background .3s}
.stack__item:hover{background:var(--cream-2)}
.stack__item:nth-child(5n){border-right:0}
.stack__name{font-family:var(--f-display);font-size:1.4rem;font-weight:600;letter-spacing:-.02em}
.stack__sub{font-family:var(--f-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin-top:.35rem;display:block}
.stack__desc{font-size:.92rem;line-height:1.5;color:var(--ink);margin-top:1rem}
@media (max-width:980px){
  .stack__list{grid-template-columns:repeat(2,1fr)}
  .stack__item:nth-child(5n){border-right:1px solid var(--line)}
  .stack__item:nth-child(2n){border-right:0}
}
@media (max-width:540px){
  .stack__list{grid-template-columns:1fr}
  .stack__item{border-right:0 !important}
}

/* ---------- IMPACT STAT ---------- */
.impact{padding:6rem var(--pad);background:var(--cream);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.impact__grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:2rem;align-items:end}
.impact__num{font-family:var(--f-display);font-weight:700;font-size:clamp(6rem,18vw,16rem);line-height:.85;letter-spacing:-.05em;color:var(--ink)}
.impact__num .unit{font-size:.35em;font-weight:500;color:var(--accent);vertical-align:super;margin-left:.2em}
.impact__desc{font-family:var(--f-display);font-size:clamp(1.05rem,1.6vw,1.4rem);line-height:1.4;letter-spacing:-.01em;max-width:32ch}
.impact__viz{aspect-ratio:3/4;background:linear-gradient(135deg, var(--ink) 0%, var(--ink-3) 100%);border-radius:18px;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;padding:1.5rem;color:var(--cream)}
.impact__viz .grid-lines{position:absolute;inset:0;background:repeating-linear-gradient(0deg, transparent 0 28px, rgba(255,255,255,.06) 28px 29px), repeating-linear-gradient(90deg, transparent 0 28px, rgba(255,255,255,.06) 28px 29px)}
.impact__viz .bar{position:absolute;bottom:0;left:0;right:0;height:55%;background:linear-gradient(180deg, var(--accent) 0%, rgba(249,69,45,.2) 100%);opacity:.85;clip-path:polygon(0 100%, 0 60%, 12% 65%, 25% 40%, 38% 50%, 52% 25%, 65% 35%, 78% 15%, 100% 22%, 100% 100%)}
.impact__viz .vlabel{position:relative;font-family:var(--f-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-dark)}
.impact__viz .vbig{position:relative;font-family:var(--f-display);font-size:2.2rem;font-weight:600;line-height:1;letter-spacing:-.02em;align-self:flex-end}
@media (max-width:880px){.impact__grid{grid-template-columns:1fr}}

/* ---------- WORK GRID ---------- */
.work{padding:6rem var(--pad);background:var(--paper);border-bottom:1px solid var(--line)}
.work__head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem;gap:2rem;flex-wrap:wrap}
.work h2{font-family:var(--f-display);font-size:clamp(2.4rem,5.5vw,4.5rem);font-weight:600;line-height:1;letter-spacing:-.03em}
.work__cta{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;padding:.85rem 1.3rem;border:1px solid var(--ink);border-radius:99px;transition:background .25s, color .25s}
.work__cta:hover{background:var(--ink);color:var(--cream)}
.work__grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem;grid-auto-rows:minmax(180px,auto)}
.case{
  position:relative;border-radius:14px;overflow:hidden;
  background:var(--ink-2);color:var(--cream);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:1.5rem;min-height:280px;
  transition:transform .4s ease;
  cursor:pointer;
}
.case:hover{transform:translateY(-6px)}
.case .viz{position:absolute;inset:0;z-index:0}
.case .viz svg{width:100%;height:100%;display:block}
.case .meta{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:flex-end;gap:1rem}
.case .meta .tags{display:flex;gap:.4rem;flex-wrap:wrap}
.case .meta .tag{font-family:var(--f-mono);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;padding:.35rem .7rem;border:1px solid rgba(255,255,255,.3);border-radius:99px;background:rgba(0,0,0,.4);backdrop-filter:blur(4px)}
.case .meta h3{font-family:var(--f-display);font-size:1.6rem;font-weight:600;letter-spacing:-.02em;line-height:1.05}
.case .meta p{font-size:.88rem;color:var(--muted-dark);max-width:32ch;margin-top:.45rem;line-height:1.45}
.case .arr{position:absolute;top:1.2rem;right:1.2rem;z-index:2;width:38px;height:38px;border-radius:50%;background:var(--cream);color:var(--ink);display:grid;place-items:center;font-size:1.1rem;transform:rotate(-45deg);transition:transform .3s, background .3s}
.case:hover .arr{background:var(--accent);transform:rotate(0deg)}

/* Sizes */
.case--lg{grid-column:span 7;min-height:440px}
.case--md{grid-column:span 5;min-height:440px}
.case--sm{grid-column:span 4;min-height:320px}
.case--wide{grid-column:span 8;min-height:320px}
@media (max-width:980px){
  .case--lg,.case--md,.case--sm,.case--wide{grid-column:span 12}
}

/* Case viz themes */
.viz--circuit{background:radial-gradient(circle at 70% 30%, #3a1a12 0%, var(--ink) 60%)}
.viz--mesh{background:linear-gradient(135deg, var(--ink) 0%, var(--ink-3) 100%)}
.viz--grid{background:var(--ink-2)}
.viz--gradient{background:linear-gradient(135deg, #f9452d 0%, #7a2410 100%)}

/* ---------- PROCESS ---------- */
.process{padding:6rem var(--pad);background:var(--cream);border-bottom:1px solid var(--line)}
.process__head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem;gap:2rem;flex-wrap:wrap}
.process h2{font-family:var(--f-display);font-size:clamp(2.4rem,5.5vw,4.5rem);font-weight:600;line-height:1;letter-spacing:-.03em}
.process__weeks{display:flex;gap:.4rem}
.process__weeks button{padding:.5rem 1rem;border:1px solid var(--line);border-radius:99px;font-family:var(--f-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;background:transparent;transition:all .2s}
.process__weeks button.active{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.process__weeks button:active{transform:scale(.97)}
/* clicking a week highlights the matching step */
.process__item.is-active{padding-left:1rem;background:linear-gradient(90deg, rgba(249,69,45,.06), transparent 55%)}
.process__item.is-active .process__num{color:var(--accent)}
.process__item.is-active .process__title{color:var(--ink)}
.process__item.is-active .process__tag{color:var(--ink)}
.process__item.is-active .process__tag .arr{background:var(--accent);border-color:var(--accent);color:var(--ink);transform:rotate(45deg)}
.process__item:active{transform:scale(.992)}
/* ---------- Tactile press feedback on pill / CTA buttons ---------- */
.nav__cta:active,
.btn-circle:active,
.work__cta:active,
.cta-strip__cta:active,
.work-index__filters button:active,
.foot__news button:active,
.coming-soon__form button:active,
.nav__menu a:active{transform:scale(.97)}
.process__list{border-top:1px solid var(--line)}
.process__item{border-bottom:1px solid var(--line);padding:2rem 0;display:grid;grid-template-columns:80px 1fr 1fr auto;gap:2rem;align-items:start;cursor:pointer;transition:padding .3s}
.process__item:hover{padding-left:1rem}
.process__num{font-family:var(--f-mono);font-size:.78rem;color:var(--accent);letter-spacing:.14em;padding-top:.4rem}
.process__title{font-family:var(--f-display);font-size:clamp(1.8rem,3vw,2.6rem);font-weight:600;letter-spacing:-.025em;line-height:1}
.process__body{font-size:.98rem;line-height:1.55;color:var(--ink);max-width:42ch;opacity:.85}
.process__tag{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding-top:.4rem;display:flex;align-items:center;gap:.5rem}
.process__tag .arr{display:inline-block;width:38px;height:38px;border:1px solid var(--ink);border-radius:50%;display:inline-grid;place-items:center;color:var(--ink);transition:background .25s, color .25s, transform .25s}
.process__item:hover .process__tag .arr{background:var(--accent);border-color:var(--accent);color:var(--ink);transform:rotate(45deg)}
@media (max-width:880px){
  .process__item{grid-template-columns:60px 1fr;gap:1rem}
  .process__body,.process__tag{grid-column:2}
}

/* ---------- MANIFESTO ---------- */
.manifesto{padding:7rem var(--pad);background:var(--ink);color:var(--cream);text-align:center;position:relative;overflow:hidden;border-bottom:1px solid var(--ink)}
.manifesto::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center top, rgba(249,69,45,.18) 0%, transparent 50%)}
.manifesto__inner{position:relative;max-width:1100px;margin:0 auto}
.manifesto .label--light{margin-bottom:2rem;display:inline-block}
.manifesto__big{font-family:var(--f-display);font-size:clamp(2.6rem,7vw,6rem);font-weight:600;line-height:.95;letter-spacing:-.035em;margin-bottom:2rem}
.manifesto__big em{font-style:italic;color:var(--accent)}
.manifesto__body{font-family:var(--f-display);font-size:clamp(1.1rem,1.6vw,1.4rem);line-height:1.5;max-width:62ch;margin:0 auto;color:var(--cream);opacity:.85}

/* ---------- TESTIMONIALS ---------- */
.testimonials{padding:6rem var(--pad);background:var(--paper);border-bottom:1px solid var(--line)}
.testimonials__head{margin-bottom:3rem}
.testimonials h2{font-family:var(--f-display);font-size:clamp(2.2rem,4.5vw,3.6rem);font-weight:600;letter-spacing:-.025em;line-height:1}
.testimonials__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.testimonial{padding:2rem;background:var(--cream);border:1px solid var(--line);border-radius:16px;display:flex;flex-direction:column;justify-content:space-between;min-height:320px;transition:background .3s, border-color .3s}
.testimonial:hover{background:var(--cream-2);border-color:var(--ink)}
.testimonial__quote{font-family:var(--f-display);font-size:1.15rem;line-height:1.45;letter-spacing:-.01em}
.testimonial__quote::before{content:"";display:block;width:32px;height:24px;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 24' fill='%23f9452d'><path d='M0 24V12C0 5.4 5.4 0 12 0V6C8.7 6 6 8.7 6 12H12V24H0ZM20 24V12C20 5.4 25.4 0 32 0V6C28.7 6 26 8.7 26 12H32V24H20Z'/></svg>") no-repeat center/contain;margin-bottom:1.25rem}
.testimonial__who{display:flex;align-items:center;gap:.85rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--line)}
.testimonial__avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg, var(--accent), var(--ink));display:grid;place-items:center;color:var(--cream);font-family:var(--f-display);font-weight:600;font-size:1rem}
.testimonial__who b{display:block;font-family:var(--f-display);font-weight:600;font-size:.95rem}
.testimonial__who span{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
@media (max-width:980px){.testimonials__grid{grid-template-columns:1fr}}

/* ---------- FRAMEWORK ---------- */
.framework{padding:6rem var(--pad);background:var(--cream);border-bottom:1px solid var(--line)}
.framework__head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem;gap:2rem;flex-wrap:wrap}
.framework h2{font-family:var(--f-display);font-size:clamp(2.2rem,4.5vw,3.6rem);font-weight:600;letter-spacing:-.025em;line-height:1;max-width:14ch}
.framework h2 em{font-style:italic;color:var(--accent)}
.framework__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}
.pillar{padding:2.5rem 2rem 2rem;background:var(--paper);border:1px solid var(--line);border-radius:18px;min-height:280px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;transition:background .3s,border-color .3s}
.pillar:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.pillar:hover .pillar__num,.pillar:hover .pillar__body{color:var(--muted-dark)}
.pillar__num{font-family:var(--f-mono);font-size:.78rem;color:var(--muted);letter-spacing:.14em;transition:color .3s}
.pillar__title{font-family:var(--f-display);font-size:clamp(1.6rem,2.4vw,2.1rem);font-weight:600;letter-spacing:-.025em;line-height:1.05;margin-top:1rem}
.pillar:nth-child(2n) .pillar__title em,.pillar:nth-child(1) .pillar__title em{font-style:italic;color:var(--accent)}
.pillar__body{margin-top:1.2rem;font-size:.98rem;line-height:1.55;color:var(--ink);max-width:36ch;transition:color .3s}
.pillar__icon{position:absolute;top:2rem;right:2rem;width:42px;height:42px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;color:var(--accent);transition:border-color .3s}
.pillar:hover .pillar__icon{border-color:var(--accent)}
@media (max-width:880px){.framework__grid{grid-template-columns:1fr}}

/* ---------- TEAM ---------- */
.team{padding:6rem var(--pad);background:var(--ink);color:var(--cream);border-bottom:1px solid var(--ink)}
.team__head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem;gap:2rem;flex-wrap:wrap}
.team h2{font-family:var(--f-display);font-size:clamp(2.2rem,4.5vw,3.6rem);font-weight:600;letter-spacing:-.025em;line-height:1;color:var(--cream)}
.team h2 em{font-style:italic;color:var(--accent)}
.team__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.member{background:var(--ink-2);border:1px solid var(--line-d);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;transition:transform .3s,border-color .3s}
.member:hover{transform:translateY(-4px);border-color:var(--accent)}
.member__viz{aspect-ratio:4/5;background:linear-gradient(135deg, var(--ink-3), var(--ink-2));position:relative;overflow:hidden}
.member__viz svg{position:absolute;inset:0;width:100%;height:100%}
.member__body{padding:1.5rem;display:flex;justify-content:space-between;align-items:flex-end;gap:1rem}
.member__num{font-family:var(--f-mono);font-size:.78rem;color:var(--muted-dark);letter-spacing:.14em;margin-bottom:.5rem;display:block}
.member__name{font-family:var(--f-display);font-size:1.4rem;font-weight:600;letter-spacing:-.02em;line-height:1.1}
.member__role{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-dark);margin-top:.35rem}
.member__socials{display:flex;gap:.4rem}
.member__socials a{width:34px;height:34px;border:1px solid var(--line-d);border-radius:50%;display:grid;place-items:center;color:var(--cream);transition:background .25s, color .25s}
.member__socials a:hover{background:var(--accent);color:var(--ink);border-color:var(--accent)}
@media (max-width:980px){.team__grid{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.team__grid{grid-template-columns:1fr}}

/* ---------- FAQ ---------- */
.faq{padding:6rem var(--pad);background:var(--paper);border-bottom:1px solid var(--line)}
.faq__head{display:grid;grid-template-columns:1fr 1fr;gap:3rem;margin-bottom:3rem;align-items:end}
.faq h2{font-family:var(--f-display);font-size:clamp(2.4rem,5vw,4rem);font-weight:600;letter-spacing:-.03em;line-height:.95}
.faq h2 em{font-style:italic;color:var(--accent)}
.faq__aside{justify-self:end;text-align:right;display:flex;flex-direction:column;gap:1rem;align-items:flex-end}
.faq__aside p{font-size:.95rem;color:var(--muted);max-width:24ch}
.faq__list{border-top:1px solid var(--line)}
.faq__item{border-bottom:1px solid var(--line)}
.faq__q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:2rem;padding:1.6rem 0;text-align:left;font-family:var(--f-display);font-size:clamp(1.05rem,1.6vw,1.35rem);font-weight:500;letter-spacing:-.01em;transition:padding .2s}
.faq__item:hover .faq__q{padding-left:1rem}
.faq__q .ico{flex:0 0 auto;width:38px;height:38px;border:1px solid var(--ink);border-radius:50%;display:grid;place-items:center;font-size:1.1rem;transition:background .25s, color .25s, transform .35s}
.faq__item.open .faq__q .ico{background:var(--accent);border-color:var(--accent);transform:rotate(45deg)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .4s ease, padding .4s ease;font-size:.98rem;line-height:1.6;color:var(--ink);opacity:.78}
.faq__item.open .faq__a{max-height:300px;padding-bottom:1.6rem;padding-right:4rem}
@media (max-width:880px){
  .faq__head{grid-template-columns:1fr}
  .faq__aside{justify-self:start;text-align:left;align-items:flex-start}
}

/* ---------- PRICING ---------- */
.pricing{padding:6rem var(--pad);background:var(--cream);border-bottom:1px solid var(--line)}
.pricing__head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:3rem}
.pricing h2{font-family:var(--f-display);font-size:clamp(2.4rem,5vw,4rem);font-weight:600;letter-spacing:-.03em;line-height:.95}
.pricing h2 em{font-style:italic;color:var(--accent)}
.pricing__grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.plan{padding:2.5rem 2rem;background:var(--paper);border:1px solid var(--line);border-radius:20px;display:flex;flex-direction:column;gap:1.5rem;position:relative;overflow:hidden}
.plan--dark{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.plan--dark .plan__sub,.plan--dark .plan__feat,.plan--dark .plan__price-sub{color:var(--muted-dark)}
.plan__badge{position:absolute;top:1.5rem;right:1.5rem;font-family:var(--f-mono);font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;padding:.35rem .7rem;background:var(--accent);color:var(--accent-ink);border-radius:99px}
.plan__name{font-family:var(--f-mono);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:500}
.plan__sub{font-family:var(--f-display);font-size:1.05rem;color:var(--muted);margin-top:.25rem}
.plan__price{display:flex;align-items:baseline;gap:.4rem;margin-top:.5rem}
.plan__price .currency{font-family:var(--f-display);font-size:1.4rem;font-weight:500;color:inherit;opacity:.7}
.plan__price .num{font-family:var(--f-display);font-size:clamp(3.5rem,6vw,5rem);font-weight:700;letter-spacing:-.04em;line-height:.9}
.plan__price .per{font-family:var(--f-mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted)}
.plan__price-sub{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.plan__cta{display:inline-flex;align-items:center;justify-content:space-between;padding:1rem 1.4rem;border-radius:99px;font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;background:var(--ink);color:var(--cream);transition:background .25s, color .25s}
.plan--dark .plan__cta{background:var(--accent);color:var(--accent-ink)}
.plan__cta:hover{background:var(--accent);color:var(--accent-ink)}
.plan--dark .plan__cta:hover{background:var(--cream);color:var(--ink)}
.plan__feats{list-style:none;display:flex;flex-direction:column;gap:.7rem;padding-top:1rem;border-top:1px solid var(--line)}
.plan--dark .plan__feats{border-top-color:var(--line-d)}
.plan__feat{display:flex;align-items:flex-start;gap:.65rem;font-size:.95rem;line-height:1.45}
.plan__feat::before{content:"+";color:var(--accent);font-family:var(--f-mono);font-weight:600;flex:0 0 auto;width:1rem;text-align:center}
@media (max-width:880px){.pricing__grid{grid-template-columns:1fr}}

/* ---------- REACH ---------- */
.reach{padding:6rem var(--pad);background:var(--paper);border-bottom:1px solid var(--line);overflow:hidden}
.reach__head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:3rem}
.reach h2{font-family:var(--f-display);font-size:clamp(2.4rem,5vw,4rem);font-weight:600;letter-spacing:-.03em;line-height:.95}
.reach h2 em{font-style:italic;color:var(--accent)}
.reach__map{position:relative;aspect-ratio:2.2/1;background:var(--cream-2);border-radius:20px;border:1px solid var(--line);overflow:hidden}
.reach__map svg{width:100%;height:100%;display:block;opacity:.5}
.pin{position:absolute;transform:translate(-50%,-100%);display:flex;flex-direction:column;align-items:center;gap:.3rem}
.pin__dot{width:14px;height:14px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(249,69,45,.2)}
.pin__lbl{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500;background:var(--ink);color:var(--cream);padding:.25rem .6rem;border-radius:99px;white-space:nowrap}
.pin--anchor .pin__dot{background:var(--ink);box-shadow:0 0 0 4px rgba(0,0,0,.15), 0 0 0 8px rgba(0,0,0,.08)}
.pin--anchor .pin__lbl{background:var(--accent);color:var(--accent-ink)}

/* ---------- CONTACT ---------- */
.contact{padding:6rem var(--pad);background:var(--ink);color:var(--cream);border-bottom:1px solid var(--ink)}
.contact__grid{display:grid;grid-template-columns:1fr 1.2fr;gap:4rem;align-items:start}
.contact__lede h2{font-family:var(--f-display);font-size:clamp(2.4rem,5vw,4.5rem);font-weight:600;letter-spacing:-.03em;line-height:.95;color:var(--cream)}
.contact__lede h2 em{font-style:italic;color:var(--accent)}
.contact__lede p{margin-top:1.5rem;font-family:var(--f-display);font-size:1.15rem;line-height:1.5;color:var(--muted-dark);max-width:38ch}
.contact__info{margin-top:2.5rem;display:flex;flex-direction:column;gap:1.25rem}
.contact__info .row{display:flex;flex-direction:column;gap:.2rem;padding-top:1.25rem;border-top:1px solid var(--line-d)}
.contact__info .row .label--light{color:var(--muted-dark)}
.contact__info .row .val{font-family:var(--f-display);font-size:1.1rem;color:var(--cream)}
.contact__info .row a:hover{color:var(--accent)}

.form{display:flex;flex-direction:column;gap:1rem}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{display:flex;flex-direction:column;gap:.4rem;padding-top:1.25rem;border-top:1px solid var(--line-d)}
.field label{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-dark)}
.field input,.field textarea,.field select{
  background:transparent;border:0;border-bottom:1px solid var(--line-d);padding:.6rem 0;color:var(--cream);
  font-family:var(--f-display);font-size:1.15rem;letter-spacing:-.01em;outline:none;transition:border-color .25s
}
.field input::placeholder,.field textarea::placeholder{color:var(--muted)}
.field input:focus,.field textarea:focus,.field select:focus{border-bottom-color:var(--accent)}
.field textarea{resize:vertical;min-height:80px}
.form__submit{margin-top:1rem;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1.3rem 1.6rem;background:var(--accent);color:var(--accent-ink);border-radius:99px;font-family:var(--f-mono);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500;transition:background .25s, color .25s, transform .25s}
.form__submit:hover{background:var(--cream);transform:translateY(-2px)}
@media (max-width:880px){
  .contact__grid{grid-template-columns:1fr}
  .form__row{grid-template-columns:1fr}
}

/* ---------- FOOTER ---------- */
.foot{background:var(--cream);padding:5rem var(--pad) 2rem}
.foot__top{font-family:var(--f-display);font-weight:600;font-size:clamp(3.5rem,11vw,11rem);line-height:.85;letter-spacing:-.05em;color:var(--ink);margin-bottom:3rem;border-bottom:1px solid var(--line);padding-bottom:2rem}
.foot__top .accent{color:var(--accent);font-style:italic}
.foot__top .reg{font-size:.3em;vertical-align:super;font-weight:500}
.foot__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem;margin-bottom:3rem}
.foot__col h4{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem;font-weight:500}
.foot__col a,.foot__col p{display:block;font-family:var(--f-display);font-size:1.05rem;color:var(--ink);margin-bottom:.5rem;transition:color .2s}
.foot__col a:hover{color:var(--accent)}
.foot__news input{width:100%;background:transparent;border:0;border-bottom:1px solid var(--line);padding:.8rem 0;font-family:var(--f-display);font-size:1.1rem;outline:none}
.foot__news input:focus{border-bottom-color:var(--accent)}
.foot__news button{margin-top:1rem;display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1.1rem;background:var(--ink);color:var(--cream);border-radius:99px;font-family:var(--f-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase}
.foot__bottom{display:flex;justify-content:space-between;align-items:center;padding-top:2rem;border-top:1px solid var(--line);font-family:var(--f-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);gap:2rem;flex-wrap:wrap}
.foot__bottom a:hover{color:var(--ink)}
@media (max-width:880px){.foot__grid{grid-template-columns:1fr 1fr;gap:2rem 1rem}}
@media (max-width:540px){.foot__grid{grid-template-columns:1fr}}

/* ---------- SCROLL REVEAL ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-stagger > *{opacity:0;transform:translateY(20px);transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal-stagger.in > *{opacity:1;transform:translateY(0)}
.reveal-stagger.in > *:nth-child(1){transition-delay:.05s}
.reveal-stagger.in > *:nth-child(2){transition-delay:.15s}
.reveal-stagger.in > *:nth-child(3){transition-delay:.25s}
.reveal-stagger.in > *:nth-child(4){transition-delay:.35s}
.reveal-stagger.in > *:nth-child(5){transition-delay:.45s}

/* ---------- SCROLL PROGRESS BAR ---------- */
.scroll-progress{
  position:fixed;top:0;left:0;height:2px;width:0%;
  background:var(--accent);z-index:101;
  transition:width .12s linear;
  box-shadow:0 0 12px rgba(249,69,45,.6);
}

/* ---------- HORIZONTAL SCROLL WORK SECTION ---------- */
.work-h{
  position:relative;
  background:var(--paper);
  border-bottom:1px solid var(--line);
  /* outer track height drives how far the cards translate */
}
.work-h__pin{
  position:sticky;top:0;
  height:100vh;
  display:flex;flex-direction:column;
  overflow:hidden;
}
.work-h__head{
  padding:2.5rem var(--pad) 1.5rem;
  display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;
  flex:0 0 auto;
}
.work-h__head h2{font-family:var(--f-display);font-size:clamp(2rem,4.5vw,3.8rem);font-weight:600;line-height:.95;letter-spacing:-.03em}
.work-h__head h2 em{font-style:italic;color:var(--accent)}
.work-h__progress{
  flex:0 0 auto;
  display:flex;align-items:center;gap:1rem;
  padding:0 var(--pad) 1rem;
  font-family:var(--f-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);
}
.work-h__progress .bar{flex:1;height:1px;background:var(--line);position:relative;overflow:hidden}
.work-h__progress .bar::before{content:"";position:absolute;top:0;left:0;bottom:0;width:0%;background:var(--ink);transition:width .15s linear}
.work-h__viewport{
  flex:1;
  display:flex;align-items:center;
  overflow:hidden;position:relative;
}
.work-h__track{
  display:flex;gap:1.25rem;
  padding:0 var(--pad);
  will-change:transform;
  transition:transform .05s linear;
}
.work-h__card{
  flex:0 0 auto;
  width:min(560px, 72vw);
  height:min(560px, 70vh);
  position:relative;
  border-radius:18px;overflow:hidden;
  background:var(--ink-2);color:var(--cream);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:2rem;
  transition:transform .4s ease;
}
.work-h__card:hover{transform:translateY(-6px)}
.work-h__card .viz{position:absolute;inset:0;z-index:0}
.work-h__card .viz svg{width:100%;height:100%;display:block}
.work-h__card .meta{position:relative;z-index:2}
.work-h__card .meta .tags{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1rem}
.work-h__card .meta .tag{font-family:var(--f-mono);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;padding:.35rem .7rem;border:1px solid rgba(255,255,255,.3);border-radius:99px;background:rgba(0,0,0,.4);backdrop-filter:blur(4px)}
.work-h__card .meta h3{font-family:var(--f-display);font-size:clamp(1.6rem,2.2vw,2.1rem);font-weight:600;letter-spacing:-.02em;line-height:1.05}
.work-h__card .meta p{font-size:.95rem;color:var(--muted-dark);max-width:36ch;margin-top:.5rem;line-height:1.5}
.work-h__card .arr{position:absolute;top:1.5rem;right:1.5rem;z-index:2;width:44px;height:44px;border-radius:50%;background:var(--cream);color:var(--ink);display:grid;place-items:center;font-size:1.2rem;transform:rotate(-45deg);transition:transform .3s, background .3s}
.work-h__card:hover .arr{background:var(--accent);transform:rotate(0deg)}
.work-h__card .index{position:absolute;top:1.5rem;left:1.5rem;z-index:2;font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;color:var(--muted-dark)}

/* hint */
.work-h__hint{
  position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);
  font-family:var(--f-mono);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
  z-index:3;display:flex;align-items:center;gap:.6rem;
}
.work-h__hint .line{width:30px;height:1px;background:var(--muted);position:relative;overflow:hidden}
.work-h__hint .line::after{content:"";position:absolute;inset:0;width:50%;background:var(--accent);animation:slide 1.8s ease-in-out infinite}
@keyframes slide{0%{transform:translateX(-100%)}100%{transform:translateX(200%)}}

@media (max-width:880px){
  .work-h__pin{height:auto;position:relative}
  .work-h__viewport{overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
  .work-h__viewport::-webkit-scrollbar{display:none}
  .work-h__track{transform:none !important;padding:0 var(--pad) 2rem}
  .work-h__card{scroll-snap-align:start;width:85vw;height:480px}
  .work-h__progress{display:none}
}

/* ---------- PARALLAX HELPERS ---------- */
.parallax{will-change:transform}
.parallax-slow{will-change:transform}
.parallax-deep{will-change:transform}

/* parallax for hero type */
.hero__type h1{transition:transform .05s linear}

/* parallax-friendly banner viz */
.banner__viz{will-change:transform}

/* ---------- WORD-BY-WORD REVEAL ---------- */
.split-words{display:inline}
.split-words .w{
  display:inline-block;
  opacity:0;
  transform:translateY(40%) rotate(2deg);
  transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1);
}
.split-words.in .w{opacity:1;transform:translateY(0) rotate(0)}
.split-words .w:nth-child(1){transition-delay:.04s}
.split-words .w:nth-child(2){transition-delay:.10s}
.split-words .w:nth-child(3){transition-delay:.16s}
.split-words .w:nth-child(4){transition-delay:.22s}
.split-words .w:nth-child(5){transition-delay:.28s}
.split-words .w:nth-child(6){transition-delay:.34s}
.split-words .w:nth-child(7){transition-delay:.40s}
.split-words .w:nth-child(8){transition-delay:.46s}
.split-words .w:nth-child(9){transition-delay:.52s}
.split-words .w:nth-child(10){transition-delay:.58s}

/* ---------- STICKY MANIFESTO (pin while scrolling through) ---------- */
.manifesto-wrap{
  position:relative;
  /* outer height controls how long it stays pinned */
}
.manifesto.is-sticky{
  position:sticky;top:0;
  min-height:100vh;
  display:flex;align-items:center;
  padding-top:7rem;padding-bottom:7rem;
}
.manifesto__big .word{
  display:inline-block;
  transition:color .4s ease;
}

/* ---------- SECTION INDICATOR (right rail) ---------- */
.section-dots{
  position:fixed;right:1.2rem;top:50%;transform:translateY(-50%);
  z-index:90;
  display:flex;flex-direction:column;gap:.7rem;
  padding:.9rem .55rem;
  background:rgba(255,255,255,.6);
  backdrop-filter:blur(8px);
  border:1px solid var(--line);
  border-radius:99px;
}
.section-dots a{
  width:7px;height:7px;border-radius:50%;
  background:var(--ink);opacity:.25;
  transition:opacity .3s, transform .3s;
  position:relative;
}
.section-dots a:hover{opacity:.7;transform:scale(1.4)}
.section-dots a.active{opacity:1;background:var(--accent);transform:scale(1.4)}
.section-dots a span{
  position:absolute;right:calc(100% + .8rem);top:50%;transform:translateY(-50%);
  font-family:var(--f-mono);font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);
  white-space:nowrap;opacity:0;pointer-events:none;
  background:var(--ink);color:var(--cream);padding:.3rem .55rem;border-radius:99px;
  transition:opacity .25s, transform .25s;
}
.section-dots a:hover span{opacity:1;transform:translateY(-50%) translateX(-4px)}
@media (max-width:880px){.section-dots{display:none}}

/* ---------- VELOCITY MARQUEE ---------- */
.ticker__track{transition:animation-duration .4s ease}

/* ---------- ACCESSIBILITY ---------- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
  .ticker__track{animation:none}
}
/* ========== MULTI-PAGE ADDITIONS ========== */

/* nav active state for multi-page */
.nav__menu a.is-active{background:var(--ink);color:var(--cream)}

/* page-load fade */
body{opacity:0;animation:pageIn .6s ease forwards}
@keyframes pageIn{to{opacity:1}}

/* generic page hero (used on /studio, /work, /journal, /contact) */
.page-hero{
  padding:9rem var(--pad) 4rem;
  background:var(--cream);
  border-bottom:1px solid var(--line);
  position:relative;
}
.page-hero__grid{display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:end}
.page-hero__crumb{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:1.5rem;display:block}
.page-hero__crumb .ink{color:var(--ink)}
.page-hero h1{
  font-family:var(--f-display);
  font-weight:600;line-height:.92;letter-spacing:-.04em;
  font-size:clamp(3rem,9vw,9rem);
  color:var(--ink);
}
.page-hero h1 em{font-style:italic;color:var(--accent)}
.page-hero__lede{max-width:48ch;margin-top:2rem;font-family:var(--f-display);font-size:clamp(1.1rem,1.7vw,1.5rem);line-height:1.45;color:var(--ink)}
.page-hero__meta{display:flex;gap:2rem;font-family:var(--f-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);justify-self:end;text-align:right}
.page-hero__meta b{display:block;color:var(--ink);font-weight:500;margin-bottom:.2rem}
@media (max-width:880px){.page-hero__grid{grid-template-columns:1fr}.page-hero__meta{justify-self:start;text-align:left}}
/* studio hero: founder/studio image slot balancing the headline */
.page-hero__aside{justify-self:end;display:flex;flex-direction:column;align-items:flex-end;gap:2rem}
.page-hero__img{width:clamp(220px,24vw,320px);aspect-ratio:4/5;border-radius:16px;overflow:hidden}
@media (max-width:880px){.page-hero__aside{align-items:flex-start;width:100%}.page-hero__img{width:min(280px,62vw)}}

/* CTA strip (used as soft handoff at bottom of subpages) */
.cta-strip{
  background:var(--ink);color:var(--cream);
  padding:5rem var(--pad);
  border-bottom:1px solid var(--ink);
  position:relative;overflow:hidden;
}
.cta-strip::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 80% 0%, rgba(249,69,45,.18) 0%, transparent 50%)}
.cta-strip__inner{position:relative;max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:2fr 1fr;gap:3rem;align-items:end}
.cta-strip h2{font-family:var(--f-display);font-size:clamp(2.4rem,5vw,4.5rem);font-weight:600;line-height:.95;letter-spacing:-.03em;max-width:18ch}
.cta-strip h2 em{font-style:italic;color:var(--accent)}
.cta-strip__lede{font-family:var(--f-display);font-size:1.15rem;line-height:1.5;color:var(--muted-dark);max-width:36ch;margin-top:1.5rem}
.cta-strip__cta-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:1rem;justify-self:end}
.cta-strip__cta{display:inline-flex;align-items:center;gap:.6rem;background:var(--accent);color:var(--accent-ink);padding:1.2rem 1.6rem;border-radius:99px;font-family:var(--f-mono);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500;transition:background .25s, transform .25s}
.cta-strip__cta:hover{background:var(--cream);transform:translateY(-2px)}
.cta-strip__note{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-dark)}
@media (max-width:880px){.cta-strip__inner{grid-template-columns:1fr}.cta-strip__cta-wrap{align-items:flex-start;justify-self:start}}

/* WORK INDEX grid (vertical) */
.work-index{padding:5rem var(--pad);background:var(--paper);border-bottom:1px solid var(--line)}
.work-index__head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:3rem}
.work-index__filters{display:flex;gap:.4rem;flex-wrap:wrap}
.work-index__filters button{padding:.55rem 1rem;border:1px solid var(--line);border-radius:99px;font-family:var(--f-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;background:transparent;cursor:pointer;transition:all .2s}
.work-index__filters button.active,.work-index__filters button:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.work-index__list{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.work-row{
  display:grid;grid-template-columns:80px 2fr 2fr 1fr auto;gap:2rem;align-items:center;
  padding:1.6rem 0;border-bottom:1px solid var(--line);
  cursor:pointer;transition:padding .25s, background .25s;
  position:relative;
}
.work-row:hover{padding-left:1rem;background:linear-gradient(90deg, var(--cream-2) 0%, transparent 100%)}
.work-row__num{font-family:var(--f-mono);font-size:.78rem;color:var(--accent);letter-spacing:.14em}
.work-row__name{font-family:var(--f-display);font-size:clamp(1.4rem,2.5vw,2rem);font-weight:600;letter-spacing:-.02em;line-height:1.05}
.work-row__desc{font-size:.95rem;line-height:1.5;color:var(--muted);max-width:38ch}
.work-row__tags{display:flex;gap:.4rem;flex-wrap:wrap}
.work-row__tag{font-family:var(--f-mono);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;padding:.3rem .65rem;border:1px solid var(--line);border-radius:99px;color:var(--muted)}
.work-row__arr{width:42px;height:42px;border:1px solid var(--ink);border-radius:50%;display:grid;place-items:center;transition:background .25s, color .25s, transform .25s}
.work-row:hover .work-row__arr{background:var(--accent);border-color:var(--accent);transform:rotate(45deg)}
@media (max-width:880px){
  .work-row{grid-template-columns:1fr;gap:.5rem}
  .work-row__arr{display:none}
}

/* CASE STUDY page */
.case-meta{
  background:var(--paper);padding:3rem var(--pad);border-bottom:1px solid var(--line);
}
.case-meta__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;max-width:var(--max);margin:0 auto}
.case-meta__item{display:flex;flex-direction:column;gap:.4rem}
.case-meta__item .label{margin-bottom:.2rem}
.case-meta__item .val{font-family:var(--f-display);font-size:1.15rem;color:var(--ink);font-weight:500}
@media (max-width:880px){.case-meta__grid{grid-template-columns:repeat(2,1fr)}}

.case-body{padding:5rem var(--pad);background:var(--cream);border-bottom:1px solid var(--line)}
.case-body__grid{display:grid;grid-template-columns:1fr 2fr;gap:4rem;max-width:var(--max);margin:0 auto}
.case-body__nav{position:sticky;top:7rem;align-self:start;display:flex;flex-direction:column;gap:.6rem}
.case-body__nav a{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding:.6rem 0;border-top:1px solid var(--line);transition:color .2s, padding .2s}
.case-body__nav a:hover{color:var(--accent);padding-left:.5rem}
.case-body__nav a.is-active{color:var(--ink);padding-left:.5rem}
.case-body__sections{display:flex;flex-direction:column;gap:4rem}
.case-section h2{font-family:var(--f-display);font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:600;letter-spacing:-.03em;line-height:1;margin-bottom:1.5rem}
.case-section h2 em{font-style:italic;color:var(--accent)}
.case-section p{font-size:1.05rem;line-height:1.65;color:var(--ink);margin-bottom:1rem;max-width:60ch}
.case-section ul{list-style:none;display:flex;flex-direction:column;gap:.6rem;margin-top:1rem;max-width:60ch}
.case-section ul li{padding-left:1.4rem;position:relative;font-size:.98rem;line-height:1.55}
.case-section ul li::before{content:"→";position:absolute;left:0;color:var(--accent);font-family:var(--f-mono)}
.case-section__viz{margin-top:2rem;aspect-ratio:16/9;border-radius:14px;background:var(--ink);position:relative;overflow:hidden}
.case-section__viz svg{width:100%;height:100%}
.case-quote{padding:4rem var(--pad);background:var(--ink);color:var(--cream);border-bottom:1px solid var(--ink);text-align:center}
.case-quote blockquote{font-family:var(--f-display);font-size:clamp(1.4rem,2.5vw,2rem);line-height:1.4;letter-spacing:-.015em;max-width:30ch;margin:0 auto 2rem}
.case-quote blockquote em{font-style:italic;color:var(--accent)}
.case-quote cite{font-family:var(--f-mono);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-dark);font-style:normal;display:block}

.case-outcome{padding:5rem var(--pad);background:var(--paper);border-bottom:1px solid var(--line)}
.case-outcome__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:var(--max);margin:0 auto}
.outcome-stat{padding:2rem;background:var(--cream);border:1px solid var(--line);border-radius:16px;display:flex;flex-direction:column;gap:.5rem;min-height:200px;justify-content:flex-end}
.outcome-stat .big{font-family:var(--f-display);font-size:clamp(2.4rem,5vw,4rem);font-weight:700;letter-spacing:-.04em;line-height:.9}
.outcome-stat .big .unit{font-size:.4em;color:var(--accent-lime);margin-left:.2em}
.outcome-stat .lbl{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
@media (max-width:880px){.case-outcome__grid{grid-template-columns:1fr}.case-body__grid{grid-template-columns:1fr}.case-body__nav{position:relative;top:0;flex-direction:row;flex-wrap:wrap}}

.case-next{padding:4rem var(--pad);background:var(--cream);border-bottom:1px solid var(--line)}
.case-next a{display:grid;grid-template-columns:1fr auto;align-items:center;gap:2rem;max-width:var(--max);margin:0 auto;padding:2rem 0;border-top:1px solid var(--line);transition:padding .25s}
.case-next a:hover{padding-left:1rem}
.case-next .lbl{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem;display:block}
.case-next h3{font-family:var(--f-display);font-size:clamp(2rem,4vw,3rem);font-weight:600;letter-spacing:-.03em;line-height:1}
.case-next .arr{width:54px;height:54px;border-radius:50%;background:var(--ink);color:var(--cream);display:grid;place-items:center;font-size:1.4rem;transform:rotate(-45deg);transition:transform .3s,background .3s}
.case-next a:hover .arr{background:var(--accent);transform:rotate(0)}

/* JOURNAL */
.journal-list{padding:5rem var(--pad);background:var(--paper);border-bottom:1px solid var(--line)}
.journal-list__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:var(--max);margin:0 auto}
.post{background:var(--cream);border:1px solid var(--line);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;transition:transform .3s,border-color .3s}
.post:hover{transform:translateY(-6px);border-color:var(--ink)}
.post__cover{aspect-ratio:4/3;background:linear-gradient(135deg, var(--accent), var(--ink));position:relative;overflow:hidden}
.post__cover svg{position:absolute;inset:0;width:100%;height:100%;opacity:.7}
.post__body{padding:1.5rem;display:flex;flex-direction:column;gap:.8rem;flex:1}
.post__meta{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.post__title{font-family:var(--f-display);font-size:1.35rem;font-weight:600;letter-spacing:-.02em;line-height:1.15}
.post__excerpt{font-size:.95rem;line-height:1.5;color:var(--muted);margin-top:auto}
@media (max-width:880px){.journal-list__grid{grid-template-columns:1fr}}

.coming-soon{padding:6rem var(--pad);text-align:center;background:var(--cream);border-bottom:1px solid var(--line)}
.coming-soon h2{font-family:var(--f-display);font-size:clamp(2.5rem,6vw,5rem);font-weight:600;letter-spacing:-.04em;line-height:1;margin-bottom:1.5rem}
.coming-soon h2 em{font-style:italic;color:var(--accent)}
.coming-soon p{max-width:48ch;margin:0 auto 2.5rem;font-family:var(--f-display);font-size:1.15rem;line-height:1.5;color:var(--muted)}
.coming-soon__form{display:flex;max-width:480px;margin:0 auto;gap:.6rem}
.coming-soon__form input{flex:1;background:transparent;border:1px solid var(--line);border-radius:99px;padding:1rem 1.4rem;font-family:var(--f-display);font-size:1rem;outline:none;transition:border-color .2s}
.coming-soon__form input:focus{border-color:var(--accent)}
.coming-soon__form button{padding:1rem 1.4rem;background:var(--ink);color:var(--cream);border-radius:99px;font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:background .25s}
.coming-soon__form button:hover{background:var(--accent);color:var(--accent-ink)}

/* CONTACT page – next steps */
.next-steps{padding:5rem var(--pad);background:var(--paper);border-bottom:1px solid var(--line)}
.next-steps__head{margin-bottom:3rem}
.next-steps h2{font-family:var(--f-display);font-size:clamp(2rem,4vw,3.4rem);font-weight:600;letter-spacing:-.025em;line-height:1}
.next-steps h2 em{font-style:italic;color:var(--accent)}
.next-steps__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:var(--max);margin:0 auto}
.step-card{padding:2rem;background:var(--cream);border:1px solid var(--line);border-radius:16px;min-height:240px;display:flex;flex-direction:column;justify-content:space-between}
.step-card__num{font-family:var(--f-display);font-size:3rem;font-weight:700;letter-spacing:-.05em;color:var(--accent);line-height:.9}
.step-card h3{font-family:var(--f-display);font-size:1.35rem;font-weight:600;letter-spacing:-.02em;line-height:1.15;margin-top:1.5rem}
.step-card p{font-size:.95rem;line-height:1.5;color:var(--muted);margin-top:.6rem}
@media (max-width:880px){.next-steps__grid{grid-template-columns:1fr}}

/* hide section dots on subpages by default - opt in per page if needed */
.section-dots{display:none}

/* ---------- IMAGE PLACEHOLDER (hybrid slots) ----------
   Styled panel for real photography to be dropped in later.
   To use a real image: replace the .img-ph element with
   <img src="..." alt="..." style="width:100%;height:100%;object-fit:cover"> */
.img-ph{
  position:relative;width:100%;height:100%;
  display:flex;flex-direction:column;justify-content:space-between;
  background:
    repeating-linear-gradient(135deg, rgba(0,0,0,.025) 0 12px, transparent 12px 24px),
    var(--paper);
  border:1px dashed var(--line);
  overflow:hidden;
}
.img-ph::after{
  content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:54px;height:54px;border-radius:50%;
  border:1px dashed rgba(0,0,0,.25);
  background:
    radial-gradient(circle at center, var(--accent-lime) 0 5px, transparent 6px);
  opacity:.5;
}
.img-ph__tag{
  position:relative;z-index:1;
  align-self:flex-start;margin:3.25rem 1rem 1rem;
  font-family:var(--f-mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);background:var(--cream);
  padding:.35rem .6rem;border-radius:99px;border:1px solid var(--line);
}
.img-ph__ratio{
  position:relative;z-index:1;
  align-self:flex-end;margin:1rem;
  font-family:var(--f-mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted-dark);
}
/* dark variant for use inside dark cards */
.img-ph--dark{
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.03) 0 12px, transparent 12px 24px),
    var(--ink-2);
  border-color:var(--line-d);
}
.img-ph--dark .img-ph__tag{color:var(--muted-dark);background:var(--ink-3);border-color:var(--line-d)}

/* ---------- REAL IMAGES (downloaded from Pexels) ---------- */
/* Service cards: a faded photographic band at the top; card content sits above it. */
.service > *:not(.service__media){position:relative;z-index:1}
.service__media{
  position:absolute;inset:0 0 auto 0;height:62%;z-index:0;pointer-events:none;opacity:.5;
  -webkit-mask-image:linear-gradient(to bottom,#000 28%,transparent);
  mask-image:linear-gradient(to bottom,#000 28%,transparent);
}
.service__media img{width:100%;height:100%;object-fit:cover;display:block}
/* Work showcase cards: photo fill behind the meta, with a shade for legibility. */
.work-h__card .viz img{width:100%;height:100%;object-fit:cover;display:block}
.work-h__card .viz .viz__shade{position:absolute;inset:0;background:linear-gradient(to top,rgba(14,14,16,.93) 14%,rgba(14,14,16,.55) 46%,rgba(14,14,16,.34) 100%)}
/* keep the small index label legible over photographic cards */
.work-h__card:has(.viz img) .index{text-shadow:0 1px 6px rgba(0,0,0,.65)}
/* Journal post covers */
.post__cover img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
