/* =========================================================================
   BIG RED OAK — Hybrid design system (Big Red Oak identity × Integrated Bio energy)
   Quiet Premium + one expressive fluid hero. Mulish lowercase huge tight + Roboto
   Mono data-tags. Red Oak #a53a2b is the only accent. Single stylesheet.
   ========================================================================= */

/* ---- Fonts (self-hosted, no Google Fonts) ------------------------------- */
@font-face{font-family:"Mulish";src:url(assets/fonts/mulish-var.woff2) format("woff2");
  font-weight:200 1000;font-style:normal;font-display:swap}
@font-face{font-family:"Mulish";src:url(assets/fonts/mulish-italic-var.woff2) format("woff2");
  font-weight:200 1000;font-style:italic;font-display:swap}
@font-face{font-family:"Roboto Mono";src:url(assets/fonts/roboto-mono-400.woff2) format("woff2");
  font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Roboto Mono";src:url(assets/fonts/roboto-mono-500.woff2) format("woff2");
  font-weight:500;font-style:normal;font-display:swap}
/* Brand fonts (brand-fonts branch): Avenir for text, Bebas Neue for display */
@font-face{font-family:"Avenir";src:url(assets/fonts/avenir-book.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Avenir";src:url(assets/fonts/avenir-regular.woff2) format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Avenir";src:url(assets/fonts/avenir-heavy.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Bebas Neue";src:url(assets/fonts/bebas-neue.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}

/* ---- Tokens ------------------------------------------------------------- */
:root{
  color-scheme:light;
  --ink:#2a2521; --ink-soft:#5b5249; --clay:#7c6553;
  --bark:#3b342f; --bark-deep:#272320;
  --paper:#fbf8f2; --off:#f3eee4; --cream:#ece4d4; --sand:#dbc7af;
  --sage:#4e7a5c; --sage-deep:#3c5e47; --lake:#6e7251;
  --oak:#a53a2b; --oak-soft:#bf5444;
  --line:rgba(42,37,33,.14); --line-soft:rgba(42,37,33,.08);
  --line-inv:rgba(219,199,175,.20);

  --sans:"Avenir","Mulish",ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --mono:"Avenir","Roboto Mono",ui-sans-serif,system-ui,sans-serif;
  --display:"Bebas Neue",ui-sans-serif,system-ui,sans-serif;
  --w-reg:400; --w-head:480; --w-strong:760;

  --r-card:32px; --r-btn:13px; --r-pill:999px;
  --maxw:1320px; --pad:clamp(20px,5vw,72px);
  --section-pad:clamp(72px,11vw,168px);
  --ease:cubic-bezier(.22,.61,.36,1);

  --fg:var(--ink); --fg-soft:var(--ink-soft); --bg:var(--off);
}

/* ---- Reset / base ------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scrollbar-gutter:stable}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;background:var(--off);color:var(--ink);font-family:var(--sans);
  font-weight:var(--w-reg);font-size:clamp(16px,1.05vw,18px);line-height:1.6;
  letter-spacing:-.005em;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  font-variant-numeric:oldstyle-nums proportional-nums;overflow-x:hidden}
img,svg,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
h1,h2,h3,h4,p{margin:0}
::selection{background:var(--oak);color:var(--paper)}
:focus-visible{outline:2px solid var(--oak);outline-offset:3px;border-radius:4px}

@view-transition{navigation:auto}

/* ---- Layout ------------------------------------------------------------- */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad);
  position:relative;z-index:1}
.section{padding-block:var(--section-pad);position:relative;isolation:isolate}
.section--tight{padding-block:clamp(48px,7vw,96px)}

/* surfaces */
.s-off{background:var(--off);color:var(--ink)}
.s-paper{background:var(--paper);color:var(--ink)}
.s-cream{background:var(--cream);color:var(--ink)}
.s-bark{background:var(--bark);color:var(--sand)}
.s-bark-deep{background:var(--bark-deep);color:var(--sand)}
.s-sage{background:var(--sage);color:var(--paper)}
.s-sage-deep{background:var(--sage-deep);color:var(--paper)}
.s-bark .ink-soft,.s-bark-deep .ink-soft,.s-sage .ink-soft,.s-sage-deep .ink-soft{
  color:rgba(219,199,175,.74)}

/* ---- Grain overlay on flat sections (atmosphere, never flat fills) ------ */
.grain::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.5;mix-blend-mode:soft-light}
.s-bark.grain::before,.s-bark-deep.grain::before,.s-sage.grain::before,.s-sage-deep.grain::before{opacity:.42}

/* ---- Typography utilities ---------------------------------------------- */
.display{font-weight:var(--w-head);font-size:clamp(2.9rem,8.4vw,8.6rem);line-height:1.04;
  letter-spacing:-.03em;text-wrap:balance}
.head{font-weight:var(--w-head);font-size:clamp(2.1rem,5vw,4.5rem);line-height:1.09;
  letter-spacing:-.028em;text-wrap:balance}
.head-sm{font-weight:520;font-size:clamp(1.5rem,2.4vw,2.15rem);line-height:1.14;
  letter-spacing:-.02em;text-wrap:balance}
.lead{font-size:clamp(1.05rem,1.5vw,1.45rem);font-weight:400;line-height:1.5;
  letter-spacing:-.01em;text-wrap:pretty}
.prose{max-width:62ch;text-wrap:pretty;color:var(--ink-soft)}
.prose p+p{margin-top:1.1em}
.faded{color:var(--clay);opacity:.92}
.s-bark .faded,.s-bark-deep .faded{color:var(--sand);opacity:.5}
.s-sage .faded,.s-sage-deep .faded{color:var(--paper);opacity:.62}
.lower{text-transform:none}

