/* ============ HEARTWOOD · one ring per year ============ */
:root{
  --umber:#4A3826;
  --umber-deep:#3E2E1E;
  --oak:#6F5639;
  --tan:#C7AF8F;
  --tan-lt:#E8DEC9;
  --sage:#76806B;
  --moss:#525B49;
  --cream:#F4ECDD;
  --cream-2:#EFE5D2;
  --clay:#A66B3F;
  --clay-ink:#875428;
  --ink:#3A2E20;
  --ink-soft:#5E4E3A;
  --line:#D9CBB0;
  --line-soft:#E5DAC3;
  --wrap:1140px;
  --serif:"Fraunces", Georgia, serif;
  --sans:"Albert Sans", -apple-system, sans-serif;
  --mono:"Spline Sans Mono", ui-monospace, monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html.loaded{scroll-behavior:smooth} /* gated post-load so deep-link hash jumps don't animate (AUDIT-6) */
@media (prefers-reduced-motion: reduce){ html.loaded{scroll-behavior:auto} }
[id]{scroll-margin-top:92px}
body{
  font-family:var(--sans);font-size:17.5px;line-height:1.65;color:var(--ink);
  background:var(--cream);-webkit-font-smoothing:antialiased;
}
@media (max-width:720px){ body{font-size:16.5px} }
img{max-width:100%;display:block}
a{color:var(--moss);text-decoration:none}
a:hover{color:var(--umber)}
:focus-visible{outline:2.5px solid var(--sage);outline-offset:3px;border-radius:2px}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 28px}
section{position:relative}

h1,h2,h3{font-family:var(--serif);font-weight:300;color:var(--umber);line-height:1.12;letter-spacing:-.01em}
h1{font-size:clamp(40px,5.4vw,66px)}
h2{font-size:clamp(30px,3.5vw,44px)}
h3{font-size:clamp(20px,2vw,24px);line-height:1.28}
h1 em,h2 em{font-style:italic;font-weight:300;color:var(--oak)}
.lead{font-size:clamp(17.5px,1.45vw,19.5px);color:var(--ink-soft);max-width:62ch}
p{max-width:68ch}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-weight:400;font-size:13px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--oak);margin-bottom:18px;
}
.eyebrow .ringdot{width:13px;height:13px;flex:none}
.eyebrow .ringdot circle{fill:none;stroke:var(--oak);stroke-width:1.3}
.eyebrow .ringdot .c{fill:var(--oak);stroke:none}

