/* =========================================================
   SOFOHNY — Cameroon hardwood & veneer
   Design language: "Timber Editorial"
   warm walnut + ember · sharp architectural grid
   heavy sans display + serif numerals
   (intentionally distinct from the reference green/honey site)
   ========================================================= */

:root{
  /* ---- warm timber palette ---- */
  --paper:#f3ede2;       /* warm bone — page background */
  --paper-2:#eadfce;     /* sand — alt blocks / tags */
  --paper-3:#e2d4bd;     /* deeper sand line panels */
  --ink:#241a12;         /* espresso near-black */
  --ink-2:#5d4d3d;       /* muted brown body text */
  --wood:#8a4b24;        /* walnut / sienna — primary brand */
  --ember:#c2632b;       /* burnt orange — accent */
  --ember-2:#e4925a;     /* lighter ember on dark */
  --dark:#1c130c;        /* espresso — dark sections */
  --dark-2:#27190f;      /* slightly lifted dark panel */
  --line:rgba(36,26,18,.16);
  --line-2:rgba(36,26,18,.28);
  --line-d:rgba(244,237,226,.16);
  --line-d2:rgba(244,237,226,.28);

  --sans:"Noto Sans SC","PingFang SC","Hiragino Sans GB","Microsoft YaHei",sans-serif;
  --serif:"Noto Serif SC","Songti SC","Source Han Serif SC",serif;

  --maxw:1220px;
  --pad:clamp(76px,9.5vw,132px);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);color:var(--ink);background:var(--paper);
  line-height:1.78;-webkit-font-smoothing:antialiased;overflow-x:hidden;
  font-weight:350;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
section{scroll-margin-top:84px}
::selection{background:var(--ember);color:#fff}

.wrap{width:min(var(--maxw),90vw);margin-inline:auto}

/* ---------- Typographic primitives ---------- */
.eyebrow{
  font-size:.7rem;font-weight:700;letter-spacing:.34em;text-transform:uppercase;
  color:var(--ember);display:inline-flex;align-items:center;gap:.8em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:currentColor;opacity:.7}
.eyebrow.solo::before{display:none}

h1,h2,h3,h4{font-family:var(--sans);font-weight:800;letter-spacing:-.018em;line-height:1.12;color:var(--ink)}
.title{font-size:clamp(2rem,4.4vw,3.35rem);letter-spacing:-.025em}
.title .em{color:var(--wood)}
.lead{color:var(--ink-2);font-size:clamp(1rem,1.55vw,1.16rem);max-width:60ch;font-weight:350}

/* section index marker  [01] ── label */
.sec-head{display:flex;flex-direction:column;gap:.9rem;margin-bottom:clamp(40px,5vw,64px)}
.sec-head.center{align-items:center;text-align:center}
.idx{display:flex;align-items:center;gap:1rem;width:100%}
.idx .n{font-family:var(--serif);font-weight:700;font-size:.95rem;color:var(--ember);letter-spacing:.05em}
.idx .lbl{font-size:.7rem;font-weight:700;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-2);white-space:nowrap}
.idx::after{content:"";flex:1;height:1px;background:var(--line-2)}
.sec-head.center .idx{justify-content:center}
.sec-head.center .idx::after,.sec-head.center .idx::before{display:none}
.sec-head .lead{margin-top:.2rem}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.7em;border-radius:2px;
  padding:15px 30px;font-weight:700;font-size:.86rem;letter-spacing:.02em;cursor:pointer;border:1px solid transparent;
  transition:background .25s ease,color .25s ease,border-color .25s ease,transform .25s ease;
}
.btn .ar{transition:transform .25s ease}
.btn:hover .ar{transform:translateX(4px)}
.btn-solid{background:var(--ember);color:#fff}
.btn-solid:hover{background:var(--wood)}
.btn-ink{background:var(--ink);color:var(--paper)}
.btn-ink:hover{background:var(--wood)}
.btn-line{border-color:var(--line-2);color:var(--ink);background:transparent}
.btn-line:hover{border-color:var(--ink);background:var(--ink);color:var(--paper)}
.btn-ghost{border-color:var(--line-d2);color:var(--paper);background:transparent}
.btn-ghost:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}

/* ---------- Header ---------- */
header{
  position:fixed;inset:0 0 auto 0;z-index:50;
  transition:background .35s ease,box-shadow .35s ease,border-color .35s ease;
  border-bottom:1px solid transparent;
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:20px 0;
  transition:padding .35s ease}
