/* ============================================================
   Agentum — site-v5  ·  shared design system
   Lighter · premium · bold · a LIBRARY of distinct sections
   See DESIGN-SPEC-v5.md. Single source — no per-page drift.
   ============================================================ */

/* ---------- fonts (self-hosted) ---------- */
@font-face{font-family:"Inter";src:url("../fonts/Inter-Variable.ttf") format("truetype-variations");font-weight:100 900;font-display:swap;font-style:normal}
@font-face{font-family:"Courier Prime";src:url("../fonts/CourierPrime-Regular.ttf") format("truetype");font-weight:400;font-display:swap}
@font-face{font-family:"Courier Prime";src:url("../fonts/CourierPrime-Bold.ttf") format("truetype");font-weight:700;font-display:swap}

/* ---------- tokens ---------- */
:root{
  --ink:#0E0E10; --ink-2:#16161A; --ink-3:#1E1E24;
  --paper:#F6F5F2; --paper-2:#EFEEE9; --white:#FFFFFF;
  --pink:#FF2D9B; --pink-deep:#B81576; --pink-soft:rgba(255,45,155,.10);
  --on-ink:#F6F5F2; --on-ink-dim:#9A9AA2;
  --on-paper:#121215; --on-paper-dim:#62626B;
  --rule:#E2E0DA; --rule-2:#D6D4CD; --rule-dark:rgba(255,255,255,.14);
  --sans:"Inter","Helvetica Neue",Arial,sans-serif;
  --mono:"Courier Prime","Courier New",monospace;
  --ease-expo:cubic-bezier(0.16,1,0.3,1);
  --ease-out:cubic-bezier(0.22,0.61,0.36,1);
  /* type scale — bolder, premium */
  --fs-display:clamp(3rem,8vw,6rem);     /* statement display */
  --fs-hero:clamp(2.6rem,6.4vw,5rem);
  --fs-h2:clamp(1.9rem,4vw,3.4rem);
  --fs-h3:clamp(1.2rem,1.9vw,1.6rem);
  --fs-lead:clamp(1.1rem,1.5vw,1.45rem);
  --fs-body:1.0625rem;
  --fs-label:0.72rem;
  --maxw:1320px; --maxw-wide:1640px; --maxw-text:760px;
  --pad-x:clamp(20px,5vw,80px);
  --section-y:clamp(64px,9vh,128px);
  --hdr-h:74px;
  --shadow-soft:0 1px 2px rgba(16,16,20,.04),0 12px 40px -16px rgba(16,16,20,.16);
  --shadow-lift:0 2px 4px rgba(16,16,20,.06),0 30px 60px -22px rgba(16,16,20,.28);
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--sans);font-size:var(--fs-body);line-height:1.6;color:var(--on-paper);background:var(--paper);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img,video,svg{display:block;max-width:100%}
img,video{height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
ul,ol{list-style:none}
::selection{background:var(--pink);color:#fff}

/* ---------- film grain ---------- */
.grain{position:fixed;inset:0;z-index:60;pointer-events:none;mix-blend-mode:soft-light;opacity:.05;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3' stitchTiles='stitch'/><feColorMatrix type='saturate' values='0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  background-size:200px 200px}

/* ---------- layout primitives ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad-x)}
.wrap-wide{max-width:var(--maxw-wide);margin-inline:auto;padding-inline:var(--pad-x)}
.wrap-full{max-width:none;margin-inline:0;padding-inline:var(--pad-x)}
.bleed{width:100%;position:relative;overflow:hidden}
.section{padding-block:var(--section-y);position:relative}
.section-sm{padding-block:clamp(48px,7vh,96px)}
.grid12{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(16px,2.4vw,40px)}
.measure{max-width:var(--maxw-text)}
.s-ink{background:var(--ink);color:var(--on-ink)}
.s-ink-2{background:var(--ink-2);color:var(--on-ink)}
.s-paper{background:var(--paper);color:var(--on-paper)}
.s-paper-2{background:var(--paper-2);color:var(--on-paper)}
.s-pink{background:var(--pink);color:#0E0E10}

/* ---------- typography ---------- */
.eyebrow{font-family:var(--mono);font-size:var(--fs-label);text-transform:uppercase;letter-spacing:.14em;color:var(--pink-deep);display:inline-flex;align-items:center;gap:.6em}
.eyebrow::before{content:"";width:18px;height:1px;background:currentColor;opacity:.8}
.s-ink .eyebrow,.s-ink-2 .eyebrow{color:var(--pink)}
.s-pink .eyebrow{color:#0E0E10}
h1,h2,h3{font-weight:800;letter-spacing:-.025em;line-height:1.02}
.h-hero{font-size:var(--fs-hero);line-height:1.0}
.h-display{font-size:var(--fs-display);line-height:.98;letter-spacing:-.035em;font-weight:850}
.h2{font-size:var(--fs-h2)}
.h3{font-size:var(--fs-h3);font-weight:700;letter-spacing:-.015em;line-height:1.12}
.lead{font-size:var(--fs-lead);line-height:1.45;color:var(--on-paper-dim);font-weight:400}
.s-ink .lead,.s-ink-2 .lead{color:var(--on-ink-dim)}
.dim{color:var(--on-paper-dim)} .s-ink .dim,.s-ink-2 .dim{color:var(--on-ink-dim)}
.mono{font-family:var(--mono);font-size:var(--fs-label);text-transform:uppercase;letter-spacing:.12em}
.pink{color:var(--pink-deep)} .s-ink .pink,.s-ink-2 .pink,.s-pink .pink{color:var(--pink)}
em.key{font-style:normal;color:var(--pink-deep);font-weight:650}
.s-ink em.key,.s-ink-2 em.key{color:var(--pink);font-weight:inherit}

/* line / word reveal masks */
.lines,.words{}
.line-mask,.word-mask{display:block;overflow:hidden}
.word-mask{display:inline-block;vertical-align:top}
.line-inner,.word-inner{display:block;will-change:transform}
.word-inner{display:inline-block;padding-right:.18em}

/* ---------- buttons (+ corner-bracket detail) ---------- */
.btn{position:relative;display:inline-flex;align-items:center;gap:.6em;font-family:var(--mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;padding:1em 1.6em;border:1px solid currentColor;border-radius:0;transition:background-color .35s var(--ease-out),color .35s var(--ease-out),transform .25s var(--ease-out);will-change:transform}
.btn .arrow{transition:transform .35s var(--ease-out)}
.btn:hover .arrow{transform:translateX(5px)}
.btn-solid{background:var(--pink);border-color:var(--pink);color:#0E0E10}
.btn-solid:hover{background:var(--pink-deep);border-color:var(--pink-deep);color:#fff}
.btn-ink{background:var(--ink);border-color:var(--ink);color:var(--on-ink)}
.btn-ink:hover{background:#000}
.btn-ghost{background:transparent;color:inherit}
.btn-ghost:hover{background:currentColor}
.s-ink .btn-ghost:hover,.s-ink-2 .btn-ghost:hover{color:var(--ink)} .s-paper .btn-ghost:hover{color:var(--paper)}
.s-pink .btn-solid{background:var(--ink);border-color:var(--ink);color:var(--on-ink)}
.s-pink .btn-solid:hover{background:#000;color:#fff}
.btn:focus-visible,a:focus-visible{outline:2px solid var(--pink);outline-offset:3px}
.s-paper a:focus-visible{outline-color:var(--pink-deep)}
/* corner brackets that appear on hover of bracket buttons / nav */
.bkt{position:relative}
.bkt::before,.bkt::after{content:"";position:absolute;width:9px;height:9px;border:1.5px solid var(--pink);opacity:0;transition:opacity .3s,transform .3s;pointer-events:none}
.bkt::before{top:-4px;left:-4px;border-right:0;border-bottom:0;transform:translate(4px,4px)}
.bkt::after{bottom:-4px;right:-4px;border-left:0;border-top:0;transform:translate(-4px,-4px)}
.bkt:hover::before,.bkt:hover::after,.bkt.is-active::before,.bkt.is-active::after{opacity:1;transform:translate(0,0)}

/* ---------- corner brackets (section/figure motif) ---------- */
.bracket-box{position:relative}
.bracket-box>.bk{position:absolute;width:22px;height:22px;color:var(--pink);pointer-events:none}
.bk svg{width:100%;height:100%;overflow:visible}
.bk path{fill:none;stroke:currentColor;stroke-width:2}
.bk-tl{top:-1px;left:-1px}.bk-tr{top:-1px;right:-1px;transform:scaleX(-1)}.bk-bl{bottom:-1px;left:-1px;transform:scaleY(-1)}.bk-br{bottom:-1px;right:-1px;transform:scale(-1)}

/* ---------- Ai element tile ---------- */
.tile{position:relative;display:flex;flex-direction:column;justify-content:space-between;aspect-ratio:1/1;padding:.7rem;border:1px solid var(--rule);background:var(--white);color:var(--on-paper);font-family:var(--mono)}
.s-ink .tile,.s-ink-2 .tile{background:var(--ink-2);border-color:var(--rule-dark);color:var(--on-ink)}
.tile .t-no{font-size:.6rem;letter-spacing:.1em;opacity:.55}
.tile .t-sym{font-family:var(--sans);font-weight:800;font-size:clamp(1.4rem,3vw,2.4rem);letter-spacing:-.02em;line-height:1}
.tile .t-name{font-size:.5rem;letter-spacing:.14em;text-transform:uppercase;opacity:.55}
.tile.is-ai{border-color:var(--pink);box-shadow:0 0 0 1px var(--pink) inset,0 0 40px -8px var(--pink-soft)}
.tile.is-ai .t-sym{color:var(--pink)}

/* ============================================================
   HEADER
   ============================================================ */
.scroll-prog{position:fixed;top:0;left:0;height:2px;width:0;background:var(--pink);z-index:70;transition:width .1s linear}
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;height:var(--hdr-h);display:flex;align-items:center;transition:background-color .4s var(--ease-out),border-color .4s var(--ease-out),color .4s;border-bottom:1px solid transparent;color:var(--on-paper)}
.site-header.on-ink{color:var(--on-ink)}
.site-header.scrolled{background:rgba(246,245,242,.82);backdrop-filter:blur(14px);border-bottom-color:var(--rule)}
.site-header.scrolled.on-ink{background:rgba(14,14,16,.72);border-bottom-color:var(--rule-dark)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;width:100%}
/* logo lockup — coded Ai monogram tile + Absolute Intelligence wordmark */
.brand{display:flex;align-items:center;gap:.6rem}
.brand-tile{width:34px;height:34px;border:1.5px solid var(--pink);display:flex;align-items:center;justify-content:center;position:relative;flex:0 0 auto}
.brand-tile span{font-weight:800;font-size:1.02rem;letter-spacing:-.03em;color:var(--pink);line-height:1}
.brand-tile::before{content:"119";position:absolute;top:2px;left:3px;font-family:var(--mono);font-size:.3rem;letter-spacing:.04em;opacity:.7;color:var(--pink)}
.brand-tile::after{content:"[225]";position:absolute;bottom:2px;right:3px;font-family:var(--mono);font-size:.26rem;letter-spacing:.02em;opacity:.5;color:var(--pink)}
.brand-word{font-weight:800;font-size:1.06rem;letter-spacing:-.02em;line-height:1;white-space:nowrap}
.brand-word b{font-weight:800}
.brand-word span{color:var(--pink-deep);font-weight:800}
.on-ink .brand-word span{color:var(--pink)}
.nav{display:flex;align-items:center;gap:clamp(.8rem,2vw,2rem)}
.nav-links{display:flex;align-items:center;gap:clamp(.7rem,1.8vw,1.8rem)}
.nav-item{position:relative;display:flex;align-items:center}
.nav a.nl,.nav .nl{font-family:var(--mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:inherit;opacity:.72;padding:.4em .2em;transition:opacity .3s,color .3s;cursor:pointer;display:inline-flex;align-items:center;gap:.35em;background:none;border:0}
.nav a.nl:hover,.nav a.nl[aria-current="page"],.nav .nl:hover,.nav-item:hover .nl{opacity:1;color:var(--pink-deep)}
.on-ink .nav a.nl:hover,.on-ink .nav a.nl[aria-current="page"],.on-ink .nav-item:hover .nl{color:var(--pink)}
.nl .caret{width:7px;height:7px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg) translateY(-1px);transition:transform .3s}
.nav-item:hover .caret{transform:rotate(45deg) translateY(1px)}
/* dropdown submenu */
.submenu{position:absolute;top:100%;left:-.4rem;min-width:236px;background:var(--paper);border:1px solid var(--rule);padding:.5rem;display:flex;flex-direction:column;opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .28s var(--ease-out),transform .28s var(--ease-out),visibility .28s;box-shadow:var(--shadow-soft);z-index:55}
.on-ink .submenu{background:var(--ink-2);border-color:var(--rule-dark)}
.nav-item:hover .submenu,.nav-item:focus-within .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.submenu a{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;padding:.7em .8em;opacity:.82;transition:opacity .2s,color .2s,background .2s;display:flex;flex-direction:column;gap:.2em}
.submenu a small{font-family:var(--sans);text-transform:none;letter-spacing:0;font-size:.78em;opacity:.6}
.submenu a:hover{opacity:1;color:var(--pink-deep);background:var(--paper-2)}
.on-ink .submenu a:hover{color:var(--pink);background:rgba(255,255,255,.05)}
.nav-toggle{display:none;flex-direction:column;gap:5px;width:30px;height:24px;justify-content:center;z-index:51}
.nav-toggle span{display:block;height:2px;background:currentColor;transition:transform .3s,opacity .3s}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--ink);color:var(--on-ink);padding-block:clamp(64px,9vh,120px) 40px}
.site-footer .f-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}
.site-footer .f-brand .brand-word{color:var(--on-ink)}
.site-footer .f-brand p{margin-top:1.2rem;max-width:32ch;color:var(--on-ink-dim)}
.f-col h4{font-family:var(--mono);font-size:.66rem;text-transform:uppercase;letter-spacing:.16em;color:var(--on-ink-dim);margin-bottom:1.1rem}
.f-col a{display:block;padding:.32em 0;color:var(--on-ink);opacity:.85;transition:color .3s,opacity .3s}
.f-col a:hover{color:var(--pink);opacity:1}
.f-bottom{display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-top:clamp(48px,7vh,88px);padding-top:24px;border-top:1px solid var(--rule-dark);font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;color:var(--on-ink-dim);text-transform:uppercase}

/* ============================================================
   ARCHETYPE: hero-cine (home)
   ============================================================ */
.hero-cine{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;background:var(--ink);color:var(--on-ink)}
.hero-cine .hero-media{position:absolute;inset:0;z-index:0}
.hero-cine .hero-media video,.hero-cine .hero-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
/* seamless-loop crossfade: two stacked video copies */
.vid-loop{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-cine .hero-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,14,16,.5),rgba(14,14,16,.15) 38%,rgba(14,14,16,.92))}
.hero-cine .hero-inner{position:relative;z-index:2;width:100%;padding-bottom:clamp(56px,11vh,128px);padding-top:calc(var(--hdr-h) + 40px)}
.hero-cine .h-hero{max-width:16ch;font-weight:850}
.hero-cine .hero-sub{margin-top:1.4rem;max-width:46ch}
.hero-ctas{margin-top:2.2rem;display:flex;flex-wrap:wrap;gap:1rem;align-items:center}
.hero-meta{position:absolute;right:var(--pad-x);bottom:clamp(56px,11vh,128px);z-index:2;text-align:right;color:var(--on-ink-dim)}

/* ARCHETYPE: hero-ed (interior, light, editorial) */
.hero-ed{padding-top:calc(var(--hdr-h) + clamp(56px,10vh,120px));padding-bottom:clamp(40px,7vh,90px);position:relative}
.hero-ed .he-grid{display:grid;grid-template-columns:1.5fr .9fr;gap:clamp(24px,4vw,64px);align-items:end}
.hero-ed .h-hero{font-weight:850}
.hero-ed .he-side{align-self:end}
.hero-ed .he-figure{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--ink-2)}
.hero-ed .he-figure img{width:100%;height:100%;object-fit:cover}
.hero-ed .he-lead{margin-top:1.4rem;max-width:52ch}

/* ARCHETYPE: statement (big type, scrub words) */
.statement{padding-block:clamp(80px,13vh,170px)}
.statement .st-text{font-size:var(--fs-display);font-weight:850;letter-spacing:-.035em;line-height:1.02;max-width:18ch}
.statement .st-text .word-inner{color:inherit}
.statement.is-scrub .word-inner{color:var(--rule-2)}
.s-ink .statement.is-scrub .word-inner{color:#3a3a42}

/* ARCHETYPE: marquee */
.marquee{overflow:hidden;border-block:1px solid var(--rule);padding-block:clamp(20px,3vh,40px)}
.s-ink .marquee{border-color:var(--rule-dark)}
.mq-track{display:flex;gap:2.5rem;width:max-content;will-change:transform}
.mq-item{font-size:clamp(1.4rem,3vw,2.4rem);font-weight:800;letter-spacing:-.02em;display:flex;align-items:center;gap:2.5rem;white-space:nowrap}
.mq-item::after{content:"●";color:var(--pink);font-size:.5em}

/* ARCHETYPE: bento (asymmetric grid) */
.bento-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(180px,auto);gap:clamp(12px,1.6vw,22px)}
.bento-cell{position:relative;padding:clamp(22px,2.4vw,36px);border:1px solid var(--rule);background:var(--white);display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;transition:transform .4s var(--ease-out),box-shadow .4s var(--ease-out),border-color .4s}
.s-ink .bento-cell{background:var(--ink-2);border-color:var(--rule-dark)}
.bento-cell:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft);border-color:var(--pink)}
.bento-cell.col2{grid-column:span 2}.bento-cell.col3{grid-column:span 3}.bento-cell.row2{grid-row:span 2}
.bento-cell.is-media{padding:0}.bento-cell.is-media img{width:100%;height:100%;object-fit:cover}
.bento-cell .c-no{font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;color:var(--pink-deep);text-transform:uppercase}
.s-ink .bento-cell .c-no{color:var(--pink)}
.bento-cell .h3{margin-top:auto;padding-top:1.2rem}
.bento-cell.is-pink{background:var(--pink);color:#0E0E10;border-color:var(--pink)}
.bento-cell.is-ink{background:var(--ink);color:var(--on-ink);border-color:var(--ink)}

/* ARCHETYPE: scrolly (pinned text + swapping media) */
.scrolly{position:relative}
.scrolly .sc-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,5vw,80px);align-items:start}
.scrolly .sc-steps{display:flex;flex-direction:column;gap:clamp(40px,30vh,60vh);padding-block:30vh}
.scrolly .sc-step{opacity:.32;transition:opacity .4s}
.scrolly .sc-step.is-active{opacity:1}
.scrolly .sc-step .s-idx{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;color:var(--pink-deep)}
.s-ink .scrolly .sc-step .s-idx{color:var(--pink)}
.scrolly .sc-step .h3{margin-top:.8rem}
.scrolly .sc-step p{margin-top:.8rem;max-width:42ch}
.scrolly .sc-media{position:sticky;top:0;height:100svh;display:flex;align-items:center}
.scrolly .sc-media-inner{position:relative;width:100%;aspect-ratio:4/3;overflow:hidden;background:var(--ink-2)}
.scrolly .sc-fig{position:absolute;inset:0;opacity:0;transition:opacity .6s var(--ease-out)}
.scrolly .sc-fig.is-active{opacity:1}
.scrolly .sc-fig img{width:100%;height:100%;object-fit:cover}