.sec{padding:62px 0}
.sec-head{max-width:780px;margin-bottom:32px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head.center .eyebrow{justify-content:center}
.sec-head h2{margin-bottom:18px}
.band{background:var(--cream-2)}
.band-solid{background:var(--cream)}

.skip{
  position:absolute;left:-9999px;top:0;z-index:300;background:var(--umber);color:var(--cream);
  padding:12px 22px;border-radius:0 0 10px 0;font-weight:500;
}
.skip:focus{left:0;color:var(--cream)}

/* buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--sans);
  font-weight:500;font-size:16.5px;padding:15px 28px;min-height:48px;border-radius:999px;
  border:1.5px solid transparent;cursor:pointer;
  transition:background-color .2s ease,color .2s ease,border-color .2s ease,transform .2s ease,box-shadow .2s ease;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 24px -12px rgba(62,46,30,.45)}
.btn .arr{transition:transform .2s ease}
.btn:hover .arr{transform:translateX(3px)}
.btn-dark{background:var(--umber);color:var(--cream)}
.btn-dark:hover{background:var(--umber-deep);color:var(--cream)}
.btn-outline{border-color:var(--oak);color:var(--umber);background:transparent}
.btn-outline:hover{background:rgba(122,95,67,.09);color:var(--umber)}
.btn-cream{background:var(--cream);color:var(--umber)}
.btn-cream:hover{background:#fff;color:var(--umber-deep)}
.btn-outline-light{border-color:rgba(244,236,221,.6);color:var(--cream);background:transparent}
.btn-outline-light:hover{border-color:var(--cream);color:#fff}
.btn-sm{padding:10px 20px;font-size:15px;min-height:44px}
@media (prefers-reduced-motion: reduce){ .btn:hover{transform:none} .btn:hover .arr{transform:none} }

/* ============ THE RING COUNT (fixed right stump + counter) ============ */
.rail{
  position:fixed;top:50%;right:0;z-index:0;pointer-events:none;
  width:min(96vmin,1020px);height:min(96vmin,1020px);
  transform:translate(50%,-50%);
}
.rail svg{width:100%;height:100%;overflow:visible}
html.js:not(.reduced) .rail .yr{opacity:.13;transition:opacity .9s ease}
html.js:not(.reduced) .rail .yr.on{opacity:1}
.rail.dim,.note-fix.dim,.note-fix.gone{opacity:0}
@media (prefers-reduced-motion: no-preference){
  .rail{transition:opacity .7s ease}
  .note-fix{transition:opacity .45s ease}
}
.note-fix{
  position:fixed;z-index:60;right:clamp(18px,3.5vw,48px);bottom:30px;pointer-events:none;
  text-align:right;font-family:var(--mono);font-weight:400;font-size:13px;
  letter-spacing:.13em;color:var(--ink);text-transform:uppercase;
  background:rgba(244,236,221,.95);border:1px solid var(--line);border-radius:10px;
  padding:10px 14px;box-shadow:0 10px 26px -14px rgba(74,56,38,.4);max-width:300px;
}
.note-fix .nf-yr{display:block;font-size:11.5px;color:var(--clay-ink);letter-spacing:.2em;margin-bottom:3px}
@media (max-width:999px){
  .rail{display:none}
  .note-fix{display:none}
}

/* ============ NAV ============ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;background:transparent;
  border-bottom:1px solid transparent;
  transition:background-color .3s ease,border-color .3s ease,transform .35s ease;
}
@media (prefers-reduced-motion: reduce){ .nav{transition:none} }
.nav.hide{transform:translateY(-100%)}
.nav.is-stuck{
  background:rgba(244,236,221,.93);
  -webkit-backdrop-filter:blur(14px) saturate(130%);backdrop-filter:blur(14px) saturate(130%);
  border-bottom-color:var(--line-soft);
}
.nav-row{display:flex;align-items:center;justify-content:space-between;height:76px;gap:24px}
.brand{display:inline-flex;align-items:center;gap:12px;color:var(--umber);min-height:44px}
.brand:hover{color:var(--umber)}
.brand svg{width:34px;height:34px;flex:none}
.brand .bn{font-family:var(--serif);font-weight:400;font-size:21px;letter-spacing:.02em;color:var(--umber);line-height:1}
.brand .bt{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--oak);text-transform:uppercase;margin-top:3px}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none}
.nav-links a{position:relative;font-size:16px;color:var(--ink);padding:12px 2px;display:inline-block}
.nav-links a:hover{color:var(--umber)}
.nav-links a::after{
  content:"";position:absolute;left:2px;right:2px;bottom:6px;height:1.5px;background:var(--oak);
  transform:scaleX(0);transform-origin:left center;transition:transform .25s ease;
}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-right{display:flex;align-items:center;gap:18px}
.nav-phone{font-family:var(--mono);font-size:15px;color:var(--umber);padding:12px 2px;display:inline-block}
.nav-phone:hover{color:var(--clay-ink)}
.navtoggle{display:none;width:44px;height:44px;background:none;border:none;cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px}
.navtoggle span{width:22px;height:2px;background:var(--umber);border-radius:2px;transition:transform .3s ease,opacity .3s ease}
.mobile-menu{display:none}
@media (max-width:980px){
  .nav-links,.nav-phone{display:none}
  .navtoggle{display:flex}
  .mobile-menu{
    display:block;max-height:0;overflow:hidden;background:rgba(244,236,221,.97);
    border-bottom:1px solid var(--line-soft);transition:max-height .35s ease;
  }
  .nav.menu-open .mobile-menu{max-height:380px}
  .nav.menu-open{background:rgba(244,236,221,.97);border-bottom-color:var(--line-soft)}
  .mobile-menu a{display:block;padding:15px 28px;font-size:18px;color:var(--umber);border-top:1px solid var(--line-soft)}
  .nav.menu-open .navtoggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav.menu-open .navtoggle span:nth-child(2){opacity:0}
  .nav.menu-open .navtoggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* ============ HERO (block 1) ============ */
.hero{padding:140px 0 80px;overflow:hidden;background:#F5EEE0}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.hero-bg picture{display:contents}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:right center}
.hero-bg .hero-ann{position:absolute;inset:0;width:100%;height:100%}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(245,238,224,.95) 0%,rgba(245,238,224,.84) 32%,rgba(245,238,224,.3) 54%,rgba(245,238,224,0) 70%);
}
.hero .wrap{position:relative;width:100%}
.hero-copy{max-width:640px}
.hero-kicker{
  font-family:var(--mono);font-size:13px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--oak);margin-bottom:22px;display:flex;align-items:center;gap:12px;
}
.hero-kicker::before{content:"";width:34px;height:1px;background:var(--oak)}
.hero h1{margin-bottom:24px}
.hero .lead{margin-bottom:34px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:18px}
.cta-aside{font-size:16.5px;color:var(--ink-soft);max-width:34em;margin-bottom:30px}
.cta-aside a{color:var(--clay-ink);font-weight:500;text-decoration:underline;text-underline-offset:3px}
.cta-aside a:hover{color:var(--umber)}
.hero-facts{
  display:flex;flex-wrap:wrap;gap:.9em 2.4em;list-style:none;
  font-family:var(--mono);font-weight:400;font-size:13.5px;letter-spacing:.13em;
  text-transform:uppercase;color:var(--oak);
}
.hero-facts li{display:flex;align-items:center;gap:.7em}
.hero-facts li::before{content:"";width:9px;height:9px;border:1.5px solid var(--oak);border-radius:50%;flex:none}
/* dendrochronology callouts: drawn after the headline settles */
.hero-ann .ld{stroke:#54422F;stroke-width:2;fill:none}
.hero-ann text{font-family:var(--mono);font-size:18px;letter-spacing:1.5px;fill:#54422F}
html.js:not(.reduced) .hero-ann .ld{stroke-dasharray:210;stroke-dashoffset:210}
html.js:not(.reduced) .hero-ann text{opacity:0}
html.js:not(.reduced) .hero-ann.drawn .ld{stroke-dashoffset:0;transition:stroke-dashoffset .4s ease .3s}
html.js:not(.reduced) .hero-ann.drawn .ld.l2{transition-delay:.55s}
html.js:not(.reduced) .hero-ann.drawn text{opacity:1;transition:opacity .35s ease .15s}
html.js:not(.reduced) .hero-ann.drawn text.t2{transition-delay:.4s}
@media (max-width:920px){
  .hero{padding:150px 0 90px;min-height:0}
  .hero-bg img{object-position:78% center}
  .hero-bg .hero-ann{display:none}
  .hero-bg::after{background:rgba(245,238,224,.88)}
}

/* ============ TRUST STRIP (block 2 · HW-17) ============ */
.cred{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--cream-2)}
.cred .wrap{display:flex;flex-wrap:wrap;justify-content:center;gap:12px 0;padding-top:24px;padding-bottom:24px}
.cred span{
  font-family:var(--mono);font-size:13.5px;letter-spacing:.15em;text-transform:uppercase;color:var(--umber);
  display:inline-flex;align-items:center;
}
.cred .rd{width:9px;height:9px;border:1.4px solid var(--oak);border-radius:50%;display:inline-block;margin:0 22px;flex:none;align-self:center}
@media (max-width:700px){ .cred .rd{margin:0 12px} .cred span{font-size:12px} }

/* ============ ABOUT (block 3 · rail window) ============ */
.about-col{max-width:660px}
.about-col p{margin-bottom:20px;color:var(--ink-soft)}
.about-col p strong{color:var(--umber);font-weight:600}
.about-grove{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(20px,2vw,24px);color:var(--clay-ink);margin-bottom:22px}
.about-art{max-width:540px;margin-top:34px}
.about-art .mat{border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:0 24px 60px -28px rgba(74,56,38,.32)}
.about-art img{width:100%;height:auto;aspect-ratio:4/3;object-fit:cover}
.figcap{
  margin-top:13px;font-family:var(--mono);font-size:12.5px;letter-spacing:.13em;
  text-transform:uppercase;color:var(--oak);
}
@media (min-width:1000px){ .about-col,.about-art{max-width:min(660px,54vw)} }

/* ============ PROCESS · THREE SEASONS (block 4 · HW-19) ============ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.step{
  background:var(--cream);border:1px solid var(--line);border-radius:18px;padding:36px 32px 34px;
  transition:transform .3s ease,box-shadow .3s ease;
}
.step:hover{transform:translateY(-4px);box-shadow:0 22px 48px -26px rgba(74,56,38,.35)}
@media (prefers-reduced-motion: reduce){ .step:hover{transform:none} }
.step .n{
  font-family:var(--mono);font-weight:300;font-size:13.5px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--clay-ink);display:flex;align-items:center;gap:14px;margin-bottom:20px;
}
.step .n::after{content:"";height:1px;flex:1;background:var(--line)}
.step h3{margin-bottom:13px}
.step p{color:var(--ink-soft);font-size:16.5px}
.step .ic{width:48px;height:48px;margin-bottom:20px}
.step .ic svg{width:100%;height:100%}
@media (max-width:920px){ .steps{grid-template-columns:1fr;max-width:560px} }

/* ============ BEDROCK (block 5 · signature set-piece) ============ */
.bedrock{background:var(--cream-2)}
.bed-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.bed-fig{position:sticky;top:96px;margin:0}
.bed-fig svg{width:100%;height:auto;display:block;overflow:visible}
.bed-status{
  margin-top:10px;text-align:center;font-family:var(--mono);font-size:13px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--oak);
}
.bed-status b{font-weight:500;color:var(--umber)}
.bed-legend{
  margin-top:8px;text-align:center;font-family:var(--mono);font-size:12.5px;
  letter-spacing:.1em;color:var(--oak);
}
.bed-legend .notch{display:inline-block;width:12px;height:2.5px;background:var(--clay);border-radius:2px;vertical-align:middle;margin:0 3px 2px}
.bparts{list-style:none}
.bpart{padding:24px 0;border-top:1px solid var(--line)}
.bpart:first-child{border-top:none;padding-top:6px}
.bpart .bn{
  font-family:var(--mono);font-weight:300;font-size:13.5px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--oak);margin-bottom:10px;display:flex;align-items:center;gap:12px;transition:color .6s ease;
}
.bpart .bn .tick{width:14px;height:14px;flex:none;opacity:1;transition:opacity .6s ease}
.bpart .bn .tick circle{fill:none;stroke:var(--oak);stroke-width:1.4}
.bpart .bn .tick .hc{fill:var(--oak);stroke:none}
html.js:not(.reduced) .bpart:not(.bpart-next):not(.live) .bn .tick{opacity:.25}
.bpart h3{margin-bottom:10px}
.bpart p{color:var(--ink-soft);font-size:16.5px;max-width:54ch}
.bpart-next{border-top:1.5px dashed var(--tan);margin-top:6px;padding-top:28px}
.bpart-next .bn{color:var(--clay-ink)}
.bpart-next h3 em{font-style:italic;color:var(--oak)}
/* ring states + hover highlight (HW-10) */
.hw-rings .band{stroke:var(--done);transition:stroke 1.1s ease}
.hw-rings .notches{opacity:1;transition:opacity .9s ease .4s}
html.js:not(.reduced) .hw-rings .ring:not(.on) .band{stroke:#E4D8BF}
html.js:not(.reduced) .hw-rings .ring:not(.on) .notches{opacity:0}
.hw-rings .ring:hover .band{stroke:var(--clay) !important;transition:stroke .18s ease}
@media (max-width:920px){
  .bed-grid{grid-template-columns:1fr;gap:40px}
  .bed-fig{position:static;max-width:540px;margin:0 auto}
}

/* ============ REVIEWS · TWO NOTCHES (block 5b · HW-06 · rail window) ============ */
.rev-col{max-width:660px}
.rev-col p{margin-bottom:18px;color:var(--ink-soft)}
.mono-note{
  font-family:var(--mono);font-weight:400;font-size:13px;letter-spacing:.13em;
  color:var(--moss);line-height:1.9;text-transform:uppercase;max-width:46em;
  border:1px solid var(--tan);border-radius:12px;padding:16px 20px;background:rgba(244,236,221,.75);
}
.rev-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:18px 48px;align-items:center}
.rev-grid .rev-copy{grid-row:1 / span 2}
@media (max-width:919px){.rev-grid{grid-template-columns:1fr}.rev-grid .rev-copy{grid-row:auto}}
.notch-fig{max-width:320px;margin-top:0}
.notch-fig svg{width:100%;height:auto;overflow:visible}
.notch-fig .nstamp{transform-box:fill-box;transform-origin:center}
html.js:not(.reduced) .notch-fig:not(.in) .nstamp{opacity:0;transform:scale(.4)}
html.js:not(.reduced) .notch-fig.in .nstamp{opacity:1;transform:scale(1);transition:opacity .2s ease .35s,transform .2s ease .35s}
html.js:not(.reduced) .notch-fig.in .n2{transition-delay:.65s}
.notch-tags{display:flex;justify-content:space-between;max-width:320px;margin-top:12px;font-family:var(--mono);font-size:12.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--oak)}
@media (min-width:1000px){ .rev-col{max-width:min(820px,58vw)} }

