/* Cureon v4 — 2026 flagship design system */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0}

:root{
  --paper:#F4F1E9; --paper-2:#FBF9F4; --card:#FFFFFF;
  --ink:#0E1A14; --ink-2:#2C3A32; --ink-soft:#5C6A61;
  --emerald:#0E5C43; --emerald-2:#15774F; --emerald-3:#0A3D2C;
  --lime:#C4F546; --lime-deep:#A6D62E;
  --sand:#E7DDC7; --gold:#C9A861;
  --forest:#0B1611; --forest-2:#0E201700;
  --line:rgba(14,26,20,.10); --line-2:rgba(14,26,20,.16);
  --inv:#F4F1E9; --inv-soft:rgba(244,241,233,.66); --inv-line:rgba(244,241,233,.14);
  --r:18px; --r-lg:30px; --r-xl:42px;
  --sans:'Inter',system-ui,sans-serif; --disp:'Fraunces',Georgia,serif; --mono:'Space Grotesk',ui-monospace,monospace;
  --wrap:1200px;
  --e:cubic-bezier(.2,.7,.2,1);
  /* fluid steps */
  --t-hero:clamp(3rem,11vw,9.5rem);
  --t-h1:clamp(2.4rem,6vw,4.6rem);
  --t-h2:clamp(2rem,4.6vw,3.5rem);
  --t-h3:clamp(1.3rem,2.4vw,1.9rem);
}
body{font-family:var(--sans);background:var(--paper);color:var(--ink);font-size:clamp(1rem,1.05vw,1.08rem);line-height:1.6;-webkit-font-smoothing:antialiased;letter-spacing:-.01em;overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--disp);font-weight:400;line-height:1.02;letter-spacing:-.02em;margin:0}
a{color:inherit;text-decoration:none}
em{font-style:italic}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 clamp(20px,4vw,48px)}
.mono{font-family:var(--mono);letter-spacing:0}

/* grain + reveal */
.grain{position:absolute;inset:0;pointer-events:none;opacity:.5;mix-blend-mode:overlay;z-index:1;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E")}
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--e),transform .8s var(--e)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* scroll progress */
.scroll-bar{position:fixed;top:0;left:0;height:3px;width:100%;transform:scaleX(0);transform-origin:0 50%;background:linear-gradient(90deg,var(--emerald),var(--lime));z-index:200}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--sans);font-weight:600;font-size:.94rem;letter-spacing:-.01em;padding:.85em 1.4em;border-radius:100px;background:var(--ink);color:var(--paper);border:1px solid var(--ink);cursor:pointer;transition:transform .5s var(--e),background .3s,color .3s,box-shadow .5s var(--e)}
.btn:hover{transform:translateY(-2px);box-shadow:0 12px 30px -12px rgba(14,26,20,.5)}
.btn .arr{transition:transform .4s var(--e)}
.btn:hover .arr{transform:translateX(4px)}
.btn-sm{padding:.6em 1.05em;font-size:.85rem}
.btn-lg{padding:1em 1.7em;font-size:1.02rem}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn-lime{background:var(--lime);color:var(--emerald-3);border-color:var(--lime)}
.btn-lime:hover{background:var(--lime-deep);border-color:var(--lime-deep)}

.eyebrow{font-family:var(--mono);font-size:.8rem;text-transform:uppercase;letter-spacing:.16em;color:var(--emerald)}
.klabel{font-family:var(--mono);font-size:.8rem;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-soft)}
.klabel-inv{color:var(--inv-soft)}

