/* =========================================================
   D.A.K Pallets Ltd  -  "Kiln & Timber" design system
   Warm pine base, kiln-amber heat accent, charred-wood dark.
   Palette derived from the material: pine in, heat-treated out.
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Anton&family=Archivo:wght@400;500;600;700;800;900&family=Manrope:wght@400;500;600;700;800&family=JetBrains+Mono:wght@500;700&display=swap');

:root{
  /* light - raw / kiln-dried pine */
  --pine:#F5EFE3;
  --pine-2:#EFE7D7;
  --pine-3:#E8DDC8;
  --sand:#DED1B6;
  /* heat - kiln amber */
  --ember:#C2641F;
  --ember-bright:#E68A3A;
  --ember-deep:#9C4E16;
  /* charred wood dark */
  --char:#1B1510;
  --char-2:#241B14;
  --char-3:#30241A;
  --bone:#F5EFE3;
  --ash:#6E6253;
  --ash-light:rgba(245,239,227,.66);
  /* lines */
  --line:rgba(27,21,16,.12);
  --line-2:rgba(27,21,16,.18);
  --line-light:rgba(245,239,227,.14);
  /* glow + shadow */
  --glow:0 0 0 1px rgba(194,100,31,.35), 0 18px 40px -18px rgba(194,100,31,.45);
  --shadow:0 26px 60px -28px rgba(27,21,16,.5);
  --shadow-sm:0 10px 26px -16px rgba(27,21,16,.4);
  /* radii - sleek + rounded */
  --r-xs:8px;
  --r-sm:12px;
  --r:18px;
  --r-lg:24px;
  --r-xl:30px;
  --maxw:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Manrope',system-ui,sans-serif;
  background:var(--pine);
  color:var(--char);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
a,button,input,textarea,select,.btn,.card,.gallery a,.stat,.lumber .item{-webkit-tap-highlight-color:transparent}
::selection{background:var(--ember);color:#fff}

/* ---------------- type ---------------- */
.display{font-family:'Anton',sans-serif;font-weight:400;text-transform:uppercase;line-height:.88;letter-spacing:.005em}
h1,h2,h3,h4{font-family:'Archivo',sans-serif;font-weight:800;line-height:1.06;letter-spacing:-.015em}
.mono{font-family:'JetBrains Mono',monospace;font-weight:500;letter-spacing:-.01em}
.eyebrow{
  font-family:'JetBrains Mono',monospace;font-weight:700;text-transform:uppercase;
  letter-spacing:.18em;font-size:.72rem;color:var(--ember-deep);
  display:inline-flex;align-items:center;gap:.65rem;
}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--ember);border-radius:2px}
.eyebrow.center{justify-content:center}
.eyebrow.light{color:var(--ember-bright)}
.lead{font-size:1.13rem;color:var(--ash);max-width:60ch}
.amber{color:var(--ember)}

