/* ============================================================
   PALLET NATION INC. — shared stylesheet (multi-page build)
   Design: "Mill & Yard" — warm sawn-lumber palette on a
   shadowed-yard near-black, deck-board structural motif,
   stamped-spec signature (IPPC/HT mark vernacular).
   ============================================================ */

:root{
  /* Material-derived palette */
  --ink:        #14100B;   /* shadowed yard — warm near-black */
  --ink-2:      #1C1610;   /* lifted surface */
  --ink-3:      #271F16;   /* card / elevated */
  --line:       #3A2F22;   /* hairline border (kiln-warm) */
  --line-soft:  #2C2318;

  --pine:       #5C9E4A;   /* fresh-sawn pine — primary accent */
  --pine-hi:    #74B860;   /* lit edge */
  --oak:        #B47C49;   /* deeper kraft / oak — secondary */
  --sap:        #6FA85B;   /* living wood / recycle green — eco accent */
  --sap-dim:    #4E7A41;

  --paper:      #F2EADC;   /* warm paper-white text */
  --paper-2:    #C9BCA7;   /* secondary text */
  --paper-3:    #8C8170;   /* muted / captions */

  --maxw: 1240px;
  --pad: clamp(20px, 5vw, 64px);
  --sec: clamp(72px, 11vw, 132px);   /* section vertical rhythm */

  --speed: .28s;
  --ease: cubic-bezier(.2,.7,.2,1);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--ink);
  color:var(--paper);
  font-family:"Inter", system-ui, -apple-system, sans-serif;
  font-size:17px;
  line-height:1.6;
  font-feature-settings:"ss01";
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* Subtle ambient sawdust grain over the whole page */
body::before{
  content:"";
  position:fixed; inset:0;
  pointer-events:none;
  z-index:1;
  opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

::selection{ background:var(--pine); color:var(--ink); }

:focus-visible{ outline:3px solid var(--pine); outline-offset:3px; }

/* ---------- Layout helpers ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--pad); position:relative; z-index:2; }
.section{ padding-block:var(--sec); position:relative; z-index:2; }

.eyebrow{
  font-family:"IBM Plex Mono", monospace;
  font-size:13px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--pine); display:inline-flex; align-items:center; gap:.7em; margin:0 0 18px;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--pine); display:inline-block; }

h1,h2,h3,h4,.h-xl,.h-lg,.h-md,.h-sm{ font-family:"Barlow Condensed", system-ui, sans-serif; font-weight:700; line-height:1.02; letter-spacing:.01em; margin:0; text-wrap:balance; }
.h-xl{ font-size:clamp(2.8rem, 8vw, 6.2rem); text-transform:uppercase; }
.h-lg{ font-size:clamp(2rem, 5vw, 3.6rem); text-transform:uppercase; }
.h-md{ font-size:clamp(1.3rem, 2.4vw, 1.85rem); letter-spacing:-.01em; }
.lead{ font-size:clamp(1.05rem,1.5vw,1.22rem); color:var(--paper-2); max-width:60ch; }
p{ margin:0 0 1em; }

/* ---------- Stamp (IPPC/HT signature motif) ---------- */
.stamp{
  font-family:"IBM Plex Mono", monospace;
  border:1.5px solid var(--line);
  padding:14px 16px;
  display:flex; flex-direction:column; gap:4px;
  background:linear-gradient(180deg, rgba(226,167,90,.04), transparent);
}
.stamp b{ font-size:clamp(1.5rem,3vw,2.1rem); color:var(--pine); line-height:1; letter-spacing:0; }
.stamp span{ font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--paper-3); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.6em;
  padding:15px 26px; font-weight:700; font-size:.95rem;
  letter-spacing:.02em; border:1.5px solid transparent;
  transition:transform var(--speed) var(--ease), background var(--speed), color var(--speed), border-color var(--speed);
  min-height:48px;
}
.btn svg{ width:18px; height:18px; }
.btn-primary{ background:var(--pine); color:var(--ink); }
.btn-primary:hover{ background:var(--pine-hi); transform:translateY(-2px); }
.btn-ghost{ border-color:var(--line); color:var(--paper); }
.btn-ghost:hover{ border-color:var(--pine); color:var(--pine); transform:translateY(-2px); }

/* ============================================================
   PRELOADER
   ============================================================ */
#pre{
  position:fixed; inset:0; z-index:9999;
  background:radial-gradient(125% 110% at 50% 36%, #1E5030 0%, #133621 44%, #0C2417 74%, #06140C 100%);
  display:grid; place-items:center; transition:opacity .6s ease, visibility .6s;
}
#pre.done{ opacity:0; visibility:hidden; }
.pre-stack{ display:flex; flex-direction:column; gap:6px; width:120px; }
.pre-stack i{ height:11px; background:var(--line); transform-origin:left; transform:scaleX(0); }
.pre-stack i:nth-child(1){ animation:plank .5s var(--ease) .0s forwards; }
.pre-stack i:nth-child(2){ animation:plank .5s var(--ease) .12s forwards; background:var(--oak); }
.pre-stack i:nth-child(3){ animation:plank .5s var(--ease) .24s forwards; background:var(--pine); }
.pre-stack i:nth-child(4){ animation:plank .5s var(--ease) .36s forwards; background:var(--oak); }
.pre-stack i:nth-child(5){ animation:plank .5s var(--ease) .48s forwards; background:var(--line); }
@keyframes plank{ to{ transform:scaleX(1); } }
.pre-stack b{ font-family:"IBM Plex Mono",monospace; font-size:11px; letter-spacing:.2em; color:var(--paper-3); text-align:center; margin-top:10px; font-weight:400; }
@media (prefers-reduced-motion: reduce){ .pre-stack i{ transform:scaleX(1); animation:none; } }

/* ============================================================
   NAV
   ============================================================ */
header{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:rgba(18,14,9,.62); backdrop-filter:blur(10px);
  transition:background var(--speed), border-color var(--speed), backdrop-filter var(--speed);
  border-bottom:1px solid rgba(242,234,220,.09);
}
header.scrolled{
  background:rgba(20,16,11,.86); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line-soft);
}
.nav{ display:flex; align-items:center; justify-content:space-between; height:74px; }
.brand{ display:flex; align-items:center; gap:11px; font-weight:900; letter-spacing:-.01em; font-size:1.18rem; text-transform:uppercase; }
.brand .mark{ width:34px; height:34px; flex:0 0 auto; }
.brand small{ display:block; font-family:"IBM Plex Mono",monospace; font-size:9px; letter-spacing:.18em; color:var(--pine); font-weight:400; margin-top:1px; }
.brand .logo-img{ height:44px; width:auto; }
.foot-brand .brand .logo-img{ height:54px; }
@media (max-width:480px){ .brand .logo-img{ height:38px; } }
.nav-links{ display:flex; align-items:center; gap:30px; list-style:none; margin:0; padding:0; }
.nav-links a{ font-size:.92rem; font-weight:600; color:var(--paper-2); position:relative; padding:6px 0; transition:color var(--speed); }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:0; height:2px; width:0; background:var(--pine); transition:width var(--speed) var(--ease); }
.nav-links a:hover{ color:var(--paper); } .nav-links a:hover::after{ width:100%; }
.nav-links a.active{ color:var(--paper); }
.nav-links a.active::after{ width:100%; }
.nav-cta{ display:flex; align-items:center; gap:14px; }
.nav-tel{ font-family:"IBM Plex Mono",monospace; font-size:.86rem; color:var(--paper-2); display:none; }
.nav-tel:hover{ color:var(--pine); }
.burger{ display:none; background:none; border:1.5px solid var(--line); width:46px; height:46px; padding:0; align-items:center; justify-content:center; }
.burger span{ display:block; width:20px; height:2px; background:var(--paper); position:relative; transition:.3s; }
.burger span::before,.burger span::after{ content:""; position:absolute; left:0; width:20px; height:2px; background:var(--paper); transition:.3s; }
.burger span::before{ top:-6px; } .burger span::after{ top:6px; }
.burger.open span{ background:transparent; }
.burger.open span::before{ top:0; transform:rotate(45deg); }
.burger.open span::after{ top:0; transform:rotate(-45deg); }

.mobile-menu{
  position:fixed; inset:74px 0 0; z-index:999; background:var(--ink);
  padding:30px var(--pad); display:flex; flex-direction:column; gap:6px;
  transform:translateY(-12px); opacity:0; pointer-events:none; transition:.3s var(--ease);
  border-top:1px solid var(--line);
}
.mobile-menu.open{ transform:none; opacity:1; pointer-events:auto; }
.mobile-menu a{ font-size:1.5rem; font-weight:800; text-transform:uppercase; padding:14px 0; border-bottom:1px solid var(--line-soft); }
.mobile-menu a.active{ color:var(--pine); }
.mobile-menu .btn{ margin-top:18px; justify-content:center; }

/* ============================================================
   HERO (home)
   ============================================================ */