header.scrolled{background:rgba(28,19,12,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-color:var(--line-d)}
header.scrolled .nav{padding:13px 0}

.brand{display:flex;flex-direction:column;line-height:1}
.brand b{font-weight:800;font-size:1.32rem;letter-spacing:.22em;color:var(--paper)}
.brand span{font-size:.56rem;letter-spacing:.3em;color:var(--ember-2);text-transform:uppercase;margin-top:6px;font-weight:600}

.nav-group{display:flex;align-items:center;gap:1.6rem}
.nav-links{display:flex;align-items:center;gap:2rem}
.nav-links a{
  color:rgba(244,237,226,.82);font-size:.84rem;font-weight:500;letter-spacing:.04em;position:relative;padding:6px 0;
  transition:color .2s;
}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--ember);transition:width .28s ease}
.nav-links a:hover{color:#fff}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:#fff}

/* language dropdown */
.lang{position:relative;font-weight:600;font-size:.78rem}
.lang[open]{z-index:70}
.lang>summary{list-style:none;cursor:pointer;display:inline-flex;align-items:center;gap:.55em;
  color:var(--paper);line-height:1;padding:8px 13px;border-radius:2px;
  border:1px solid var(--line-d2);background:rgba(0,0,0,.18);letter-spacing:.06em;
  transition:border-color .2s,background .2s}
.lang>summary::-webkit-details-marker{display:none}
.lang>summary::marker{content:""}
.lang>summary:hover,.lang[open]>summary{border-color:var(--ember-2);background:rgba(0,0,0,.3)}
.lang>summary i{width:.42em;height:.42em;border-right:1.6px solid var(--ember-2);border-bottom:1.6px solid var(--ember-2);
  transform:rotate(45deg) translateY(-1px);transition:transform .25s}
.lang[open]>summary i{transform:rotate(-135deg) translateY(1px)}
.lang-menu{position:absolute;top:calc(100% + 9px);right:0;min-width:148px;display:flex;flex-direction:column;
  padding:5px;background:var(--dark-2);border:1px solid var(--line-d);border-radius:3px;
  box-shadow:0 24px 50px -20px rgba(0,0,0,.7);animation:pop .18s ease}
@keyframes pop{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.lang-menu a{color:rgba(244,237,226,.82);padding:9px 14px;border-radius:2px;white-space:nowrap;font-weight:500;letter-spacing:.04em;
  transition:background .18s,color .18s}
.lang-menu a:hover{background:rgba(244,237,226,.08);color:#fff}
.lang-menu a.active{color:var(--dark);background:var(--ember-2)}

.burger{display:none;flex-direction:column;gap:6px;background:none;border:0;cursor:pointer;padding:6px;z-index:60}
.burger span{width:26px;height:2px;background:var(--paper);transition:.3s}
.nav-scrim{position:fixed;inset:0;z-index:45;background:rgba(12,8,5,.6);backdrop-filter:blur(2px);
  opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
.nav-scrim.open{opacity:1;visibility:visible}
body.menu-open{overflow:hidden}

/* ---------- Hero (home) — full-bleed editorial cover ---------- */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;
  background:var(--dark);overflow:hidden}
.hero-photo{position:absolute;inset:0;background:url('assets/ilomba-log.jpg') center/cover no-repeat;will-change:transform}
.hero-photo::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,13,8,.4) 0%,rgba(20,13,8,.28) 32%,rgba(20,13,8,.8) 80%,rgba(20,13,8,.96) 100%)}
.hero-inner{position:relative;z-index:3;width:min(var(--maxw),90vw);margin-inline:auto;
  padding:0 0 clamp(38px,6vh,72px)}
.hero-meta{display:flex;align-items:center;flex-wrap:wrap;gap:0 28px;margin-bottom:24px;
  font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ember-2);font-weight:700}
.hero-meta span{position:relative;padding-left:20px}
.hero-meta span:first-child{padding-left:0}
.hero-meta span:first-child::before{display:none}
.hero-meta span::before{content:"";position:absolute;left:0;top:50%;width:5px;height:5px;margin-top:-2.5px;
  background:var(--ember);transform:rotate(45deg)}