/* mono tag with swatch */
.tag{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-weight:500;
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
.tag::before{content:"";width:9px;height:9px;border-radius:3px;background:var(--oak);flex:none}
.tag.sage::before{background:var(--sage)}
.s-bark .tag,.s-bark-deep .tag,.s-sage .tag,.s-sage-deep .tag{color:var(--sand)}
.idx{font-family:var(--mono);font-weight:500;font-size:12px;letter-spacing:.14em;color:var(--clay)}
.s-bark .idx,.s-bark-deep .idx,.s-sage .idx,.s-sage-deep .idx{color:rgba(219,199,175,.6)}
.eyebrow{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:clamp(28px,4vw,56px)}

/* arrow icon (fonts carry no arrow glyph -> inline SVG) */
.ico{width:1em;height:1em;flex:none;stroke:currentColor;fill:none;stroke-width:2;
  stroke-linecap:round;stroke-linejoin:round}

/* ---- Buttons ------------------------------------------------------------ */
.btn{display:inline-flex;align-items:stretch;gap:6px;font-family:var(--mono);font-weight:500;
  font-size:13px;letter-spacing:.1em;text-transform:uppercase}
.btn-main{display:inline-flex;align-items:center;background:var(--ink);color:var(--paper);
  padding:15px 22px;border-radius:var(--r-btn);transition:background .4s var(--ease),color .4s var(--ease)}
.btn-chip{display:inline-grid;place-items:center;width:48px;background:var(--oak);color:var(--paper);
  border-radius:var(--r-btn);transition:background .4s var(--ease)}
.btn-chip .ico{width:18px;height:18px;transition:transform .4s var(--ease)}
.btn:hover .btn-chip{background:var(--oak-soft)}
.btn:hover .btn-chip .ico{transform:translateX(4px)}
.btn:hover .btn-main{background:#1f1b18}
.s-bark .btn-main,.s-bark-deep .btn-main,.s-sage .btn-main,.s-sage-deep .btn-main{
  background:var(--paper);color:var(--ink)}
.s-bark .btn:hover .btn-main,.s-sage .btn:hover .btn-main{background:#fff}

/* text link with arrow */
.link-arrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-weight:500;
  font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);
  padding-bottom:5px;border-bottom:1px solid var(--line);transition:gap .35s var(--ease),
  border-color .35s var(--ease),color .35s var(--ease)}
.link-arrow .ico{width:16px;height:16px}
.link-arrow:hover{gap:15px;border-color:var(--oak);color:var(--oak)}
.s-bark .link-arrow,.s-bark-deep .link-arrow,.s-sage .link-arrow,.s-sage-deep .link-arrow{
  color:var(--sand);border-color:var(--line-inv)}
.s-bark .link-arrow:hover,.s-sage .link-arrow:hover{color:#fff;border-color:var(--oak-soft)}

/* =========================================================================
   NAV
   ========================================================================= */
.nav{position:fixed;inset:0 0 auto 0;z-index:1000;display:flex;align-items:center;
  justify-content:space-between;gap:16px;padding:18px var(--pad);
  transition:padding .4s var(--ease),background .4s var(--ease),backdrop-filter .4s var(--ease),
  border-color .4s var(--ease);border-bottom:1px solid transparent}
.nav.is-scrolled{padding-block:11px;background:rgba(243,238,228,.82);
  backdrop-filter:saturate(1.3) blur(14px);border-bottom:1px solid var(--line)}
.brand{display:inline-flex;align-items:center;height:30px;color:var(--paper);transition:color .4s var(--ease)}
.nav.is-scrolled .brand{color:var(--sage-deep)}
.brand-mark{display:block;height:25px;aspect-ratio:1920/632.35;background:currentColor;
  -webkit-mask:url(assets/img/logo-mark.svg) no-repeat center/contain;
  mask:url(assets/img/logo-mark.svg) no-repeat center/contain}

.nav-links{display:flex;align-items:center;gap:4px;padding:6px;border-radius:var(--r-pill);
  background:rgba(251,248,242,.1);border:1px solid var(--line-inv);
  transition:background .4s var(--ease),border-color .4s var(--ease)}
.nav.is-scrolled .nav-links{background:var(--paper);border-color:var(--line)}
.nav-links a{position:relative;padding:8px 15px;border-radius:var(--r-pill);font-size:14px;
  font-weight:500;color:var(--sand);transition:background .3s var(--ease),color .3s var(--ease)}
.nav.is-scrolled .nav-links a{color:var(--ink-soft)}
.nav-links a:hover{background:rgba(251,248,242,.14);color:var(--paper)}
.nav.is-scrolled .nav-links a:hover{background:var(--off);color:var(--ink)}
.nav-links a[aria-current="page"]{color:var(--paper)}
.nav.is-scrolled .nav-links a[aria-current="page"]{color:var(--oak)}
.nav-right{display:flex;align-items:center;gap:10px}
.nav-cta{padding:11px 18px;border-radius:var(--r-pill);background:var(--oak);color:var(--paper);
  font-size:14px;font-weight:600;transition:background .3s var(--ease),transform .3s var(--ease)}
.nav-cta:hover{background:var(--oak-soft)}
.nav-burger{display:none;width:46px;height:42px;border-radius:var(--r-pill);
  border:1px solid var(--line-inv);place-items:center}
.nav.is-scrolled .nav-burger{border-color:var(--line)}
.nav-burger .bar{display:block;width:18px;height:2px;background:currentColor;color:var(--sand);
  position:relative}
.nav.is-scrolled .nav-burger .bar{color:var(--ink)}
.nav-burger .bar::before,.nav-burger .bar::after{content:"";position:absolute;left:0;width:18px;
  height:2px;background:currentColor}
.nav-burger .bar::before{top:-6px}.nav-burger .bar::after{top:6px}

/* mobile popover menu — scoped to open state only */
#menu{display:none;margin:0;padding:0;border:0;width:100%;max-width:none;height:100%;max-height:none;
  background:var(--bark);color:var(--sand);inset:0;overflow:auto}
#menu::backdrop{background:rgba(20,18,16,.5)}
#menu:popover-open,#menu.is-open{display:flex;flex-direction:column;justify-content:center;
  padding:max(96px,14vh) var(--pad) var(--pad)}
.menu-close{position:absolute;top:18px;right:var(--pad);width:46px;height:46px;border-radius:var(--r-pill);
  border:1px solid var(--line-inv);display:grid;place-items:center}
.menu-close .ico{width:20px;height:20px}
.menu-list{display:flex;flex-direction:column;gap:6px}
.menu-list a{display:flex;align-items:baseline;gap:16px;font-size:clamp(2.2rem,11vw,3.6rem);
  font-weight:var(--w-head);letter-spacing:-.03em;line-height:1.05;color:var(--sand);
  text-transform:lowercase;padding-block:8px;border-bottom:1px solid var(--line-inv)}
.menu-list a .mi{font-family:var(--mono);font-size:13px;letter-spacing:.1em;color:var(--clay)}
.menu-list a:hover{color:var(--paper)}
.menu-foot{margin-top:auto;padding-top:40px;font-family:var(--mono);font-size:12px;
  letter-spacing:.06em;color:rgba(219,199,175,.6)}

/* =========================================================================
   HERO
   ========================================================================= */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;
  padding:clamp(96px,13vh,128px) 0 clamp(48px,7vh,104px);overflow:hidden;background:var(--bark-deep);color:var(--paper)}
.hero-media{position:absolute;inset:-12% 0;z-index:0;overflow:hidden}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:30% 50%;
  will-change:transform;animation:heroBreathe 32s var(--ease) infinite alternate}
.hero-media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(100deg,rgba(20,22,18,.74) 0%,rgba(20,22,18,.4) 34%,rgba(20,22,18,0) 62%),
  linear-gradient(0deg,rgba(20,22,18,.66) 0%,rgba(20,22,18,0) 38%)}
@keyframes heroBreathe{from{transform:scale(1.04)}to{transform:scale(1.13)}}

.hero .wrap{width:100%}
.hero-kicker{margin-bottom:clamp(20px,3vw,34px);color:rgba(244,236,221,.9)}
.hero h1{font-weight:440;font-size:clamp(2.7rem,7.4vw,7rem);line-height:1;
  letter-spacing:-.035em;max-width:18ch;margin-left:-.02em}
.hero h1 .faded,.hero h1 .l2{display:block}
.hero h1 .l2{color:#f4ecdd}
.hero h1 .faded{color:rgba(244,236,221,.46)}
.hero-sub{margin-top:clamp(22px,3vw,38px);max-width:46ch;font-size:clamp(1.1rem,1.7vw,1.55rem);
  line-height:1.42;color:rgba(244,236,221,.82);letter-spacing:-.01em;text-wrap:pretty}
.hero-cta{margin-top:clamp(28px,3.4vw,44px)}
.hero-scroll{position:absolute;right:var(--pad);bottom:clamp(40px,6vh,72px);z-index:2;
  display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:11px;
  letter-spacing:.16em;text-transform:uppercase;color:rgba(244,236,221,.6);writing-mode:vertical-rl}
.hero-scroll .ico{width:14px;height:14px;writing-mode:horizontal-tb}
@media (max-width:880px){.hero-scroll{display:none}}

/* =========================================================================
   MARQUEE / social proof ticker
   ========================================================================= */
.proof{padding-block:clamp(26px,3.2vw,42px);border-block:1px solid var(--line);overflow:hidden}
.proof-label{display:block;text-align:center;margin-bottom:clamp(30px,3.6vw,48px)}
.marquee{display:flex;width:100%;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,
  transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-row{flex:none;display:flex;align-items:center;gap:clamp(36px,5vw,76px);padding-right:clamp(36px,5vw,76px);
  white-space:nowrap;animation:marquee 46s linear infinite;will-change:transform}
.marquee:hover .marquee-row{animation-play-state:paused}
.marquee-item{display:inline-flex;align-items:center;opacity:.66;transition:opacity .4s var(--ease)}
.marquee-item img{height:clamp(26px,3vw,38px);width:auto;display:block}
.marquee:hover .marquee-item{opacity:1}
@keyframes marquee{to{transform:translateX(-50%)}}
.marquee-link{display:inline-flex;align-items:center;border-radius:8px;transition:transform .4s var(--ease)}
.marquee-link:hover{transform:translateY(-2px)}
.marquee-link:focus-visible{outline:2px solid var(--oak);outline-offset:5px}

/* =========================================================================
   WHO WE ARE  + stats band
   ========================================================================= */
.intro-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,6vw,96px);align-items:start}
.intro-grid .lead{margin-top:24px}
.intro-cta{margin-top:clamp(28px,3vw,40px)}
@media (max-width:860px){.intro-grid{grid-template-columns:1fr;gap:36px}}