/* ============ WHO WE SERVE (block 6 · HW-20) ============ */
.fit-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:64px;align-items:center}
.fit-art .mat{border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:0 24px 60px -28px rgba(74,56,38,.3)}
.fit-art img{width:100%;height:auto;aspect-ratio:1/1;object-fit:cover}
.fit-copy p{color:var(--ink-soft);margin-bottom:18px}
.fit-list{list-style:none;margin-top:26px;display:grid;gap:14px}
.fit-list li{display:flex;gap:14px;align-items:flex-start;font-size:17px;color:var(--ink)}
.fit-list .rd{flex:none;width:18px;height:18px;margin-top:4px}
.fit-list .rd circle{fill:none;stroke:var(--sage);stroke-width:1.5}
.fit-list .rd .c{fill:var(--sage);stroke:none}
@media (max-width:920px){ .fit-grid{grid-template-columns:1fr;gap:44px} .fit-art{max-width:460px} }

/* ============ FOUNDER + TEAM (block 7 · HW-21/30) ============ */
.founder{background:var(--cream)}
.letter{
  max-width:820px;margin:0 auto 40px;background:#FBF6EA;border:1px solid var(--line);
  border-radius:20px;padding:clamp(36px,5vw,60px);box-shadow:0 26px 60px -30px rgba(74,56,38,.3);
}
.letter .salut{font-family:var(--mono);font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--oak);margin-bottom:24px}
.letter p{font-family:var(--serif);font-weight:300;font-size:clamp(19px,1.85vw,22px);line-height:1.55;color:var(--umber);margin-bottom:20px;max-width:none}
.letter p em{color:var(--clay-ink);font-style:italic}
.letter .qlist{list-style:none;margin:0 0 20px;display:grid;gap:8px}
.letter .qlist li{
  font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(18px,1.7vw,21px);
  color:var(--oak);display:flex;gap:12px;align-items:baseline;
}
.letter .qlist .qn{font-family:var(--mono);font-style:normal;font-size:12.5px;letter-spacing:.16em;color:var(--clay-ink);flex:none}
.letter .sig{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px;margin-top:30px}
.letter .sig .sname{font-family:var(--serif);font-style:italic;font-size:24px;color:var(--umber)}
.letter .sig .srole{font-family:var(--mono);font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--oak)}
.letter .yt{
  display:inline-flex;align-items:center;gap:9px;font-size:16px;font-weight:500;color:var(--clay-ink);
  padding:10px 0;min-height:44px;
}
.letter .yt:hover{color:var(--umber)}
.letter .yt svg{width:20px;height:20px;flex:none}
.team{display:flex;flex-wrap:wrap;justify-content:center;gap:22px}
.tcard{
  flex:1 1 196px;max-width:260px;background:#FBF6EA;border:1px solid var(--line);border-radius:18px;
  padding:30px 22px 28px;text-align:center;transition:transform .3s ease,box-shadow .3s ease;
}
.tcard:hover{transform:translateY(-4px);box-shadow:0 22px 48px -26px rgba(74,56,38,.32)}
@media (prefers-reduced-motion: reduce){ .tcard:hover,.step:hover{transform:none} }
.tcard .av{width:92px;height:92px;margin:0 auto 18px;border-radius:50%;overflow:hidden;border:1px solid var(--line)}
.tcard .av img{width:100%;height:100%;object-fit:cover}
.tcard .av svg{width:100%;height:100%}
.tcard .nm{font-family:var(--serif);font-weight:400;font-size:19.5px;color:var(--umber);margin-bottom:5px}
.tcard .ro{font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--oak);margin-bottom:12px;min-height:32px}
.tcard .bio{font-size:15px;color:var(--ink-soft)}
@media (max-width:560px){ .tcard{max-width:none;flex-basis:100%} }