/* ARCHETYPE: hgallery (horizontal pinned) */
.hgallery{overflow:hidden}
.h-track{display:flex;gap:clamp(16px,2vw,32px);padding-inline:var(--pad-x);width:max-content;align-items:stretch}
.h-card{position:relative;width:clamp(280px,40vw,520px);flex:0 0 auto;display:flex;flex-direction:column}
.h-card .h-media{position:relative;overflow:hidden;aspect-ratio:4/3;background:var(--ink-2)}
.h-card .h-media img{width:100%;height:100%;object-fit:cover}
.h-card .h-cap{font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--on-paper-dim);margin-top:1rem}
.s-ink .h-card .h-cap{color:var(--on-ink-dim)}
.h-card .h3{margin-top:.5rem}
.h-intro{flex:0 0 auto;width:clamp(280px,32vw,440px);display:flex;flex-direction:column;justify-content:center;padding-right:clamp(20px,3vw,56px)}

/* ARCHETYPE: indexlist (numbered expanding rows) */
.indexlist{border-top:1px solid var(--rule)}
.s-ink .indexlist{border-color:var(--rule-dark)}
.ix-row{display:grid;grid-template-columns:auto 1fr auto;gap:clamp(16px,4vw,64px);align-items:baseline;padding-block:clamp(28px,4vh,52px);border-bottom:1px solid var(--rule);position:relative;transition:padding-left .4s var(--ease-out)}
.s-ink .ix-row{border-color:var(--rule-dark)}
.ix-row:hover{padding-left:clamp(8px,1.5vw,24px)}
.ix-row .ix-no{font-family:var(--mono);font-size:.8rem;color:var(--pink-deep);letter-spacing:.1em}
.s-ink .ix-row .ix-no{color:var(--pink)}
.ix-row .ix-title{font-size:clamp(1.5rem,3.4vw,2.6rem);font-weight:800;letter-spacing:-.025em;line-height:1.05}
.ix-row .ix-desc{max-width:40ch;color:var(--on-paper-dim)}
.s-ink .ix-row .ix-desc{color:var(--on-ink-dim)}
.ix-row .ix-go{font-family:var(--mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:var(--pink-deep);white-space:nowrap;transition:transform .35s var(--ease-out)}
.ix-row:hover .ix-go{transform:translateX(6px)}

/* ARCHETYPE: statband (count-up numbers) */
.statband{}
.statband .sb-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:clamp(24px,4vw,64px)}
.stat .s-num{font-weight:850;font-size:clamp(2.8rem,7vw,5.5rem);letter-spacing:-.04em;line-height:.95}
.stat .s-lab{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--on-paper-dim);margin-top:.8rem}
.s-ink .stat .s-lab,.s-pink .stat .s-lab{color:inherit;opacity:.75}