.hero{ position:relative; padding-top:148px; padding-bottom:var(--sec); overflow:hidden; }
.hero-grid{
  position:absolute; inset:0; z-index:0; opacity:.5;
  background:
    repeating-linear-gradient(0deg, transparent 0 46px, var(--line-soft) 46px 47px),
    radial-gradient(120% 80% at 80% 0%, rgba(226,167,90,.10), transparent 60%);
  mask-image:linear-gradient(180deg, #000 0%, #000 40%, transparent 92%);
}
.hero-inner{ position:relative; z-index:2; display:grid; grid-template-columns:1.05fr .95fr; gap:56px; align-items:center; }
.hero-tag{ display:inline-flex; align-items:center; gap:10px; font-family:"IBM Plex Mono",monospace; font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--paper-2); border:1px solid rgba(242,234,220,.34); border-radius:999px; padding:8px 16px; margin-bottom:26px; }
.hero-tag i{ width:7px; height:7px; background:var(--sap); border-radius:50%; box-shadow:0 0 0 4px rgba(111,168,91,.18); }
.hero h1 .amber{ color:var(--pine); }
.hero h1 .stroke{ -webkit-text-stroke:1.5px var(--pine); color:transparent; }
.hero-lead{ margin:26px 0 32px; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; }
.hero-stamps{ display:flex; gap:0; margin-top:42px; border:1.5px solid var(--line); }
.hero-stamps .stamp{ border:none; border-right:1.5px solid var(--line); flex:1; background:none; }
.hero-stamps .stamp:last-child{ border-right:none; }

/* SVG pallet illustration */
.hero-art{ position:relative; }
.hero-art svg{ width:100%; height:auto; filter:drop-shadow(0 40px 60px rgba(0,0,0,.55)); }
.hero-art .float{ animation:floaty 7s ease-in-out infinite; }
@keyframes floaty{ 0%,100%{ transform:translateY(0) } 50%{ transform:translateY(-14px) } }
@media (prefers-reduced-motion: reduce){ .hero-art .float{ animation:none; } }

/* ============================================================
   PAGE HERO (interior pages)
   ============================================================ */
.page-hero{ position:relative; padding-top:148px; padding-bottom:clamp(48px,7vw,84px); overflow:hidden; border-bottom:1px solid var(--line); }
.page-hero .hero-grid{ mask-image:linear-gradient(180deg, #000 0%, #000 55%, transparent 100%); }
.page-hero-inner{ position:relative; z-index:2; max-width:64ch; }
.crumb{ font-family:"IBM Plex Mono",monospace; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--paper-3); margin-bottom:20px; display:flex; gap:9px; align-items:center; flex-wrap:wrap; }
.crumb a{ color:var(--paper-3); } .crumb a:hover{ color:var(--pine); }
.crumb span{ color:var(--line); }
.crumb b{ color:var(--paper-2); font-weight:400; }
.page-hero h1{ margin-bottom:18px; }
.page-hero .lead{ margin:0; }

/* ============================================================
   MARQUEE / TRUST BAR
   ============================================================ */
.trust{ border-block:1px solid var(--line); background:var(--ink-2); overflow:hidden; }
.marquee{ display:flex; gap:0; white-space:nowrap; animation:scroll 32s linear infinite; }
.marquee:hover{ animation-play-state:paused; }
@media (prefers-reduced-motion: reduce){ .marquee{ animation:none; flex-wrap:wrap; white-space:normal; } }
.marquee .item{ display:inline-flex; align-items:center; gap:12px; padding:20px 34px; font-family:"IBM Plex Mono",monospace; font-size:.82rem; letter-spacing:.12em; text-transform:uppercase; color:var(--paper-2); border-right:1px solid var(--line-soft); }
.marquee .item svg{ width:16px; height:16px; color:var(--pine); }
@keyframes scroll{ to{ transform:translateX(-50%); } }

/* ============================================================
   ABOUT
   ============================================================ */
.about-grid{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.about-media{ position:relative; }
.ph{ /* photo placeholder */
  position:relative; aspect-ratio:4/3; background:
    repeating-linear-gradient(135deg, var(--ink-2) 0 18px, var(--ink-3) 18px 36px);
  border:1.5px solid var(--line); display:grid; place-items:center; overflow:hidden;
}
.ph img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.ph::after{ content:attr(data-label); position:absolute; bottom:14px; left:14px; font-family:"IBM Plex Mono",monospace; font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--paper-3); background:var(--ink); padding:5px 9px; border:1px solid var(--line); }
.ph.has-img::after{ display:none; }
.ph svg{ width:64px; height:64px; color:var(--line); opacity:.7; }
.about-media .badge{
  position:absolute; bottom:-22px; right:-14px; background:var(--pine); color:var(--ink);
  padding:18px 22px; max-width:240px; box-shadow:0 24px 40px rgba(0,0,0,.45);
}
.about-media .badge b{ display:flex; align-items:center; gap:8px; font-size:1.05rem; font-weight:900; text-transform:uppercase; letter-spacing:-.01em; }
.about-media .badge p{ margin:6px 0 0; font-size:.85rem; line-height:1.45; color:rgba(20,16,11,.82); }
.about-media .badge svg{ width:20px; height:20px; }
.about-copy h2{ margin-bottom:22px; }

/* ============================================================
   SERVICES
   ============================================================ */
.sec-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:30px; margin-bottom:54px; flex-wrap:wrap; }
.sec-head .lead{ margin-top:14px; }
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.svc{
  background:var(--ink); padding:38px 32px 34px; position:relative;
  transition:background var(--speed) var(--ease); overflow:hidden; min-height:300px;
  display:flex; flex-direction:column;
}
.svc::before{ content:""; position:absolute; left:0; top:0; height:3px; width:0; background:var(--pine); transition:width var(--speed) var(--ease); }
.svc:hover{ background:var(--ink-2); }
.svc:hover::before{ width:100%; }
.svc-num{ font-family:"IBM Plex Mono",monospace; font-size:.8rem; color:var(--paper-3); letter-spacing:.1em; }
.svc-ico{ width:46px; height:46px; color:var(--pine); margin:18px 0 22px; }
.svc h3{ font-size:1.32rem; text-transform:uppercase; margin-bottom:12px; }
.svc p{ font-size:.95rem; color:var(--paper-2); flex:1; }
.svc .more{ display:inline-flex; align-items:center; gap:7px; font-family:"IBM Plex Mono",monospace; font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--pine); margin-top:18px; transition:gap var(--speed); }
.svc:hover .more{ gap:13px; }
.svc .more svg{ width:14px; height:14px; }

/* ---------- Detailed service blocks (services page) ---------- */
.svc-detail{ display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; padding-block:clamp(40px,6vw,72px); border-bottom:1px solid var(--line); }
.svc-detail:last-child{ border-bottom:none; }
.svc-detail.flip .svc-detail-media{ order:2; }
.svc-detail-media .ph{ aspect-ratio:5/4; }
.svc-detail-body .svc-num{ display:inline-block; margin-bottom:14px; }
.svc-detail-body h2{ text-transform:uppercase; margin-bottom:16px; }
.svc-detail-body p{ color:var(--paper-2); }
.svc-detail-body .incl{ list-style:none; margin:20px 0 26px; padding:0; display:grid; gap:11px; }
.svc-detail-body .incl li{ display:flex; gap:11px; font-size:.95rem; color:var(--paper-2); align-items:flex-start; }
.svc-detail-body .incl li svg{ width:18px; height:18px; color:var(--sap); flex:0 0 auto; margin-top:3px; }

/* ============================================================
   PALLET VISUALIZER (signature interactive)
   ============================================================ */
.viz{ background:var(--ink-2); border-block:1px solid var(--line); }
.viz-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:56px; align-items:center; }
.viz-stage{ position:relative; aspect-ratio:1/1; border:1.5px solid var(--line); background:
  radial-gradient(120% 120% at 50% 0%, rgba(226,167,90,.06), transparent 55%),
  repeating-linear-gradient(0deg, transparent 0 31px, var(--line-soft) 31px 32px),
  repeating-linear-gradient(90deg, transparent 0 31px, var(--line-soft) 31px 32px);
  display:grid; place-items:center; padding:8%; overflow:hidden; }
.viz-stage .ruler{ position:absolute; font-family:"IBM Plex Mono",monospace; font-size:11px; color:var(--paper-3); letter-spacing:.08em; }
.viz-stage .ruler.top{ top:12px; left:50%; transform:translateX(-50%); }
.viz-stage .ruler.side{ left:12px; top:50%; transform:translateY(-50%) rotate(-90deg); transform-origin:left; }
#palletSvg{ width:100%; height:100%; transition:.5s var(--ease); }
#palletSvg .deck{ fill:var(--pine); transition:.4s; }
#palletSvg .deck.alt{ fill:var(--oak); }
#palletSvg .gap{ fill:var(--ink); }
#palletSvg .edge{ fill:none; stroke:var(--ink); stroke-width:2; }

.viz-panel .chips{ display:flex; flex-wrap:wrap; gap:8px; margin:22px 0 30px; }
.chip{ font-family:"IBM Plex Mono",monospace; font-size:.78rem; letter-spacing:.06em; padding:9px 14px; border:1.5px solid var(--line); background:none; color:var(--paper-2); transition:.2s; min-height:40px; }
.chip:hover{ border-color:var(--oak); color:var(--paper); }
.chip[aria-pressed="true"]{ background:var(--pine); border-color:var(--pine); color:var(--ink); font-weight:700; }
.viz-readout h3{ font-size:1.7rem; text-transform:uppercase; margin-bottom:4px; }
.viz-dim{ font-family:"IBM Plex Mono",monospace; color:var(--pine); font-size:1.05rem; margin-bottom:18px; letter-spacing:.04em; }
.viz-specs{ display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--line); border:1px solid var(--line); margin-bottom:22px; }
.viz-specs div{ background:var(--ink); padding:14px 16px; }
.viz-specs dt{ font-family:"IBM Plex Mono",monospace; font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--paper-3); margin-bottom:5px; }
.viz-specs dd{ margin:0; font-size:.95rem; font-weight:600; }
.viz-note{ font-size:.9rem; color:var(--paper-2); min-height:2.6em; }