/* nav */
.nav{position:sticky;top:0;z-index:100;transition:background .4s,border-color .4s,backdrop-filter .4s}
.nav-in{display:flex;align-items:center;justify-content:space-between;gap:24px;height:74px}
.nav.stuck{background:color-mix(in oklab,var(--paper) 82%,transparent);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:.55em;font-family:var(--disp);font-size:1.5rem;font-weight:500;letter-spacing:-.02em}
.brand-mark{width:16px;height:16px;border-radius:50%;background:radial-gradient(circle at 35% 30%,var(--lime),var(--emerald) 70%);box-shadow:0 0 0 4px color-mix(in oklab,var(--emerald) 18%,transparent)}
.brand-lg{font-size:1.9rem}
.nav-links{display:flex;gap:30px;font-size:.92rem;font-weight:500}
.nav-links a{color:var(--ink-2);transition:color .3s}
.nav-links a:hover{color:var(--emerald)}
@media(max-width:820px){.nav-links{display:none}}

/* ===== HERO ===== */
.hero{position:relative;min-height:clamp(600px,96vh,1000px);display:flex;flex-direction:column;justify-content:center;background:var(--forest);color:var(--inv);overflow:hidden;border-radius:0 0 var(--r-xl) var(--r-xl)}
.hero-bg{position:absolute;inset:-10%;z-index:0;filter:blur(10px);
  background:
    radial-gradient(45% 55% at 18% 22%,rgba(21,119,79,.9),transparent 60%),
    radial-gradient(40% 50% at 82% 30%,rgba(196,245,70,.28),transparent 60%),
    radial-gradient(60% 60% at 70% 95%,rgba(11,61,44,.9),transparent 65%),
    radial-gradient(50% 60% at 30% 88%,rgba(14,92,67,.6),transparent 60%);
  animation:mesh 22s var(--e) infinite alternate}