/* ARCHETYPE: overlap (parallax depth feature) */
.overlap{position:relative}
.overlap .ov-grid{display:grid;grid-template-columns:repeat(12,1fr);align-items:center}
.overlap .ov-media{grid-column:1 / span 7;grid-row:1;position:relative;aspect-ratio:16/11;overflow:hidden;z-index:1}
.overlap .ov-media img{width:100%;height:100%;object-fit:cover;will-change:transform}
.overlap .ov-panel{grid-column:7 / span 6;grid-row:1;z-index:2;background:var(--ink);color:var(--on-ink);padding:clamp(28px,4vw,56px);box-shadow:var(--shadow-lift)}
.overlap.flip .ov-media{grid-column:6 / span 7}
.overlap.flip .ov-panel{grid-column:1 / span 6}
.overlap .ov-panel.is-paper{background:var(--white);color:var(--on-paper)}
.overlap .ov-panel.is-pink{background:var(--pink);color:#0E0E10}

/* ARCHETYPE: quote */
.quote{}
.quote blockquote{font-size:clamp(1.6rem,4vw,3rem);font-weight:800;letter-spacing:-.025em;line-height:1.12;max-width:20ch}
.quote .q-mark{color:var(--pink);font-size:1.2em;line-height:0}
.quote figcaption{margin-top:2rem;font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--on-paper-dim)}
.s-ink .quote figcaption{color:var(--on-ink-dim)}