/* ============================================================
   KNOWLEDGE / GUIDE (tabs)
   ============================================================ */
.guide-tabs{ display:flex; flex-wrap:wrap; gap:0; border:1px solid var(--line); margin-bottom:0; }
.guide-tab{ flex:1; min-width:150px; background:var(--ink); border:none; border-right:1px solid var(--line); padding:18px 20px; text-align:left; color:var(--paper-2); transition:.25s; }
.guide-tab:last-child{ border-right:none; }
.guide-tab b{ display:block; font-size:1.02rem; font-weight:800; text-transform:uppercase; letter-spacing:-.01em; }
.guide-tab small{ font-family:"IBM Plex Mono",monospace; font-size:10px; letter-spacing:.1em; color:var(--paper-3); }
.guide-tab[aria-selected="true"]{ background:var(--ink-3); color:var(--paper); box-shadow:inset 0 -3px 0 var(--pine); }
.guide-tab:hover{ background:var(--ink-2); }
.guide-panel{ border:1px solid var(--line); border-top:none; padding:clamp(28px,4vw,46px); display:none; }
.guide-panel.active{ display:block; animation:fade .4s var(--ease); }
@keyframes fade{ from{ opacity:0; transform:translateY(8px); } to{ opacity:1; transform:none; } }
.cmp{ display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--line); border:1px solid var(--line); }
.cmp .col{ background:var(--ink-2); padding:26px; }
.cmp .col h4{ display:flex; align-items:center; gap:10px; font-size:1.15rem; text-transform:uppercase; margin:0 0 14px; font-weight:800; }
.cmp .col h4 svg{ width:24px; height:24px; color:var(--pine); }
.cmp ul{ margin:0; padding:0; list-style:none; }
.cmp li{ display:flex; gap:10px; padding:8px 0; font-size:.93rem; color:var(--paper-2); border-bottom:1px dashed var(--line-soft); }
.cmp li:last-child{ border-bottom:none; }
.cmp li svg{ width:16px; height:16px; color:var(--sap); flex:0 0 auto; margin-top:3px; }
.grade-row{ display:grid; grid-template-columns:auto 1fr; gap:18px; padding:18px 0; border-bottom:1px solid var(--line-soft); align-items:start; }
.grade-row:last-child{ border-bottom:none; }
.grade-tag{ font-family:"IBM Plex Mono",monospace; font-weight:700; font-size:.9rem; color:var(--ink); background:var(--pine); padding:6px 12px; white-space:nowrap; }
.grade-tag.b{ background:var(--oak); } .grade-tag.c{ background:var(--line); color:var(--paper-2); }
.grade-row p{ margin:0; font-size:.93rem; color:var(--paper-2); }
.grade-row b{ color:var(--paper); }

/* ISPM-15 explainer */
.ispm{ display:grid; grid-template-columns:1.1fr .9fr; gap:48px; align-items:center; }
.ispm-steps{ counter-reset:step; }
.ispm-steps li{ list-style:none; display:grid; grid-template-columns:auto 1fr; gap:18px; padding:18px 0; border-bottom:1px solid var(--line-soft); }
.ispm-steps li::before{ counter-increment:step; content:counter(step,decimal-leading-zero); font-family:"IBM Plex Mono",monospace; color:var(--pine); font-size:1.1rem; font-weight:700; }
.ispm-steps b{ display:block; text-transform:uppercase; letter-spacing:-.01em; margin-bottom:4px; }
.ispm-steps p{ margin:0; font-size:.92rem; color:var(--paper-2); }
.ht-stamp{ border:2.5px solid var(--paper); padding:26px; position:relative; aspect-ratio:1.45/1; display:flex; flex-direction:column; justify-content:center; gap:6px; background:var(--ink); }
.ht-stamp .wheat{ position:absolute; top:18px; right:18px; width:54px; height:54px; color:var(--paper); }
.ht-stamp .row{ font-family:"IBM Plex Mono",monospace; letter-spacing:.06em; }
.ht-stamp .big{ font-size:1.5rem; font-weight:700; color:var(--pine); }
.ht-stamp .mut{ font-size:.78rem; color:var(--paper-3); text-transform:uppercase; letter-spacing:.12em; }
.ht-cap{ font-family:"IBM Plex Mono",monospace; font-size:11px; color:var(--paper-3); text-align:center; margin-top:12px; letter-spacing:.1em; }

/* ============================================================
   WHY US
   ============================================================ */
.why-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.why{ background:var(--ink); padding:34px 30px; transition:background var(--speed); }
.why:hover{ background:var(--ink-2); }
.why svg{ width:38px; height:38px; color:var(--pine); margin-bottom:18px; }
.why h3{ font-size:1.12rem; text-transform:uppercase; margin-bottom:10px; }
.why p{ font-size:.92rem; color:var(--paper-2); margin:0; }

/* ============================================================
   SUSTAINABILITY (stats count-up)
   ============================================================ */
.eco{ background:linear-gradient(180deg, var(--ink-2), var(--ink)); border-top:1px solid var(--line); position:relative; }
.eco .wrap{ position:relative; }
.eco-head{ max-width:760px; margin-bottom:54px; }
.eco-head .eyebrow{ color:var(--sap); } .eco-head .eyebrow::before{ background:var(--sap); }
.eco-stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.eco-stat{ background:var(--ink); padding:34px 26px; }
.eco-stat b{ display:block; font-family:"IBM Plex Mono",monospace; font-size:clamp(2.2rem,4.5vw,3.2rem); font-weight:700; color:var(--sap); line-height:1; letter-spacing:-.02em; }
.eco-stat span{ display:block; margin-top:12px; font-size:.86rem; color:var(--paper-2); line-height:1.45; }
.eco-stat small{ font-family:"IBM Plex Mono",monospace; font-size:10px; color:var(--paper-3); letter-spacing:.08em; display:block; margin-top:8px; }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.quotes{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.quote{ border:1px solid var(--line); padding:34px 30px; background:var(--ink-2); display:flex; flex-direction:column; transition:border-color var(--speed), transform var(--speed); }
.quote:hover{ border-color:var(--oak); transform:translateY(-4px); }
.quote .marks{ font-family:"IBM Plex Mono",monospace; font-size:3rem; line-height:.6; color:var(--pine); margin-bottom:14px; }
.quote p{ font-size:1rem; color:var(--paper); flex:1; line-height:1.55; }
.quote .who{ display:flex; align-items:center; gap:13px; margin-top:24px; padding-top:20px; border-top:1px solid var(--line); }
.quote .who .av{ width:44px; height:44px; background:var(--ink-3); border:1px solid var(--line); display:grid; place-items:center; font-weight:900; color:var(--pine); font-size:1.05rem; }
.quote .who b{ display:block; font-size:.95rem; } .quote .who span{ font-family:"IBM Plex Mono",monospace; font-size:11px; color:var(--paper-3); letter-spacing:.08em; text-transform:uppercase; }

/* ============================================================
   FAQ
   ============================================================ */
.faq-grid{ display:grid; grid-template-columns:.8fr 1.2fr; gap:48px; align-items:start; }
.faq-list{ border-top:1px solid var(--line); }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{ width:100%; background:none; border:none; color:var(--paper); text-align:left; padding:24px 0; display:flex; justify-content:space-between; align-items:center; gap:20px; font-size:1.08rem; font-weight:700; }
.faq-q .ic{ width:30px; height:30px; flex:0 0 auto; border:1.5px solid var(--line); position:relative; transition:.3s; }
.faq-q .ic::before,.faq-q .ic::after{ content:""; position:absolute; background:var(--pine); left:50%; top:50%; transition:.3s; }
.faq-q .ic::before{ width:12px; height:2px; transform:translate(-50%,-50%); }
.faq-q .ic::after{ width:2px; height:12px; transform:translate(-50%,-50%); }
.faq-q[aria-expanded="true"] .ic{ background:var(--pine); border-color:var(--pine); }
.faq-q[aria-expanded="true"] .ic::before,.faq-q[aria-expanded="true"] .ic::after{ background:var(--ink); }
.faq-q[aria-expanded="true"] .ic::after{ transform:translate(-50%,-50%) rotate(90deg); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .35s var(--ease); }
.faq-a p{ padding:0 0 24px; color:var(--paper-2); font-size:.96rem; margin:0; max-width:62ch; }

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band{ background:var(--pine); color:var(--ink); position:relative; overflow:hidden; }
.cta-band::before{ content:""; position:absolute; inset:0; background:repeating-linear-gradient(90deg, transparent 0 60px, rgba(20,16,11,.05) 60px 61px); }
.cta-inner{ position:relative; display:flex; justify-content:space-between; align-items:center; gap:40px; flex-wrap:wrap; }
.cta-inner h2{ color:var(--ink); max-width:18ch; }
.cta-inner p{ color:rgba(20,16,11,.78); margin:14px 0 0; max-width:44ch; }
.cta-band .btn-dark{ background:var(--ink); color:var(--paper); }
.cta-band .btn-dark:hover{ background:#000; transform:translateY(-2px); }

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:56px; }
.contact-info .ci{ display:flex; gap:16px; padding:22px 0; border-bottom:1px solid var(--line); }
.contact-info .ci:first-of-type{ border-top:1px solid var(--line); }
.contact-info .ci svg{ width:24px; height:24px; color:var(--pine); flex:0 0 auto; margin-top:3px; }
.contact-info .ci b{ font-family:"IBM Plex Mono",monospace; font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--paper-3); display:block; margin-bottom:4px; font-weight:400; }
.contact-info .ci a,.contact-info .ci span{ font-size:1.12rem; font-weight:700; }
.contact-info .ci a:hover{ color:var(--pine); }
form{ display:grid; gap:16px; }
.f-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field{ display:flex; flex-direction:column; gap:7px; }
.field label{ font-family:"IBM Plex Mono",monospace; font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--paper-3); }
.field input,.field select,.field textarea{
  background:var(--ink-2); border:1.5px solid var(--line); color:var(--paper); border-radius:10px;
  padding:14px 15px; font-family:inherit; font-size:1rem; transition:border-color var(--speed); min-height:50px;
}
.field textarea{ min-height:130px; resize:vertical; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--pine); }
.field input::placeholder,.field textarea::placeholder{ color:var(--paper-3); }
form .btn-primary{ justify-content:center; margin-top:6px; }
.form-note{ font-family:"IBM Plex Mono",monospace; font-size:11px; color:var(--paper-3); letter-spacing:.04em; }
#formMsg{ display:none; padding:14px 16px; border:1.5px solid var(--sap); border-radius:10px; color:var(--sap); font-size:.92rem; font-family:"IBM Plex Mono",monospace; }