@keyframes mesh{50%{transform:translate3d(2%,-2%,0) scale(1.08) rotate(2deg)}100%{transform:translate3d(-2%,1%,0) scale(1.04) rotate(-1deg)}}
@media (prefers-reduced-motion:reduce){.hero-bg{animation:none}}
.hero-in{position:relative;z-index:2;padding-top:clamp(40px,8vh,90px);padding-bottom:clamp(40px,7vh,80px)}
.hero .eyebrow{color:var(--lime)}
.hero-h{font-size:var(--t-hero);font-weight:300;margin:.28em 0 0;letter-spacing:-.035em}
.hero-h em{font-style:italic;font-weight:400;background:linear-gradient(100deg,var(--lime),#eaffb0);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero-sub{max-width:37ch;margin:1.4em 0 0;font-size:clamp(1.05rem,1.5vw,1.3rem);color:var(--inv-soft);line-height:1.5}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:2.2em}
.hero .btn-ghost{color:var(--inv);border-color:var(--inv-line)}
.hero .btn-ghost:hover{background:var(--inv);color:var(--ink)}
.hero-stats{display:flex;flex-wrap:wrap;gap:clamp(28px,5vw,64px);margin-top:clamp(40px,7vh,80px);padding-top:34px;border-top:1px solid var(--inv-line)}
.hstat{display:flex;flex-direction:column}
.hstat-n{font-family:var(--disp);font-size:clamp(2.2rem,4vw,3.4rem);line-height:1;color:var(--inv);font-variant-numeric:tabular-nums}
.hstat-l{margin-top:.5em;font-size:.82rem;color:var(--inv-soft);text-transform:uppercase;letter-spacing:.05em;max-width:16ch}

/* marquee */
.marquee{position:relative;z-index:2;border-top:1px solid var(--inv-line);overflow:hidden;padding:16px 0;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;gap:26px;width:max-content;animation:scroll 34s linear infinite;align-items:center;font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;font-size:.82rem;color:var(--inv-soft)}
.marquee-track .dot{color:var(--lime)}
@keyframes scroll{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee-track{animation:none}}

/* sections */
.sec{padding:clamp(70px,12vh,150px) 0;position:relative}
.sec-top{padding-top:clamp(30px,5vh,50px)}
.sec-head{max-width:760px;margin-bottom:clamp(40px,6vh,70px)}
.sec-head-row{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;max-width:100%}
.sec-h{font-size:var(--t-h2);font-weight:400;margin-top:.4em}
.klabel+.sec-h{margin-top:.5em}

/* bento */
.bento{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(14px,1.6vw,22px)}
.tile{position:relative;display:flex;flex-direction:column;justify-content:space-between;min-height:230px;padding:clamp(22px,2.4vw,34px);border-radius:var(--r-lg);background:var(--card);border:1px solid var(--line);overflow:hidden;transition:transform .6s var(--e),box-shadow .6s var(--e),border-color .4s}
.tile:hover{transform:translateY(-4px);box-shadow:0 30px 60px -30px rgba(14,26,20,.28);border-color:var(--line-2)}
.tile-big{grid-row:span 2;min-height:480px;background:var(--emerald-3);color:var(--inv);border-color:transparent}
.tile-big::before{content:"";position:absolute;inset:0;background:radial-gradient(80% 70% at 80% 100%,rgba(196,245,70,.22),transparent 60%),radial-gradient(70% 60% at 10% 0%,rgba(21,119,79,.5),transparent 60%)}
.tile-top,.tile-body{position:relative;z-index:1}
.tile-top{display:flex;justify-content:space-between;align-items:center}
.tile-tag{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;padding:.45em .8em;border-radius:100px;border:1px solid var(--line-2);color:var(--ink-soft)}
.tile-big .tile-tag{border-color:var(--inv-line);color:var(--lime)}
.tile-arr{font-size:1.3rem;color:var(--ink-soft);transition:transform .4s var(--e)}
.tile:hover .tile-arr{transform:translate(3px,-3px)}
.tile-big .tile-arr{color:var(--inv)}
.tile-body h3{font-size:var(--t-h3);margin-bottom:.35em}
.tile-big .tile-body h3{font-size:clamp(2rem,3.4vw,3rem)}
.tile-body p{color:var(--ink-soft);max-width:34ch;font-size:.98rem}
.tile-big .tile-body p{color:var(--inv-soft);max-width:26ch}
@media(max-width:760px){.bento{grid-template-columns:1fr}.tile-big{grid-row:auto;min-height:300px}}

/* dark approach */
.sec-dark{background:var(--forest);color:var(--inv);overflow:hidden;border-radius:var(--r-xl)}
.sec-dark{margin:0 clamp(8px,2vw,20px)}
.approach{position:relative;z-index:2;text-align:center}
.manifesto{font-family:var(--disp);font-weight:300;font-size:clamp(2.4rem,6.4vw,5.6rem);line-height:.98;letter-spacing:-.03em;margin:.35em auto 0;max-width:16ch}
.manifesto em{color:var(--lime);font-weight:400}
.approach-sub{max-width:52ch;margin:1.6em auto 0;color:var(--inv-soft);font-size:1.15rem}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,44px);margin-top:clamp(50px,8vh,90px);text-align:left}
.pillar{padding-top:22px;border-top:1px solid var(--inv-line)}
.pillar-n{font-family:var(--mono);color:var(--lime);font-size:.85rem}
.pillar h4{font-size:1.4rem;margin:.5em 0 .4em;color:var(--inv)}
.pillar p{color:var(--inv-soft);font-size:.96rem}
@media(max-width:760px){.pillars{grid-template-columns:1fr}}