/* ARCHETYPE: timeline (SVG draw + steps) */
.timeline{}
.tl-wrap{position:relative;padding-left:clamp(28px,5vw,72px)}
.tl-line{position:absolute;left:6px;top:0;bottom:0;width:2px;overflow:visible}
.tl-line svg{height:100%;width:2px;overflow:visible}
.tl-line path{stroke:var(--pink);stroke-width:2;fill:none}
.tl-step{position:relative;padding-block:clamp(24px,4vh,48px)}
.tl-step::before{content:"";position:absolute;left:calc(-1*clamp(28px,5vw,72px) + 1px);top:calc(clamp(24px,4vh,48px) + .4em);width:12px;height:12px;border-radius:50%;background:var(--paper);border:2px solid var(--pink);transform:translateX(-4px)}
.s-ink .tl-step::before{background:var(--ink)}
.tl-step .t-idx{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;color:var(--pink-deep)}
.s-ink .tl-step .t-idx{color:var(--pink)}
.tl-step .h3{margin-top:.6rem}
.tl-step p{margin-top:.6rem;max-width:48ch}

/* ARCHETYPE: stack (sticky stacking cards) */
.stack{position:relative}
.stack-card{position:sticky;top:calc(var(--hdr-h) + 24px);border:1px solid var(--rule);background:var(--white);padding:clamp(28px,4vw,56px);margin-bottom:24px;box-shadow:var(--shadow-soft)}
.s-ink .stack-card{background:var(--ink-2);border-color:var(--rule-dark)}
.stack-card .sk-no{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;color:var(--pink-deep)}
.s-ink .stack-card .sk-no{color:var(--pink)}