.stats{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,5vw,80px)}
.stat{display:flex;flex-direction:column;gap:10px;padding-top:26px;border-top:1px solid rgba(251,248,242,.28)}
.stat-num{font-weight:440;font-size:clamp(3.4rem,8vw,7rem);line-height:.9;letter-spacing:-.03em;
  font-variant-numeric:tabular-nums lining-nums;display:inline-flex;align-items:flex-start}
.stat-num .plus{font-size:.42em;line-height:1;margin-top:.3em;margin-left:.06em;color:rgba(251,248,242,.66)}
.stat-label{font-family:var(--mono);font-size:13px;letter-spacing:.08em;color:rgba(251,248,242,.82);
  text-transform:uppercase}

/* =========================================================================
   THE PROBLEM WE SOLVE (dark)
   ========================================================================= */
.problem-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:clamp(32px,6vw,90px);align-items:center}
.problem-grid .head{font-size:clamp(1.95rem,4.5vw,4rem)}
@media (max-width:860px){.problem-grid{grid-template-columns:1fr;gap:32px}}
.problem-aside{display:flex;flex-direction:column;gap:26px;padding-top:14px}
.problem-pay{margin-top:clamp(48px,6vw,84px);padding-top:clamp(40px,4.6vw,60px);border-top:1px solid var(--line-inv)}
.problem-pay p{font-weight:480;font-size:clamp(1.5rem,3.1vw,2.6rem);line-height:1.22;letter-spacing:-.02em;
  max-width:none}
.problem-pay .em{color:var(--oak-soft)}
.problem-own .po-break{display:inline}
@media (max-width:760px){.problem-own .po-break{display:block}}

/* =========================================================================
   WHY BIG RED OAK — feature card among smaller ones
   ========================================================================= */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,1.4vw,20px)}
.card{position:relative;isolation:isolate;display:flex;flex-direction:column;background:var(--paper);
  border:1px solid var(--line);border-radius:var(--r-card);padding:clamp(26px,3vw,44px);
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s var(--ease)}
.card::after{content:"";position:absolute;inset:0;z-index:-1;border-radius:inherit;pointer-events:none;
  opacity:0;transition:opacity .5s var(--ease);
  background:radial-gradient(440px circle at var(--mx,50%) var(--my,50%),rgba(165,58,43,.14),transparent 60%)}
.card:hover::after{opacity:1}
.card:hover{transform:translateY(-4px);box-shadow:0 26px 60px -34px rgba(42,37,33,.5);border-color:var(--line-soft)}
.card .c-idx{font-family:var(--mono);font-size:12px;letter-spacing:.12em;color:var(--clay)}
.card .why-mark{display:block;width:clamp(30px,3.4vw,40px);height:auto;color:var(--oak);
  margin-top:clamp(20px,2.8vw,34px);stroke-width:1.6}
.card h3{margin-top:clamp(16px,1.8vw,24px);font-weight:520;
  font-size:clamp(1.35rem,1.9vw,1.8rem);line-height:1.12;letter-spacing:-.02em}
.card p{margin-top:14px;color:var(--ink-soft);text-wrap:pretty}
.card--feature{grid-column:span 1;background:var(--bark);color:var(--sand);border-color:transparent}
.card--feature .c-idx{color:rgba(219,199,175,.62)}
.card--feature h3{font-size:clamp(1.7rem,2.6vw,2.5rem)}
.card--feature p{color:rgba(219,199,175,.78)}
.card--feature .why-mark,.card--wide .why-mark{color:var(--oak-soft)}
.card--wide{grid-column:1/-1;background:var(--sage-deep);border-color:transparent;color:var(--paper)}
.card--wide .c-idx{color:rgba(244,236,221,.62)}
.card--wide p{color:rgba(244,236,221,.84)}
.card--feature::after,.card--wide::after{
  background:radial-gradient(460px circle at var(--mx,50%) var(--my,50%),rgba(255,255,255,.16),transparent 60%)}
@media (max-width:900px){.why-grid{grid-template-columns:1fr 1fr}
  .card--feature{grid-column:1/-1;grid-row:auto;flex-direction:row;align-items:center;gap:24px;flex-wrap:wrap}
  .card--feature .why-mark{margin-top:0}
  .card--feature h3{margin-top:0;flex:1 1 12ch}.card--feature p{flex:2 1 28ch;margin-top:0}}
@media (max-width:560px){.why-grid{grid-template-columns:1fr}.card--feature{flex-direction:column;align-items:flex-start}
  .card--feature .why-mark{margin-top:clamp(16px,4vw,24px)}
  .card--feature h3{flex:none;margin-top:14px;font-size:clamp(1.35rem,1.9vw,1.8rem)}
  .card--feature p{flex:none;margin-top:14px}
  .card--wide{grid-column:auto}}

/* =========================================================================
   WHO WE SERVE — photo tiles, expand on hover/focus/click
   ========================================================================= */
.serve-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(14px,1.4vw,20px)}
@media (max-width:760px){.serve-grid{grid-template-columns:1fr}}
.tile{position:relative;border-radius:var(--r-card);overflow:hidden;isolation:isolate;
  min-height:clamp(320px,38vw,440px);display:flex;flex-direction:column;justify-content:flex-end;
  color:var(--paper);border:1px solid transparent}
.tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;
  transition:transform .8s var(--ease)}
.tile::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(0deg,rgba(24,22,18,.9) 0%,rgba(24,22,18,.55) 34%,rgba(24,22,18,.12) 70%)}
.tile:hover img,.tile:focus-within img{transform:scale(1.05)}
.tile-body{padding:clamp(24px,2.4vw,36px)}
.tile-num{font-family:var(--mono);font-size:12px;letter-spacing:.14em;color:rgba(219,199,175,.8)}
.tile h3{margin-top:12px;font-weight:520;font-size:clamp(1.35rem,2.1vw,1.95rem);line-height:1.1;
  letter-spacing:-.02em}
.tile-desc{margin-top:14px}
.tile-desc>span{color:rgba(244,236,221,.85);max-width:46ch;text-wrap:pretty}

/* =========================================================================
   TESTIMONIAL (dark pull-quote + portrait)
   ========================================================================= */
.quote-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(28px,5vw,80px);align-items:center}
@media (max-width:820px){.quote-grid{grid-template-columns:1fr;gap:32px}}
.quote-photo{border-radius:var(--r-card);overflow:hidden;aspect-ratio:4/5;max-width:380px}
.quote-photo img{width:100%;height:100%;object-fit:cover}
.quote-body blockquote{margin:0;font-weight:460;font-size:clamp(1.6rem,3.2vw,2.85rem);line-height:1.16;
  letter-spacing:-.022em;text-wrap:pretty}
.quote-body blockquote .mark{color:inherit}
.quote-cite{margin-top:clamp(26px,3vw,40px);display:flex;align-items:center;gap:14px;font-style:normal}
.quote-cite .nm{font-weight:600}.quote-cite .ro{font-family:var(--mono);font-size:12px;letter-spacing:.06em;
  color:rgba(219,199,175,.7);text-transform:uppercase}
.quote-cite::before{content:"";width:34px;height:1px;background:var(--oak-soft)}