/* ============ VALUES · CUSTODY (block 8 · HW-26 · rail window) ============ */
.val-col{max-width:660px}
.val-col>p{color:var(--ink-soft);margin-bottom:18px}
.val-list{list-style:none;margin-top:34px;display:grid;gap:18px;max-width:600px}
.val-list li{border:1px solid var(--line);border-radius:14px;padding:20px 24px;background:rgba(244,236,221,.8)}
.val-list .vk{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--clay-ink);margin-bottom:6px;display:block}
.val-list p{font-size:16.5px;color:var(--ink-soft)}
@media (min-width:1000px){ .val-col{max-width:min(660px,54vw)} }

/* ============ NUMBERS (block 9 · HW-09/22) ============ */
.numbers{
  background:var(--moss);
  background-image:radial-gradient(120% 140% at 80% 10%,rgba(74,84,64,.0) 0%,rgba(52,60,45,.55) 100%);
  color:var(--cream);padding:66px 0;
}
.numbers h2{color:var(--cream);max-width:760px;margin:0 auto 14px;text-align:center}
.numbers h2 em{color:var(--tan)}
.numbers .eyebrow{color:var(--tan-lt);justify-content:center;display:flex}
.numbers .sub{color:var(--tan-lt);text-align:center;max-width:620px;margin:0 auto 46px;font-size:17px}
.num-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.num{padding:26px 10px;border-top:1px solid rgba(244,236,221,.25)}
.num .val{font-family:var(--mono);font-weight:300;font-size:clamp(42px,4.6vw,58px);color:var(--cream);line-height:1.05}
.num .lbl{margin-top:10px;font-family:var(--mono);font-size:12.5px;letter-spacing:.15em;text-transform:uppercase;color:var(--tan-lt)}
@media (max-width:880px){ .num-grid{grid-template-columns:repeat(2,1fr)} }