/* ARCHETYPE: showcase (clip reveal media) */
.showcase .sh-media{position:relative;overflow:hidden;aspect-ratio:16/9}
.showcase .sh-media img{width:100%;height:100%;object-fit:cover;will-change:transform,clip-path}

/* ARCHETYPE: closer (CTA) */
.closer{text-align:center}
.closer .cl-inner{max-width:880px;margin-inline:auto}
.closer .h2{margin-top:1rem}
.closer .lead{margin:1.2rem auto 0}
.closer .hero-ctas{justify-content:center;margin-top:2.2rem}

/* ============================================================
   LAYERED ARCHETYPES (v7) — depth · parallax · full-bleed
   Built to fix: everything column-locked, flat, no layers.
   ============================================================ */

/* depth-layer helpers (used inside any .stage / full-bleed band) */
.stage{position:relative;overflow:hidden}
.ly{position:absolute;will-change:transform}
.ly-bg{position:absolute;left:-2%;right:-2%;top:-20%;width:104%;height:140%;z-index:0;will-change:transform}
.ly-bg img,.ly-bg video{width:100%;height:100%;object-fit:cover}
.ly-scrim{position:absolute;inset:0;z-index:1;pointer-events:none}
.scrim-dark{background:linear-gradient(180deg,rgba(12,12,14,.62),rgba(12,12,14,.30) 44%,rgba(12,12,14,.88))}
.scrim-side{background:linear-gradient(95deg,rgba(12,12,14,.90),rgba(12,12,14,.50) 50%,rgba(12,12,14,.06))}
.scrim-paper{background:linear-gradient(95deg,rgba(246,245,242,.96),rgba(246,245,242,.62) 46%,rgba(246,245,242,0))}