/* ---- Testimonial slider (scroll-snap track + controls) ----------------- */
.slider{position:relative}
.slider:focus-visible{outline:2px solid var(--oak-soft);outline-offset:6px;border-radius:10px}
.slider-track{display:flex;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scroll-behavior:smooth;align-items:flex-start;scrollbar-width:none;transition:height .45s var(--ease)}
.slider-track::-webkit-scrollbar{display:none}
.slide{flex:0 0 100%;min-width:0;scroll-snap-align:start}
.slide blockquote{font-size:clamp(1.3rem,2.2vw,1.95rem);line-height:1.32}
.slide--lg blockquote{font-size:clamp(1.15rem,1.9vw,1.55rem);line-height:1.36}
.slide--xl blockquote{font-size:clamp(1.02rem,1.55vw,1.3rem);line-height:1.42}
@media (prefers-reduced-motion:reduce){.slider-track{scroll-behavior:auto;transition:none}}
.slider-nav{display:flex;align-items:center;gap:16px;margin-top:clamp(30px,3.6vw,52px)}
.slider-btn{flex:none;width:50px;height:50px;border-radius:var(--r-pill);border:1px solid var(--line-inv);
  display:grid;place-items:center;color:var(--sand);transition:background .35s var(--ease),
  border-color .35s var(--ease),color .35s var(--ease),opacity .35s var(--ease)}
.slider-btn .ico{width:20px;height:20px}
.slider-btn:hover:not(:disabled){background:var(--oak);border-color:var(--oak);color:var(--paper)}
.slider-btn:disabled{opacity:.32;cursor:default}
.slider-dots{display:flex;align-items:center;gap:9px;margin-inline:6px}
.slider-dot{width:9px;height:9px;border-radius:var(--r-pill);background:rgba(219,199,175,.32);
  transition:background .35s var(--ease),transform .35s var(--ease)}
.slider-dot.is-active{background:var(--oak-soft);transform:scale(1.3)}
/* monogram stand-in until a real portrait is supplied */
.quote-photo--mono{display:grid;place-items:center;background:linear-gradient(150deg,var(--sage),var(--sage-deep))}
.quote-photo--mono span{font-family:var(--mono);font-weight:500;font-size:clamp(2.6rem,6vw,4.4rem);
  letter-spacing:.06em;color:var(--paper);opacity:.9}

/* =========================================================================
   CLOSING CTA
   ========================================================================= */
.closing{display:grid;gap:clamp(30px,4vw,52px);justify-items:start}
.closing .display{font-size:clamp(1.8rem,3.6vw,3.3rem);line-height:1.16;max-width:none}

/* =========================================================================
   FAQ — native <details> accordion
   ========================================================================= */
.faq-grid{display:grid;grid-template-columns:.66fr 1.34fr;gap:clamp(28px,5vw,80px);align-items:start}
@media (max-width:860px){.faq-grid{grid-template-columns:1fr;gap:28px}}
.faq-list{border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;display:flex;align-items:flex-start;gap:clamp(16px,2.4vw,34px);
  padding:clamp(22px,2.4vw,30px) 0;transition:color .3s var(--ease)}
.faq summary::-webkit-details-marker{display:none}
.faq summary:hover{color:var(--oak)}
.faq .q-idx{font-family:var(--mono);font-size:12px;letter-spacing:.12em;color:var(--clay);padding-top:.5em;flex:none}
.faq .q{flex:1;font-weight:500;font-size:clamp(1.15rem,1.8vw,1.6rem);line-height:1.18;letter-spacing:-.018em}
.faq .q-mark{flex:none;width:30px;height:30px;border-radius:var(--r-pill);border:1px solid var(--line);
  display:grid;place-items:center;transition:background .4s var(--ease),border-color .4s var(--ease),transform .4s var(--ease)}
.faq .q-mark .ico{width:15px;height:15px;transition:transform .4s var(--ease)}
.faq details[open] .q-mark{background:var(--oak);border-color:var(--oak);color:var(--paper)}
.faq details[open] .q-mark .ico{transform:rotate(45deg)}
.faq .a{overflow:hidden;color:var(--ink-soft);max-width:64ch;padding-left:calc(clamp(16px,2.4vw,34px) + 2.4em);
  padding-right:46px}
.faq details[open] .a{padding-bottom:clamp(22px,2.4vw,30px)}
.faq .a p{padding-top:2px}
@media (max-width:560px){.faq .a{padding-left:0}}

/* =========================================================================
   FOOTER
   ========================================================================= */
.footer{position:relative;background:var(--bark-deep);color:var(--sand);overflow:hidden;isolation:isolate}
.footer-media{position:absolute;inset:0;z-index:-2}
.footer-media img{width:100%;height:100%;object-fit:cover;opacity:.5}
.footer::before{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(28,26,22,.7),rgba(28,26,22,.92))}
.footer-inner{padding-block:clamp(64px,9vw,120px) 0;container-type:inline-size}
.footer-top{display:grid;grid-template-columns:1.4fr .8fr .8fr auto;gap:clamp(28px,5vw,72px);
  padding-bottom:clamp(48px,7vw,96px);border-bottom:1px solid var(--line-inv)}
@media (max-width:820px){.footer-top{grid-template-columns:1fr 1fr;gap:40px}}
@media (max-width:520px){.footer-top{grid-template-columns:1fr}}
.footer-claim{font-weight:460;font-size:clamp(1.4rem,2.5vw,2.1rem);line-height:1.18;letter-spacing:-.02em;
  max-width:20ch;color:var(--paper);text-wrap:balance}
.footer-col h4{font-family:var(--mono);font-weight:500;font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(219,199,175,.55);margin-bottom:18px}
.footer-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.footer-col a{font-size:1.05rem;color:var(--sand);transition:color .3s var(--ease),padding-left .3s var(--ease)}
.footer-col a:hover{color:var(--paper);padding-left:6px}
.footer-up{justify-self:end;align-self:start;width:54px;height:54px;border-radius:var(--r-pill);
  border:1px solid var(--line-inv);display:grid;place-items:center;transition:background .4s var(--ease),
  border-color .4s var(--ease),transform .4s var(--ease)}
.footer-up:hover{background:var(--oak);border-color:var(--oak);color:var(--paper);transform:translateY(-3px)}
.footer-up .ico{width:20px;height:20px}
.footer-logo{display:block;width:clamp(124px,14vw,164px);aspect-ratio:1920/632.35;
  background:var(--paper);margin-bottom:clamp(28px,4vw,48px);
  -webkit-mask:url(assets/img/logo-mark.svg) no-repeat left center/contain;
  mask:url(assets/img/logo-mark.svg) no-repeat left center/contain}
.footer-legal{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:14px;
  padding-block:clamp(26px,3vw,40px);font-family:var(--mono);font-size:12px;letter-spacing:.06em;
  color:rgba(219,199,175,.55)}
.footer-legal a:hover{color:var(--sand)}

/* =========================================================================
   Reveals — gated behind html.is-ready so content shows if JS fails
   ========================================================================= */
html.is-ready [data-reveal]{opacity:0;transform:translateY(20px);
  transition:opacity .9s var(--ease),transform .9s var(--ease)}
html.is-ready [data-reveal].is-in{opacity:1;transform:none}
html.is-ready [data-reveal-stagger]>*{opacity:0;transform:translateY(18px);
  transition:opacity .8s var(--ease),transform .8s var(--ease)}
html.is-ready [data-reveal-stagger].is-in>*{opacity:1;transform:none}
[data-split] .word{display:inline-block}
html.is-ready.gsap-on [data-split] .word{will-change:opacity}

/* hero orchestrated load (JS adds .hero-in on the section once ready) */
html.is-ready .hero [data-hero]{opacity:0;transform:translateY(26px);
  transition:opacity 1s var(--ease),transform 1s var(--ease)}
html.is-ready .hero.hero-in [data-hero]{opacity:1;transform:none}
html.is-ready .hero.hero-in [data-hero="1"]{transition-delay:.05s}
html.is-ready .hero.hero-in [data-hero="2"]{transition-delay:.18s}
html.is-ready .hero.hero-in [data-hero="3"]{transition-delay:.34s}
html.is-ready .hero.hero-in [data-hero="4"]{transition-delay:.5s}
html.is-ready .hero.hero-in [data-hero="5"]{transition-delay:.64s}

