/* The Vellum Room - Mulberry Reflection */
:root{
  --primary:#6E3F63;      /* mulberry */
  --secondary:#9B93AE;    /* lavender-grey */
  --accent:#3FA98A;       /* mint, the single accent */
  --bg:#F7F3F6;
  --fg:#241B26;
  --primary-soft:#8a5a80;
  --line:rgba(110,63,99,.16);
  --line-soft:rgba(110,63,99,.09);
  --paper:#FCFAFB;
  --shadow:0 22px 50px -28px rgba(110,63,99,.42);
  --shadow-sm:0 10px 30px -22px rgba(110,63,99,.5);
  --radius:12px;
  --measure:66ch;
  --maxw:1180px;
  --font-display:"Della Respira",Georgia,serif;
  --font-body:"Tenor Sans",system-ui,sans-serif;
  --font-mono:"Spline Sans Mono",ui-monospace,monospace;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--fg);
  font-family:var(--font-body);font-size:18px;line-height:1.7;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline;text-underline-offset:3px}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:400;color:var(--primary);line-height:1.12;letter-spacing:.2px;margin:0}
em{font-style:italic}
.wrap{width:min(var(--maxw),92vw);margin-inline:auto}
.skip{position:absolute;left:-999px;top:0;background:var(--primary);color:#fff;padding:.7rem 1.1rem;border-radius:0 0 var(--radius) 0;z-index:200}
.skip:focus{left:0}
:focus-visible{outline:2.5px solid var(--accent);outline-offset:3px;border-radius:3px}

/* ---- background wash ---- */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(1100px 620px at 82% -8%, rgba(110,63,99,.10), transparent 60%),
    radial-gradient(900px 560px at 6% 12%, rgba(155,147,174,.16), transparent 62%),
    radial-gradient(760px 600px at 50% 108%, rgba(63,169,138,.07), transparent 60%),
    var(--bg);
}
body::after{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background-image:linear-gradient(var(--line-soft) 1px,transparent 1px);
  background-size:100% 96px;mask-image:linear-gradient(transparent,#000 14%,#000 86%,transparent);
}

/* ---- eyebrow ---- */
.eyebrow{
  font-family:var(--font-mono);font-size:.7rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--primary-soft);margin:0 0 1.1rem;display:inline-flex;align-items:center;gap:.6rem;font-weight:500;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--accent)}

/* ---- header ---- */
.site-head{position:sticky;top:0;z-index:100;backdrop-filter:blur(12px);
  background:rgba(247,243,246,.82);border-bottom:1px solid var(--line-soft)}
.head-inner{display:flex;align-items:center;justify-content:space-between;gap:1.4rem;padding:.95rem 0}
.brand{display:inline-flex;align-items:center;gap:.7rem;color:var(--primary)}
.brand:hover{text-decoration:none}
.brand-mark{display:grid;place-items:center;width:38px;height:38px;border-radius:10px;
  background:linear-gradient(150deg,var(--primary),#52304b);color:var(--bg);
  font-family:var(--font-mono);font-size:.82rem;letter-spacing:.04em;box-shadow:var(--shadow-sm)}
.brand-name{font-family:var(--font-display);font-size:1.28rem;letter-spacing:.3px}
.nav{display:flex;align-items:center;gap:1.7rem}
.nav>a{color:var(--fg);font-size:.96rem;letter-spacing:.2px;position:relative}
.nav>a:not(.nav-cta):hover{color:var(--primary);text-decoration:none}
.nav>a:not(.nav-cta)::after{content:"";position:absolute;left:0;right:100%;bottom:-6px;height:1.5px;background:var(--accent);transition:right .3s ease}
.nav>a:not(.nav-cta):hover::after,.nav>a[aria-current]::after{right:0}
.nav>a[aria-current]{color:var(--primary)}
.nav-cta{display:inline-flex;align-items:center;gap:.5rem;background:var(--primary);color:var(--bg)!important;
  padding:.62rem 1.05rem;border-radius:var(--radius);font-size:.9rem;box-shadow:var(--shadow-sm);transition:transform .25s,background .25s}
.nav-cta:hover{text-decoration:none;background:#5d3454;transform:translateY(-2px)}
.nav-cta svg{transition:transform .25s}
.nav-cta:hover svg{transform:translateX(3px)}
.menu-toggle{display:none}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-body);font-size:1rem;
  padding:.95rem 1.6rem;border-radius:var(--radius);border:1px solid transparent;cursor:pointer;transition:transform .25s,box-shadow .25s,background .25s}