/* ghost — giant faint background type/number that drifts at its own speed (depth) */
.ghost{position:absolute;z-index:1;font-weight:850;letter-spacing:-.05em;line-height:.74;
  font-size:clamp(7rem,26vw,22rem);color:rgba(255,255,255,.055);white-space:nowrap;pointer-events:none;user-select:none;will-change:transform}
.s-paper .ghost,.s-paper-2 .ghost,.feature.on-paper .ghost{color:rgba(14,14,16,.05)}
.ghost.pink{color:rgba(255,45,155,.12)}

/* ARCHETYPE: hero-layer — full-bleed cinematic interior hero (replaces hero-ed) */
.hero-layer{position:relative;min-height:clamp(560px,88vh,920px);display:flex;align-items:flex-end;overflow:hidden;background:var(--ink);color:var(--on-ink)}
.hero-layer .hl-inner{position:relative;z-index:3;width:100%;padding-top:calc(var(--hdr-h) + clamp(48px,10vh,110px));padding-bottom:clamp(44px,8vh,104px)}
.hero-layer .h-hero{max-width:17ch;font-weight:850}
.hero-layer .he-lead{margin-top:1.3rem;max-width:50ch}
.hero-layer .hero-ctas{margin-top:2rem}
.hero-layer .ghost{bottom:-6%;left:-1%}
.hero-layer .eyebrow{color:var(--pink)}

/* ARCHETYPE: feature — full-bleed band, bg image + foreground copy + floating parallax card */
.feature{position:relative;min-height:clamp(520px,82vh,860px);display:flex;align-items:center;overflow:hidden;color:var(--on-ink);background:var(--ink-2)}
.feature .ft-inner{position:relative;z-index:3;width:100%;padding-block:clamp(56px,10vh,120px)}
.feature .ft-grid{display:grid;grid-template-columns:1.35fr .85fr;gap:clamp(24px,5vw,88px);align-items:center}
.feature .ft-col{max-width:48ch}
.feature .eyebrow{color:var(--pink)}
.feature.on-paper{color:var(--on-paper);background:var(--paper)}
.feature.on-paper .eyebrow{color:var(--pink-deep)}
.feature.on-paper .lead{color:var(--on-paper-dim)}
.feature.center{text-align:center}
.feature.center .ft-col{max-width:26ch;margin-inline:auto}
.feature.center .hero-ctas{justify-content:center}
/* floating parallax accent card */
.ft-card{position:relative;z-index:3;background:var(--white);color:var(--on-paper);padding:clamp(24px,2.6vw,40px);box-shadow:var(--shadow-lift);will-change:transform}
.ft-card.is-pink{background:var(--pink);color:#0E0E10}
.ft-card.is-ink{background:var(--ink);color:var(--on-ink)}
.ft-card .fc-num{font-weight:850;font-size:clamp(2.6rem,6vw,4.6rem);letter-spacing:-.04em;line-height:.9}
.ft-card .fc-lab{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;margin-top:.7rem;opacity:.8}
@media(max-width:860px){.feature .ft-grid{grid-template-columns:1fr;gap:32px}.feature .ft-col{max-width:none}}

/* ARCHETYPE: statement-bleed — big statement over full-bleed media + ghost layer */
.statement-bleed{position:relative;min-height:clamp(500px,76vh,800px);display:flex;align-items:center;overflow:hidden;color:var(--on-ink);background:var(--ink)}
.statement-bleed .sb-inner{position:relative;z-index:3;width:100%}
.statement-bleed .st-text{font-size:var(--fs-display);font-weight:850;letter-spacing:-.035em;line-height:1.05;max-width:20ch}
.statement-bleed .eyebrow{color:var(--pink)}
.statement-bleed.is-scrub .word-inner{color:rgba(255,255,255,.24)}
.statement-bleed .ghost{top:50%;right:-1%;transform:translateY(-50%)}

/* dark-context text + controls for the layered bands */
.hero-layer .lead,.statement-bleed .lead,.feature:not(.on-paper) .lead{color:var(--on-ink-dim)}
.hero-layer .dim,.statement-bleed .dim,.feature:not(.on-paper) .dim{color:var(--on-ink-dim)}
.hero-layer .btn-ghost:hover,.statement-bleed .btn-ghost:hover,.feature:not(.on-paper) .btn-ghost:hover{color:var(--ink)}
.hero-layer em.key,.statement-bleed em.key,.feature:not(.on-paper) em.key{color:var(--pink)}

/* ============================================================
   ARCHETYPE: work-gallery (filterable proof grid) + live demo toy
   ============================================================ */
.wg-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:clamp(22px,4vh,44px)}
.wg-filter{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;padding:.62em 1.1em;border:1px solid var(--rule-2);background:transparent;color:var(--on-paper);transition:background-color .3s,color .3s,border-color .3s}
.wg-filter:hover{border-color:var(--ink)}
.wg-filter.is-on{background:var(--ink);color:var(--on-ink);border-color:var(--ink)}
.s-ink .wg-filter,.s-ink-2 .wg-filter{color:var(--on-ink);border-color:var(--rule-dark)}
.s-ink .wg-filter.is-on,.s-ink-2 .wg-filter.is-on{background:var(--pink);color:#0E0E10;border-color:var(--pink)}
.wg-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(12px,1.6vw,22px);grid-auto-flow:dense}
.wg-item{position:relative;overflow:hidden;background:var(--ink-2);grid-column:span 4;aspect-ratio:3/2;display:block}
.wg-item.span6{grid-column:span 6}.wg-item.span8{grid-column:span 8}
.wg-item.tall{aspect-ratio:4/5}
.wg-item img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease-out)}
.wg-item:hover img,.wg-item:focus-visible img{transform:scale(1.06)}
.wg-item::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(0deg,rgba(12,12,14,.5),transparent 55%);opacity:.5;transition:opacity .4s}
.wg-item:hover::before{opacity:.85}
.wg-cap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:clamp(14px,1.6vw,22px);color:#fff;transform:translateY(10px);opacity:0;transition:transform .4s var(--ease-out),opacity .4s}
.wg-item:hover .wg-cap,.wg-item:focus-within .wg-cap{transform:none;opacity:1}
.wg-cat{font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--pink)}
.wg-ttl{font-weight:700;letter-spacing:-.01em;margin-top:.25em;line-height:1.15;font-size:1.02rem}
.wg-item.is-hidden{display:none}
.wg-item.is-video::after{content:"\25B6";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:rgba(255,45,155,.94);color:#0E0E10;border-radius:50%;font-size:1rem;padding-left:3px;transition:transform .3s}
.wg-item.is-video:hover::after{transform:translate(-50%,-50%) scale(1.12)}
.wg-badge{position:absolute;top:12px;left:12px;z-index:2;font-family:var(--mono);font-size:.56rem;letter-spacing:.1em;text-transform:uppercase;background:rgba(14,14,16,.66);color:#fff;padding:.42em .7em;backdrop-filter:blur(4px)}
@media(max-width:760px){.wg-grid{grid-template-columns:repeat(2,1fr)}.wg-item,.wg-item.span6{grid-column:span 1}.wg-item.span8{grid-column:span 2}}

/* article index cards (insights) */
.insights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,1.6vw,22px)}
.insight-card{display:flex;flex-direction:column;gap:.55rem;background:var(--white);border:1px solid var(--rule);padding:clamp(20px,2.2vw,30px);transition:transform .4s var(--ease-out),box-shadow .4s,border-color .4s}
.s-paper-2 .insight-card{background:var(--paper)}
.insight-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft);border-color:var(--pink)}
.insight-card.is-hidden{display:none}
.insight-card .ic-cat{font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--pink-deep)}
.insight-card .ic-ttl{font-size:1.16rem;font-weight:700;letter-spacing:-.01em;line-height:1.2}
.insight-card .ic-ex{color:var(--on-paper-dim);font-size:.95rem;line-height:1.5}
.insight-card .ic-go{margin-top:auto;padding-top:.5rem;font-family:var(--mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--pink-deep);transition:transform .35s var(--ease-out)}
.insight-card:hover .ic-go{transform:translateX(5px)}
@media(max-width:860px){.insights-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.insights-grid{grid-template-columns:1fr}}

