/* ============================================================
   AVENIR LABS — brand story  ·  "one studio, many colours"
   Single self-contained file. Self-hosted fonts. Vanilla JS.
   Built to port into a WordPress theme.
   ============================================================ */

/* ---------- Self-hosted fonts (base64 woff2, latin) ---------- */
@font-face{font-family:"Bricolage";font-weight:600;font-display:swap;src:url(fonts/bricolage-600.woff2) format("woff2") format("woff2");}
@font-face{font-family:"Bricolage";font-weight:700;font-display:swap;src:url(fonts/bricolage-700.woff2) format("woff2") format("woff2");}
@font-face{font-family:"Bricolage";font-weight:800;font-display:swap;src:url(fonts/bricolage-800.woff2) format("woff2") format("woff2");}
@font-face{font-family:"Inter";font-weight:400;font-display:swap;src:url(fonts/inter-400.woff2) format("woff2") format("woff2");}
@font-face{font-family:"Inter";font-weight:500;font-display:swap;src:url(fonts/inter-500.woff2) format("woff2") format("woff2");}
@font-face{font-family:"Inter";font-weight:600;font-display:swap;src:url(fonts/inter-600.woff2) format("woff2") format("woff2");}
@font-face{font-family:"Inter";font-weight:700;font-display:swap;src:url(fonts/inter-700.woff2) format("woff2") format("woff2");}
@font-face{font-family:"Geist Mono";font-weight:500;font-display:swap;src:url(fonts/geist-mono-500.woff2) format("woff2") format("woff2");}

/* ---------- Tokens ---------- */
:root{
  --paper:#F6F4EE; --paper-2:#EEEAE0; --paper-3:#E8E3D6;
  --ink:#1A1714; --ink-2:#5B564E; --ink-3:#8C877C;
  --line:#E4E0D6; --line-2:#D5D0C4;
  --dark:#15120F; --dark-2:#221F1A; --on-dark:#F1EEE6; --on-dark-2:#A39E92;

  --accent:#E73D1B; --accent-deep:#B5321A;

  /* brand world */
  --yaya:#CABFEB;  --yaya-2:#9D8BD7; --yaya-ink:#46396F;
  --hop:#F6C7B6;   --hop-2:#F0A284;  --hop-ink:#9C5034;
  --gifts:#F5DE97; --gifts-2:#EAC558;--gifts-ink:#6E5410;

  /* logos — embedded once, reused everywhere */
  --img-avenir:url(/wp-content/uploads/2026/06/avenir-wordmark.png); --img-yaya:url(img/yaya.png);
  --img-hop:url(img/hop.png); --img-gifts:url(img/gifts.png);

  --maxw:1200px;
  --pad:clamp(20px,5vw,64px);
  --d:"Bricolage","Inter",system-ui,sans-serif;       /* display  */
  --b:"Inter",system-ui,-apple-system,sans-serif;      /* body     */
  --m:"Geist Mono",ui-monospace,Menlo,monospace;       /* utility  */
}

*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--b);
  font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:none;}
:focus-visible{outline:2.5px solid var(--accent);outline-offset:3px;border-radius:3px;}
::selection{background:var(--accent);color:#fff;}

/* logo utility (background-image, deduped) */
.logo{display:block;background-repeat:no-repeat;background-position:center;background-size:contain;flex:none;}
.logo.l-avenir{background-image:var(--img-avenir);--ar:1.083;}
.logo.l-yaya{background-image:var(--img-yaya);--ar:1.04;}
.logo.l-hop{background-image:var(--img-hop);--ar:1.512;}
.logo.l-gifts{background-image:var(--img-gifts);--ar:1.233;}

.eyebrow{font-family:var(--m);font-weight:500;font-size:.72rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--accent-deep);display:inline-flex;align-items:center;gap:.6em;}
.eyebrow.muted{color:var(--ink-3);}
.dots{display:inline-flex;gap:5px;}
.dots i{width:8px;height:8px;border-radius:50%;display:inline-block;}
.dots .y{background:var(--yaya-2);} .dots .h{background:var(--hop-2);} .dots .g{background:var(--gifts-2);}

h1,h2,h3,h4{font-family:var(--d);font-weight:700;letter-spacing:-.03em;line-height:1.0;margin:0;}
p{margin:0;}
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad);}
.rule{height:1px;background:var(--line);border:0;margin:0;}

/* ============================================================ NAV */
.nav{position:sticky;top:0;z-index:80;background:rgba(246,244,238,.8);
  backdrop-filter:saturate(150%) blur(14px);-webkit-backdrop-filter:saturate(150%) blur(14px);
  border-bottom:1px solid transparent;transition:border-color .3s;}