/* featured + cards */
.feat{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(20px,3vw,44px);align-items:center;padding:clamp(18px,2vw,26px);border-radius:var(--r-xl);background:var(--card);border:1px solid var(--line);transition:transform .6s var(--e),box-shadow .6s var(--e)}
.feat:hover{transform:translateY(-4px);box-shadow:0 40px 80px -40px rgba(14,26,20,.32)}
.feat-art{position:relative;aspect-ratio:16/12;border-radius:calc(var(--r-xl) - 12px);overflow:hidden;display:flex;align-items:flex-end;padding:22px}
.feat-cat,.jcard-cat{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:#fff;background:rgba(0,0,0,.28);padding:.5em .85em;border-radius:100px;backdrop-filter:blur(6px);position:relative;z-index:2}
.feat-body{padding:clamp(6px,1.5vw,26px) clamp(14px,2vw,30px)}
.feat-body h3{font-size:clamp(1.6rem,2.8vw,2.5rem);margin:.4em 0}
.feat-ex{color:var(--ink-soft);max-width:44ch}
.feat-meta{display:inline-flex;align-items:center;gap:.5em;margin-top:1.4em;font-family:var(--mono);font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;color:var(--emerald)}
@media(max-width:820px){.feat{grid-template-columns:1fr}}

.jgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:clamp(16px,2vw,26px);margin-top:clamp(30px,5vh,54px)}
.jgrid-full{margin-top:40px}
.jcard{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:transform .5s var(--e),box-shadow .5s var(--e),border-color .3s}
.jcard:hover{transform:translateY(-5px);box-shadow:0 28px 55px -30px rgba(14,26,20,.3);border-color:var(--line-2)}
.jcard-art{position:relative;aspect-ratio:16/10;display:flex;align-items:flex-end;padding:16px}
.jcard-body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.jcard-body h3{font-size:1.28rem;line-height:1.12;margin-bottom:.5em;transition:color .3s}
.jcard:hover .jcard-body h3{color:var(--emerald)}
.jcard-body p{color:var(--ink-soft);font-size:.92rem;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.jcard-meta{margin-top:1.2em;font-family:var(--mono);font-size:.76rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft)}
.jcard.hide{display:none}

/* cta band */
.cta-band{background:linear-gradient(120deg,var(--emerald-3),var(--emerald));color:var(--inv);border-radius:var(--r-xl);margin:0 clamp(8px,2vw,20px) clamp(20px,4vw,40px);overflow:hidden;text-align:center}
.cta-in h2{font-size:var(--t-h2);font-weight:400}
.cta-in p{max-width:46ch;margin:1em auto 0;color:var(--inv-soft);font-size:1.15rem}
.cta-in .hero-cta{justify-content:center}
.cta-band .btn-ghost{color:var(--inv);border-color:var(--inv-line)}
.cta-band .btn-ghost:hover{background:var(--inv);color:var(--emerald-3)}

/* ===== JOURNAL INDEX ===== */
.jhero{position:relative;background:var(--forest);color:var(--inv);padding:clamp(90px,16vh,180px) 0 clamp(50px,8vh,90px);overflow:hidden;border-radius:0 0 var(--r-xl) var(--r-xl)}
.jhero::before{content:"";position:absolute;inset:0;background:radial-gradient(50% 60% at 80% 10%,rgba(21,119,79,.6),transparent 60%),radial-gradient(40% 50% at 10% 90%,rgba(196,245,70,.16),transparent 60%)}
.jhero>.wrap{position:relative;z-index:2}
.jhero .eyebrow{color:var(--lime)}
.jhero-h{font-size:var(--t-h1);font-weight:300;margin:.3em 0 0}
.jhero-sub{max-width:50ch;margin:1.3em 0 0;color:var(--inv-soft);font-size:1.15rem}
.jsearch{display:flex;align-items:center;gap:12px;margin-top:2.2em;max-width:520px;background:rgba(244,241,233,.08);border:1px solid var(--inv-line);border-radius:100px;padding:.4em 1.2em;transition:border-color .3s,background .3s}
.jsearch:focus-within{border-color:var(--lime);background:rgba(244,241,233,.12)}
.jsearch svg{width:20px;height:20px;color:var(--inv-soft);flex:none}
.jsearch input{flex:1;background:none;border:none;outline:none;color:var(--inv);font-family:var(--sans);font-size:1.02rem;padding:.7em 0}
.jsearch input::placeholder{color:var(--inv-soft)}
.chips{display:flex;flex-wrap:wrap;gap:9px;position:sticky;top:74px;z-index:40;padding:14px 0;background:color-mix(in oklab,var(--paper) 88%,transparent);backdrop-filter:blur(8px)}
.chip{font-family:var(--sans);font-size:.85rem;font-weight:600;color:var(--ink-soft);background:var(--card);border:1px solid var(--line);border-radius:100px;padding:.55em 1em;cursor:pointer;transition:all .25s var(--e)}
.chip span{opacity:.5;margin-left:.2em}
.chip:hover{border-color:var(--emerald);color:var(--emerald)}
.chip.is-on{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.chip.is-on span{opacity:.6}
.jempty{text-align:center;padding:80px 0;color:var(--ink-soft)}
.jempty button{color:var(--emerald);font-weight:600;text-decoration:underline;background:none;border:none;cursor:pointer;font-size:1rem}

/* ===== ARTICLE ===== */
.art-head{position:relative}
.art-art{position:relative;height:clamp(220px,38vh,420px);border-radius:0 0 var(--r-xl) var(--r-xl);overflow:hidden}
.art-head-in{position:relative;margin-top:clamp(-90px,-9vh,-70px);z-index:3;text-align:center;max-width:820px}
.crumb{display:inline-block;font-family:var(--mono);font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;color:var(--emerald);margin-bottom:1.2em}
.art-cat{font-family:var(--mono);font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;color:var(--gold)}
.art-h{font-size:var(--t-h1);font-weight:400;margin:.35em auto 0;max-width:20ch}
.art-ex{max-width:56ch;margin:1em auto 0;color:var(--ink-soft);font-size:1.2rem;line-height:1.5}
.art-meta{margin-top:1.4em;font-family:var(--mono);font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft)}
.dotm{margin:0 .4em;color:var(--gold)}