.btn-primary{background:var(--primary);color:var(--bg);box-shadow:var(--shadow)}
.btn-primary:hover{text-decoration:none;background:#5d3454;transform:translateY(-2px)}
.btn-primary svg{transition:transform .25s}
.btn-primary:hover svg{transform:translateX(4px)}
.btn-ghost{background:transparent;color:var(--primary);border-color:var(--line)}
.btn-ghost:hover{text-decoration:none;border-color:var(--primary);background:rgba(110,63,99,.04)}

/* ---- hero ---- */
.hero{position:relative;padding:clamp(3.4rem,8vh,6rem) 0 clamp(3rem,7vh,5rem)}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.hero h1{font-size:clamp(2.7rem,6vw,4.6rem);letter-spacing:-.4px;margin-bottom:1.3rem}
.hero h1 em{color:var(--primary-soft)}
.hero .stand{font-size:clamp(1.05rem,1.7vw,1.24rem);color:var(--fg);max-width:42ch;line-height:1.6;margin-bottom:1.9rem;opacity:.92}
.hero-cta{display:flex;gap:.9rem;flex-wrap:wrap;align-items:center}
.hero-note{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;color:var(--secondary);text-transform:uppercase;margin-top:1.7rem}
.hero-figure{position:relative;aspect-ratio:4/5;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line-soft)}
.hero-figure img{width:100%;height:100%;object-fit:cover}
.hero-figure::after{content:"";position:absolute;inset:0;background:linear-gradient(200deg,transparent 40%,rgba(110,63,99,.28))}
.hero-badge{position:absolute;left:-18px;bottom:26px;z-index:3;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius);padding:.95rem 1.15rem;box-shadow:var(--shadow);max-width:200px}
.hero-badge .n{font-family:var(--font-mono);font-size:1.5rem;color:var(--primary);font-weight:600}
.hero-badge .t{font-size:.82rem;color:var(--fg);opacity:.8;line-height:1.4;margin-top:.2rem}
.hero-orbit{position:absolute;right:-30px;top:-22px;width:120px;height:120px;border:1px solid var(--line);border-radius:50%;z-index:-1}
.hero-orbit::after{content:"";position:absolute;width:11px;height:11px;border-radius:50%;background:var(--accent);top:-6px;left:50%;transform:translateX(-50%)}

/* ---- section frame ---- */
.section{padding:clamp(3.4rem,8vh,6rem) 0}
.section-head{max-width:60ch;margin-bottom:2.8rem}
.section-head.center{margin-inline:auto;text-align:center}
.section-head h2{font-size:clamp(1.9rem,3.6vw,2.9rem);margin-bottom:1rem}
.section-head p{color:var(--fg);opacity:.85;font-size:1.06rem;line-height:1.7;max-width:60ch}
.section-head.center p{margin-inline:auto}
.hr{border:0;height:1px;background:var(--line);margin:0}

/* ---- stats ---- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--paper)}
.stat{padding:2rem 1.5rem;border-right:1px solid var(--line-soft)}
.stat:last-child{border-right:0}
.stat .num{font-family:var(--font-mono);font-size:clamp(2rem,3.4vw,2.7rem);color:var(--primary);font-weight:600;letter-spacing:-.02em;line-height:1}
.stat .lab{margin-top:.7rem;font-size:.92rem;color:var(--fg);opacity:.78;line-height:1.45}

/* ---- pillars / services cards ---- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
.card{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius);padding:2rem 1.85rem;
  position:relative;transition:transform .35s,box-shadow .35s,border-color .35s}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--line)}
.card .ico{display:grid;place-items:center;width:52px;height:52px;border-radius:13px;
  background:rgba(110,63,99,.07);color:var(--primary);margin-bottom:1.3rem}
.card:hover .ico{color:var(--accent)}
.card h3{font-size:1.32rem;margin-bottom:.7rem}
.card p{font-size:.99rem;line-height:1.65;opacity:.85;margin:0}
.card .ix{font-family:var(--font-mono);font-size:.72rem;color:var(--secondary);position:absolute;top:1.6rem;right:1.7rem;letter-spacing:.1em}
.card .more{display:inline-flex;align-items:center;gap:.45rem;margin-top:1.2rem;font-size:.9rem;color:var(--accent)}
.card .more svg{transition:transform .25s}
.card:hover .more svg{transform:translateX(4px)}

/* ---- split / approach ---- */
.split{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.split-figure{position:relative;aspect-ratio:5/4;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line-soft)}
.split-figure img{width:100%;height:100%;object-fit:cover}
.steps{list-style:none;margin:1.8rem 0 0;padding:0;display:grid;gap:1.3rem}
.steps li{display:grid;grid-template-columns:auto 1fr;gap:1.1rem;align-items:start}
.steps .k{font-family:var(--font-mono);font-size:.82rem;color:var(--accent);border:1px solid var(--line);border-radius:8px;
  width:34px;height:34px;display:grid;place-items:center;flex:0 0 auto}