/* ============================================================
   FOOTER
   ============================================================ */
footer{ border-top:1px solid var(--line); background:var(--ink-2); padding-block:64px 30px; position:relative; z-index:2; }
.foot-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; padding-bottom:46px; border-bottom:1px solid var(--line); }
.foot-brand .brand{ margin-bottom:18px; }
.foot-brand p{ color:var(--paper-2); font-size:.92rem; max-width:34ch; }
.foot-slogan{ font-family:"IBM Plex Mono",monospace; font-size:18px; letter-spacing:.12em; text-transform:uppercase; color:var(--sap); margin-top:18px; display:inline-flex; align-items:flex-start; gap:10px; line-height:1.45; }
.foot-slogan svg{ width:24px; height:24px; flex:0 0 auto; margin-top:1px; }
.foot-col h4{ font-family:"IBM Plex Mono",monospace; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--paper-3); margin:0 0 18px; font-weight:400; }
.foot-col ul{ list-style:none; margin:0; padding:0; display:grid; gap:11px; }
.foot-col a{ color:var(--paper-2); font-size:.92rem; transition:color var(--speed); }
.foot-col a:hover{ color:var(--pine); }
.foot-bottom{ display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap; padding-top:26px; }
.foot-bottom small{ font-family:"IBM Plex Mono",monospace; font-size:11px; color:var(--paper-3); letter-spacing:.05em; }
.foot-bottom .legal{ display:flex; gap:22px; }
.foot-bottom .legal a{ font-size:.82rem; color:var(--paper-3); }
.foot-bottom .legal a:hover{ color:var(--paper-2); }

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .nav-links{ display:none; }
  .burger{ display:flex; }
  .hero-inner{ grid-template-columns:1fr; gap:46px; }
  .hero-art{ max-width:480px; }
  .svc-grid,.why-grid{ grid-template-columns:repeat(2,1fr); }
  .eco-stats{ grid-template-columns:repeat(2,1fr); }
  .quotes{ grid-template-columns:1fr; }
  .viz-grid,.about-grid,.ispm,.faq-grid,.contact-grid,.cmp,.svc-detail{ grid-template-columns:1fr; gap:40px; }
  .svc-detail.flip .svc-detail-media{ order:0; }
  .ispm .ht-stamp{ max-width:380px; }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:34px; }
}
@media (min-width:721px){ .nav-tel{ display:inline; } }
@media (max-width:720px){
  body{ font-size:16px; }
  .svc-grid,.why-grid,.eco-stats{ grid-template-columns:1fr; }
  .hero-stamps{ flex-wrap:wrap; } .hero-stamps .stamp{ min-width:50%; }
  .f-row{ grid-template-columns:1fr; }
  .guide-tabs{ flex-direction:column; } .guide-tab{ border-right:none; border-bottom:1px solid var(--line); }
  .guide-tab:last-child{ border-bottom:none; }
  .viz-specs{ grid-template-columns:1fr; }
  .foot-grid{ grid-template-columns:1fr; }
  .about-media .badge{ right:0; }
}


/* ============================================================
   PHOTO HERO (home)
   ============================================================ */
.hero.has-photo{ display:flex; align-items:center; min-height:92vh; }
.hero.has-photo .hero-photo{ position:absolute; inset:0; z-index:0; overflow:hidden; }
.hero.has-photo .hero-photo img{ width:100%; height:100%; object-fit:cover; object-position:center 62%; }
.hero.has-photo .hero-photo::after{ content:""; position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(0,0,0,.82) 0%, rgba(0,0,0,.6) 46%, rgba(0,0,0,.3) 100%),
    linear-gradient(0deg, rgba(0,0,0,.78) 0%, rgba(0,0,0,.06) 55%); }
.hero.has-photo .hero-grid{ opacity:.20; }
.hero.has-photo .hero-inner{ grid-template-columns:1fr; }
.hero.has-photo .hero-art{ display:none; }
.hero.has-photo .hero-copy{ max-width:780px; }
@media (max-width:720px){
  .hero.has-photo .hero-photo::after{ background:linear-gradient(0deg, rgba(0,0,0,.8), rgba(0,0,0,.42)); }
}


/* ============================================================
   LIGHT SECTIONS (warm tan) — break up the dark
   ============================================================ */
:root{
  --lt-bg:#FAF8F4; --lt-card:#FFFFFF; --lt-line:#E6E2DB; --lt-line-soft:#F1EFEB;
  --lt-ink:#1C1610; --lt-ink2:#4A3F30; --lt-ink3:#7A6C58; --lt-accent:#3F7A33;
}
.section.light{ background:var(--lt-bg); color:var(--lt-ink); border-block:1px solid var(--lt-line); }
.section.light h1,.section.light h2,.section.light h3,.section.light h4{ color:var(--lt-ink) !important; }
.section.light p{ color:var(--lt-ink2) !important; }
.section.light .lead{ color:var(--lt-ink2) !important; }
.section.light .eyebrow{ color:var(--lt-accent); }
.section.light .eyebrow::before{ background:var(--lt-accent); }
.section.light .btn-ghost{ border-color:var(--lt-line); color:var(--lt-ink); }
.section.light .btn-ghost:hover{ border-color:var(--lt-accent); color:var(--lt-accent); }
.section.light .about-copy .lead{ color:var(--lt-ink) !important; }