.hero h1{
  font-weight:800;color:#fff;line-height:1.06;letter-spacing:-.03em;
  font-size:clamp(2.5rem,6.4vw,5rem);margin-bottom:1.5rem;max-width:18ch;
}
.hero h1 .thin{font-weight:300;color:rgba(255,255,255,.92)}
.hero h1 .ember{color:var(--ember-2)}
.hero-sub{color:rgba(244,237,226,.84);font-size:clamp(1rem,1.7vw,1.18rem);max-width:52ch;font-weight:350}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:2.4rem}
/* hero stat ticker */
.hero-ticker{position:relative;z-index:3;border-top:1px solid var(--line-d);background:rgba(15,10,6,.5);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.hero-ticker .wrap{display:grid;grid-template-columns:repeat(4,1fr)}
.tk{padding:22px 0;display:flex;flex-direction:column;gap:5px;border-left:1px solid var(--line-d);padding-left:26px}
.tk:first-child{border-left:0;padding-left:0}
.tk b{font-family:var(--serif);font-weight:700;font-size:clamp(1.4rem,2.5vw,2.05rem);color:#fff;line-height:1}
.tk b sup{font-size:.5em;color:var(--ember-2)}
.tk span{font-size:.72rem;letter-spacing:.08em;color:rgba(244,237,226,.62)}

/* hero entrance */
.hero-inner>*{opacity:0;transform:translateY(24px);animation:hin .85s cubic-bezier(.2,.7,.3,1) forwards}
.hero-inner>*:nth-child(1){animation-delay:.1s}
.hero-inner>*:nth-child(2){animation-delay:.24s}
.hero-inner>*:nth-child(3){animation-delay:.38s}
.hero-inner>*:nth-child(4){animation-delay:.5s}
@keyframes hin{to{opacity:1;transform:none}}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{position:relative;background:var(--dark);overflow:hidden;min-height:52vh;
  display:flex;align-items:flex-end;padding:150px 0 52px}
.page-hero::before{content:"";position:absolute;inset:0;
  background:var(--ph-img,url('assets/wood-grain.jpg')) center/cover no-repeat;opacity:.4;will-change:transform}
.page-hero::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,13,8,.6),rgba(20,13,8,.78) 60%,rgba(20,13,8,.92))}
.page-hero .wrap{position:relative;z-index:2}
.page-hero .eyebrow{color:var(--ember-2)}
.page-hero h1{color:#fff;font-size:clamp(2.2rem,5.4vw,3.9rem);letter-spacing:-.03em;margin:.6rem 0 .7rem}
.page-hero p{color:rgba(244,237,226,.82);max-width:58ch;font-weight:350}
.crumb{margin-top:22px;font-size:.78rem;color:rgba(244,237,226,.6);display:flex;gap:.6em;align-items:center;flex-wrap:wrap;letter-spacing:.04em}
.crumb a:hover{color:var(--ember-2)}
.crumb .sep{opacity:.5}
.crumb .cur{color:var(--ember-2)}

/* ---------- Section base ---------- */
.sec{padding:var(--pad) 0}
.sec--sand{background:var(--paper-2)}
.sec--dark{background:var(--dark);color:var(--paper)}
.sec--dark .title{color:#fff}
.sec--dark .idx .lbl{color:rgba(244,237,226,.6)}
.sec--dark .idx::after{background:var(--line-d2)}
.sec--dark .lead{color:rgba(244,237,226,.74)}

/* ---------- Intro split (home) ---------- */
.intro{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,5vw,72px);align-items:center}
.intro-text .title{margin-bottom:1.4rem}
.intro-text p{color:var(--ink-2);font-size:1.04rem;margin-bottom:1.1rem}
.intro-text p .hl{color:var(--wood);font-weight:700}
.intro-quote{font-family:var(--serif);font-weight:600;color:var(--ink);font-size:1.15rem;line-height:1.7;
  border-left:2px solid var(--ember);padding-left:22px;margin:1.6rem 0 .4rem}
.intro-fig{position:relative}
.intro-fig img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:2px;filter:saturate(.96)}
.intro-fig .cap{position:absolute;left:0;bottom:0;background:var(--ink);color:var(--paper);
  font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;padding:11px 18px;font-weight:600}
.intro-fig .frame{position:absolute;inset:14px -14px -14px 14px;border:1px solid var(--line-2);z-index:-1;border-radius:2px}

/* ---------- Advantages (editorial numbered grid) ---------- */
.adv{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.adv .cell{padding:clamp(28px,3.4vw,44px);border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  position:relative;transition:background .3s ease}
.adv .cell:hover{background:rgba(194,99,43,.06)}
.adv .cell .no{font-family:var(--serif);font-weight:700;font-size:1.05rem;color:var(--ember);letter-spacing:.05em}
.adv .cell h3{font-size:1.3rem;margin:.9rem 0 .7rem;letter-spacing:-.01em}
.adv .cell p{color:var(--ink-2);font-size:.97rem}
.adv .cell::after{content:"";position:absolute;left:0;top:0;width:0;height:2px;background:var(--ember);transition:width .35s ease}
.adv .cell:hover::after{width:100%}

/* ---------- Stat band (dark) ---------- */
.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border:1px solid var(--line-d);border-radius:2px}
.statband .s{padding:clamp(26px,3.4vw,42px);border-right:1px solid var(--line-d)}
.statband .s:last-child{border-right:0}
.statband .s b{font-family:var(--serif);font-weight:700;font-size:clamp(1.8rem,3.4vw,2.9rem);color:var(--ember-2);
  display:block;line-height:1;white-space:nowrap}
.statband .s b sup{font-size:.46em;color:var(--paper)}
.statband .s span{display:block;margin-top:12px;font-size:.86rem;color:rgba(244,237,226,.72);
  border-top:1px solid var(--line-d);padding-top:12px}
.statband .s small{display:block;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ember-2);margin-bottom:14px;font-weight:700}

/* ---------- Product preview (home) / lineup ---------- */
.prodrow{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,26px)}
.pcard{position:relative;display:block;background:var(--paper);border:1px solid var(--line);border-radius:2px;overflow:hidden;
  transition:border-color .3s ease,transform .3s ease}