/* ---------------- layout ---------------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
section{padding:100px 0}
.section-head{max-width:64ch;margin-bottom:52px}
.section-head h2{font-size:clamp(1.9rem,4vw,2.9rem);margin-top:18px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head .lead{margin-top:18px}

/* ---------------- buttons ---------------- */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:'Archivo',sans-serif;font-weight:700;font-size:.94rem;
  letter-spacing:.01em;padding:15px 28px;border-radius:999px;
  border:2px solid transparent;cursor:pointer;
  transition:transform .3s var(--ease), background .25s ease, color .25s ease, box-shadow .3s ease, border-color .25s ease;
  position:relative;
}
.btn-primary{background:var(--ember);color:#fff;box-shadow:0 10px 24px -12px rgba(194,100,31,.7)}
.btn-primary:hover{background:var(--ember-deep);transform:translateY(-2px);box-shadow:0 16px 34px -12px rgba(194,100,31,.85)}
.btn-ghost{border-color:var(--line-2);color:var(--char)}
.btn-ghost:hover{background:var(--char);color:var(--bone);border-color:var(--char);transform:translateY(-2px)}
.btn-ghost.light{border-color:var(--line-light);color:var(--bone)}
.btn-ghost.light:hover{background:var(--bone);color:var(--char);border-color:var(--bone)}
.btn .arrow{transition:transform .3s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}
.btn:focus-visible{outline:3px solid var(--ember-bright);outline-offset:3px}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{outline:3px solid var(--ember-bright);outline-offset:2px}

/* ---------------- header ---------------- */
.site-header{
  position:sticky;top:0;z-index:80;
  background:rgba(245,239,227,.78);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--line);
  view-transition-name:site-header;
  transition:box-shadow .3s ease, background .3s ease;
}
.site-header.scrolled{box-shadow:0 10px 30px -22px rgba(27,21,16,.6);background:rgba(245,239,227,.9)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:44px;width:auto}
.brand .tag{font-family:'JetBrains Mono',monospace;font-weight:700;font-size:.58rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ash);border-left:1px solid var(--line-2);padding-left:12px;line-height:1.4}
.nav-links{display:flex;align-items:center;gap:32px}
.nav-links a{
  font-family:'Archivo',sans-serif;font-weight:600;font-size:.93rem;
  position:relative;padding:6px 0;color:var(--char-2);transition:color .2s;
}
.nav-links a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--ember);border-radius:2px;transition:width .28s var(--ease)}
.nav-links a:not(.nav-cta):hover{color:var(--char)}
.nav-links a:not(.nav-cta):hover::after,.nav-links a.active:not(.nav-cta)::after{width:100%}
.nav-links a.active:not(.nav-cta){color:var(--char)}
.nav-cta{margin-left:4px;padding:11px 22px;font-size:.9rem}
.nav-cta.active{background:var(--ember-deep);box-shadow:0 0 0 2px var(--pine),0 0 0 4px var(--ember-deep),0 10px 24px -12px rgba(194,100,31,.7)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;z-index:90}
.burger span{width:24px;height:2px;background:var(--char);border-radius:2px;transition:.3s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------------- hero ---------------- */
.hero{position:relative;background:var(--char);color:var(--bone);overflow:hidden;padding:0}
.hero::before{ /* grain */
  content:"";position:absolute;inset:0;opacity:.05;pointer-events:none;z-index:1;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.hero::after{ /* warm radial heat bloom behind product */
  content:"";position:absolute;right:-6%;top:50%;transform:translateY(-50%);
  width:60vw;max-width:760px;aspect-ratio:1;border-radius:50%;pointer-events:none;z-index:0;
  background:radial-gradient(circle, rgba(230,138,58,.20) 0%, rgba(194,100,31,.08) 38%, transparent 66%);
}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.12fr .88fr;align-items:center;gap:24px;min-height:90vh}
.hero-copy{padding:96px 0}
.hero h1{font-size:clamp(3.3rem,8.6vw,7.4rem)}
.hero h1 .outline{-webkit-text-stroke:2px var(--bone);color:transparent;
  transition:color .4s ease,-webkit-text-stroke-color .4s ease}
.hero h1 .outline:hover{color:var(--ember);-webkit-text-stroke-color:var(--ember)}
.hero-sub{margin:30px 0 38px;font-size:1.16rem;color:var(--ash-light);max-width:47ch}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-art{position:relative;align-self:stretch;display:flex;align-items:flex-end;justify-content:center}
.hero-art img{height:94%;width:auto;object-fit:contain;filter:drop-shadow(0 36px 46px rgba(0,0,0,.55))}
.hero-badge{
  position:absolute;left:-6px;bottom:78px;background:var(--ember);color:#fff;z-index:3;
  font-family:'JetBrains Mono',monospace;font-weight:700;font-size:.72rem;letter-spacing:.06em;
  padding:10px 16px;border-radius:var(--r-sm);transform:rotate(-3deg);box-shadow:var(--shadow);
}
/* hero entrance animation */
.hero-copy .eyebrow,.hero h1,.hero-sub,.hero-actions{opacity:0;transform:translateY(22px);animation:rise .9s var(--ease) forwards}
.hero h1{animation-delay:.08s}
.hero-sub{animation-delay:.2s}
.hero-actions{animation-delay:.3s}
.hero-art img{opacity:0;animation:rise 1.1s var(--ease) .25s forwards}
.hero-badge{opacity:0;animation:pop .6s var(--ease) .9s forwards}
@keyframes rise{to{opacity:1;transform:none}}
@keyframes pop{0%{opacity:0;transform:rotate(-3deg) scale(.85)}100%{opacity:1;transform:rotate(-3deg) scale(1)}}

/* ---------------- marquee strip ---------------- */
.strip{background:var(--ember);color:#fff;padding:13px 0;overflow:hidden;border-block:1px solid rgba(0,0,0,.1)}
.strip-track{display:flex;gap:0;white-space:nowrap;animation:scroll 30s linear infinite;
  font-family:'JetBrains Mono',monospace;font-weight:700;letter-spacing:.1em;text-transform:uppercase;font-size:.8rem}
.strip-track span{display:inline-flex;align-items:center;gap:16px;padding:0 28px}
.strip-track span::after{content:"\25C6";color:rgba(255,255,255,.55);font-size:.55rem}
.strip:hover .strip-track{animation-play-state:paused}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------------- stats row ---------------- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(0,1fr));gap:14px}
.stat{
  padding:30px 26px;border:1px solid var(--line);border-radius:var(--r);
  background:var(--pine-2);transition:transform .3s var(--ease),box-shadow .3s ease,border-color .25s ease;
}
.stat:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm);border-color:rgba(194,100,31,.4)}
.stat .num{font-family:'Anton';font-size:2.8rem;line-height:1;color:var(--char)}
.stat .num small{font-size:1.05rem;color:var(--ember)}
.stat .label{font-size:.85rem;color:var(--ash);margin-top:10px;font-weight:600}