/* why grid */
.section.light .why-grid{ background:var(--lt-line); border-color:var(--lt-line); }
.section.light .why{ background:var(--lt-card); }
.section.light .why:hover{ background:#fff; }
.section.light .why svg{ color:var(--lt-accent); }

/* services overview grid */
.section.light .svc-grid{ background:var(--lt-line); border-color:var(--lt-line); }
.section.light .svc{ background:var(--lt-card); }
.section.light .svc:hover{ background:#fff; }
.section.light .svc-num{ color:var(--lt-ink3); }
.section.light .svc .more{ color:var(--lt-accent); }

/* services detail blocks */
.section.light .svc-detail{ border-color:var(--lt-line); }
.section.light .svc-detail-body .svc-num{ color:var(--lt-ink3); }
.section.light .incl li{ color:var(--lt-ink2); }

/* eco / sustainability */
.section.light.eco{ background:var(--lt-bg); border-top-color:var(--lt-line); }
.section.light .eco-head .eyebrow{ color:var(--sap-dim); }
.section.light .eco-head .eyebrow::before{ background:var(--sap-dim); }
.section.light .eco-stats{ background:var(--lt-line); border-color:var(--lt-line); }
.section.light .eco-stat{ background:var(--lt-card); }
.section.light .eco-stat span{ color:var(--lt-ink2); }
.section.light .eco-stat small{ color:var(--lt-ink3); }

/* faq */
.section.light .faq-list{ border-color:var(--lt-line); }
.section.light .faq-item{ border-color:var(--lt-line); }
.section.light .faq-q{ color:var(--lt-ink); }
.section.light .faq-q .ic{ border-color:var(--lt-line); }
.section.light .faq-a p{ color:var(--lt-ink2) !important; }


/* ============================================================
   HERO LEFT-ALIGN (explicit)
   ============================================================ */
.hero .hero-copy{ text-align:left; }
.hero .hero-copy h1,
.hero .hero-copy .lead,
.hero .hero-copy .hero-actions{ text-align:left; }

/* ============================================================
   GREEN CTA BAND + GREEN QUOTE BAND (white text)
   ============================================================ */
:root{ --green-band:#2E5E37; --green-soft:#CFE8C2; }
.cta-band{ background:var(--green-band); color:var(--paper); }
.cta-band::before{ background:repeating-linear-gradient(90deg, transparent 0 60px, rgba(0,0,0,.07) 60px 61px); }
.cta-inner h2{ color:var(--paper); }
.cta-inner p{ color:rgba(242,234,220,.85); }
.cta-band .btn-dark{ background:var(--pine); color:var(--ink); }
.cta-band .btn-dark:hover{ background:var(--pine-hi); }

.quote-band{ background:var(--green-band); color:var(--paper); position:relative; overflow:hidden; }
.quote-band::before{ content:""; position:absolute; inset:0; background:repeating-linear-gradient(90deg, transparent 0 60px, rgba(0,0,0,.07) 60px 61px); }
.quote-band .wrap{ position:relative; z-index:2; }
.quote-band .eyebrow{ color:var(--green-soft); }
.quote-band .eyebrow::before{ background:var(--green-soft); }
.quote-band h2{ color:var(--paper); }
.quote-band .qb-lead{ color:rgba(242,234,220,.85); margin-bottom:26px; max-width:46ch; }
.quote-band .contact-info .ci{ border-color:rgba(242,234,220,.2); }
.quote-band .contact-info .ci:first-of-type{ border-top-color:rgba(242,234,220,.2); }
.quote-band .ci b{ color:rgba(242,234,220,.7); }
.quote-band .ci a,.quote-band .ci span{ color:var(--paper); }
.quote-band .ci a:hover{ color:var(--green-soft); }
.quote-band .ci svg{ color:var(--green-soft); }
.quote-card{ background:var(--ink); border:1px solid rgba(116,184,96,.5); border-radius:18px; padding:clamp(22px,3vw,34px); }


/* ============================================================
   POLISH PASS — loader, video, tickers, centered titles,
   smooth scroll, responsive/touch
   ============================================================ */

/* Anchor offset under fixed header + tap behavior */
html{ scroll-padding-top:92px; }
a,button,.btn,.chip,.guide-tab,.faq-q{ touch-action:manipulation; }

/* ---- Logo page loader ---- */
.pre-logo{ display:flex; flex-direction:column; align-items:center; gap:18px; width:min(70vw,240px); }
.pre-logo img{ width:200px; height:auto; animation:prePulse 1.7s var(--ease) infinite; }
.pre-bar{ display:block; width:170px; height:3px; background:rgba(255,255,255,.16); overflow:hidden; position:relative; border-radius:2px; }
.pre-bar i{ position:absolute; top:0; bottom:0; left:-42%; width:42%; background:var(--pine); animation:preSlide 1.15s var(--ease) infinite; }
.pre-logo b{ font-family:"IBM Plex Mono",monospace; font-size:10px; letter-spacing:.22em; color:rgba(233,240,230,.74); font-weight:400; text-align:center; }
@keyframes prePulse{ 0%,100%{ transform:scale(1); opacity:1 } 50%{ transform:scale(1.06); opacity:.82 } }
@keyframes preSlide{ 0%{ left:-42% } 100%{ left:100% } }
@media (prefers-reduced-motion:reduce){ .pre-logo img{ animation:none } .pre-bar i{ animation:none; left:0; width:100% } }

/* ---- Centered section titles ---- */
.sec-head{ flex-direction:column; align-items:center; justify-content:center; text-align:center; }
.sec-head .lead{ margin-left:auto; margin-right:auto; }
.sec-head .eyebrow{ justify-content:center; }
.eco-head{ text-align:center; margin-left:auto; margin-right:auto; }
.eco-head .eyebrow{ justify-content:center; }
.eco-head .lead{ margin-left:auto; margin-right:auto; }
.page-hero-inner{ text-align:center; margin-left:auto; margin-right:auto; }
.page-hero-inner .crumb{ justify-content:center; }
.page-hero-inner .eyebrow{ justify-content:center; }
.page-hero-inner .lead{ margin-left:auto; margin-right:auto; }

/* ---- Bold scrolling ticker ---- */
.ticker{ background:var(--green-band); overflow:hidden; padding-block:15px; border-block:1px solid rgba(0,0,0,.22); position:relative; z-index:2; }
.ticker-row{ display:inline-flex; align-items:center; white-space:nowrap; animation:scroll 34s linear infinite; }
.ticker-row span{ font-size:clamp(1.05rem,2.1vw,1.7rem); font-weight:900; text-transform:uppercase; letter-spacing:-.01em; padding:0 20px; color:var(--paper); }
.ticker-row b{ color:var(--pine); font-size:.9rem; }
.ticker:hover .ticker-row{ animation-play-state:paused; }
@media (prefers-reduced-motion:reduce){ .ticker-row{ animation:none; white-space:normal; flex-wrap:wrap; justify-content:center; } }

/* ---- Video background band ---- */
.video-band{ position:relative; overflow:hidden; min-height:clamp(440px,70vh,640px); display:flex; align-items:center; border-block:1px solid var(--line); }
.video-bg{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.video-overlay{ position:absolute; inset:0; z-index:1; background:linear-gradient(0deg, rgba(20,16,11,.9) 0%, rgba(20,16,11,.5) 60%, rgba(20,16,11,.75) 100%); }
.video-content{ position:relative; z-index:2; text-align:center; max-width:780px; margin-inline:auto; }
.video-content .eyebrow{ justify-content:center; }
.video-content .lead{ margin:16px auto 26px; }
@media (prefers-reduced-motion:reduce){ .video-bg{ display:none } .video-band{ background:#14100B url(assets/pallets-poster.jpg) center/cover; } }

/* ---- Mobile / responsive polish ---- */
@media (max-width:720px){
  .ticker-row span{ padding:0 14px; }
  .video-band{ min-height:64vh; }
  .sec-head{ gap:18px; }
  .hero.has-photo{ min-height:88vh; }
  .hero-stamps .stamp{ padding:12px; }
}
@media (max-width:480px){
  .pre-logo img{ width:96px; }
  .hero .hero-actions .btn{ width:100%; justify-content:center; }
}

/* ---- Tighten + speed up the trust marquee ("take it in") ---- */
.trust .marquee{ animation-duration:22s; }
.trust .marquee .item{ padding:12px 20px; font-size:.76rem; gap:9px; letter-spacing:.1em; }
.trust .marquee .item svg{ width:13px; height:13px; }
@media (max-width:720px){ .trust .marquee .item{ padding:11px 14px; } }


/* ============================================================
   ENGAGEMENT PASS — process, stats, scroll bar, back-to-top, lifts
   ============================================================ */

/* card hover lift */
.svc{ transition:background var(--speed) var(--ease), transform var(--speed) var(--ease), box-shadow var(--speed) var(--ease); }
.svc:hover{ transform:translateY(-4px); box-shadow:0 18px 40px rgba(0,0,0,.34); }
.why{ transition:background var(--speed) var(--ease), transform var(--speed) var(--ease); }
.why:hover{ transform:translateY(-4px); }

/* How-it-works steps */
.process{ background:var(--ink-2); border-block:1px solid var(--line); }
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.step{ background:var(--ink); padding:36px 28px; position:relative; transition:background var(--speed) var(--ease), transform var(--speed) var(--ease); }
.step::before{ content:""; position:absolute; left:0; top:0; height:3px; width:0; background:var(--pine); transition:width var(--speed) var(--ease); }
.step:hover{ background:var(--ink-2); transform:translateY(-4px); }
.step:hover::before{ width:100%; }
.step .n{ font-family:"IBM Plex Mono",monospace; font-size:2.2rem; font-weight:700; color:var(--pine); line-height:1; display:block; }
.step h3{ font-size:1.08rem; text-transform:uppercase; margin:16px 0 9px; }
.step p{ font-size:.92rem; color:var(--paper-2); margin:0; }
@media (max-width:980px){ .steps{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .steps{ grid-template-columns:1fr; } }

/* Animated stats band (green) */
.stats-band{ background:var(--green-band); color:var(--paper); position:relative; overflow:hidden; }
.stats-band::before{ content:""; position:absolute; inset:0; background:repeating-linear-gradient(90deg,transparent 0 60px, rgba(0,0,0,.06) 60px 61px); }
.stats-band .wrap{ position:relative; z-index:2; }
.stat-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:40px; }
.stat{ text-align:center; }
.stat b{ display:block; font-family:"IBM Plex Mono",monospace; font-size:clamp(2.4rem,5vw,3.6rem); font-weight:700; color:var(--paper); line-height:1; letter-spacing:-.02em; }
.stat span{ display:block; margin-top:12px; font-size:.9rem; color:rgba(242,234,220,.82); line-height:1.45; max-width:24ch; margin-inline:auto; }
@media (max-width:860px){ .stat-grid{ grid-template-columns:1fr 1fr; gap:32px; } }

/* Scroll progress bar */
#scrollProgress{ position:fixed; top:0; left:0; height:3px; width:100%; background:var(--pine); transform:scaleX(0); transform-origin:0 50%; z-index:1200; will-change:transform; }
@media (prefers-reduced-motion:reduce){ #scrollProgress{ display:none; } }

/* Back to top */
#toTop{ position:fixed; right:20px; bottom:20px; width:48px; height:48px; border:none; border-radius:50%; background:var(--pine); color:var(--ink); display:grid; place-items:center; opacity:0; transform:translateY(12px); pointer-events:none; transition:opacity .3s var(--ease), transform .3s var(--ease), background .3s; z-index:1100; box-shadow:0 10px 24px rgba(0,0,0,.4); }
#toTop.show{ opacity:1; transform:none; pointer-events:auto; }
#toTop:hover{ background:var(--pine-hi); transform:translateY(-3px); }
#toTop svg{ width:22px; height:22px; }


/* ---- Green/white/brown harmonization ---- */
.cta-band .btn-dark{ background:var(--paper); color:var(--ink); }
.cta-band .btn-dark:hover{ background:#fff; transform:translateY(-2px); }
.ticker .ticker-row b{ color:var(--green-soft); }


/* ---- Faint photo backgrounds inside service cards ---- */
.svc{ isolation:isolate; }
.svc-bg{ position:absolute; inset:0; z-index:0; background-size:cover; background-position:center; opacity:.14; transition:opacity .4s var(--ease), transform .7s var(--ease); pointer-events:none; }
.svc:hover .svc-bg{ opacity:.30; transform:scale(1.06); }
.svc-num,.svc-ico,.svc h3,.svc p,.svc .more{ position:relative; z-index:1; }
.svc::before{ z-index:2; }


/* ---- Why Choose Us: 2-column list (replaces boxy grid) ---- */
.why2{ display:grid; grid-template-columns:.92fr 1.08fr; gap:clamp(36px,5vw,64px); align-items:start; }
.why2-head .lead{ margin:18px 0 26px; }
.why2-photo{ margin-top:28px; border:1.5px solid var(--line); aspect-ratio:4/3; overflow:hidden; }
.why2-photo img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.why2-photo:hover img{ transform:scale(1.04); }
.why2-list{ border-top:1px solid var(--line); }
.why2-row{ display:grid; grid-template-columns:auto 1fr; gap:22px; padding:24px 2px; border-bottom:1px solid var(--line); align-items:start; transition:padding-left .3s var(--ease); }
.why2-row:hover{ padding-left:10px; }
.why2-ic{ flex:0 0 auto; color:var(--pine); line-height:0; }
.why2-ic svg{ width:38px; height:38px; }
.why2-row h3{ font-size:1.1rem; text-transform:uppercase; margin:0 0 7px; letter-spacing:-.01em; }
.why2-row p{ font-size:.95rem; color:var(--paper-2); margin:0; }
.section.light .why2-list, .section.light .why2-row{ border-color:var(--lt-line); }
.section.light .why2-photo{ border-color:var(--lt-line); }
@media (min-width:981px){ .why2-head{ position:sticky; top:100px; } }
@media (max-width:980px){ .why2{ grid-template-columns:1fr; gap:30px; } .why2-photo{ display:none; } .why2-head{ position:static; } }


/* ---- Why Choose Us v2: 2-col grid + green circle badges (match brand ref) ---- */
.why2-grid{ display:grid; grid-template-columns:1fr 1fr; gap:30px 40px; }
.why2-item .top{ display:flex; align-items:center; gap:15px; margin-bottom:12px; }
.why2-badge{ width:52px; height:52px; border-radius:50%; background:var(--pine); color:#fff; display:grid; place-items:center; flex:0 0 auto; box-shadow:0 8px 20px rgba(0,0,0,.2); }
.why2-badge svg{ width:25px; height:25px; }
.why2-item h3{ font-size:1.05rem; text-transform:uppercase; margin:0; letter-spacing:-.01em; }
.why2-item p{ font-size:.95rem; color:var(--paper-2); margin:0; }
.why2-item:nth-child(n+3){ border-top:1px solid var(--line); padding-top:30px; }
.section.light .why2-item:nth-child(n+3){ border-top-color:var(--lt-line); }
@media (max-width:680px){
  .why2-grid{ grid-template-columns:1fr; gap:26px; }
  .why2-item:nth-child(2){ border-top:1px solid var(--line); padding-top:26px; }
  .section.light .why2-item:nth-child(2){ border-top-color:var(--lt-line); }
}

/* ---- Full-bleed services grid ---- */
.svc-grid.full{ width:100vw; max-width:100vw; margin-left:calc(50% - 50vw); margin-right:calc(50% - 50vw); border-left:none; border-right:none; }

/* ---- Hero centered (override earlier left-align) ---- */
.hero.has-photo .hero-copy{ text-align:center; margin-inline:auto; }
.hero.has-photo .hero-copy h1,
.hero.has-photo .hero-copy .lead,
.hero.has-photo .hero-copy .hero-actions{ text-align:center; }
.hero.has-photo .hero-actions{ justify-content:center; }
.hero.has-photo .hero-lead{ margin-left:auto; margin-right:auto; }


/* ---- Trust badges (bold, static) ---- */
.trust-badges{ background:var(--ink-2); border-block:1px solid var(--line); padding-block:30px; position:relative; z-index:2; }
.tb-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:26px; }
.tb{ display:flex; align-items:center; gap:15px; justify-content:center; }
.tb-ic{ width:54px; height:54px; border-radius:50%; background:rgba(92,158,74,.14); border:1.5px solid var(--pine); color:var(--pine); display:grid; place-items:center; flex:0 0 auto; }
.tb-ic svg{ width:26px; height:26px; }
.tb b{ display:block; font-size:1rem; text-transform:uppercase; letter-spacing:-.01em; line-height:1.1; margin-bottom:3px; }
.tb span{ font-size:.78rem; color:var(--paper-3); font-family:"IBM Plex Mono",monospace; letter-spacing:.04em; }
@media (max-width:860px){ .tb-grid{ grid-template-columns:1fr 1fr; gap:24px 18px; } }
@media (max-width:480px){ .tb-grid{ grid-template-columns:1fr; } .tb{ justify-content:flex-start; } }

/* ---- Testimonial slider ---- */
.tslider{ position:relative; max-width:880px; margin:0 auto; }
.tviewport{ overflow:hidden; }
.ttrack{ display:flex; transition:transform .55s var(--ease); }
.tslide{ min-width:100%; text-align:center; padding:6px clamp(4px,4vw,50px); box-sizing:border-box; }
.tslide .marks{ font-family:"IBM Plex Mono",monospace; font-size:3.4rem; line-height:.5; color:var(--pine); margin-bottom:18px; }
.tslide p{ font-size:clamp(1.2rem,2.3vw,1.7rem); line-height:1.5; color:var(--paper); max-width:46ch; margin:0 auto 26px; font-weight:500; }
.tslide .who{ display:inline-flex; align-items:center; gap:13px; justify-content:center; }
.tslide .who .av{ width:46px; height:46px; background:var(--ink-3); border:1px solid var(--line); display:grid; place-items:center; font-weight:900; color:var(--pine); }
.tslide .who b{ display:block; font-size:1rem; } .tslide .who span{ font-family:"IBM Plex Mono",monospace; font-size:11px; color:var(--paper-3); letter-spacing:.08em; text-transform:uppercase; }
.tcontrols{ display:flex; align-items:center; justify-content:center; gap:20px; margin-top:34px; }
.tnav{ width:46px; height:46px; border-radius:50%; border:1.5px solid var(--line); background:none; color:var(--paper); display:grid; place-items:center; transition:.25s var(--ease); }
.tnav:hover{ border-color:var(--pine); color:var(--pine); }
.tnav svg{ width:20px; height:20px; }
.tdots{ display:flex; gap:10px; }
.tdot{ width:10px; height:10px; border-radius:50%; background:var(--line); border:none; cursor:pointer; padding:0; transition:.25s; }
.tdot.active{ background:var(--pine); transform:scale(1.2); }


/* ---- Hero headline: wider area, smaller letters, 3 lines ---- */
.hero.has-photo .hero-copy{ max-width:1200px; }
.hero.has-photo .hero-h1{ font-size:clamp(2.2rem, 6vw, 4.6rem); line-height:1.05; }
@media (max-width:680px){
  .hero.has-photo .hero-h1{ font-size:clamp(2rem, 8.5vw, 3rem); }
  .hero.has-photo .hero-h1 br{ display:none; }
}

/* ---- Lighter form fields ---- */
.field input,.field select,.field textarea{ background:var(--paper); border-color:var(--lt-line); color:var(--ink); }
.field input::placeholder,.field textarea::placeholder{ color:#9a8e7a; }
.field select{ color:var(--ink); }
.field input:focus,.field select:focus,.field textarea:focus{ border-color:var(--pine); box-shadow:0 0 0 3px rgba(92,158,74,.18); }


/* ---- Wider interior page-hero header ---- */
.page-hero-inner{ max-width:58rem; }
@media (max-width:600px){ .page-hero-inner h1 br{ display:none; } }


/* ---- Interactive 3D pallet viewer ---- */
.pallet3d{ position:absolute; inset:0; z-index:1; cursor:grab; touch-action:none; }
.pallet3d canvas{ display:block; width:100%; height:100%; }
.viz-stage .ruler{ z-index:3; }
.viz-stage .drag-hint{ position:absolute; bottom:12px; right:12px; z-index:3; font-family:"IBM Plex Mono",monospace; font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--paper-3); pointer-events:none; display:flex; align-items:center; gap:6px; }
.viz-stage .drag-hint::before{ content:""; width:14px; height:14px; border:1.5px solid var(--paper-3); border-radius:50%; }


/* ---- Pallet types reference ---- */
.types-sec{ background:var(--ink); border-block:1px solid var(--line); }
.types-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2vw,28px); }
.type{ background:var(--ink-2); border:1px solid var(--line); border-radius:16px; padding:clamp(28px,2.4vw,40px) clamp(26px,2.2vw,34px); transition:border-color .28s var(--ease), transform .28s var(--ease), box-shadow .28s var(--ease); position:relative; }
.type:hover{ box-shadow:0 16px 40px rgba(0,0,0,.32); }
@media (max-width:900px){ .types-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .types-grid{ grid-template-columns:1fr; } }
.type:hover{ border-color:var(--pine); transform:translateY(-4px); }
.type .cat{ font-family:"IBM Plex Mono",monospace; font-size:10px; letter-spacing:.16em; color:var(--pine); display:inline-block; margin-bottom:12px; }
.type h3{ font-size:clamp(1.35rem,1.5vw,1.68rem); text-transform:uppercase; letter-spacing:-.01em; margin:0 0 11px; }
.type p{ font-size:.92rem; color:var(--paper-2); margin:0; line-height:1.5; }


/* ---- Larger 3D viewer box so the whole pallet fits ---- */
.viz-grid{ grid-template-columns:1fr 1fr; gap:48px; }
@media (max-width:1080px){ .viz-grid{ grid-template-columns:1fr; } }


/* ---- Photo behind interior page-hero (breadcrumb/title) ---- */
.page-hero-photo{ position:absolute; inset:0; z-index:0; background-size:cover; background-position:center; }
.page-hero-photo::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(20,16,11,.74) 0%, rgba(20,16,11,.86) 70%, rgba(20,16,11,.95) 100%); }
.page-hero .hero-grid{ opacity:.28; }
.page-hero-inner{ position:relative; z-index:2; }

/* ---- Pallet Types diagrams ---- */
.diagram{ position:relative; aspect-ratio:16/10; border:1.5px solid var(--line); background:
  radial-gradient(120% 120% at 50% 0%, rgba(92,158,74,.05), transparent 55%),
  repeating-linear-gradient(0deg, transparent 0 31px, var(--line-soft) 31px 32px),
  repeating-linear-gradient(90deg, transparent 0 31px, var(--line-soft) 31px 32px);
  display:grid; place-items:center; padding:5%; overflow:hidden; }
.diagram svg{ width:100%; height:auto; }
.diagram .dlabel{ position:absolute; top:12px; left:14px; font-family:"IBM Plex Mono",monospace; font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--paper-3); }

/* ---- Fit 7 nav items ---- */
.nav-links{ gap:24px; }
@media (max-width:1160px){ .nav-links{ display:none; } .burger{ display:flex; } }


/* ============================================================
   CENTERED LOGO NAV (links left & right)
   ============================================================ */
.nav{ display:grid; grid-template-columns:1fr auto 1fr; align-items:center; height:auto; min-height:96px; column-gap:24px; }
.nav-side{ display:flex; }
.nav-left{ justify-content:flex-end; }
.nav-right{ justify-content:flex-start; }
.nav-side .nav-links{ display:flex; align-items:center; gap:24px; list-style:none; margin:0; padding:0; }
.brand-center{ justify-self:center; }
.nav-logo-img{ height:78px; width:auto; display:block; }
header.scrolled .nav-logo-img{ height:64px; transition:height var(--speed) var(--ease); }
.nav-logo-img{ transition:height var(--speed) var(--ease); }
html{ scroll-padding-top:112px; }
@media (max-width:1160px){
  .nav{ display:flex; justify-content:space-between; min-height:72px; }
  .nav-side{ display:none; }
  .nav-logo-img, header.scrolled .nav-logo-img{ height:50px; }
  .burger{ display:flex; }
}

/* ---- Nav logo +40% ---- */
.nav{ min-height:128px; }
.nav-logo-img{ height:110px; }
header.scrolled .nav-logo-img{ height:90px; }
.hero{ padding-top:178px; }
.page-hero{ padding-top:174px; }
html{ scroll-padding-top:142px; }
.mobile-menu{ top:84px; }
@media (max-width:1160px){
  .nav{ min-height:84px; }
  .nav-logo-img, header.scrolled .nav-logo-img{ height:70px; }
  .hero, .page-hero{ padding-top:130px; }
}


/* ---- Photo behind homepage quote form (green-tinted) ---- */
.quote-photo{ position:absolute; inset:0; z-index:0; background-size:cover; background-position:center; }
.quote-photo::after{ content:""; position:absolute; inset:0; background:linear-gradient(120deg, rgba(46,94,55,.93) 0%, rgba(46,94,55,.74) 55%, rgba(20,16,11,.8) 100%); }
.quote-band::before{ z-index:1; }
.quote-band .wrap{ z-index:2; }

/* ---- Quote section overlay -> dark brown ---- */
.quote-band{ background:#241a10; }
.quote-photo::after{ background:linear-gradient(120deg, rgba(26,18,11,.93) 0%, rgba(40,29,18,.80) 55%, rgba(18,14,9,.92) 100%); }


/* ---- Wider services section on desktop ---- */
@media (min-width:1100px){
  #services .wrap{ max-width:min(1600px, 94vw); }
}

/* ---- Services: separated, rounded cards ---- */
.svc-grid{ gap:18px; background:none; border:none; }
.svc{ border:1px solid var(--line); border-radius:16px; }
.svc:hover{ border-color:var(--line); }

/* ============================================================
   "Serving California" + sticky mobile CTA bar (Call / Quote)
   ============================================================ */
.foot-serving{ margin-top:16px; display:inline-flex; align-items:center; gap:8px; font-family:"IBM Plex Mono",monospace; font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--pine); }
.foot-serving svg{ width:16px; height:16px; flex:0 0 auto; }

.mcta{ position:fixed; left:0; right:0; bottom:0; z-index:1150; display:none; gap:10px;
  padding:10px 12px calc(10px + env(safe-area-inset-bottom));
  background:rgba(20,16,11,.96); backdrop-filter:blur(10px); border-top:1px solid var(--line); }
.mcta a{ flex:1; display:inline-flex; align-items:center; justify-content:center; gap:9px; min-height:52px;
  font-weight:800; font-size:.95rem; text-transform:uppercase; letter-spacing:.02em; border-radius:12px; }
.mcta .mcta-call{ background:var(--pine); color:var(--ink); }
.mcta .mcta-call:active{ background:var(--pine-hi); }
.mcta .mcta-quote{ background:rgba(242,234,220,.06); color:var(--paper); border:1.5px solid var(--line); }
.mcta a svg{ width:18px; height:18px; }
.mobile-menu.open ~ .mcta{ display:none !important; }
@media (max-width:900px){
  .mcta{ display:flex; }
  body{ padding-bottom:76px; }
  #toTop{ bottom:84px; }
}

/* Even darker brown footer */
footer{ background:#0E0A06; }

/* ============================================================
   Testimonials — full width, no slider, no card box
   ============================================================ */
.tgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(30px,4vw,66px);
  max-width:min(1760px,92vw); margin:48px auto 0; }
.tgrid .tcard{ background:none; border:none; padding:0 clamp(0px,1.5vw,22px); text-align:center; }
.tgrid .marks{ font-family:"IBM Plex Mono",monospace; font-size:3rem; line-height:.5; color:var(--pine); margin-bottom:16px; }
.tgrid p{ font-size:clamp(1.02rem,1.15vw,1.16rem); line-height:1.62; color:var(--paper); margin:0 0 24px; font-weight:500; }
.tgrid .who{ display:inline-flex; align-items:center; gap:13px; justify-content:center; }
.tgrid .who .av{ width:46px; height:46px; background:var(--ink-3); border:1px solid var(--line); display:grid; place-items:center; font-weight:900; color:var(--pine); }
.tgrid .who b{ display:block; font-size:1rem; }
.tgrid .who > span:last-child > span{ font-family:"IBM Plex Mono",monospace; font-size:11px; color:var(--paper-3); letter-spacing:.08em; text-transform:uppercase; }
@media (max-width:860px){ .tgrid{ grid-template-columns:1fr; gap:50px; } }

/* ============================================================
   Services detail: keep 2-col, just a little wider
   ============================================================ */
.svc-wide .wrap{ max-width:min(1420px, 94vw); }

/* ============================================================
   Card sections (why-grid) — detached, rounded, centered
   ============================================================ */
.why-grid{ background:none; border:none; gap:clamp(16px,1.7vw,24px); }
.why{ border:1px solid var(--line); border-radius:16px; text-align:center; }
.why svg{ display:block; margin:0 auto 18px; }
.section.light .why-grid{ background:none; border:none; }
.section.light .why{ border-color:var(--lt-line); }

/* White light-sections: give detached cards subtle separation */
.section.light .why{ box-shadow:0 1px 2px rgba(20,16,11,.05); }

/* ============================================================
   Pallet visualizer — LIGHT variant (off-white section)
   ============================================================ */
.viz.light .viz-stage{
  border-color:var(--lt-line);
  background:
    radial-gradient(120% 120% at 50% 0%, rgba(92,158,74,.08), transparent 55%),
    repeating-linear-gradient(0deg, transparent 0 31px, var(--lt-line-soft) 31px 32px),
    repeating-linear-gradient(90deg, transparent 0 31px, var(--lt-line-soft) 31px 32px);
}
.viz.light .viz-stage .ruler{ color:var(--lt-ink3); }
.viz.light .viz-stage .drag-hint{ color:var(--lt-ink3); }
.viz.light .viz-stage .drag-hint::before{ border-color:var(--lt-ink3); }
.viz.light .chip{ border-color:var(--lt-line); color:var(--lt-ink2); }
.viz.light .chip:hover{ border-color:var(--lt-accent); color:var(--lt-ink); }
.viz.light .chip[aria-pressed="true"]{ background:var(--lt-accent); border-color:var(--lt-accent); color:#fff; }
.viz.light .viz-dim{ color:var(--lt-accent); }
.viz.light .viz-specs{ background:var(--lt-line); border-color:var(--lt-line); }
.viz.light .viz-specs div{ background:var(--lt-card); }
.viz.light .viz-specs dt{ color:var(--lt-ink3); }
.viz.light .viz-specs dd{ color:var(--lt-ink); }
.viz.light .viz-note{ color:var(--lt-ink2); }

/* ============================================================
   Animated scroll arrows (hero cue + section dividers)
   ============================================================ */
.chev-flow{ display:flex; flex-direction:column; align-items:center; line-height:0; }
.chev-flow svg{ width:26px; height:26px; color:var(--pine); margin-top:-13px; animation:chevFlow 1.6s var(--ease) infinite; }
.chev-flow svg:first-child{ margin-top:0; }
.chev-flow svg:nth-child(2){ animation-delay:.18s; }
.chev-flow svg:nth-child(3){ animation-delay:.36s; }
@keyframes chevFlow{ 0%,100%{ opacity:.16; transform:translateY(-2px);} 50%{ opacity:1; transform:translateY(3px);} }

.scroll-cue{ position:absolute; left:50%; bottom:20px; transform:translateX(-50%); z-index:5; transition:opacity .4s ease, transform .4s ease; }
.scroll-cue.hide{ opacity:0; transform:translate(-50%,10px); pointer-events:none; }

.chev-divide{ display:flex; justify-content:center; padding:30px 0; }

@media (prefers-reduced-motion:reduce){
  .chev-flow svg{ animation:none; opacity:.55; margin-top:-13px; }
  .chev-flow svg:first-child{ margin-top:0; }
}

/* ============================================================
   Parallax on full-bleed photo / video backgrounds
   ============================================================ */
.hero.has-photo .hero-photo img, .page-hero-photo, .video-bg{ will-change:transform; }
@media (min-width:768px) and (prefers-reduced-motion:no-preference){
  .hero.has-photo .hero-photo img{ position:absolute; left:0; right:auto; top:-14%; bottom:auto; width:100%; height:128%; }
  .page-hero-photo{ top:-14%; bottom:auto; height:128%; }
  .video-bg{ top:-14%; bottom:auto; height:128%; }
}

/* ============================================================
   Common sizes table (sizes.html)
   ============================================================ */
.size-table-wrap{ background:var(--lt-card); border:1px solid var(--lt-line); border-radius:18px; overflow:hidden; box-shadow:0 1px 3px rgba(20,16,11,.05); }
.size-table{ width:100%; border-collapse:collapse; font-size:1rem; }
.size-table .ta-r{ text-align:right; }
.size-table thead th{ background:#5A4632; color:#fff; text-align:left; font-family:"IBM Plex Mono",monospace; font-size:11px; letter-spacing:.12em; text-transform:uppercase; padding:20px 26px; font-weight:700; }
.size-table tbody td{ padding:19px 26px; border-top:1px solid var(--lt-line); color:var(--lt-ink2); vertical-align:middle; }
.size-table tbody tr:first-child td{ border-top:none; }
.size-table tbody tr:first-child{ background:#FBF7EC; }
.size-table tbody tr:first-child td:first-child{ box-shadow:inset 4px 0 0 var(--pine); }
.size-table .sz{ font-weight:700; color:var(--lt-ink); font-size:1.04rem; white-space:nowrap; }
.avail{ display:inline-block; font-family:"IBM Plex Mono",monospace; font-size:11px; font-weight:700; letter-spacing:.07em; text-transform:uppercase; padding:7px 14px; border-radius:999px; white-space:nowrap; }
.avail.in{ background:#DDEFD8; color:#3F7A33; }
.avail.avl{ background:#D6E8EE; color:#2E6B82; }
.avail.req{ background:#F6E7BC; color:#937414; }
.avail.con{ background:#F6E7BC; color:#937414; }
.size-note{ margin-top:22px; background:#ECE1CC; border-left:4px solid var(--pine); border-radius:10px; padding:18px 22px; color:var(--lt-ink2); font-size:.95rem; line-height:1.55; }
.size-note b{ color:var(--lt-ink); }
@media (max-width:640px){
  .size-table-wrap{ overflow-x:auto; }
  .size-table{ min-width:600px; }
  .size-table thead th{ padding:14px 16px; }
  .size-table tbody td{ padding:14px 16px; }
}

/* ============================================================
   Staggered card reveal (per-card, on scroll)
   ============================================================ */
.r-stagger > *{ opacity:0; }
.r-stagger.in > *{ animation:riseIn .6s var(--ease) both; animation-delay:calc(var(--i,0) * 65ms); }
@keyframes riseIn{ from{ opacity:0; translate:0 26px; } to{ opacity:1; translate:0 0; } }
@media (prefers-reduced-motion:reduce){ .r-stagger > *{ opacity:1; } .r-stagger.in > *{ animation:none; } }

/* ============================================================
   Custom cursor (desktop / fine-pointer only)
   ============================================================ */
.cursor-dot,.cursor-ring{ position:fixed; top:0; left:0; border-radius:50%; pointer-events:none; z-index:10000; transform:translate(-50%,-50%); opacity:0; }
.cursor-dot{ width:7px; height:7px; background:var(--pine); }
.cursor-ring{ width:34px; height:34px; border:1.5px solid rgba(92,158,74,.55);
  transition:width .22s var(--ease), height .22s var(--ease), background .22s var(--ease), border-color .22s var(--ease); }
.cursor-ring.hovering{ width:56px; height:56px; background:rgba(92,158,74,.10); border-color:var(--pine); }
body.cursor-on .cursor-dot, body.cursor-on .cursor-ring{ opacity:1; }
@media (hover:hover) and (pointer:fine){
  body.cursor-on, body.cursor-on a, body.cursor-on button, body.cursor-on .chip{ cursor:none; }
}

/* ============================================================
   Nav "Get a Quote" button (desktop)
   ============================================================ */
.nav-right{ align-items:center; gap:22px; }
.nav-cta{ margin-left:auto; padding:10px 20px; font-size:.82rem; letter-spacing:.02em; min-height:0; white-space:nowrap; }
@media (max-width:1160px){ .nav-cta{ display:none; } }

/* ============================================================
   A11y / responsive / perf hardening (QA pass)
   ============================================================ */
.skip-link{ position:absolute; left:-9999px; top:0; z-index:10001; background:var(--pine); color:var(--ink); padding:10px 16px; font-weight:800; }
.skip-link:focus{ left:0; }

:focus-visible{ outline:2px solid var(--pine); outline-offset:3px; }
.btn:focus-visible{ outline-offset:4px; }
body.cursor-on a:focus-visible, body.cursor-on button:focus-visible,
body.cursor-on input:focus-visible, body.cursor-on select:focus-visible, body.cursor-on textarea:focus-visible{ outline:2px solid var(--pine); outline-offset:3px; }

section[id], article[id], main[id]{ scroll-margin-top:108px; }

img{ max-width:100%; }

.chip{ min-height:44px; }
@media (max-width:720px){
  .mobile-menu a{ min-height:46px; display:flex; align-items:center; }
}

/* "All Services" button in the services section: lighter green, black on hover */
#services .btn-ghost{
  background:var(--pine-hi); border-color:var(--pine-hi); color:var(--ink);
  transition:background var(--speed) var(--ease), color var(--speed) var(--ease), border-color var(--speed) var(--ease);
}
#services .btn-ghost:hover{ background:#000; border-color:#000; color:var(--paper); }

/* Wider container for the Pallet Types grid (bigger cards) */
.wrap:has(.types-grid){ max-width:min(1600px, 94vw); }

/* ============================================================
   Animated loader — pallets stacking
   ============================================================ */
.pallet-stack{ display:flex; flex-direction:column-reverse; align-items:center; gap:6px; margin-bottom:6px; }
.pallet-stack .plt{ line-height:0; opacity:0; transform:translateY(-18px); animation:pltDrop 2.6s var(--ease) infinite; }
.pallet-stack .plt svg{ width:clamp(90px,22vw,122px); height:auto; display:block; color:#C08A4E; filter:drop-shadow(0 3px 5px rgba(0,0,0,.4)); }
.pallet-stack .plt:nth-child(even) svg{ color:#9A6A30; }
.pallet-stack .plt:nth-child(2){ animation-delay:.3s; }
.pallet-stack .plt:nth-child(3){ animation-delay:.6s; }
.pallet-stack .plt:nth-child(4){ animation-delay:.9s; }
@keyframes pltDrop{ 0%{ opacity:0; transform:translateY(-18px); } 10%,72%{ opacity:1; transform:translateY(0); } 88%,100%{ opacity:0; transform:translateY(-18px); } }
@media (prefers-reduced-motion:reduce){ .pallet-stack .plt{ opacity:1; transform:none; animation:none; } }

/* Hero "Explore Services" button: off-white with brown letters (stops blending) */
.hero-actions .btn-ghost{ background:var(--lt-bg); border-color:var(--lt-bg); color:var(--lt-ink); }
.hero-actions .btn-ghost:hover{ background:#fff; border-color:#fff; color:var(--ink); }