@media (prefers-reduced-motion:reduce){
  html.is-ready [data-reveal],html.is-ready [data-reveal-stagger]>*,
  html.is-ready .hero [data-hero]{opacity:1!important;transform:none!important;transition:none!important}
  .hero-media img{animation:none}
  .marquee-row{animation:none}
  .tile-desc{transition:none}
}

/* =========================================================================
   Responsive nav
   ========================================================================= */
@media (max-width:880px){
  .nav-links,.nav-cta{display:none}
  .nav-burger{display:grid}
}
@media (min-width:881px){.menu-close{display:none}}

/* =========================================================================
   ABOUT PAGE  (interior hero + story + oak metaphor + team + memberships)
   ========================================================================= */
/* interior hero — shorter than the Home landing hero, different fluid crop */
.hero--about{min-height:clamp(560px,82vh,820px)}
.hero--about .hero-media img{object-position:54% 42%;animation-duration:38s}
.hero--about h1{font-size:clamp(2rem,4.8vw,4.4rem);max-width:24ch}

/* page intro tag row that sits alone (no index sibling) */
.eyebrow--solo{justify-content:flex-start}

/* ---- Our Story: editorial split with a fluid media card ---------------- */
.story-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(32px,5vw,84px);align-items:center}
@media (max-width:860px){.story-grid{grid-template-columns:1fr;gap:38px}}
.story-copy{display:flex;flex-direction:column;gap:1.05em;color:var(--ink-soft);max-width:58ch}
.story-copy .lead{color:var(--ink)}
.story-emph{margin-top:.3em;font-weight:480;font-size:clamp(1.3rem,2.2vw,1.95rem);line-height:1.18;
  letter-spacing:-.02em;color:var(--ink);text-wrap:balance}
.story-emph .em{color:var(--oak)}
.story-media{position:relative;border-radius:var(--r-card);overflow:hidden;aspect-ratio:5/4;
  border:1px solid var(--line);margin:0}
.story-media img{width:100%;height:100%;object-fit:cover}
.story-media figcaption{position:absolute;left:clamp(16px,1.8vw,24px);bottom:clamp(14px,1.8vw,22px);
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--paper);
  background:rgba(28,26,22,.4);padding:7px 13px;border-radius:var(--r-pill);backdrop-filter:blur(6px)}

/* ---- What's in a name: the oak metaphor (SIGNATURE) -------------------- */
.name-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(36px,6vw,104px);align-items:start}
@media (max-width:880px){.name-grid{grid-template-columns:1fr;gap:48px}}
.oak-intro{display:flex;flex-direction:column;gap:clamp(18px,2.4vw,28px)}
.oak-intro .head{font-size:clamp(1.9rem,3.7vw,3.3rem)}
.oak-intro p{color:rgba(219,199,175,.82);max-width:40ch;text-wrap:pretty}
.oak-figure{width:clamp(48px,6vw,78px);aspect-ratio:1191.53/1858.49;background:var(--oak-soft);opacity:.92;
  -webkit-mask:url(assets/img/logo-mark-vertical.svg) no-repeat center/contain;
  mask:url(assets/img/logo-mark-vertical.svg) no-repeat center/contain}
.oak-aspire{font-weight:480;font-size:clamp(1.3rem,2vw,1.7rem);line-height:1.18;letter-spacing:-.02em;color:var(--sand)}
.oak-aspire .em{color:var(--oak-soft)}
.oak-layers{position:relative;display:flex;flex-direction:column;padding-left:clamp(26px,3vw,40px)}
.oak-trunk{position:absolute;left:0;top:.7em;bottom:.7em;width:2px;border-radius:2px;transform-origin:top center;
  background:linear-gradient(180deg,var(--oak-soft),rgba(219,199,175,.18))}
.oak-layer{position:relative;padding-block:clamp(20px,2.6vw,30px);border-bottom:1px solid var(--line-inv)}
.oak-layer:last-child{border-bottom:0}
.oak-layer::before{content:"";position:absolute;left:calc(-1*clamp(26px,3vw,40px) - 4px);
  top:calc(clamp(20px,2.6vw,30px) + .25em);width:11px;height:11px;border-radius:50%;background:var(--sand);
  box-shadow:0 0 0 5px var(--bark)}
.oak-layer .part{display:block;margin-bottom:11px;font-family:var(--mono);font-size:12px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--oak-soft)}
.oak-layer .meaning{font-weight:460;font-size:clamp(1.3rem,2.4vw,2.05rem);line-height:1.1;letter-spacing:-.02em;
  color:var(--sand)}
.oak-layer .meaning .faded{color:rgba(219,199,175,.5)}

/* ---- Our Team: real photos + quirky bios (expand on click) ------------- */
.team-head{max-width:62ch;margin-bottom:clamp(40px,5vw,72px)}
.team-head .lead{margin-top:22px;color:var(--ink-soft)}
.people-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(24px,2.6vw,44px) clamp(16px,1.8vw,30px);
  align-items:start}
@media (max-width:900px){.people-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:560px){.people-grid{grid-template-columns:repeat(2,1fr)}}
.person{display:flex;flex-direction:column;cursor:pointer}
.person-photo{width:100%;aspect-ratio:1/1;border-radius:var(--r-card);overflow:hidden}
.person-photo img{width:100%;height:100%;object-fit:contain;transition:transform .6s var(--ease)}
.person:hover .person-photo img{transform:scale(1.05) rotate(-.7deg)}
.person-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:14px}
.person .nm{font-weight:560;font-size:clamp(1.1rem,1.4vw,1.35rem);letter-spacing:-.02em;color:var(--ink)}
.person-emoji{margin-left:7px;font-size:.95em}
.person-role{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--clay);margin-top:6px}
.person--nobio{cursor:default}
.person-photo--ph{display:grid;place-items:center}
.person-photo--ph .ph-shape{width:84%;aspect-ratio:1/1;border-radius:50%;background:var(--sage);
  display:grid;place-items:center;color:rgba(251,248,242,.82)}
.person-photo--ph .ico{width:42%;height:42%;stroke-width:1.5}
.person .plus{flex:none;width:30px;height:30px;border-radius:var(--r-pill);border:1px solid var(--line);
  display:grid;place-items:center;color:var(--clay);
  transition:background .4s var(--ease),border-color .4s var(--ease),color .4s var(--ease)}
.person .plus .ico{width:15px;height:15px;transition:transform .4s var(--ease)}
.person:hover .plus,.person .plus:hover{border-color:var(--oak);color:var(--oak)}
/* bios stay in the DOM as the modal's data source; hidden inline */
.person-bio{display:none}
.person-bio dl{margin:0}
.trait{padding:11px 0;border-top:1px solid var(--line)}
.trait:first-child{border-top:0;padding-top:2px}
.trait dt{margin:0;font-family:var(--mono);font-size:11px;letter-spacing:.11em;text-transform:uppercase;color:var(--oak)}
.trait dd{margin:5px 0 0;color:var(--ink-soft);font-size:.92rem;line-height:1.46;text-wrap:pretty}
.team-note{margin-top:clamp(36px,4vw,60px);font-family:var(--mono);font-size:12px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--clay);display:inline-flex;align-items:center;gap:10px}
.team-note::before{content:"";width:8px;height:8px;border-radius:2px;background:var(--oak)}

/* ---- Team bio modal (native <dialog> + light-dismiss) ------------------ */
.person-modal{margin:auto;border:0;padding:0;width:min(660px,92vw);max-height:88vh;overflow:auto;
  color:var(--ink);background:var(--paper);border-radius:var(--r-card);
  box-shadow:0 50px 120px -40px rgba(20,18,16,.7)}
/* the dialog appears instantly and is always visible when open — never dependent on an
   entry animation resolving, so it can't get stuck hidden in any browser. only the backdrop fades. */