.art-grid{display:grid;grid-template-columns:1fr;max-width:760px;margin-top:clamp(40px,6vh,70px);padding-bottom:clamp(60px,10vh,120px)}
.art-side{display:none}
@media(min-width:1080px){
  .art-grid{grid-template-columns:230px 1fr;gap:60px;max-width:1080px}
  .art-side{display:block}
  .toc{position:sticky;top:110px}
}
.toc-h{font-family:var(--mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);margin:0 0 1em}
.toc ol{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.7em;border-left:1px solid var(--line)}
.toc a{display:flex;gap:.7em;font-size:.9rem;color:var(--ink-soft);padding-left:16px;margin-left:-1px;border-left:2px solid transparent;transition:color .3s,border-color .3s;line-height:1.3}
.toc a span{font-family:var(--mono);font-size:.72rem;color:var(--gold)}
.toc a:hover{color:var(--emerald)}
.toc a.active{color:var(--ink);border-color:var(--emerald);font-weight:500}

.key{background:var(--emerald-3);color:var(--inv);border-radius:var(--r-lg);padding:clamp(24px,3vw,36px);margin-bottom:clamp(30px,4vh,48px);position:relative;overflow:hidden}
.key::before{content:"";position:absolute;inset:0;background:radial-gradient(70% 80% at 90% 10%,rgba(196,245,70,.18),transparent 60%)}
.key-h{position:relative;font-family:var(--mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--lime);margin:0 0 1em}
.key ul{position:relative;list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.85em}
.key li{position:relative;padding-left:1.7em;color:var(--inv);line-height:1.5}
.key li::before{content:"";position:absolute;left:0;top:.55em;width:8px;height:8px;border-radius:50%;background:var(--lime)}