/* live demo toy (e.g. ad-caption generator) */
.demo-toy{border:1px solid var(--rule-2);background:var(--white);padding:clamp(20px,3vw,40px);max-width:760px}
.s-ink .demo-toy,.s-ink-2 .demo-toy{background:var(--ink-2);border-color:var(--rule-dark)}
.demo-row{display:flex;gap:.6rem;flex-wrap:wrap}
.demo-row input{flex:1 1 240px;font:inherit;font-size:1rem;color:inherit;background:var(--paper-2);border:1px solid var(--rule-2);border-bottom-width:2px;padding:.75em .8em}
.s-ink .demo-row input{background:var(--ink);border-color:var(--rule-dark)}
.demo-row input:focus{outline:none;border-color:var(--pink);background:var(--white)}
.s-ink .demo-row input:focus{background:#000}
.demo-out{margin-top:1.4rem;display:flex;flex-direction:column;gap:.8rem;min-height:1em}
.demo-line{padding:.9em 1em;border-left:3px solid var(--pink);background:var(--paper-2);font-size:1.06rem;line-height:1.45}
.s-ink .demo-line{background:rgba(255,255,255,.04)}
.demo-note{font-family:var(--mono);font-size:.68rem;letter-spacing:.06em;color:var(--on-paper-dim);margin-top:1.1rem}
.s-ink .demo-note{color:var(--on-ink-dim)}
.demo-cursor::after{content:"\258C";color:var(--pink);animation:demoblink 1s steps(1) infinite}
@keyframes demoblink{50%{opacity:0}}

/* ---------- prose (articles / insights) ---------- */
.prose{max-width:68ch}
.prose>*+*{margin-top:1.25em}
.prose p{font-size:1.12rem;line-height:1.7;color:var(--on-paper)}
.prose h2{font-size:clamp(1.5rem,3vw,2.1rem);letter-spacing:-.02em;line-height:1.15;margin-top:2.2em}
.prose h3{font-size:clamp(1.15rem,1.8vw,1.4rem);font-weight:700;margin-top:1.8em}
.prose h2+p,.prose h3+p{margin-top:.7em}
.prose ul{margin-left:1.1em;list-style:disc}
.prose ul li{margin-top:.5em;padding-left:.2em}
.prose a{color:var(--pink-deep);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.prose a:hover{color:var(--pink)}
.prose blockquote{border-left:3px solid var(--pink);padding-left:1.1em;font-size:1.25rem;font-weight:600;letter-spacing:-.01em;line-height:1.35}
.prose .lead{font-size:clamp(1.25rem,2vw,1.5rem);line-height:1.45;color:var(--on-paper);font-weight:500}
.article-meta{font-family:var(--mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:var(--on-paper-dim);display:flex;gap:1.2em;flex-wrap:wrap;margin-top:1.2rem}

/* split (contact form + routes) */
.split-grid{display:grid;grid-template-columns:1.3fr .9fr;gap:clamp(28px,5vw,72px)}

/* ---------- form ---------- */
.field{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}
.field label{font-family:var(--mono);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--on-paper)}
.s-ink .field label{color:var(--on-ink)}
.field input,.field textarea{font:inherit;font-size:1rem;color:inherit;background:var(--paper-2);border:1px solid var(--rule-2);border-bottom-width:2px;padding:.75em .8em;border-radius:0;transition:border-color .3s,background-color .3s}
.field input:hover,.field textarea:hover{border-color:var(--on-paper-dim)}
.s-ink .field input,.s-ink .field textarea{border-bottom-color:var(--rule-dark)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--pink);background:var(--white)}
.field textarea{resize:vertical;min-height:120px}
.form-status{font-family:var(--mono);font-size:.8rem;letter-spacing:.04em;margin-top:1rem;min-height:1.2em}
.form-status.ok{color:var(--pink-deep)}
.contact-routes a{display:block;padding:.4em 0}
.contact-routes .r-lab{font-family:var(--mono);font-size:.66rem;text-transform:uppercase;letter-spacing:.12em;color:var(--on-paper-dim)}

/* ---------- utilities ---------- */
.stack-gap>*+*{margin-top:1.1rem}
.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}.mt-3{margin-top:3rem}
.skip-link{position:absolute;left:-999px;top:0;z-index:100;background:var(--pink);color:#fff;padding:.6em 1em}
.skip-link:focus{left:8px;top:8px}
.section-head{max-width:60ch}
.section-head .h2{margin-top:1rem}
.section-head .lead{margin-top:1.2rem}

/* ---------- responsive ---------- */
@media (max-width:1000px){
  .site-footer .f-top{grid-template-columns:1fr 1fr}
}
@media (max-width:900px){
  .nav-links{position:fixed;inset:0;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:.8rem;background:var(--paper);transform:translateY(-100%);transition:transform .5s var(--ease-expo);z-index:49;padding:calc(var(--hdr-h) + 28px) var(--pad-x) 48px;overflow-y:auto}
  .on-ink .nav-links{background:var(--ink)}
  .nav-links.open{transform:translateY(0)}
  .nav a.nl,.nav .nl{font-size:1.25rem;opacity:1}
  .nav-item{flex-direction:column;align-items:flex-start;width:100%}
  .nl .caret{display:none}
  .submenu{position:static;opacity:1!important;visibility:visible!important;transform:none!important;box-shadow:none;border:0;background:transparent;padding:.2rem 0 .6rem 1rem;min-width:0}
  .on-ink .submenu{background:transparent}
  .submenu a{font-size:.95rem;padding:.45em 0}
  .nav .nav-cta{margin-top:1rem}
  .nav-toggle{display:flex}
  .nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle.open span:nth-child(2){opacity:0}
  .nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .hero-ed .he-grid{grid-template-columns:1fr;gap:32px}
  .hero-ed .he-figure{aspect-ratio:16/10;max-height:46vh}
  .scrolly .sc-grid{grid-template-columns:1fr}
  .scrolly .sc-media{position:relative;height:auto;margin-bottom:32px}
  .scrolly .sc-steps{gap:24px;padding-block:0}
  .scrolly .sc-step{opacity:1}
  .scrolly .sc-media-inner .sc-fig{position:relative;opacity:1}
  .scrolly .sc-media-inner{aspect-ratio:auto}
  .scrolly .sc-media-inner .sc-fig+.sc-fig{display:none}
  .overlap .ov-grid{display:block}
  .overlap .ov-media,.overlap.flip .ov-media{aspect-ratio:16/10}
  .overlap .ov-panel,.overlap.flip .ov-panel{margin-top:-40px;margin-inline:16px}
  .split-grid{grid-template-columns:1fr}
}
@media (max-width:760px){
  .grid12{grid-template-columns:1fr;gap:clamp(20px,5vw,32px)}
  .grid12>*{grid-column:auto!important}
  .bento-grid{grid-template-columns:1fr 1fr;grid-auto-rows:minmax(150px,auto)}
  .bento-cell.col2,.bento-cell.col3{grid-column:span 2}.bento-cell.row2{grid-row:auto}
  .ix-row{grid-template-columns:1fr;gap:8px}
  .ix-row .ix-go{display:none}
}
@media (max-width:640px){
  :root{--hdr-h:60px}
  .bento-grid{grid-template-columns:1fr}
  .bento-cell.col2,.bento-cell.col3{grid-column:1 / -1}
  .bento-cell.row2{grid-row:auto}
}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .line-inner,.word-inner{transform:none!important;color:inherit!important}
  .scrolly .sc-fig{opacity:1!important;position:relative!important}
  .scrolly .sc-step{opacity:1!important}
}