.person-modal::backdrop{background:rgba(24,20,16,.5);backdrop-filter:blur(3px);animation:personBackdropIn .35s var(--ease) both}
@keyframes personBackdropIn{from{opacity:0}to{opacity:1}}
.person-modal-grid{display:grid;grid-template-columns:.82fr 1fr}
@media (max-width:560px){.person-modal-grid{grid-template-columns:1fr}}
.person-modal-photo{display:grid;place-items:center;background:var(--cream);padding:clamp(22px,3vw,34px)}
.person-modal-photo img{width:100%;height:auto;max-width:240px;display:block}
.person-modal-text{padding:clamp(28px,3.6vw,46px)}
.person-modal-name{font-weight:560;font-size:clamp(1.5rem,3vw,2.1rem);letter-spacing:-.02em;line-height:1.05;margin-bottom:5px}
.person-modal-name .person-emoji{margin-left:8px}
.person-modal-role{margin:0 0 22px;font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--oak)}
.person-modal-traits{margin:0}
.person-modal-close{position:absolute;top:14px;right:14px;z-index:3;width:40px;height:40px;border-radius:var(--r-pill);
  background:rgba(251,248,242,.92);border:1px solid var(--line);display:grid;place-items:center;color:var(--ink);
  transition:background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease)}
.person-modal-close:hover{background:var(--oak);color:var(--paper);border-color:var(--oak)}
.person-modal-close .ico{width:18px;height:18px}
@media (prefers-reduced-motion:reduce){.person-modal[open],.person-modal[open]::backdrop{animation:none}}

/* ---- Partners & advisors: ecosystem statement + pending list ----------- */
.partners-copy{display:flex;flex-direction:column;gap:24px;padding-top:6px}
.partners-note{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(244,236,221,.6);display:inline-flex;align-items:center;gap:10px}
.partners-note::before{content:"";width:8px;height:8px;border-radius:2px;background:var(--oak-soft)}

/* ---- Memberships: association wordmarks (no fabricated logos) ----------- */
.mem-head{margin-bottom:clamp(34px,4vw,56px)}
.mem-head .head-sm{max-width:24ch}
.mem-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(12px,1.2vw,18px)}
@media (max-width:820px){.mem-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.mem-grid{grid-template-columns:1fr}}
.member{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  gap:clamp(16px,1.8vw,22px);min-height:clamp(126px,14vw,166px);background:var(--paper);border:1px solid var(--line);
  border-radius:var(--r-card);padding:clamp(24px,2.4vw,34px);transition:transform .5s var(--ease),
  box-shadow .5s var(--ease),border-color .5s var(--ease)}
.member:hover{transform:translateY(-3px);box-shadow:0 22px 50px -34px rgba(42,37,33,.5);border-color:var(--line-soft)}
.member-logo{width:100%;height:clamp(42px,5vw,56px);background:var(--bark);
  -webkit-mask-repeat:no-repeat;-webkit-mask-position:center;-webkit-mask-size:contain;
  mask-repeat:no-repeat;mask-position:center;mask-size:contain}
.m-cna{-webkit-mask-image:url(assets/img/memberships/cna.png);mask-image:url(assets/img/memberships/cna.png)}
.m-cns{-webkit-mask-image:url(assets/img/memberships/cns.png);mask-image:url(assets/img/memberships/cns.png)}
.m-ans{-webkit-mask-image:url(assets/img/memberships/ans.svg);mask-image:url(assets/img/memberships/ans.svg)}
.m-ocni{-webkit-mask-image:url(assets/img/memberships/ocni.webp);mask-image:url(assets/img/memberships/ocni.webp)}
.m-cnic{-webkit-mask-image:url(assets/img/memberships/cnic.png);mask-image:url(assets/img/memberships/cnic.png)}
.m-trbot{-webkit-mask-image:url(assets/img/memberships/trbot.png);mask-image:url(assets/img/memberships/trbot.png)}
.member-name{font-family:var(--mono);font-size:12px;letter-spacing:.06em;color:var(--ink-soft);text-transform:uppercase;text-wrap:pretty}

/* =========================================================================
   OUR WORK  ·  CONTACT  ·  CLEAN CURRENTS  (interior pages)
   ========================================================================= */
/* shared interior hero crop variants */
.hero--work .hero-media img{object-position:36% 50%}
.hero--cc .hero-media img{object-position:62% 60%;animation-duration:40s}

/* ---- Where We Work: editorial challenge list --------------------------- */
.challenge-list{display:grid;border-top:1px solid var(--line)}
.challenge{display:grid;grid-template-columns:auto 1fr;gap:clamp(18px,3.5vw,60px);align-items:start;
  padding-block:clamp(28px,3.4vw,48px);border-bottom:1px solid var(--line)}
.challenge{position:relative;isolation:isolate}
.challenge .c-num,.challenge .c-body{position:relative;z-index:1}
.challenge .c-num{font-family:var(--mono);font-size:13px;letter-spacing:.12em;color:var(--oak);padding-top:.55em}
/* botanical accent that follows the cursor on hover (sits behind the text) */
.challenge-botanical{position:absolute;left:0;top:0;
  height:clamp(110px,12vw,168px);width:auto;max-width:none;pointer-events:none;opacity:0;z-index:0;
  transform:translate3d(calc(var(--x,0px) - 50%),calc(var(--y,0px) - 50%),0) rotate(-4deg);
  transition:opacity .35s var(--ease),transform .25s cubic-bezier(.22,.61,.36,1);
  filter:drop-shadow(0 14px 28px rgba(42,37,33,.18));will-change:transform,opacity}
.challenge:hover .challenge-botanical{opacity:.85}
.challenge-botanical--sm{height:clamp(70px,8vw,108px)}
@media (max-width:820px){.challenge-botanical{display:none}}
@media (prefers-reduced-motion:reduce){.challenge-botanical{transition:opacity .2s}}
.challenge .c-body{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(14px,3vw,56px);align-items:start}
@media (max-width:820px){.challenge{grid-template-columns:1fr;gap:14px}.challenge .c-body{grid-template-columns:1fr;gap:12px}}
.challenge h3{font-weight:520;font-size:clamp(1.5rem,2.6vw,2.25rem);line-height:1.05;letter-spacing:-.02em}
.challenge p{color:var(--ink-soft);text-wrap:pretty}

/* ---- Capabilities: two-column tag list --------------------------------- */
.cap-cols{columns:2;column-gap:clamp(28px,5vw,80px);list-style:none;margin:0;padding:0}
@media (max-width:620px){.cap-cols{columns:1}}
.cap-cols li{break-inside:avoid;display:flex;align-items:center;gap:14px;padding-block:clamp(13px,1.4vw,18px);
  border-bottom:1px solid var(--line-inv);font-size:clamp(1.05rem,1.4vw,1.3rem);font-weight:480;letter-spacing:-.01em;color:var(--sand)}
.cap-cols li::before{content:"";width:7px;height:7px;border-radius:2px;background:var(--oak-soft);flex:none}

/* ---- Featured work cards ------------------------------------------------ */
.work-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,2vw,32px)}
@media (max-width:760px){.work-grid{grid-template-columns:1fr}}
.work-card{display:flex;flex-direction:column;border-radius:var(--r-card);overflow:hidden;background:var(--paper);
  border:1px solid var(--line);transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s var(--ease)}
.work-card:hover{transform:translateY(-4px);box-shadow:0 30px 70px -42px rgba(42,37,33,.55);border-color:var(--line-soft)}
.work-shot{aspect-ratio:16/10;overflow:hidden;background:var(--cream)}
.work-shot img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.work-card:hover .work-shot img{transform:scale(1.045)}
.work-body{padding:clamp(24px,2.6vw,38px);display:flex;flex-direction:column;gap:13px;flex:1}
.work-card h3{font-weight:520;font-size:clamp(1.4rem,2.1vw,1.95rem);line-height:1.08;letter-spacing:-.02em}
.work-card p{color:var(--ink-soft);text-wrap:pretty}