.steps h4{font-size:1.1rem;margin-bottom:.25rem}
.steps p{margin:0;font-size:.97rem;opacity:.84;line-height:1.6}

/* ---- journal cards ---- */
.j-list{display:grid;gap:1.4rem}
.j-card{display:grid;grid-template-columns:300px 1fr;gap:1.8rem;background:var(--paper);border:1px solid var(--line-soft);
  border-radius:var(--radius);overflow:hidden;transition:transform .35s,box-shadow .35s,border-color .35s}
.j-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line)}
.j-card .thumb{position:relative;aspect-ratio:1/1;overflow:hidden}
.j-card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.j-card:hover .thumb img{transform:scale(1.05)}
.j-card .body{padding:1.8rem 1.9rem 1.8rem 0;display:flex;flex-direction:column;justify-content:center}
.j-meta{display:flex;gap:.9rem;align-items:center;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;
  color:var(--secondary);text-transform:uppercase;margin-bottom:.8rem}
.j-meta .tag{color:var(--primary-soft)}
.j-card h3{font-size:1.5rem;margin-bottom:.6rem;color:var(--primary)}
.j-card h3 a{color:inherit}
.j-card h3 a:hover{color:var(--accent);text-decoration:none}
.j-card p{font-size:.99rem;opacity:.85;line-height:1.6;margin:0 0 1rem}
.j-card .read{display:inline-flex;align-items:center;gap:.45rem;color:var(--accent);font-size:.92rem}
.j-card .read svg{transition:transform .25s}
.j-card:hover .read svg{transform:translateX(4px)}

/* ---- resources blogroll ---- */
.roll{display:grid;grid-template-columns:repeat(2,1fr);gap:1.1rem}
.roll a.roll-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:var(--paper);
  border:1px solid var(--line-soft);border-radius:var(--radius);padding:1.15rem 1.4rem;color:var(--fg);transition:border-color .3s,transform .3s}
.roll a.roll-item:hover{text-decoration:none;border-color:var(--accent);transform:translateX(4px)}
.roll .rl{display:flex;flex-direction:column;gap:.2rem}
.roll .rl .a{font-size:1.05rem;color:var(--primary)}
.roll .rl .u{font-family:var(--font-mono);font-size:.72rem;color:var(--secondary);letter-spacing:.04em}
.roll .ra{color:var(--accent);flex:0 0 auto}