/* ---------------- bento + cards ---------------- */
.bento{display:grid;grid-template-columns:repeat(6,1fr);gap:18px;grid-auto-rows:minmax(0,auto)}
.card{
  position:relative;background:var(--pine-2);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:30px;overflow:hidden;
  transition:transform .35s var(--ease),box-shadow .35s ease,border-color .3s ease;
}
.card::after{ /* heat halo that fades in on hover */
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;opacity:0;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,0%), rgba(230,138,58,.16), transparent 60%);
  transition:opacity .4s ease;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--glow);border-color:rgba(194,100,31,.55)}
.card:hover::after{opacity:1}
.card .ic{
  width:48px;height:48px;border-radius:var(--r-sm);background:var(--char);color:var(--ember-bright);
  display:grid;place-items:center;font-family:'Anton';font-size:1.15rem;margin-bottom:20px;
  transition:transform .35s var(--ease),background .3s ease;
}
.card:hover .ic{transform:translateY(-2px) rotate(-4deg);background:var(--char-3)}
.card h3{font-size:1.28rem;margin-bottom:10px}
.card p{color:var(--ash);font-size:.99rem}
.card .tag-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px}
.card .chip{font-family:'JetBrains Mono',monospace;font-size:.66rem;font-weight:700;letter-spacing:.05em;
  text-transform:uppercase;color:var(--ember-deep);background:rgba(194,100,31,.1);
  padding:5px 10px;border-radius:999px;border:1px solid rgba(194,100,31,.22)}

/* bento spans (home "Why D.A.K") */
/* bento spans (home "Why D.A.K") - clean 2x2 of equal cards */
.b-heat{grid-column:span 3}
.b-cost{grid-column:span 3}
.b-supply{grid-column:span 3}
.b-export{grid-column:span 3}
.b-cap{grid-column:span 3}

/* generic equal grids */
.grid{display:grid;gap:18px}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-2{grid-template-columns:repeat(2,1fr)}

/* dark section variants */
.dark{background:var(--char);color:var(--bone);position:relative}
.dark .lead,.dark .card p{color:var(--ash-light)}
.dark .card{background:var(--char-2);border-color:var(--line-light)}
.dark .card:hover{border-color:rgba(230,138,58,.6);box-shadow:0 0 0 1px rgba(230,138,58,.4),0 24px 50px -24px rgba(0,0,0,.7)}
.dark .stat{background:var(--char-2);border-color:var(--line-light)}
.dark .stat .num{color:var(--bone)}
.dark .stat .label{color:var(--ash-light)}
.dark .card .ic{background:var(--char-3)}

/* ---------------- kiln gauge (signature) ---------------- */
.gauge{margin-top:auto;padding-top:24px}
.gauge-top{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:12px}
.gauge-read{font-family:'Anton';font-size:2.7rem;line-height:.9;color:var(--ember)}
.gauge-read .u{font-size:1.1rem;color:var(--ember);vertical-align:super;margin-left:2px}
.gauge-spec{font-family:'JetBrains Mono',monospace;font-size:.66rem;font-weight:700;letter-spacing:.04em;
  text-transform:uppercase;color:var(--ash);text-align:right;line-height:1.5}