/* ============ FAQ (block 10 · HW-23) ============ */
.faq-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:64px;align-items:start}
.faq-aside h2{margin-bottom:18px}
.faq-aside .lead{margin-bottom:30px}
.email-card{background:var(--cream-2);border:1px solid var(--line);border-radius:16px;padding:24px 26px}
.email-card .k{font-family:var(--mono);font-size:12.5px;letter-spacing:.15em;text-transform:uppercase;color:var(--oak);margin-bottom:8px}
.email-card a{font-size:17px;color:var(--umber);font-weight:500;word-break:break-all;display:inline-block;padding:6px 0}
.email-card a:hover{color:var(--clay-ink)}
.faq-item{border-top:1px solid var(--line)}
.faq-item:last-child{border-bottom:1px solid var(--line)}
.faq-q{
  width:100%;background:none;border:none;cursor:pointer;text-align:left;
  display:flex;justify-content:space-between;align-items:center;gap:20px;
  padding:24px 4px;min-height:56px;font-family:var(--serif);font-weight:400;
  font-size:clamp(19px,1.8vw,22px);color:var(--umber);line-height:1.3;
}
.faq-q:hover{color:var(--clay-ink)}
.faq-q .chev{flex:none;width:22px;height:22px;color:var(--oak);transition:transform .25s ease}
.faq-q[aria-expanded="true"] .chev{transform:rotate(45deg)}
.faq-a{padding:0 4px 26px;color:var(--ink-soft);font-size:16.5px;max-width:64ch}
.faq-a p{margin-bottom:12px}
@media (max-width:920px){ .faq-grid{grid-template-columns:1fr;gap:44px} }