/* ---- More work: compact portfolio grid --------------------------------- */
.work-more{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,1.6vw,24px)}
@media (max-width:860px){.work-more{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.work-more{grid-template-columns:1fr}}
.work-mini{border-radius:var(--r-card);overflow:hidden;border:1px solid var(--line);background:var(--paper);
  transition:transform .5s var(--ease),border-color .5s var(--ease)}
.work-mini:hover{transform:translateY(-3px);border-color:var(--line-soft)}
.work-mini-shot{aspect-ratio:16/10;overflow:hidden;background:var(--cream)}
.work-mini-shot img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.work-mini:hover .work-mini-shot img{transform:scale(1.05)}
.work-mini .ml{padding:clamp(16px,1.6vw,22px);display:flex;flex-direction:column;gap:5px}
.work-mini .nm{font-weight:520;font-size:1.08rem;letter-spacing:-.015em}
.work-mini .ty{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--clay)}

/* ---- Forms (contact + newsletter), dark sections ----------------------- */
.form{display:grid;gap:clamp(16px,1.8vw,22px)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,1.8vw,22px)}
@media (max-width:620px){.form-row{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:8px;min-width:0}
.field label{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(219,199,175,.72)}
.field input,.field textarea{font:inherit;color:var(--paper);background:transparent;border:0;border-bottom:1px solid var(--line-inv);
  padding:11px 2px;border-radius:0;transition:border-color .3s var(--ease)}
.field textarea{resize:vertical;min-height:96px}
.field input::placeholder,.field textarea::placeholder{color:rgba(219,199,175,.38)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--sand)}
.field input:user-invalid,.field textarea:user-invalid{border-color:var(--oak-soft)}
.form .btn{margin-top:8px;justify-self:start;border:0;background:none;cursor:pointer;padding:0}
.hp{position:absolute!important;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-status{font-family:var(--mono);font-size:13px;letter-spacing:.03em;color:var(--sand);min-height:1em}

/* ---- Contact layout ----------------------------------------------------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,104px);align-items:start}
@media (max-width:880px){.contact-grid{grid-template-columns:1fr;gap:48px}}
.contact-lead{display:flex;flex-direction:column;gap:clamp(22px,2.8vw,34px)}
.contact-lead .display{font-size:clamp(2.4rem,5.4vw,4.4rem)}
.contact-lead p{color:rgba(244,236,221,.82);max-width:48ch;text-wrap:pretty}
.contact-details{display:flex;flex-direction:column;gap:20px;margin-top:6px}
.contact-detail{display:flex;flex-direction:column;gap:5px}
.contact-detail .k{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(219,199,175,.6)}
.contact-detail a{font-size:clamp(1.1rem,1.6vw,1.4rem);color:var(--sand);width:fit-content;
  border-bottom:1px solid var(--line-inv);padding-bottom:3px;transition:color .3s var(--ease),border-color .3s var(--ease)}
.contact-detail a:hover{color:#fff;border-color:var(--oak-soft)}
.contact-form{background:rgba(20,18,16,.28);border:1px solid var(--line-inv);border-radius:var(--r-card);
  padding:clamp(26px,3.2vw,46px)}

/* ---- Clean Currents ----------------------------------------------------- */
.cc-feature{display:grid;grid-template-columns:.85fr 1.15fr;gap:0;background:var(--bark);color:var(--sand);
  border-radius:var(--r-card);overflow:hidden;border:1px solid transparent}
@media (max-width:820px){.cc-feature{grid-template-columns:1fr}}
.cc-feature-shot{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--bark-deep)}
.cc-feature-shot img{width:100%;height:100%;object-fit:cover}
.cc-feature-body{padding:clamp(28px,3.6vw,56px);display:flex;flex-direction:column;gap:16px;justify-content:center}
.cc-feature-body h3{font-weight:480;font-size:clamp(1.6rem,2.8vw,2.5rem);line-height:1.1;letter-spacing:-.02em;color:var(--paper)}
.cc-feature-body p{color:rgba(219,199,175,.82);text-wrap:pretty}
.cc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,1.8vw,28px)}
@media (max-width:860px){.cc-grid{grid-template-columns:1fr 1fr}}
@media (max-width:460px){.cc-grid{grid-template-columns:1fr}}
.cc-ep{display:flex;flex-direction:column;gap:14px}
.cc-ep-shot{aspect-ratio:1/1;border-radius:var(--r-card);overflow:hidden;background:var(--cream)}
.cc-ep-shot img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.cc-ep:hover .cc-ep-shot img{transform:scale(1.05)}
.cc-ep .meta{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--clay)}
.cc-ep .nm{font-weight:520;font-size:clamp(1.1rem,1.5vw,1.35rem);letter-spacing:-.02em;line-height:1.15}
.cc-ep .ep-play{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-soft)}
.cc-ep .ep-play .ico{width:14px;height:14px;color:var(--oak)}

/* newsletter band */
.news{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,84px);align-items:center}
@media (max-width:820px){.news{grid-template-columns:1fr;gap:30px}}
.news .head{font-size:clamp(1.9rem,4vw,3.2rem)}
.news-lead{color:rgba(244,236,221,.82);margin-top:18px;max-width:42ch}

/* ---- Clean Currents: blog grid ----------------------------------------- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2vw,30px)}
@media (max-width:860px){.blog-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.blog-grid{grid-template-columns:1fr}}
.blog-card{display:flex;flex-direction:column;gap:13px;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--r-card);padding:clamp(26px,2.8vw,38px);min-height:clamp(230px,24vw,290px);color:inherit;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s var(--ease)}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 26px 60px -38px rgba(42,37,33,.5);border-color:var(--line-soft)}
.blog-card h3{font-weight:520;font-size:clamp(1.3rem,1.9vw,1.7rem);line-height:1.12;letter-spacing:-.02em;color:var(--ink)}
.blog-card p{color:var(--ink-soft);text-wrap:pretty;flex:1}
.blog-card .card-read{margin-top:4px;font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--oak);display:inline-flex;align-items:center;gap:8px;transition:gap .35s var(--ease)}
.blog-card .card-read .ico{width:15px;height:15px}
.blog-card:hover .card-read{gap:14px}

/* ---- Article (blog post) pages ----------------------------------------- */
.article-head{padding-top:clamp(122px,17vh,184px)}
.article-head .head{max-width:22ch;margin-top:10px;font-size:clamp(2rem,4.4vw,3.7rem)}
.article-meta{margin-top:clamp(22px,2.6vw,32px);display:flex;flex-wrap:wrap;gap:8px 20px;
  font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:rgba(219,199,175,.72)}
.article-prose{max-width:68ch;color:var(--ink-soft)}
.article-prose>p,.article-prose>div{font-size:clamp(1.02rem,1.2vw,1.18rem)}
.article-prose p{margin-top:1.15em;line-height:1.7;text-wrap:pretty}
.article-prose>p.lead{margin-top:0;color:var(--ink);font-size:clamp(1.2rem,1.7vw,1.5rem);line-height:1.5}
.article-prose h2{margin-top:1.9em;font-weight:520;font-size:clamp(1.4rem,2.3vw,2rem);line-height:1.16;
  letter-spacing:-.02em;color:var(--ink)}
.article-prose h3{margin-top:1.6em;font-weight:560;font-size:clamp(1.12rem,1.6vw,1.4rem);line-height:1.25;
  letter-spacing:-.01em;color:var(--ink)}
.article-prose .qa{margin-top:.85em}
.article-prose .qa .who{font-weight:600;color:var(--oak)}
.article-prose .article-back{margin-top:clamp(40px,5vw,64px)}

/* ---- Work cards: clickable cue ---------------------------------------- */
.work-view{margin-top:auto;padding-top:8px;font-family:var(--mono);font-size:12px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--oak);display:inline-flex;align-items:center;gap:8px;transition:gap .35s var(--ease)}
.work-view .ico{width:15px;height:15px}
.work-card:hover .work-view{gap:14px}

/* ---- Project (case study) pages --------------------------------------- */
.project-head{padding-top:clamp(122px,17vh,184px)}
.project-head .head{max-width:16ch;margin-top:10px;font-size:clamp(2.6rem,7vw,5.2rem)}
.project-cat{margin-top:10px;font-family:var(--mono);font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--sand)}
.project-intro{margin-top:clamp(22px,2.6vw,32px);max-width:62ch;font-size:clamp(1.12rem,1.5vw,1.4rem);
  line-height:1.5;color:rgba(244,236,221,.86);text-wrap:pretty}