.nav.scrolled{border-bottom-color:var(--line);}
.nav-in{max-width:var(--maxw);margin:0 auto;padding:13px var(--pad);
  display:flex;align-items:center;justify-content:space-between;gap:22px;}
.brand{display:flex;align-items:center;gap:11px;}
.brand .logo{height:70px;width:calc(70px*var(--ar));}
.brand .lab{font-family:var(--m);font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-2);padding-left:11px;border-left:1px solid var(--line-2);transform:translateY(1px);}
.nav-links{display:flex;align-items:center;gap:28px;}
.nav-links a.lnk{font-family:var(--d);font-weight:600;font-size:.94rem;color:var(--ink-2);
  transition:color .2s;position:relative;}
.nav-links a.lnk::after{content:"";position:absolute;left:0;right:100%;bottom:-5px;height:2px;
  background:var(--accent);transition:right .25s ease;border-radius:2px;}
.nav-links a.lnk:hover{color:var(--ink);} .nav-links a.lnk:hover::after{right:0;}
/* Products dropdown */
.nav-links .has-dd{font-family:var(--d);font-weight:600;font-size:.94rem;color:var(--ink-2);position:relative;display:inline-flex;align-items:center;gap:5px;cursor:pointer;transition:color .2s;}
.nav-links .has-dd:hover{color:var(--ink);}
.nav-links .has-dd .dd-caret{font-size:.7em;transition:transform .2s;}
.nav-links .has-dd:hover .dd-caret{transform:rotate(180deg);}
.nav-links .dd{position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(6px);min-width:222px;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:8px;box-shadow:0 24px 48px -26px rgba(26,23,20,.45);display:flex;flex-direction:column;gap:2px;opacity:0;visibility:hidden;transition:opacity .2s,transform .2s;z-index:60;}
.nav-links .has-dd:hover .dd,.nav-links .has-dd:focus-within .dd{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.nav-links .dd::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px;}
.nav-links .dd a{font-family:var(--b);font-weight:500;font-size:.9rem;color:var(--ink-2);padding:10px 13px;border-radius:9px;white-space:nowrap;transition:background .15s,color .15s;}
.nav-links .dd a:hover{background:var(--paper-2);color:var(--accent-deep);}
.nav-cta{font-family:var(--d);font-weight:700;font-size:.9rem;display:inline-flex;align-items:center;gap:7px;
  color:#fff;background:var(--accent);border-radius:100px;padding:9px 17px;transition:transform .2s,background .2s;}
.nav-cta .arr{transition:transform .25s;}
.nav-cta:hover{background:var(--ink);} .nav-cta:hover .arr{transform:translate(2px,-2px);}
.nav-toggle{display:none;width:44px;height:44px;align-items:center;justify-content:center;
  border:1px solid var(--line-2);border-radius:12px;}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{content:"";display:block;width:18px;height:2px;background:var(--ink);transition:.25s;}
.nav-toggle span::before{transform:translateY(-6px);}
.nav-toggle span::after{transform:translateY(4px);}
.nav-toggle[aria-expanded="true"] span{background:transparent;}
.nav-toggle[aria-expanded="true"] span::before{transform:rotate(45deg);}
.nav-toggle[aria-expanded="true"] span::after{transform:rotate(-45deg);}

/* ============================================================ HERO */
.hero{position:relative;overflow:hidden;}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:36px;align-items:center;
  padding-top:clamp(40px,7vw,84px);padding-bottom:clamp(44px,7vw,88px);}
.hero h1{font-family:var(--d);font-weight:800;font-size:clamp(2.6rem,6.6vw,5.6rem);
  letter-spacing:-.04em;line-height:.98;margin:20px 0 0;max-width:15ch;}
.hero h1 .w{display:inline-block;overflow:hidden;vertical-align:top;padding-bottom:.06em;}
.hero h1 .w>span{display:inline-block;transform:translateY(115%);
  animation:rise .85s cubic-bezier(.2,.8,.2,1) both;animation-delay:calc(var(--i)*.06s + .15s);}
@keyframes rise{to{transform:none;}}
.hero h1 .mark{position:relative;color:var(--accent);}
.hero h1 .mark svg{position:absolute;left:-2%;width:104%;bottom:-.18em;height:.4em;overflow:visible;}
.hero h1 .mark path{fill:none;stroke:var(--accent);stroke-width:7;stroke-linecap:round;
  stroke-dasharray:340;stroke-dashoffset:340;animation:draw 1s cubic-bezier(.6,0,.2,1) forwards;animation-delay:.95s;}