.sec--sand .pcard{background:var(--paper)}
.pcard:hover{transform:translateY(-6px);border-color:var(--line-2)}
.pcard .ph{overflow:hidden;aspect-ratio:4/3;background:var(--paper-3)}
.pcard .ph img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease;filter:saturate(.97)}
.pcard:hover .ph img{transform:scale(1.06)}
.pcard .body{padding:22px 22px 26px}
.pcard .kicker{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ember);font-weight:700}
.pcard h3{font-size:1.22rem;margin:9px 0 0;letter-spacing:-.01em}
.pcard h3 .zh{display:block;font-size:.92rem;font-weight:500;color:var(--ink-2);margin-top:3px;letter-spacing:0}
.pcard p{color:var(--ink-2);font-size:.92rem;margin-top:12px}
.pcard .spectag{display:inline-block;margin-top:14px;font-size:.74rem;font-weight:600;color:var(--wood);
  background:var(--paper-2);border:1px solid var(--line);border-radius:2px;padding:5px 11px;letter-spacing:.02em}
.pcard .go{position:absolute;top:16px;right:16px;width:34px;height:34px;border-radius:50%;
  background:var(--ink);color:var(--paper);display:flex;align-items:center;justify-content:center;
  opacity:0;transform:translateY(-6px);transition:opacity .3s,transform .3s;font-size:.9rem}
.pcard:hover .go{opacity:1;transform:none}

/* sub category heading in products */
.subhead{display:flex;align-items:center;gap:1.1rem;margin:clamp(48px,6vw,76px) 0 30px}
.subhead .e{font-size:.68rem;font-weight:700;letter-spacing:.26em;text-transform:uppercase;color:var(--ember)}
.subhead h3{font-size:1.5rem;white-space:nowrap;letter-spacing:-.01em}
.subhead h3 small{font-weight:500;color:var(--ink-2);font-size:.78em;margin-left:.5em}
.subhead::after{content:"";flex:1;height:1px;background:var(--line)}

/* spec sheet */
.specgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.specgrid .si{padding:26px 28px;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.specgrid .si dt{font-size:.68rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--ember);
  display:flex;align-items:center;gap:.6em;margin-bottom:11px}
.specgrid .si dt::before{content:"";width:16px;height:1px;background:currentColor}
.specgrid .si dd{font-family:var(--serif);font-weight:600;font-size:1.12rem;color:var(--ink);line-height:1.45}
.pills{display:flex;flex-wrap:wrap;gap:9px;margin-top:24px}
.pill{background:var(--paper-2);border:1px solid var(--line);color:var(--wood);border-radius:2px;padding:7px 14px;
  font-size:.78rem;font-weight:600;letter-spacing:.02em}
.sec--dark .pill{background:rgba(244,237,226,.07);border-color:var(--line-d);color:var(--paper)}