.project-services{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:clamp(34px,4vw,56px)}
.project-services .svc{font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--clay);border:1px solid var(--line);border-radius:var(--r-pill);padding:8px 15px}
.project-body{max-width:66ch}
.project-body h2{font-weight:520;font-size:clamp(1.45rem,2.4vw,2.1rem);line-height:1.12;letter-spacing:-.02em;
  color:var(--ink);margin-top:1.7em}
.project-body h2:first-child{margin-top:0}
.project-body p{color:var(--ink-soft);line-height:1.7;text-wrap:pretty;margin-top:.8em}
.video-embed{position:relative;width:100%;aspect-ratio:16/9;border-radius:var(--r-card);overflow:hidden;
  background:var(--bark-deep);margin-top:clamp(18px,2.2vw,28px)}
.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-stack{display:grid;gap:clamp(16px,2vw,26px);margin-top:clamp(26px,3vw,44px)}
.proj-gallery{display:grid;grid-template-columns:1fr 1fr;gap:clamp(12px,1.5vw,20px);margin-top:clamp(28px,3.4vw,48px);align-items:start}
@media (max-width:600px){.proj-gallery{grid-template-columns:1fr}}
.proj-gallery img{width:100%;height:auto;display:block;border-radius:var(--r-card);border:1px solid var(--line)}
.proj-gallery .full{grid-column:1 / -1}
.proj-quote{margin-top:clamp(32px,4vw,56px);display:flex;gap:clamp(18px,2.4vw,30px);align-items:center;
  border-left:3px solid var(--oak);padding-left:clamp(20px,2.5vw,32px)}
.proj-quote img{flex:none;width:clamp(64px,8vw,92px);height:clamp(64px,8vw,92px);border-radius:var(--r-pill);object-fit:cover}
.proj-quote blockquote{margin:0;font-size:clamp(1.2rem,1.8vw,1.55rem);line-height:1.36;letter-spacing:-.01em;color:var(--ink);font-weight:460}
.proj-quote .cite{display:block;margin-top:12px;font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--clay)}
.proj-stat{margin-top:clamp(30px,3.6vw,52px);display:flex;flex-wrap:wrap;gap:clamp(26px,4vw,64px)}
.proj-stat .s b{display:block;font-size:clamp(2rem,3.6vw,3rem);font-weight:560;letter-spacing:-.02em;color:var(--oak);line-height:1}
.proj-stat .s span{font-family:var(--mono);font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}
.project-back{margin-top:clamp(40px,5vw,64px)}

/* ---- Case study / article refinements --------------------------------- */
/* Focused, centered body column — removes the empty right-hand gutter */
main > article > div.section > .wrap{max-width:1200px}
/* text stays a readable, centered measure; media (video/gallery/quote) fills the wide column */
.article-prose{max-width:760px;margin-inline:auto}
.article-prose>p,.article-prose>div,.article-prose>.qa{font-size:1.1rem;line-height:1.72}
.project-body{max-width:760px;margin-inline:auto;margin-top:clamp(26px,3.2vw,46px)}
.project-body h2:first-child{margin-top:0}
.project-body p{font-size:1.1rem}
/* services + PDF now live in the dark hero */
.project-head .project-services{margin-top:clamp(22px,2.6vw,32px);margin-bottom:0}
.project-head .project-services .svc{color:rgba(244,236,221,.82);border-color:rgba(244,236,221,.26)}
.project-head .project-pdf{margin-top:clamp(18px,2vw,26px)}

/* ===== Brand-fonts branch: Bebas Neue for the big display headings ====== */
.display,.head,.hero h1,.menu-list a{font-family:var(--display);font-weight:400;letter-spacing:.02em}
.display{line-height:1.06}
.head{line-height:1.08}
.hero h1{line-height:1.05;font-size:clamp(2.5rem,5.2vw,5.2rem);max-width:none}
.hero--about h1,.hero--work h1,.hero--cc h1{font-size:clamp(2rem,4.8vw,4.4rem);max-width:24ch}

/* ===== Section video (Who We Are) ====================================== */
.section-video{margin:clamp(48px,5vw,80px) 0 0;border-radius:var(--r-card);overflow:hidden}
.section-video video{width:100%;height:auto;display:block;aspect-ratio:1600/700;background:#000}
@media (max-width:760px){
  .section-video video{aspect-ratio:16/9;object-fit:cover}
  .section--flush-next{padding-bottom:clamp(48px,8vw,72px)}
}

/* ===== About > What's in a Name: animated oak instead of the vertical mark ===== */
.oak-video{margin:0 0 clamp(10px,1.4vw,20px);border-radius:var(--r-card);overflow:hidden;
  width:clamp(260px,34vw,440px);aspect-ratio:16/9;background:transparent}
.oak-video video{width:100%;height:100%;display:block;object-fit:cover;
  transform:scale(1.45);transform-origin:50% 56%}

/* ===== About > Our Team: vertical mark moved to the right of the heading ===== */
.team-head{display:grid;grid-template-columns:1fr auto;gap:clamp(24px,4vw,60px);
  align-items:start;max-width:none;margin-bottom:clamp(40px,5vw,72px)}
.team-head-text{max-width:62ch}
.team-head .team-oak{flex:none;align-self:start;background:var(--ink);opacity:.85;
  width:clamp(80px,10vw,130px)}
@media (max-width:680px){.team-head{grid-template-columns:1fr}.team-head .team-oak{justify-self:start;width:clamp(64px,14vw,96px)}}

/* ===== Botanical accents (watercolour oak leaves & acorns) ============= */
.botanical-accent{display:block;pointer-events:none;user-select:none;
  filter:drop-shadow(0 18px 36px rgba(42,37,33,.18))}
.faq-head .botanical-leaf{width:clamp(72px,9vw,128px);height:auto;
  margin:clamp(28px,3.6vw,48px) 0 0;opacity:.9;transform:rotate(-6deg);transform-origin:top center}
.closing .botanical-acorns{position:absolute;right:0;bottom:-8px;
  width:clamp(140px,18vw,240px);height:auto;opacity:.95;transform:rotate(8deg);
  pointer-events:none;z-index:0}
#closing .wrap.closing{position:relative}
#closing .display,#closing .btn{position:relative;z-index:1}
@media (max-width:760px){.closing .botanical-acorns{position:static;margin-top:clamp(24px,4vw,40px);transform:none;width:clamp(140px,38vw,200px)}}
/* video section: padding-bottom handled per breakpoint */
.section--flush-next{padding-bottom:clamp(48px,6vw,80px)}
.section--flush-prev{padding-top:0}

/* ===== Mobile polish (375px audit) ====================================== */
/* nav burger: meet 44px iOS touch target */
.nav-burger{height:44px}

/* testimonials: cap portrait height when stacked */
@media (max-width:820px){
  .quote-photo{max-height:280px;max-width:280px;margin-inline:auto}
}

/* clean-currents featured: reduce square image when stacked */
@media (max-width:820px){
  .cc-feature-shot{aspect-ratio:16/9;max-height:260px}
}

/* oak-video: expand to full width on small screens */
@media (max-width:880px){
  .oak-video{width:100%;max-width:440px}
}

/* stats: single column on narrow mobile */
@media (max-width:500px){
  .stats{grid-template-columns:1fr}
}

/* contact hero: prevent flex centering overflow on short phones */
@media (max-width:560px){
  #top.section{align-items:flex-start !important;min-height:auto !important;padding-top:clamp(100px,18vh,130px)}
}

/* faq answers: remove asymmetric right padding on mobile */
@media (max-width:560px){
  .faq .a{padding-right:0}
}

/* team modal photo: smaller on mobile */
@media (max-width:560px){
  .person-modal-photo img{max-width:160px}
}