.dark .gauge-spec{color:var(--ash-light)}
.gauge-track{position:relative;height:14px;border-radius:999px;background:rgba(27,21,16,.1);overflow:hidden;border:1px solid var(--line)}
.dark .gauge-track{background:rgba(245,239,227,.08);border-color:var(--line-light)}
.gauge-fill{position:absolute;inset:0 100% 0 0;border-radius:999px;
  background:linear-gradient(90deg,#7a3d12,#C2641F 55%,#E68A3A);
  transition:right 1.7s var(--ease)}
.gauge.live .gauge-fill{right:var(--rest,12%)}
.gauge-marks{display:flex;justify-content:space-between;margin-top:8px;
  font-family:'JetBrains Mono',monospace;font-size:.6rem;font-weight:700;letter-spacing:.06em;color:var(--ash)}
.dark .gauge-marks{color:var(--ash-light)}
.gauge-swatch{display:flex;align-items:center;gap:10px;margin-top:16px;
  font-family:'JetBrains Mono',monospace;font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ash)}
.dark .gauge-swatch{color:var(--ash-light)}
.gauge-chip{width:38px;height:24px;border-radius:6px;border:1px solid var(--line-2);
  background:#E9DCC4;transition:background 1.7s var(--ease)}
.gauge.live .gauge-chip{background:#C2641F}

/* ---------------- ISPM seal (export bento card) ---------------- */
.seal-card{display:block}
.seal{width:72px;height:72px;position:relative;margin-bottom:18px}
.seal svg{width:100%;height:100%}
.seal .ring-txt{animation:spin 28s linear infinite;transform-origin:50% 50%}
.seal-card:hover .ring-txt{animation-duration:9s}
@keyframes spin{to{transform:rotate(360deg)}}
.seal .seal-core{font-family:'Anton';fill:var(--ember)}

/* ---------------- capacity meter (cap bento card) ---------------- */
.cap-row{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:14px}
.cap-num{font-family:'Anton';font-size:3.2rem;line-height:.85;color:var(--char)}
.dark .cap-num{color:var(--bone)}
.cap-num small{font-size:1.1rem;color:var(--ember)}
.cap-meta{font-family:'JetBrains Mono',monospace;font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ash);text-align:right;line-height:1.5}
.dark .cap-meta{color:var(--ash-light)}
.cap-bar{position:relative;height:10px;border-radius:999px;background:rgba(27,21,16,.1);overflow:hidden;border:1px solid var(--line)}
.cap-bar .now{position:absolute;inset:0 100% 0 0;border-radius:999px;background:var(--ember);transition:right 1.5s var(--ease)}
.cap.live .cap-bar .now{right:var(--gap,21%)}
.cap-foot{display:flex;justify-content:space-between;margin-top:8px;font-family:'JetBrains Mono',monospace;font-size:.6rem;font-weight:700;color:var(--ash)}

/* ---------------- split feature ---------------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split.reverse .split-media{order:2}
.split-media{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);position:relative}
.split-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5;transition:transform .8s var(--ease)}
.split-media:hover img{transform:scale(1.04)}
.split-media.land img{aspect-ratio:3/2}
.split-media .stamp{
  position:absolute;right:16px;top:16px;background:rgba(27,21,16,.82);color:var(--bone);
  font-family:'JetBrains Mono',monospace;font-weight:700;font-size:.66rem;letter-spacing:.06em;text-transform:uppercase;
  padding:8px 13px;border-radius:999px;backdrop-filter:blur(6px);border:1px solid rgba(245,239,227,.15)
}
.tick{list-style:none;margin-top:24px;display:grid;gap:13px}
.tick li{display:flex;gap:12px;align-items:flex-start;font-weight:500}
.tick li::before{content:"";flex:0 0 auto;width:22px;height:22px;border-radius:7px;margin-top:2px;background:var(--ember);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.17 4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/%3E%3C/svg%3E") center/14px no-repeat var(--ember);
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.17 4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/%3E%3C/svg%3E") center/14px no-repeat;
  background-color:rgba(194,100,31,.16)}

/* ---------------- lumber ---------------- */
.lumber{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.lumber .item{position:relative;border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;background:var(--pine-2);overflow:hidden;
  transition:transform .35s var(--ease),box-shadow .35s ease,border-color .3s ease}
.lumber .item:hover{transform:translateY(-6px);box-shadow:var(--glow);border-color:rgba(194,100,31,.5)}
.lumber .item .k{font-family:'JetBrains Mono',monospace;font-weight:700;font-size:.8rem;color:var(--ember-deep);letter-spacing:.06em}
.lumber .item h3{font-size:1.32rem;margin:8px 0 10px}
.lumber .item p{color:var(--ash);font-size:.96rem}
.lumber .item .grain{position:absolute;right:-30px;top:-30px;width:120px;height:120px;opacity:.08;
  background:repeating-radial-gradient(circle at 30% 30%, var(--char) 0 2px, transparent 2px 9px)}

/* ---------------- CTA ---------------- */
.cta{background:linear-gradient(135deg,var(--char-3),var(--char));color:var(--bone);
  border-radius:var(--r-xl);padding:68px;text-align:center;position:relative;overflow:hidden;border:1px solid var(--line-light)}
.cta h2{font-size:clamp(2rem,4vw,3rem);margin-bottom:16px}
.cta p{color:var(--ash-light);max-width:52ch;margin:0 auto 30px}
.cta::after{content:"";position:absolute;right:-80px;top:-80px;width:340px;height:340px;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(230,138,58,.22),transparent 65%)}
.cta>*{position:relative;z-index:1}

/* ---------------- inner page hero ---------------- */
.page-hero{background:var(--char);color:var(--bone);padding:84px 0 70px;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.page-hero::after{content:"";position:absolute;right:-4%;top:-30%;width:46vw;max-width:560px;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle,rgba(230,138,58,.18),transparent 64%);pointer-events:none}
.page-hero .wrap{position:relative;z-index:1}
.page-hero h1{font-size:clamp(2.6rem,6vw,4.6rem);font-family:'Anton';font-weight:400;text-transform:uppercase}
.page-hero p{color:var(--ash-light);max-width:58ch;margin-top:18px;font-size:1.12rem}
.crumb{font-family:'JetBrains Mono',monospace;font-weight:700;font-size:.74rem;letter-spacing:.06em;
  color:var(--ash-light);text-transform:uppercase;margin-bottom:20px}
.crumb a{transition:color .2s}
.crumb a:hover{color:var(--ember-bright)}

/* ---------------- gallery ---------------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gallery a{border-radius:var(--r);overflow:hidden;display:block;position:relative}
.gallery img{width:100%;height:240px;object-fit:cover;transition:transform .7s var(--ease)}
.gallery a::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(27,21,16,.4),transparent 50%);
  opacity:0;transition:opacity .4s ease}
.gallery a:hover img{transform:scale(1.07)}
.gallery a:hover::after{opacity:1}
.gallery .wide{grid-column:span 2}

/* ---------------- contact ---------------- */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:start}
.field{margin-bottom:18px}
.field label{display:block;font-family:'Archivo';font-weight:700;font-size:.8rem;letter-spacing:.04em;
  text-transform:uppercase;margin-bottom:8px;color:var(--char-2)}