/* species mini-list card */
.pcard--list{display:flex;flex-direction:column;justify-content:center;background:var(--dark);color:var(--paper);padding:30px 28px}
.pcard--list .kicker{color:var(--ember-2)}
.pcard--list h3{color:#fff;margin-bottom:10px}
.pcard--list ul{list-style:none;margin-top:6px}
.pcard--list li{display:flex;justify-content:space-between;gap:1em;padding:10px 0;
  border-bottom:1px dashed var(--line-d2);font-size:.94rem}
.pcard--list li:last-child{border-bottom:0}
.pcard--list li span{color:var(--ember-2);font-size:.8rem;letter-spacing:.06em;font-family:var(--serif)}

/* ---------- Process flow (about) — vertical editorial steps ---------- */
.flow{position:relative;margin-top:10px}
.flowline{position:absolute;left:25px;top:8px;bottom:8px;width:1px;background:var(--line-d2)}
.fstep{position:relative;display:grid;grid-template-columns:52px 1fr;gap:24px;align-items:start;padding:18px 0;
  opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.flow.drawn .fstep{opacity:1;transform:none}
.flow.drawn .fstep:nth-child(2){transition-delay:.08s}
.flow.drawn .fstep:nth-child(3){transition-delay:.16s}
.flow.drawn .fstep:nth-child(4){transition-delay:.24s}
.flow.drawn .fstep:nth-child(5){transition-delay:.32s}
.flow.drawn .fstep:nth-child(6){transition-delay:.4s}
.fstep .dot{width:52px;height:52px;border-radius:50%;background:transparent;border:1px solid var(--line-d2);
  color:var(--ember-2);font-family:var(--serif);font-weight:700;font-size:1.2rem;
  display:flex;align-items:center;justify-content:center;position:relative;z-index:1;
  background:var(--dark);transition:border-color .3s,background .3s,color .3s}
.fstep:hover .dot{border-color:var(--ember);background:var(--ember);color:#fff}
.fstep .ft h4{font-size:1.2rem;color:#fff;margin-bottom:4px}
.fstep .ft h4 small{font-weight:500;color:var(--ember-2);font-size:.7em;margin-left:.6em;letter-spacing:.1em}
.fstep .ft p{color:rgba(244,237,226,.7);font-size:.94rem;max-width:60ch}
.flow-photos{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:clamp(40px,5vw,60px)}
.flow-photos figure{position:relative;overflow:hidden;border-radius:2px;aspect-ratio:3/4}
.flow-photos img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease;filter:saturate(.95)}
.flow-photos figure:hover img{transform:scale(1.07)}
.flow-photos figcaption{position:absolute;left:0;bottom:0;right:0;padding:14px 14px 12px;
  background:linear-gradient(0deg,rgba(15,10,6,.9),transparent);font-size:.76rem;letter-spacing:.1em;
  color:#fff;font-weight:600}

/* ---------- Profile (about) ---------- */
.profile{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(36px,5vw,68px);align-items:center}
.profile .ptext p{color:var(--ink-2);font-size:1.03rem;margin-bottom:1.1rem}
.profile .ptext p .hl{color:var(--wood);font-weight:700}
.values{display:flex;flex-wrap:wrap;gap:10px;margin-top:1.4rem}
.value{display:inline-flex;align-items:center;gap:.55em;background:var(--paper-2);border:1px solid var(--line);
  border-radius:2px;padding:9px 16px;font-size:.85rem;font-weight:600;color:var(--wood)}
.value::before{content:"";width:6px;height:6px;background:var(--ember)}
.pfig{position:relative}
.pfig img{width:100%;aspect-ratio:3/4;object-fit:cover;border-radius:2px;filter:saturate(.96)}
.pfig .frame{position:absolute;inset:-14px 14px 14px -14px;border:1px solid var(--line-2);z-index:-1;border-radius:2px}

/* ---------- Map / origin band (about) ---------- */
.origin{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line-d);border-radius:2px;overflow:hidden}
.origin .o{padding:clamp(30px,4vw,48px)}
.origin .o+.o{border-left:1px solid var(--line-d)}
.origin .o .place{font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;color:var(--ember-2);font-weight:700;margin-bottom:14px}
.origin .o h3{color:#fff;font-size:1.45rem;margin-bottom:12px}
.origin .o p{color:rgba(244,237,226,.74);font-size:.98rem}
.origin .o ul{list-style:none;margin-top:16px}
.origin .o li{display:flex;gap:12px;padding:9px 0;border-bottom:1px dashed var(--line-d2);font-size:.92rem;color:rgba(244,237,226,.82)}
.origin .o li:last-child{border-bottom:0}
.origin .o li b{color:var(--ember-2);font-family:var(--serif);font-weight:700;min-width:74px}

/* ---------- CTA band ---------- */
.cta{position:relative;background:var(--wood);color:#fff;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;background:url('assets/wood-grain.jpg') center/cover no-repeat;opacity:.14;mix-blend-mode:overlay}
.cta .wrap{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:36px;flex-wrap:wrap;
  padding:clamp(50px,6.5vw,80px) 0}
.cta h2{font-size:clamp(1.7rem,3.6vw,2.6rem);line-height:1.2;max-width:20ch;letter-spacing:-.02em;color:#fff}
.cta p{color:rgba(255,255,255,.86);margin-top:.7rem;max-width:44ch}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);border-radius:2px;overflow:hidden}
.contact-info{padding:clamp(34px,4.5vw,56px);background:var(--paper)}
.contact-info .name{font-size:1.5rem;font-weight:800;color:var(--ink);margin-bottom:4px;letter-spacing:-.01em}
.contact-info .name-en{font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ember);font-weight:700;margin-bottom:24px}
.contact-info ul{list-style:none}
.contact-info li{display:flex;gap:16px;padding:15px 0;border-bottom:1px dashed var(--line);align-items:baseline}
.contact-info li:last-child{border-bottom:0}
.contact-info li strong{color:var(--ember);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;min-width:92px;font-weight:700}
.contact-info li a:hover{color:var(--ember)}
.contact-info .todo{color:var(--ink-2);font-style:italic;opacity:.75}
.contact-aside{position:relative;background:var(--dark);color:var(--paper);padding:clamp(34px,4.5vw,56px);
  display:flex;flex-direction:column;justify-content:center;overflow:hidden}
.contact-aside::before{content:"";position:absolute;inset:0;background:url('assets/forest-log.jpg') center/cover no-repeat;opacity:.22}
.contact-aside>*{position:relative;z-index:1}
.contact-aside .q{font-family:var(--serif);font-weight:600;font-size:1.35rem;line-height:1.6;color:#fff}
.contact-aside .q b{color:var(--ember-2)}
.contact-aside .sig{margin-top:24px;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ember-2);font-weight:700}

/* ---------- Footer ---------- */
footer{background:var(--dark);color:rgba(244,237,226,.66);padding:clamp(48px,6vw,72px) 0 36px}
.ftrow{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px}
.ftbrand b{font-size:1.4rem;font-weight:800;letter-spacing:.2em;color:var(--paper);display:block}
.ftbrand span{display:block;font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ember-2);margin-top:8px;font-weight:600}
.ftbrand p{margin-top:18px;font-size:.9rem;color:rgba(244,237,226,.6);max-width:34ch;font-weight:350}
.ftcol h5{font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:rgba(244,237,226,.5);font-weight:700;margin-bottom:16px}
.ftcol a,.ftcol p{display:block;font-size:.92rem;color:rgba(244,237,226,.78);padding:6px 0;font-weight:350}
.ftcol a:hover{color:var(--ember-2)}
.ftbot{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  margin-top:clamp(34px,4vw,52px);padding-top:22px;border-top:1px solid var(--line-d);font-size:.76rem;letter-spacing:.04em}
.ftbot .tag{letter-spacing:.22em;text-transform:uppercase;color:var(--ember-2);font-weight:700}

/* ============================================================
   Distinctive layout modules (intentionally varied per section)
   ============================================================ */

/* ---------- Story / company intro (asymmetric lead + body + banner) ---------- */
.story{display:grid;grid-template-columns:5fr 7fr;gap:clamp(30px,5vw,72px);align-items:start}
.story-lead .big{font-family:var(--serif);font-weight:600;font-size:clamp(1.25rem,2vw,1.62rem);line-height:1.62;color:var(--ink)}
.story-lead .big b{color:var(--wood)}
.story-lead .values{margin-top:1.6rem}
.story-body p{color:var(--ink-2);font-size:1.02rem;margin-bottom:1.15rem}
.story-body p:last-child{margin-bottom:0}
.story-body p .hl{color:var(--wood);font-weight:700}
.story-banner{position:relative;margin-top:clamp(38px,5vw,60px);border-radius:2px;overflow:hidden}
.story-banner img{width:100%;height:clamp(220px,32vw,380px);object-fit:cover;filter:saturate(.96);display:block}
.story-banner--home img{object-position:center}
.story-banner .figs{position:absolute;left:0;right:0;bottom:0;display:grid;grid-template-columns:repeat(4,1fr);
  background:linear-gradient(0deg,rgba(15,10,6,.94),rgba(15,10,6,.34) 72%,transparent);padding:40px 28px 22px}
.story-banner .figs .fg{padding:0 20px;border-left:1px solid var(--line-d2)}
.story-banner .figs .fg:first-child{border-left:0;padding-left:0}
.story-banner .figs .fg b{font-family:var(--serif);font-weight:700;color:#fff;font-size:clamp(1.3rem,2.4vw,1.95rem);display:block;line-height:1}
.story-banner .figs .fg b sup{font-size:.48em;color:var(--ember-2)}
.story-banner .figs .fg span{font-size:.72rem;letter-spacing:.05em;color:rgba(244,237,226,.72);display:block;margin-top:8px}
@media(max-width:900px){.story{grid-template-columns:1fr}
  .story-banner .figs{grid-template-columns:1fr 1fr;gap:14px 0}
  .story-banner .figs .fg:nth-child(3){border-left:0;padding-left:0}}
@media(max-width:480px){.story-banner img{height:300px}.story-banner .figs{grid-template-columns:1fr 1fr}}

/* ---------- Capability index list ---------- */
.caplist{border-top:1px solid var(--line)}
.caprow{display:grid;grid-template-columns:auto 1fr auto;gap:clamp(18px,4vw,56px);align-items:center;
  padding:clamp(22px,3vw,36px) 0;border-bottom:1px solid var(--line);transition:padding-left .35s ease,background .35s ease}
.caprow:hover{padding-left:16px}
.caprow .cn{font-family:var(--serif);font-weight:700;font-size:clamp(1.6rem,3vw,2.4rem);color:var(--ember);line-height:1}
.caprow .ct h3{font-size:clamp(1.15rem,1.8vw,1.42rem);margin-bottom:6px}
.caprow .ct p{color:var(--ink-2);font-size:.98rem;max-width:66ch}
.caprow .cmark{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-2);white-space:nowrap;font-weight:700}
@media(max-width:760px){.caprow{grid-template-columns:auto 1fr;gap:18px}.caprow .cmark{display:none}}

/* ---------- Creed band (philosophy, dark) ---------- */
.creed{background:var(--dark);color:var(--paper);text-align:center}
.creed .wrap{padding:clamp(56px,7.5vw,96px) 0}
.creed .eyebrow{justify-content:center;color:var(--ember-2);margin-bottom:26px}
.creed .vals{display:inline-flex;flex-wrap:wrap;justify-content:center;margin-bottom:30px}
.creed .vals span{font-family:var(--serif);font-weight:700;font-size:clamp(1.7rem,3.6vw,2.7rem);color:#fff;
  padding:4px clamp(16px,2.6vw,34px);line-height:1.2}
.creed .vals span:not(:last-child){border-right:1px solid var(--line-d2)}
.creed p{max-width:58ch;margin:0 auto;color:rgba(244,237,226,.78);font-size:1.05rem}

/* ---------- Category bands (home products) ---------- */
.catband{display:grid;gap:18px;grid-auto-rows:1fr}   /* equal-height rows → uniform image height */
.cat{position:relative;display:grid;grid-template-columns:minmax(200px,34%) 1fr;align-items:center;
  border:1px solid var(--line);border-radius:2px;overflow:hidden;background:var(--paper);
  transition:border-color .3s ease,transform .3s ease}
.cat:hover{border-color:var(--line-2);transform:translateY(-4px)}
.cat .cph{align-self:stretch;overflow:hidden;display:flex;align-items:center}
/* fixed, moderate image height → uniform across bands regardless of text length */
.cat .cph img{width:100%;height:clamp(186px,19vw,224px);object-fit:cover;transition:transform .8s ease;filter:saturate(.97)}
.cat:hover .cph img{transform:scale(1.05)}
.cat .cbody{padding:clamp(24px,3vw,42px);display:flex;flex-direction:column;justify-content:center}
.cat .cbody .k{font-family:var(--serif);font-weight:700;font-size:.95rem;color:var(--ember);margin-bottom:12px}
.cat .cbody h3{font-size:clamp(1.3rem,2.2vw,1.7rem);margin-bottom:11px}
.cat .cbody h3 small{font-weight:500;color:var(--ink-2);font-size:.62em;margin-left:.5em;letter-spacing:.02em}
.cat .cbody p{color:var(--ink-2);font-size:.97rem;max-width:54ch}
.cat .cbody .cmeta{display:flex;gap:9px;flex-wrap:wrap;margin-top:18px}
.cat .arrow{position:absolute;top:24px;right:26px;color:var(--ember);font-size:1.15rem;opacity:0;transform:translateX(-6px);transition:.3s}
.cat:hover .arrow{opacity:1;transform:none}
@media(max-width:680px){.catband{grid-auto-rows:auto}.cat{grid-template-columns:1fr}.cat .cph{display:block}.cat .cph img{height:210px}}

/* ---------- Veneer cards (products) ---------- */
.veneer-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-top:clamp(26px,4vw,44px)}
.veneer-card{position:relative;display:flex;flex-direction:column;min-height:100%;padding:clamp(24px,3vw,34px);
  background:rgba(255,252,246,.76);border:1px solid var(--line);border-radius:4px;overflow:hidden}
.veneer-card::before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:linear-gradient(90deg,var(--ember),rgba(181,91,37,.18));z-index:1}
.veneer-card .vpic{margin:calc(clamp(24px,3vw,34px) * -1) calc(clamp(24px,3vw,34px) * -1) 22px;overflow:hidden;background:var(--sand-2)}
.veneer-card .vpic img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block;filter:saturate(.96);transition:transform .7s ease}
.veneer-card:hover .vpic img{transform:scale(1.04)}
.veneer-card .k{font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ember);font-weight:700}
.veneer-card h3{font-size:clamp(1.2rem,1.75vw,1.45rem);margin:12px 0 12px}
.veneer-card h3 small{display:block;font-size:.52em;font-weight:500;color:var(--ink-2);letter-spacing:.06em;margin-top:7px}
.veneer-card p{color:var(--ink-2);font-size:.96rem;line-height:1.85;margin-bottom:22px}
.veneer-card .specrow{display:grid;gap:12px;margin-top:auto;padding-top:18px;border-top:1px solid var(--line)}
.veneer-card .sp{display:grid;grid-template-columns:minmax(82px,max-content) 1fr;gap:14px;align-items:baseline}
.veneer-card .sp dt{font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);font-weight:700}
.veneer-card .sp dd{font-family:var(--serif);font-weight:600;color:var(--ink);font-size:1rem}
@media(max-width:980px){.veneer-grid{grid-template-columns:1fr 1fr}.veneer-card:last-child{grid-column:1/-1}}
@media(max-width:620px){.veneer-grid{grid-template-columns:1fr}.veneer-card:last-child{grid-column:auto}.veneer-card .sp{grid-template-columns:1fr;gap:4px}}