/* ---- testimonials ---- */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.quote{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius);padding:2rem 1.8rem;position:relative}
.quote .qm{color:rgba(110,63,99,.16);margin-bottom:.4rem}
.quote blockquote{margin:0;font-family:var(--font-display);font-size:1.18rem;line-height:1.5;color:var(--fg)}
.quote .who{margin-top:1.4rem;display:flex;align-items:center;gap:.8rem}
.quote .av{width:42px;height:42px;border-radius:50%;background:linear-gradient(150deg,var(--secondary),var(--primary));
  display:grid;place-items:center;color:#fff;font-family:var(--font-mono);font-size:.82rem;flex:0 0 auto}
.quote .who .nm{font-size:.96rem;color:var(--primary)}
.quote .who .rl{font-size:.8rem;color:var(--secondary);font-family:var(--font-mono);letter-spacing:.03em}

/* ---- team ---- */
.team{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.member{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius);padding:1.8rem;text-align:center}
.member .ph{width:88px;height:88px;border-radius:50%;margin:0 auto 1.1rem;display:grid;place-items:center;
  font-family:var(--font-display);font-size:1.7rem;color:#fff;background:linear-gradient(155deg,var(--primary),var(--secondary))}
.member h3{font-size:1.2rem;margin-bottom:.2rem}
.member .role{font-family:var(--font-mono);font-size:.74rem;color:var(--accent);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.8rem}
.member p{font-size:.92rem;opacity:.82;line-height:1.55;margin:0}

/* ---- cta band ---- */
.band{position:relative;border-radius:calc(var(--radius)*1.6);overflow:hidden;padding:clamp(2.6rem,6vw,4.5rem);
  background:linear-gradient(150deg,#5b3352,var(--primary) 55%,#7a4a6f);color:var(--bg);text-align:center}
.band::before{content:"";position:absolute;inset:0;background:
  radial-gradient(420px 320px at 18% 20%,rgba(63,169,138,.22),transparent 60%),
  radial-gradient(420px 320px at 86% 88%,rgba(155,147,174,.26),transparent 60%)}
.band>*{position:relative;z-index:1}
.band h2{color:var(--bg);font-size:clamp(2rem,4vw,3rem);margin-bottom:1rem;max-width:18ch;margin-inline:auto}
.band p{max-width:48ch;margin:0 auto 1.9rem;opacity:.92;line-height:1.6}
.band .btn-primary{background:var(--bg);color:var(--primary)}
.band .btn-primary:hover{background:#fff}
.band .btn-ghost{color:var(--bg);border-color:rgba(247,243,246,.4)}
.band .btn-ghost:hover{border-color:var(--bg);background:rgba(247,243,246,.08)}

/* ---- page hero (inner) ---- */
.page-hero{padding:clamp(3rem,7vh,5rem) 0 clamp(2rem,4vh,3rem)}
.page-hero h1{font-size:clamp(2.4rem,5vw,3.8rem);margin-bottom:1.1rem;max-width:18ch}
.page-hero .lede{font-size:1.18rem;line-height:1.65;max-width:var(--measure);color:var(--fg);opacity:.9}
.crumbs{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--secondary);margin-bottom:1.4rem}
.crumbs a{color:var(--secondary)}
.crumbs a:hover{color:var(--primary);text-decoration:none}

/* ---- article ---- */
.article{padding:clamp(2rem,5vh,3.5rem) 0 clamp(3rem,7vh,5rem)}
.art-hero{margin-bottom:2.4rem}
.art-figure{aspect-ratio:16/9;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line-soft);margin-bottom:2.4rem}
.art-figure img{width:100%;height:100%;object-fit:cover}
.prose{max-width:var(--measure);margin-inline:auto;font-size:1.08rem;line-height:1.75}
.prose>*{margin-block:1.15rem}
.prose h2{font-size:clamp(1.6rem,3vw,2.2rem);margin-top:2.6rem;margin-bottom:1rem;line-height:1.18}
.prose h3{font-size:1.32rem;margin-top:1.9rem;margin-bottom:.7rem;color:var(--primary-soft)}
.prose p{color:var(--fg)}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.prose a:hover{color:var(--primary)}
.prose strong{color:var(--primary)}
.prose ul,.prose ol{padding-inline-start:1.4rem}
.prose li{margin-block:.5rem}
.prose img{border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-block:1.8rem;width:100%;height:auto;aspect-ratio:16/9;object-fit:cover}
.prose section{margin-block:1.1rem}
.prose section h2{margin-top:2.4rem}
.prose blockquote{border-inline-start:3px solid var(--accent);padding-inline-start:1.2rem;font-style:italic;color:var(--primary-soft)}
.prose.rtl{direction:rtl;text-align:right}
.prose.rtl ul,.prose.rtl ol{padding-inline-start:0;padding-inline-end:1.4rem}
.art-foot{max-width:var(--measure);margin:3rem auto 0;padding-top:2rem;border-top:1px solid var(--line)}
.art-source{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem 1.7rem;display:flex;
  gap:1.1rem;align-items:center;justify-content:space-between;flex-wrap:wrap}
.art-source .s-l{display:flex;flex-direction:column;gap:.25rem}
.art-source .s-l .h{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--secondary)}
.art-source .s-l a{color:var(--primary);font-size:1.06rem}
.art-aside{max-width:var(--measure);margin:1.4rem auto 0;font-size:.92rem;color:var(--secondary);font-family:var(--font-mono);letter-spacing:.02em}

/* ---- contact ---- */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.form{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.8rem,3vw,2.6rem);box-shadow:var(--shadow-sm)}
.field{margin-bottom:1.3rem}
.field label{display:block;font-size:.88rem;letter-spacing:.02em;color:var(--primary);margin-bottom:.5rem}
.field label .req{color:var(--accent)}
.field input,.field textarea{width:100%;font-family:var(--font-body);font-size:1rem;color:var(--fg);background:var(--bg);
  border:1px solid var(--line);border-radius:10px;padding:.85rem 1rem;transition:border-color .25s,box-shadow .25s}
.field textarea{min-height:150px;resize:vertical;line-height:1.6}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(63,169,138,.16)}
.field input::placeholder,.field textarea::placeholder{color:var(--secondary);opacity:.7}
.form .btn-primary{width:100%;justify-content:center;font-size:1.05rem}
.form-note{font-size:.82rem;color:var(--secondary);margin-top:1rem;line-height:1.5}
.thanks{display:none;background:rgba(63,169,138,.1);border:1px solid rgba(63,169,138,.4);border-radius:var(--radius);
  padding:1.2rem 1.4rem;color:var(--primary);margin-top:1.3rem;font-size:.96rem}