.field input,.field textarea{
  width:100%;padding:14px 16px;border:1px solid var(--line-2);border-radius:var(--r-sm);
  background:var(--pine-2);font-family:'Manrope';font-size:1rem;color:var(--char);transition:.2s
}
.field input::placeholder,.field textarea::placeholder{color:rgba(110,98,83,.7)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--ember);background:#fff;box-shadow:0 0 0 3px rgba(194,100,31,.14)}
.field textarea{min-height:148px;resize:vertical}
.info-card{background:var(--char);color:var(--bone);border-radius:var(--r-lg);padding:36px;border:1px solid var(--line-light)}
.info-card h3{color:var(--bone);font-size:1.32rem;margin-bottom:24px}
.info-row{display:flex;gap:14px;align-items:flex-start;padding:15px 0;border-bottom:1px solid var(--line-light)}
.info-row:last-child{border-bottom:0}
.info-row .ic{flex:0 0 auto;width:40px;height:40px;border-radius:var(--r-sm);background:var(--char-3);
  color:var(--ember-bright);display:grid;place-items:center;transition:transform .3s var(--ease)}
.info-row:hover .ic{transform:translateY(-2px)}
.info-row .ic svg{width:18px;height:18px}
.info-row .lbl{font-family:'JetBrains Mono',monospace;font-size:.64rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ash-light);font-weight:700;margin-bottom:2px}
.info-row .val{font-weight:600}
.info-row a{transition:color .2s}
.info-row a:hover{color:var(--ember-bright)}
.map-frame{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm)}