/* ---------- Spec table (products / plywood) ---------- */
.plywood-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,360px);gap:18px;align-items:start}
.spectable-wrap{overflow-x:auto;border-radius:2px;border:1px solid var(--line)}
.spectable{width:100%;border-collapse:collapse;min-width:560px}
.spectable thead th{background:var(--dark);color:var(--paper);text-align:left;font-size:.7rem;letter-spacing:.14em;
  text-transform:uppercase;font-weight:700;padding:16px 22px}
.spectable tbody td{padding:18px 22px;border-bottom:1px solid var(--line);font-size:.96rem;color:var(--ink-2);vertical-align:middle}
.spectable tbody tr:last-child td{border-bottom:0}
.spectable tbody tr{transition:background .25s ease}
.spectable tbody tr:hover{background:rgba(194,99,43,.06)}
.spectable td.nm{font-weight:700;color:var(--ink)}
.spectable td.nm .en{display:block;font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ember);font-weight:700;margin-top:4px}
.spectable td.sz{font-family:var(--serif);font-weight:600;color:var(--ink);white-space:nowrap}
.panel-showcase{display:grid}
.panel-shot{position:relative;margin:0;overflow:hidden;border-radius:2px;aspect-ratio:4/3;background:var(--paper-3)}
.panel-shot img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.96)}
.panel-shot figcaption{position:absolute;left:0;right:0;bottom:0;padding:30px 18px 15px;
  background:linear-gradient(0deg,rgba(15,10,6,.9),transparent);color:#fff;font-weight:700}
.panel-shot figcaption span{display:block;margin-top:4px;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ember-2)}
@media(max-width:900px){.plywood-layout{grid-template-columns:1fr}.panel-shot{aspect-ratio:16/9}}