@keyframes draw{to{stroke-dashoffset:0;}}
.hero .sub{font-size:clamp(1.05rem,1.5vw,1.28rem);color:var(--ink-2);max-width:46ch;margin:26px 0 0;line-height:1.55;}
.hero .ctas{display:flex;flex-wrap:wrap;gap:13px;margin-top:34px;}
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--d);font-weight:700;font-size:1rem;
  border-radius:100px;padding:14px 24px;transition:transform .25s,background .2s,border-color .2s,color .2s;}
.btn .arr{transition:transform .25s;}
.btn-primary{background:var(--ink);color:var(--paper);}
.btn-primary:hover{background:var(--accent);} .btn-primary:hover .arr{transform:translateX(3px);}
.btn-ghost{border:1.5px solid var(--ink);color:var(--ink);}
.btn-ghost:hover{background:var(--ink);color:var(--paper);}
.mag{will-change:transform;}

/* hero sticker cluster (shows the 3 brands up top) */
.cluster{position:relative;min-height:380px;}
.chip{position:absolute;background:#fff;border-radius:20px;padding:18px;
  box-shadow:0 22px 50px -24px rgba(26,23,20,.45),0 2px 0 rgba(0,0,0,.02);
  border:1px solid rgba(0,0,0,.04);}
.chip .chip-in{animation:bob 6s ease-in-out infinite;}
.chip .logo{width:100%;aspect-ratio:var(--ar);}
.chip .tg{position:absolute;top:-11px;left:14px;font-family:var(--m);font-size:.6rem;letter-spacing:.12em;
  text-transform:uppercase;color:#fff;padding:4px 9px;border-radius:100px;}
.chip.c-yaya{width:204px;top:8%;left:8%;transform:rotate(-7deg);z-index:3;}
.chip.c-yaya .tg{background:var(--yaya-2);}
.chip.c-hop{width:196px;top:40%;right:2%;transform:rotate(6deg);z-index:2;}
.chip.c-hop .chip-in{animation-delay:-2s;} .chip.c-hop .tg{background:var(--hop-2);}
.chip.c-gifts{width:150px;bottom:4%;left:20%;transform:rotate(-3deg);z-index:1;}
.chip.c-gifts .chip-in{animation-delay:-4s;} .chip.c-gifts .tg{background:var(--gifts-2);color:var(--ink);}
.cluster .spark-arrow{position:absolute;top:2%;right:16%;width:64px;color:var(--accent);z-index:4;
  animation:bob 5s ease-in-out infinite;}
@keyframes bob{50%{transform:translateY(-13px);}}

/* ============================================================ MARQUEE */
.marquee{background:var(--accent);color:#fff;overflow:hidden;padding:16px 0;
  border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);}
.marquee.alt{background:var(--ink);color:var(--paper);border-color:var(--accent);}
.marquee__track{display:flex;align-items:center;gap:0;width:max-content;animation:marq 30s linear infinite;}
.marquee.alt .marquee__track{animation-duration:36s;}
.marquee:hover .marquee__track{animation-play-state:paused;}
.marquee__track span{font-family:var(--d);font-weight:800;font-size:clamp(1.2rem,2.4vw,1.9rem);
  letter-spacing:-.02em;text-transform:uppercase;padding:0 26px;display:inline-flex;align-items:center;gap:26px;white-space:nowrap;}