/* ============ NEWSLETTER (block 11 · HW-24) ============ */
.newsletter{background:var(--cream-2);border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.nl-card{
  max-width:880px;margin:0 auto;text-align:center;background:var(--cream);border:1px solid var(--line);
  border-radius:22px;padding:clamp(40px,6vw,64px);box-shadow:0 26px 60px -30px rgba(74,56,38,.3);
}
.nl-card .eyebrow{justify-content:center;display:inline-flex}
.nl-card h2{margin-bottom:14px}
.nl-card .lead{margin:0 auto 12px}
.nl-card .micro{font-family:var(--mono);font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--oak);margin-bottom:30px}
.nl-form{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.nl-form input{
  font-family:var(--sans);font-size:16.5px;color:var(--ink);background:#FBF6EA;
  border:1.5px solid var(--line);border-radius:999px;padding:14px 22px;min-width:0;min-height:48px;
}
.nl-form input::placeholder{color:#7E6F58}
.nl-form input:focus{outline:none;border-color:var(--sage)}
.nl-form .fn{flex:0 1 200px}
.nl-form .em{flex:1 1 280px;max-width:340px}
.nl-done{
  font-family:var(--serif);font-weight:300;font-size:clamp(19px,1.9vw,23px);color:var(--moss);
  padding:10px 0 2px;
}
@media (max-width:640px){ .nl-form .fn,.nl-form .em{flex:1 1 100%;max-width:none} }

/* ============ FINAL CTA (block 12 · HW-28) ============ */
.final{
  background:var(--umber-deep);
  background-image:radial-gradient(110% 130% at 78% 8%,rgba(94,72,48,.5) 0%,rgba(50,37,24,.9) 100%);
  color:var(--cream);padding:70px 0;text-align:center;
}
.final .eyebrow{color:var(--tan-lt);justify-content:center;display:inline-flex}
.final h2{color:var(--cream);max-width:840px;margin:0 auto 18px;font-size:clamp(38px,4.6vw,60px)}
.final h2 em{color:var(--tan)}
.final .lead{color:#E2D7C2;margin:0 auto 38px;max-width:580px}
.cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.final .cta-aside{color:#D8CDB8;max-width:none;margin:26px auto 0}
.final .cta-aside a{color:var(--tan-lt)}
.final .cta-aside a:hover{color:#fff}

/* ============ CUSTODY STRIP (HW-29) ============ */
.cust{background:var(--cream);border-top:1px solid var(--line)}
.cust .wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;padding-top:54px;padding-bottom:54px}
.cust .ck{font-family:var(--mono);font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--clay-ink);margin-bottom:8px;display:flex;align-items:center;gap:10px}
.cust .ck::before{content:"";width:9px;height:9px;border:1.4px solid var(--clay-ink);border-radius:50%;flex:none}
.cust h3{font-size:clamp(19px,1.7vw,22px);margin-bottom:6px}
.cust p{font-size:15.5px;color:var(--ink-soft)}
@media (max-width:880px){ .cust .wrap{grid-template-columns:1fr;gap:26px} }

/* ============ FOOTER (block 13 · HW-25) ============ */
.footer{background:var(--umber-deep);color:#DCD1BB;padding:78px 0 44px;font-size:15.5px}
.footer a{color:#DCD1BB;display:inline-block;padding:4px 0}
.footer a:hover{color:var(--cream)}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:44px;padding-bottom:50px;border-bottom:1px solid rgba(244,236,221,.18)}
.footer .fbrand{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.footer .fbrand svg{width:36px;height:36px;flex:none}
.footer .fbrand .bn{font-family:var(--serif);font-size:22px;color:var(--cream)}
.footer .fbrand .bt{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--tan);margin-top:3px}
.footer h5{
  font-family:var(--mono);font-weight:400;font-size:12.5px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--tan);margin-bottom:16px;
}
.footer-col a{display:block;margin-bottom:6px;padding:6px 0}
.footer-contact div{margin-bottom:10px}
.footer-contact .mono{font-family:var(--mono);font-size:14.5px}
.footer-fine{padding-top:30px;font-size:13.5px;line-height:1.75;color:#C2B49A}
.footer-fine .disc{display:block;margin-top:14px;max-width:1000px}
.footer-fine a{text-decoration:underline;text-underline-offset:3px}
@media (max-width:920px){ .footer-top{grid-template-columns:1fr 1fr} }
@media (max-width:560px){ .footer-top{grid-template-columns:1fr} }

/* ============ REVEALS (HW-01/08: fail-open, IO-driven, reduced-motion bypass) ============ */
html.js:not(.reduced) .rv{opacity:0;transform:translateY(14px);transition:opacity .45s ease,transform .45s cubic-bezier(.2,.7,.2,1)}
html.js:not(.reduced) .rv.in{opacity:1;transform:none}
html.js:not(.reduced) .rv.d1{transition-delay:.08s}
html.js:not(.reduced) .rv.d2{transition-delay:.16s}
html.js:not(.reduced) .rv.d3{transition-delay:.24s}
html.js:not(.reduced) .rv.d4{transition-delay:.32s}

/* ============ MULTI-PAGE ADDITIONS ============ */
.nav-links a[aria-current="page"]{color:var(--umber)}
.nav-links a[aria-current="page"]::after{transform:scaleX(1)}
.mobile-menu a[aria-current="page"]{color:var(--clay-ink)}
.page-hero{padding:158px 0 66px;background:var(--cream-2);border-bottom:1px solid var(--line-soft)}
.page-hero h1{margin-bottom:20px;font-size:clamp(36px,4.6vw,58px)}
.page-hero .lead{margin-bottom:0}
@media (max-width:720px){ .page-hero{padding:140px 0 54px} }