/* ---------- Swatch gallery (products / solid wood) ---------- */
.swatch{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.sw{position:relative;overflow:hidden;border-radius:2px;aspect-ratio:4/3;background:var(--paper-3)}
.sw img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease;filter:saturate(.98)}
.sw:hover img{transform:scale(1.07)}
.sw .swlab{position:absolute;left:0;right:0;bottom:0;padding:32px 18px 16px;
  background:linear-gradient(0deg,rgba(15,10,6,.92),transparent);color:#fff}
.sw .swlab b{display:block;font-size:1.1rem;font-weight:700}
.sw .swlab span{display:block;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ember-2);font-weight:700;margin-top:4px}
.sw .swlab .density{font-size:.72rem;letter-spacing:.04em;text-transform:none;color:rgba(255,255,255,.78);font-weight:600}
.sw.sw--note{background:var(--dark);display:flex;flex-direction:column;justify-content:center;padding:26px 24px}
.sw.sw--note b{color:#fff;font-size:1.05rem;margin-bottom:10px}
.sw.sw--note ul{list-style:none}
.sw.sw--note li{display:flex;justify-content:space-between;gap:1em;padding:8px 0;border-bottom:1px dashed var(--line-d2);font-size:.9rem;color:rgba(244,237,226,.82)}
.sw.sw--note li:last-child{border-bottom:0}
.sw.sw--note li span{color:var(--ember-2);font-family:var(--serif)}
@media(max-width:760px){.swatch{grid-template-columns:repeat(2,1fr)}}
@media(max-width:440px){.swatch{grid-template-columns:1fr}}
.morewood{margin-top:22px;padding:18px 22px;border:1px solid var(--line);border-left:3px solid var(--ember);
  background:var(--paper);font-size:.96rem;color:var(--ink-2);border-radius:2px}
.morewood b{color:var(--wood);font-weight:700}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.2,.7,.3,1),transform .8s cubic-bezier(.2,.7,.3,1)}
.reveal.left{transform:translateX(-34px)}
.reveal.right{transform:translateX(34px)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal,.hero-inner>*,.fstep{opacity:1!important;transform:none!important;transition:none!important;animation:none!important}
  *{transition:none!important}
}