.prose{font-size:1.12rem;line-height:1.75;color:var(--ink-2)}
.prose>p:first-of-type::first-letter{float:left;font-family:var(--disp);font-weight:500;font-size:3.6rem;line-height:.8;padding:.08em .14em 0 0;color:var(--emerald)}
.prose h2{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:400;margin:1.8em 0 .5em;scroll-margin-top:100px;letter-spacing:-.02em}
.prose h3{font-size:1.35rem;margin:1.5em 0 .4em}
.prose p{margin:0 0 1.1em}
.prose a{color:var(--emerald);text-decoration:underline;text-underline-offset:2px;text-decoration-color:color-mix(in oklab,var(--emerald) 40%,transparent)}
.prose strong{font-weight:600;color:var(--ink)}
.prose ul,.prose ol{margin:0 0 1.3em;padding-left:1.3em}
.prose li{margin:.4em 0}
.prose ul li::marker{color:var(--emerald)}
.prose blockquote{margin:1.6em 0;padding:.4em 0 .4em 1.5em;border-left:3px solid var(--emerald);font-family:var(--disp);font-size:1.5rem;line-height:1.35;color:var(--ink)}
.prose blockquote p{margin:0}
.cite a{font-size:.7em;color:var(--emerald);text-decoration:none;font-weight:600;padding:0 .1em}
.tbl-wrap{overflow-x:auto;margin:1.6em 0;border:1px solid var(--line);border-radius:var(--r)}
.prose table{border-collapse:collapse;width:100%;font-size:.95rem}
.prose th,.prose td{text-align:left;padding:.8em 1em;border-bottom:1px solid var(--line)}
.prose thead th{background:var(--paper-2);font-family:var(--sans);font-weight:600;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-soft)}

.art-cta{margin:clamp(40px,6vh,64px) 0;padding:clamp(28px,3vw,40px);border-radius:var(--r-lg);background:var(--sand);text-align:center}
.art-cta h3{font-size:1.7rem}
.art-cta p{max-width:44ch;margin:.7em auto 1.4em;color:var(--ink-2)}
.art-cta .hero-cta{justify-content:center}

.sources{margin-top:clamp(40px,6vh,60px);border-top:1px solid var(--line);padding-top:30px}
.sources h2{font-family:var(--mono);font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);font-weight:600}
.sources ol{margin:1em 0 0;padding-left:1.3em;font-size:.9rem;color:var(--ink-soft);display:flex;flex-direction:column;gap:.6em}
.sources a{color:var(--emerald)}
.sources li:target{color:var(--ink)}
.related{margin-top:clamp(50px,8vh,80px)}
.disc{margin-top:clamp(40px,5vh,56px);text-align:center;font-size:.85rem;color:var(--ink-soft)}
.disc a{color:var(--emerald);text-decoration:underline}

/* footer */
.foot{background:var(--forest);color:var(--inv);border-radius:var(--r-xl) var(--r-xl) 0 0;margin-top:40px;padding:clamp(56px,9vh,100px) 0 40px}
.foot-in{display:grid;grid-template-columns:1.3fr 2fr;gap:clamp(30px,5vw,80px)}
.foot-brand p{color:var(--inv-soft);max-width:34ch;margin:1.2em 0 1.6em}
.foot-brand .btn{background:var(--lime);color:var(--emerald-3);border-color:var(--lime)}
.foot-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.foot-cols h4{font-family:var(--mono);font-size:.76rem;text-transform:uppercase;letter-spacing:.1em;color:var(--inv-soft);font-weight:500;margin-bottom:1.2em}
.foot-cols a{display:block;color:var(--inv);opacity:.82;margin-bottom:.7em;font-size:.94rem;transition:opacity .3s,color .3s}
.foot-cols a:hover{opacity:1;color:var(--lime)}
.foot-base{display:flex;justify-content:space-between;align-items:center;margin-top:clamp(40px,7vh,70px);padding-top:26px;border-top:1px solid var(--inv-line);font-size:.82rem;color:var(--inv-soft)}
@media(max-width:760px){.foot-in{grid-template-columns:1fr}.foot-cols{grid-template-columns:repeat(2,1fr)}.foot-base{flex-direction:column;gap:10px;align-items:flex-start}}

:focus-visible{outline:2px solid var(--emerald);outline-offset:3px;border-radius:4px}
.jhero :focus-visible,.hero :focus-visible,.foot :focus-visible{outline-color:var(--lime)}