.marquee__track .o{-webkit-text-stroke:1.4px #fff;color:transparent;}
.marquee.alt .marquee__track .o{-webkit-text-stroke:1.4px var(--paper);}
.marquee__track .star{color:rgba(255,255,255,.55);font-size:.8em;}
.marquee.alt .marquee__track .star{color:var(--accent);}
@keyframes marq{to{transform:translateX(-50%);}}

/* ============================================================ BELIEF */
.belief{padding:clamp(64px,10vw,128px) 0;}
.belief .eyebrow{display:block;margin-bottom:30px;}
.belief p{font-family:var(--d);font-weight:700;letter-spacing:-.03em;line-height:1.1;
  font-size:clamp(1.85rem,4.6vw,3.4rem);max-width:17ch;}
.belief .grey{color:var(--ink-3);}
.hl{color:var(--ink);position:relative;white-space:nowrap;padding:0 .08em;}
.hl::before{content:"";position:absolute;left:0;right:0;bottom:.04em;top:.46em;z-index:-1;
  background:var(--yaya);border-radius:4px;transform:rotate(-1deg);}
.hl.h2c::before{background:var(--accent);opacity:.92;} .hl.h2c{color:#fff;}

/* ============================================================ HOW WE THINK */
.think{padding:clamp(56px,8vw,104px) 0;background:var(--paper-2);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:26px;flex-wrap:wrap;
  margin-bottom:clamp(36px,5vw,60px);}
.sec-head h2{font-family:var(--d);font-weight:800;font-size:clamp(1.9rem,4vw,3rem);letter-spacing:-.035em;max-width:16ch;}
.sec-head .lead{color:var(--ink-2);max-width:34ch;font-size:1.02rem;}
.credos{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.credo{border:1px solid var(--line-2);border-radius:18px;padding:24px 22px 26px;background:var(--paper);
  position:relative;overflow:hidden;transition:transform .25s,box-shadow .25s;}
.credo::before{content:"";position:absolute;left:0;top:0;height:5px;width:100%;}
.credo.k1::before{background:var(--yaya-2);} .credo.k2::before{background:var(--hop-2);}
.credo.k3::before{background:var(--gifts-2);} .credo.k4::before{background:var(--accent);}
.credo:hover{transform:translateY(-5px);box-shadow:0 22px 44px -30px rgba(26,23,20,.5);}
.credo .n{font-family:var(--m);font-size:.72rem;letter-spacing:.14em;color:var(--ink-3);}
.credo h3{font-family:var(--d);font-weight:700;font-size:1.35rem;letter-spacing:-.02em;margin:16px 0 10px;line-height:1.05;}
.credo p{color:var(--ink-2);font-size:.97rem;line-height:1.5;}

/* ============================================================ JOURNEY */
.journey{padding:clamp(60px,9vw,108px) 0;}
.chapter{display:grid;grid-template-columns:minmax(0,.85fr) minmax(0,1.5fr);gap:clamp(18px,5vw,64px);
  padding:clamp(30px,4.5vw,48px) 0;border-top:1px solid var(--line);align-items:start;}
.chapter .yrwrap{display:flex;flex-direction:column;gap:14px;}
.chapter .yr{font-family:var(--d);font-weight:800;letter-spacing:-.05em;line-height:.84;
  font-size:clamp(3.4rem,9.5vw,7rem);font-feature-settings:"tnum" 1;}
.chapter .bar{height:8px;width:64px;border-radius:6px;}
.chapter .body h3{font-family:var(--d);font-weight:700;font-size:clamp(1.45rem,2.7vw,2.1rem);
  letter-spacing:-.02em;margin-bottom:13px;display:flex;align-items:center;gap:13px;flex-wrap:wrap;}
.chapter .body h3 .tag{font-family:var(--m);font-weight:500;font-size:.62rem;letter-spacing:.15em;
  text-transform:uppercase;border-radius:100px;padding:5px 11px;transform:translateY(-2px);}
.chapter .body p{color:var(--ink-2);font-size:1.06rem;max-width:50ch;line-height:1.6;}
.c-g .yr{color:var(--gifts-ink);} .c-g .bar{background:var(--gifts-2);} .c-g .tag{background:var(--gifts);color:var(--gifts-ink);}
.c-y .yr{color:var(--yaya-ink);} .c-y .bar{background:var(--yaya-2);} .c-y .tag{background:var(--yaya);color:var(--yaya-ink);}
.c-h .yr{color:var(--hop-ink);} .c-h .bar{background:var(--hop-2);} .c-h .tag{background:var(--hop);color:var(--hop-ink);}
.c-k .yr{color:var(--accent);} .c-k .bar{background:var(--accent);} .c-k .tag{background:var(--accent);color:#fff;}

/* ============================================================ FLYWHEEL (dark, glowing) */
.flywheel{background:var(--dark);color:var(--on-dark);padding:clamp(68px,10vw,132px) 0;position:relative;overflow:hidden;}
.fly-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,6vw,72px);align-items:center;}
.fly-copy .eyebrow{color:var(--accent);display:block;margin-bottom:22px;}
.fly-copy h2{font-family:var(--d);font-weight:800;font-size:clamp(2rem,4.2vw,3.3rem);letter-spacing:-.035em;
  max-width:13ch;color:var(--on-dark);line-height:1.0;}
.fly-copy .cap{color:var(--on-dark-2);font-size:1.08rem;margin-top:22px;max-width:42ch;line-height:1.6;}
.fly-legend{display:flex;flex-direction:column;gap:11px;margin-top:30px;}
.fly-legend li{list-style:none;display:flex;align-items:center;gap:13px;font-family:var(--m);font-size:.78rem;
  letter-spacing:.06em;text-transform:uppercase;color:var(--on-dark-2);}
.fly-legend .sw{width:26px;height:8px;border-radius:5px;flex:0 0 auto;}
.fly-legend b{color:var(--on-dark);font-weight:500;font-family:var(--d);letter-spacing:0;text-transform:none;font-size:.92rem;}
.fly-legend .ar{color:var(--on-dark-2);margin-left:auto;}
.fly-stage{display:flex;justify-content:center;}
.fly-svg{width:100%;max-width:480px;height:auto;overflow:visible;}
.fly-base{fill:none;stroke:rgba(255,255,255,.1);stroke-width:1.4;}
.fly-dash{fill:none;stroke:rgba(255,255,255,.14);stroke-width:1.2;stroke-dasharray:2 10;
  transform-origin:200px 200px;animation:spin 70s linear infinite;}
.arc{fill:none;stroke-width:6;stroke-linecap:round;stroke-dasharray:236;stroke-dashoffset:236;
  transition:stroke-dashoffset 1s cubic-bezier(.5,0,.2,1);filter:drop-shadow(0 0 7px currentColor);}
.flywheel.in .arc{stroke-dashoffset:0;}
.arc.a1{stroke:var(--yaya);transition-delay:.05s;} .arc.a2{stroke:var(--hop);transition-delay:.3s;}
.arc.a3{stroke:var(--gifts);transition-delay:.55s;} .arc.a4{stroke:var(--accent);transition-delay:.8s;}
.fnode circle{fill:var(--dark);stroke:#fff;stroke-width:2;}
.fnode.lead circle{fill:var(--accent);stroke:var(--accent);filter:drop-shadow(0 0 8px var(--accent));}
.fnode .lbl{font-family:var(--d);font-weight:700;font-size:17px;letter-spacing:-.01em;fill:#fff;}
.fnode .num{font-family:var(--m);font-weight:500;font-size:11px;fill:var(--on-dark-2);}
.fly-spark{fill:#fff;offset-path:path("M200,50 a150,150 0 1,1 -.1,0");offset-distance:0;
  filter:drop-shadow(0 0 6px var(--accent));opacity:0;transition:opacity .5s 1.4s;animation:travel 6.5s linear infinite;}
.flywheel.in .fly-spark{opacity:1;}
.fly-center path{stroke:var(--accent);stroke-width:3.6;fill:none;stroke-linecap:round;stroke-linejoin:round;
  filter:drop-shadow(0 0 5px var(--accent));}
.fly-center text{font-family:var(--m);font-weight:500;font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;fill:var(--on-dark-2);text-anchor:middle;}
@keyframes travel{to{offset-distance:100%;}}
@keyframes spin{to{transform:rotate(360deg);}}

/* ============================================================ VENTURES (bento + logos) */
.ventures{padding:clamp(60px,9vw,112px) 0;}
.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:16px;margin-top:clamp(34px,5vw,52px);}
.vcard{position:relative;border-radius:24px;padding:clamp(22px,2.6vw,32px);overflow:hidden;
  display:flex;flex-direction:column;min-height:230px;text-decoration:none;
  transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s;transform-style:preserve-3d;}
.vcard:hover{box-shadow:0 30px 60px -34px rgba(26,23,20,.6);}
.vc-yaya{grid-column:1/8;grid-row:1/3;background:var(--yaya);}
.vc-hop{grid-column:8/13;grid-row:1/2;background:var(--hop);}
.vc-gifts{grid-column:8/13;grid-row:2/3;background:var(--gifts);}
.vc-keel{grid-column:1/13;grid-row:3/4;background:var(--dark);color:var(--on-dark);
  flex-direction:row;flex-wrap:wrap;align-items:center;gap:22px;min-height:0;}
.vcard .ix{font-family:var(--m);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink);opacity:.55;display:flex;justify-content:space-between;gap:10px;}
.sticker{background:#fff;border-radius:18px;display:flex;align-items:center;justify-content:center;
  padding:22px;margin:18px 0;box-shadow:0 12px 30px -20px rgba(0,0,0,.4);transition:transform .35s;}
.vcard:hover .sticker{transform:translateZ(28px) scale(1.02);}
.sticker .logo{width:100%;height:100%;}
.vc-yaya .sticker{height:230px;}
.vc-hop .sticker{height:120px;margin:14px 0;}
.vc-gifts .sticker{height:120px;margin:14px 0;}
.vcard p{color:var(--ink);opacity:.82;font-size:1rem;line-height:1.5;}
.vc-yaya p{font-size:1.06rem;max-width:42ch;}
.visit{margin-top:auto;padding-top:18px;display:inline-flex;align-items:center;gap:8px;
  font-family:var(--d);font-weight:700;font-size:.95rem;color:var(--ink);}
.visit .arr{transition:transform .25s;}
.vcard:hover .visit .arr{transform:translate(3px,-3px);}
/* keel software card */
.vc-keel .kl{flex:1 1 320px;}
.vc-keel .ix{color:var(--accent);opacity:1;}
.vc-keel h3{font-family:var(--d);font-weight:800;font-size:clamp(1.7rem,3vw,2.3rem);letter-spacing:-.03em;margin:14px 0 8px;color:#fff;}
.vc-keel p{color:var(--on-dark-2);opacity:1;max-width:48ch;}
.vc-keel .visit{color:#fff;margin:0;padding:0;flex:0 0 auto;}
.vc-keel .badge{position:absolute;top:clamp(22px,2.6vw,32px);right:clamp(22px,2.6vw,32px);
  font-family:var(--m);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);
  border:1px solid rgba(231,61,27,.5);border-radius:100px;padding:5px 11px;}
.vc-keel::after{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(var(--dark-2) 1px,transparent 1px),linear-gradient(90deg,var(--dark-2) 1px,transparent 1px);
  background-size:46px 46px;opacity:.5;
  -webkit-mask-image:radial-gradient(90% 120% at 92% 50%,#000,transparent 70%);mask-image:radial-gradient(90% 120% at 92% 50%,#000,transparent 70%);}

/* ============================================================ KEEL SPOTLIGHT */
.keel{background:var(--dark);color:var(--on-dark);padding:clamp(72px,11vw,140px) 0;position:relative;overflow:hidden;}
.keel::before{content:"";position:absolute;inset:0;
  background-image:linear-gradient(var(--dark-2) 1px,transparent 1px),linear-gradient(90deg,var(--dark-2) 1px,transparent 1px);
  background-size:64px 64px;opacity:.55;
  -webkit-mask-image:radial-gradient(120% 90% at 82% 0,#000,transparent 72%);mask-image:radial-gradient(120% 90% at 82% 0,#000,transparent 72%);}
.keel .wrap{position:relative;}
.keel .eyebrow{color:var(--accent);display:block;margin-bottom:24px;}
.keel h2{font-family:var(--d);font-weight:800;font-size:clamp(2.1rem,4.6vw,3.6rem);letter-spacing:-.035em;max-width:17ch;color:#fff;line-height:1.0;}
.keel .body{color:var(--on-dark-2);font-size:clamp(1.08rem,1.7vw,1.3rem);max-width:50ch;margin-top:24px;line-height:1.6;}
.keel .body b{color:#fff;font-weight:600;}
.keel .status{display:inline-flex;align-items:center;gap:11px;margin-top:28px;font-family:var(--m);font-size:.78rem;letter-spacing:.06em;color:var(--on-dark-2);}
.keel .status .live{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse 2.4s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(231,61,27,.55);}70%{box-shadow:0 0 0 10px rgba(231,61,27,0);}100%{box-shadow:0 0 0 0 rgba(231,61,27,0);}}
.keel .ctas{margin-top:36px;}
.keel .btn-primary{background:var(--accent);color:#fff;} .keel .btn-primary:hover{background:#fff;color:var(--ink);}
.keel .madeby{margin-top:44px;padding-top:22px;border-top:1px solid var(--dark-2);display:flex;align-items:center;gap:12px;
  font-family:var(--m);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--on-dark-2);}
.keel .madeby .logo{height:18px;width:calc(18px*var(--ar));filter:invert(1) brightness(1.7);opacity:.85;}

/* ============================================================ FOUNDER */
.founder{background:linear-gradient(180deg,#ECE7F8,#F1ECF9);padding:clamp(64px,10vw,128px) 0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.founder-in{max-width:780px;}
.founder .eyebrow{color:var(--yaya-ink);display:block;margin-bottom:24px;}
.founder .mark{font-family:var(--d);font-weight:800;color:var(--yaya-2);font-size:clamp(3rem,7vw,4.6rem);line-height:.3;display:block;height:.5em;}
.founder p+p{margin-top:1.1em;}
.founder p{font-family:var(--d);font-weight:600;letter-spacing:-.018em;font-size:clamp(1.25rem,2.3vw,1.7rem);line-height:1.42;color:var(--ink);}
.founder p .yaya-w{color:var(--accent);position:relative;white-space:nowrap;}
.founder p .yaya-w svg{position:absolute;left:0;width:100%;bottom:-.16em;height:.32em;overflow:visible;}
.founder p .yaya-w path{fill:none;stroke:var(--accent);stroke-width:6;stroke-linecap:round;}
.founder .sign{margin-top:34px;font-family:var(--d);font-weight:700;font-size:1.08rem;display:flex;align-items:center;gap:14px;}
.founder .sign::before{content:"";width:36px;height:3px;border-radius:3px;background:var(--accent);}

/* ============================================================ PROOF (count-up) */
.proof{background:var(--accent);color:#fff;padding:clamp(48px,7vw,76px) 0;
  border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);}
.proof-in{display:grid;grid-template-columns:repeat(3,auto) 1fr;gap:28px 40px;align-items:end;}
.proof .stat .n{font-family:var(--d);font-weight:800;font-size:clamp(2.4rem,5.5vw,4rem);letter-spacing:-.04em;line-height:.9;}
.proof .stat .l{font-family:var(--m);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.78);margin-top:10px;}
.proof .meta{justify-self:end;text-align:right;font-family:var(--m);font-size:.76rem;letter-spacing:.08em;
  text-transform:uppercase;line-height:1.9;color:rgba(255,255,255,.9);align-self:end;}
.proof .meta b{color:#fff;}

/* ============================================================ FOOTER */
.footer{padding:clamp(56px,8vw,88px) 0 38px;}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:42px;border-bottom:1px solid var(--line);}
.footer .brand .logo{height:70px;width:calc(70px*var(--ar));}
.footer .blurb{color:var(--ink-2);margin-top:18px;max-width:32ch;font-size:.98rem;}
.footer .logos{display:flex;align-items:center;gap:14px;margin-top:24px;flex-wrap:wrap;}
.footer .logos a{height:32px;display:flex;align-items:center;padding:7px 12px;background:var(--paper-2);
  border-radius:12px;border:1px solid var(--line);transition:transform .2s,border-color .2s;}
.footer .logos a:hover{transform:translateY(-3px);border-color:var(--line-2);}
.footer .logos .logo{height:18px;width:calc(18px*var(--ar));}
.footer .col h4{font-family:var(--m);font-weight:500;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);margin:0 0 14px;}
.footer .col a{display:flex;align-items:center;gap:7px;color:var(--ink-2);padding:7px 0;font-size:.98rem;transition:color .2s;width:max-content;}
.footer .col a:hover{color:var(--accent-deep);}
.footer .col a .ext{color:var(--ink-3);font-size:.8em;}
.footer-bottom{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;
  padding-top:26px;font-family:var(--m);font-size:.72rem;letter-spacing:.06em;color:var(--ink-3);}
.footer-bottom .tagline{color:var(--accent-deep);}

/* ============================================================ REVEAL */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.09s;} .reveal.d2{transition-delay:.18s;} .reveal.d3{transition-delay:.27s;} .reveal.d4{transition-delay:.36s;}

/* ============================================================ RESPONSIVE */
@media (max-width:980px){
  .nav-links{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:flex-start;gap:0;
    background:var(--paper);border-bottom:1px solid var(--line);padding:8px var(--pad) 22px;
    transform:translateY(-8px);opacity:0;pointer-events:none;transition:opacity .22s,transform .22s;}
  .nav-links.open{opacity:1;transform:none;pointer-events:auto;}
  .nav-links a.lnk{padding:13px 0;width:100%;font-size:1.05rem;border-bottom:1px solid var(--line);}
  .nav-links a.lnk::after{display:none;} .nav-cta{margin-top:14px;}
  .nav-links .has-dd{flex-direction:column;align-items:flex-start;width:100%;padding:13px 0;border-bottom:1px solid var(--line);}
  .nav-links .has-dd .dd-caret{display:none;}
  .nav-links .dd{position:static;transform:none;opacity:1;visibility:visible;min-width:0;width:100%;border:none;box-shadow:none;padding:6px 0 0 14px;background:none;margin-top:6px;}
  .nav-links .dd a{padding:9px 0;font-size:1rem;}
  .nav-toggle{display:flex;}
  .hero-grid{grid-template-columns:1fr;gap:8px;}
  .cluster{min-height:330px;margin-top:18px;order:2;}
  .fly-grid{grid-template-columns:1fr;} .fly-stage{order:-1;}
  .credos{grid-template-columns:repeat(2,1fr);}
  .footer-top{grid-template-columns:1fr 1fr;} .footer .brand-col{grid-column:1/-1;}
}
@media (max-width:680px){
  body{font-size:16px;}
  .chapter{grid-template-columns:1fr;gap:14px;}
  .chapter .bar{display:none;}
  .credos{grid-template-columns:1fr;}
  .bento{display:flex;flex-direction:column;}
  .vc-keel{flex-direction:column;align-items:flex-start;}
  .vc-keel .badge{position:static;margin-bottom:14px;}
  .vc-yaya .sticker{height:200px;}
  .proof-in{grid-template-columns:1fr 1fr;gap:24px;}
  .proof .meta{grid-column:1/-1;justify-self:start;text-align:left;}
  .sec-head{flex-direction:column;align-items:flex-start;}
  .footer-top{grid-template-columns:1fr;gap:30px;}
  .cluster{min-height:300px;}
  .chip.c-yaya{width:170px;} .chip.c-hop{width:160px;} .chip.c-gifts{width:128px;}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  *,*::before,*::after{animation:none !important;transition-duration:.001ms !important;}
  .reveal{opacity:1;transform:none;}
  .hero h1 .w>span{transform:none;}
  .hero h1 .mark path,.arc{stroke-dashoffset:0;}
  .fly-spark{opacity:1;}
}

/* ============================================================ BELIEF VISUAL */
.belief-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(32px,5vw,72px);align-items:center;}
.belief-copy{min-width:0;}
.belief-viz{justify-self:end;width:100%;max-width:380px;}
.console{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:0 24px 50px -28px rgba(26,23,20,.32);}
.console-bar{display:flex;align-items:center;gap:9px;padding:13px 18px;border-bottom:1px solid var(--line);font-family:var(--m);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);}
.console-bar .cdot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse 2.4s infinite;}
.console-body{padding:20px 18px 6px;}
.console .spark{display:block;width:100%;height:64px;}
.console .spark path{fill:none;stroke:var(--accent);stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;}
.console .rows{margin-top:14px;}
.console .row{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-top:1px solid var(--line);font-family:var(--m);font-size:.82rem;color:var(--ink-2);}
.console .row span{letter-spacing:.04em;color:var(--ink-3);}
.console .row b{color:var(--ink);font-weight:600;}
.console .row b.good{color:#2f7d52;}
.console-foot{padding:14px 18px;border-top:1px solid var(--line);background:var(--paper-2);font-family:var(--m);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);display:flex;align-items:center;gap:8px;}
.console-foot .arr{color:var(--accent);}

/* ============================================================ KEEL VISUAL */
.keel-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,5vw,72px);align-items:center;}
.keel-copy{min-width:0;}
.keel-viz{justify-self:end;width:100%;max-width:430px;}
.kapp{background:var(--dark-2);border:1px solid rgba(255,255,255,.1);border-radius:16px;overflow:hidden;box-shadow:0 40px 80px -40px rgba(0,0,0,.7);}
.kapp-bar{display:flex;align-items:center;gap:7px;padding:13px 16px;border-bottom:1px solid rgba(255,255,255,.08);}
.kapp-bar i{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.18);}
.kapp-bar i:first-child{background:var(--accent);}
.kapp-bar span{margin-left:8px;font-family:var(--m);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--on-dark-2);}
.kapp-tabs{display:flex;gap:6px;padding:12px 16px 0;}
.kapp-tabs span{font-family:var(--m);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--on-dark-2);padding:7px 11px;border-radius:8px 8px 0 0;}
.kapp-tabs span.on{background:rgba(255,255,255,.07);color:#fff;}
.kapp-body{padding:16px;border-top:1px solid rgba(255,255,255,.08);}
.kline{display:flex;align-items:center;gap:10px;padding:10px 12px;margin-bottom:9px;border-radius:10px;background:rgba(255,255,255,.04);font-family:var(--m);font-size:.76rem;color:var(--on-dark);letter-spacing:.02em;}
.kline .kdot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse 1.8s infinite;flex:none;}
.kline .kdot.slow{background:var(--yaya-2);animation-duration:2.8s;}
.kbar{height:8px;border-radius:6px;background:rgba(255,255,255,.08);overflow:hidden;margin:4px 2px 16px;}
.kbar i{display:block;height:100%;width:72%;border-radius:6px;background:linear-gradient(90deg,var(--accent),var(--accent-deep));}
.kgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.kgrid div{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.07);border-radius:11px;padding:13px 10px;text-align:center;}
.kgrid b{display:block;font-family:var(--d);font-weight:800;font-size:1.35rem;color:#fff;letter-spacing:-.02em;}
.kgrid span{font-family:var(--m);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--on-dark-2);}

/* ============================================================ FOUNDER CLIENTS */
.founder .clients{font-family:var(--m);font-weight:500;font-size:.74rem;line-height:1.9;letter-spacing:.04em;color:var(--yaya-ink);opacity:.85;margin-top:30px;max-width:640px;}
.founder .clients .ck{color:var(--yaya-2);text-transform:uppercase;letter-spacing:.14em;font-size:.64rem;margin-right:10px;}

/* ============================================================ RESPONSIVE (added sections) */
@media (max-width:980px){
  .belief-grid{grid-template-columns:1fr;gap:38px;}
  .belief-viz{justify-self:start;max-width:420px;}
  .keel-grid{grid-template-columns:1fr;gap:40px;}
  .keel-viz{justify-self:start;order:2;max-width:480px;}
}