.thanks.show{display:block}
.contact-aside h2{font-size:1.7rem;margin-bottom:1rem}
.contact-aside .lede{opacity:.88;line-height:1.7;margin-bottom:1.8rem}
.detail{display:flex;gap:.9rem;align-items:flex-start;padding:1.1rem 0;border-bottom:1px solid var(--line-soft)}
.detail:last-child{border-bottom:0}
.detail .di{color:var(--accent);flex:0 0 auto;margin-top:2px}
.detail .dh{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--secondary);font-family:var(--font-mono);margin-bottom:.25rem}
.detail .dv{display:block;color:var(--primary);font-size:1.04rem;line-height:1.4}
.detail .dv a{color:var(--primary)}

/* ---- reveal ---- */
.reveal{opacity:0;transform:translateY(24px);filter:blur(7px);transition:opacity .9s ease,transform .9s cubic-bezier(.2,.7,.2,1),filter .9s ease}
.reveal.in{opacity:1;transform:none;filter:none}

/* ---- hero entrance (CSS-driven, resilient; only when JS arms it) ---- */
[data-hero]{opacity:1}
.js-anim [data-hero]{opacity:0;transform:translateY(26px);filter:blur(8px);animation:heroIn .95s cubic-bezier(.2,.7,.2,1) forwards}
.js-anim [data-hero]:nth-child(1){animation-delay:.05s}
.js-anim .hero-copy [data-hero]:nth-of-type(2){animation-delay:.16s}
.js-anim .hero-copy [data-hero]:nth-of-type(3){animation-delay:.27s}
.js-anim .hero-copy [data-hero]:nth-of-type(4){animation-delay:.38s}
.js-anim .hero-copy [data-hero]:nth-of-type(5){animation-delay:.49s}
.js-anim .hero-figure[data-hero]{animation-delay:.2s}
@keyframes heroIn{to{opacity:1;transform:none;filter:none}}

/* ---- footer ---- */
.site-foot{margin-top:clamp(3rem,7vh,5rem);border-top:1px solid var(--line);background:rgba(252,250,251,.6)}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1.4fr 1.2fr;gap:2rem;padding:clamp(2.6rem,5vw,3.6rem) 0 2.4rem}
.foot-brand .brand-mark{margin-bottom:1rem}
.foot-name{font-family:var(--font-display);font-size:1.3rem;color:var(--primary);margin:0 0 .5rem}
.foot-tag{font-size:.92rem;opacity:.78;line-height:1.55;max-width:30ch;margin:0}
.foot-col h2{font-size:.78rem;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.14em;color:var(--secondary);margin-bottom:1rem;font-weight:500}
.foot-col a{display:block;color:var(--fg);font-size:.94rem;margin-bottom:.6rem;opacity:.85}
.foot-col a:hover{color:var(--primary);text-decoration:none;opacity:1}
.foot-mail{display:inline-flex!important;align-items:center;gap:.5rem;color:var(--primary)!important}
.foot-fine{font-size:.84rem;color:var(--secondary);margin-top:.6rem}
.foot-base{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding:1.4rem 0;border-top:1px solid var(--line-soft);
  font-family:var(--font-mono);font-size:.74rem;letter-spacing:.04em;color:var(--secondary)}
.foot-base p{margin:0}

/* ---- responsive ---- */
@media(max-width:960px){
  .hero-grid{grid-template-columns:1fr;gap:2.4rem}
  .hero-figure{aspect-ratio:16/11;max-width:520px}
  .split{grid-template-columns:1fr}
  .grid-3,.quotes,.team{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr}
  .stat:nth-child(2){border-right:0}
  .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--line-soft)}
  .contact-grid{grid-template-columns:1fr}
  .roll{grid-template-columns:1fr}
  .j-card{grid-template-columns:200px 1fr}
}
@media(max-width:680px){
  body{font-size:17px}
  .nav{gap:1rem}
  .nav>a:not(.nav-cta){display:none}
  .grid-3,.grid-2,.quotes,.team{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .j-card{grid-template-columns:1fr}
  .j-card .thumb{aspect-ratio:16/9}
  .j-card .body{padding:1.4rem 1.5rem}
  .hero-badge{left:8px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:1/-1}
}

/* ---- reduced motion ---- */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal,[data-hero],.js-anim [data-hero]{opacity:1!important;transform:none!important;filter:none!important}
}