/* ---------- Responsive ---------- */
@media (max-width:1000px){
  .intro,.profile{grid-template-columns:1fr}
  .intro-fig{max-width:520px}
  .profile .pfig{max-width:480px;order:-1}
  .prodrow{grid-template-columns:repeat(2,1fr)}
  .specgrid{grid-template-columns:repeat(2,1fr)}
  .statband{grid-template-columns:repeat(2,1fr)}
  .statband .s:nth-child(2){border-right:0}
  .flow-photos{grid-template-columns:repeat(2,1fr)}
  .ftrow{grid-template-columns:1fr 1fr}
  .ftbrand{grid-column:1/-1}
}
@media (max-width:760px){
  header.scrolled{backdrop-filter:none;-webkit-backdrop-filter:none}
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(80vw,330px);background:var(--dark);z-index:55;
    flex-direction:column;align-items:flex-start;justify-content:center;gap:1.8rem;padding:0 2rem;
    border-left:1px solid var(--line-d);transform:translateX(100%);transition:transform .35s ease;
    box-shadow:-24px 0 60px -20px rgba(0,0,0,.6)}
  .nav-links.open{transform:none}
  .nav-links a{font-size:1.15rem}
  .burger{display:flex}
  .burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .burger.open span:nth-child(2){opacity:0}
  .burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
  .hero-meta{gap:0 18px;font-size:.6rem}
  .hero-ticker .wrap{grid-template-columns:1fr 1fr}
  .tk{padding-left:18px;border-top:1px solid var(--line-d)}
  .tk:nth-child(odd){border-left:0;padding-left:0}
  .adv{grid-template-columns:1fr}
  .adv .cell{border-left:1px solid var(--line)}
  .prodrow{grid-template-columns:1fr}
  .specgrid{grid-template-columns:1fr}
  .statband{grid-template-columns:1fr 1fr}
  .flow-photos{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .origin{grid-template-columns:1fr}
  .origin .o+.o{border-left:0;border-top:1px solid var(--line-d)}
  .cta .wrap{flex-direction:column;align-items:flex-start}
  .ftrow{grid-template-columns:1fr}
  .page-hero{min-height:auto;padding:128px 0 44px}
}
@media (max-width:440px){
  .hero-ticker .wrap{grid-template-columns:1fr}
  .tk{border-left:0;padding-left:0}
  .statband{grid-template-columns:1fr}
  .statband .s{border-right:0;border-bottom:1px solid var(--line-d)}
  .flow-photos{grid-template-columns:1fr}
}