/* ---------------- footer ---------------- */
.site-footer{background:var(--char);color:var(--bone);padding:72px 0 28px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;padding-bottom:44px;border-bottom:1px solid var(--line-light)}
.foot-brand img{height:50px;width:auto;margin-bottom:20px}
.foot-brand p{color:var(--ash-light);max-width:36ch;font-size:.96rem}
.foot-col h4{font-family:'JetBrains Mono',monospace;font-weight:700;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ember-bright);margin-bottom:20px}
.foot-col a,.foot-col p{display:block;color:var(--ash-light);font-size:.96rem;margin-bottom:12px;transition:color .2s}
.foot-col a:hover{color:var(--bone)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;flex-wrap:wrap;gap:10px}
.foot-bottom p{font-size:.82rem;color:rgba(245,239,227,.42)}
.foot-bottom .pill{font-family:'JetBrains Mono',monospace;font-weight:700;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ember-bright);border:1px solid var(--line-light);padding:7px 13px;border-radius:999px}

/* ---------------- reveal + view transitions ---------------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

@view-transition{navigation:auto}
::view-transition-old(root){animation:vt-out .26s var(--ease) both}
::view-transition-new(root){animation:vt-in .42s var(--ease) both}
@keyframes vt-out{to{opacity:0;transform:translateY(-10px)}}
@keyframes vt-in{from{opacity:0;transform:translateY(16px)}}

/* ---------------- sticky contact button ---------------- */
.sticky-contact{
  position:fixed;right:22px;bottom:22px;z-index:70;
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:'Archivo',sans-serif;font-weight:700;font-size:.9rem;letter-spacing:.01em;
  padding:13px 20px;border-radius:999px;background:var(--ember);color:#fff;
  box-shadow:0 12px 30px -10px rgba(194,100,31,.75),0 0 0 1px rgba(255,255,255,.06);
  opacity:0;transform:translateY(16px) scale(.96);pointer-events:none;
  transition:opacity .35s var(--ease),transform .35s var(--ease),background .25s ease;
}
.sticky-contact.show{opacity:1;transform:none;pointer-events:auto;animation:sc-pulse 3.4s ease-in-out 1.2s infinite}
.sticky-contact:hover{background:var(--ember-deep);transform:translateY(-2px)}
.sticky-contact svg{width:16px;height:16px;flex:0 0 auto}
.sticky-contact:focus-visible{outline:3px solid var(--ember-bright);outline-offset:3px}
@keyframes sc-pulse{
  0%,100%{box-shadow:0 12px 30px -10px rgba(194,100,31,.75),0 0 0 0 rgba(230,138,58,.5)}
  50%{box-shadow:0 12px 30px -10px rgba(194,100,31,.75),0 0 0 9px rgba(230,138,58,0)}
}
@media(max-width:640px){
  .sticky-contact{right:16px;bottom:16px;padding:12px 17px;font-size:.85rem}
}

/* ---------------- responsive ---------------- */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;min-height:auto}
  .hero-art{display:none}
  .hero-copy{padding:72px 0 80px}
  .split,.contact-grid{grid-template-columns:1fr;gap:34px}
  .split.reverse .split-media{order:0}
  .bento{grid-template-columns:repeat(2,1fr)}
  .b-heat,.b-cost,.b-supply,.b-export,.b-cap{grid-column:span 1;grid-row:auto}
  .cols-3,.lumber{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr}
  .stats.stats-3{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  section{padding:68px 0}
  .nav-links{
    position:fixed;inset:76px 0 auto 0;background:var(--pine);flex-direction:column;
    align-items:flex-start;gap:0;padding:14px 28px 26px;border-bottom:1px solid var(--line);
    transform:translateY(-130%);transition:transform .4s var(--ease);box-shadow:var(--shadow)
  }
  .nav-links.open{transform:none}
  .nav-links a{width:100%;padding:15px 0;border-bottom:1px solid var(--line)}
  .nav-cta{margin:14px 0 0;justify-content:center}
  .burger{display:flex}
  .bento,.cols-3,.cols-2,.lumber{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .stats.stats-3{grid-template-columns:1fr}
  .cta{padding:44px 26px}
  .gallery{grid-template-columns:1fr}
  .gallery .wide{grid-column:span 1}
  .foot-grid{grid-template-columns:1fr}
  .seal-card{flex-direction:row}
}

/* ---------------- reduced motion ---------------- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.01ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1!important;transform:none!important}
  .gauge .gauge-fill{right:var(--rest,12%)!important}
  .gauge .gauge-chip{background:#C2641F!important}
  .cap .cap-bar .now{right:var(--gap,21%)!important}
}
