/* =====================================================================
   King Stump Grinding — Design System  (Timber-Regal, LOCKED)
   Wave A: tokens · header · hero · footer · buttons · cards
           breadcrumbs · page-hero · content-grid · spec-table · FAQ · steps
   ===================================================================== */

/* ---------- tokens ---------- */
:root{
  --bark:#2E2118;
  --heartwood:#6E4A2E;
  --sawdust:#E7D9BF;
  --cream:#F6EFE1;
  --crown:#C68A2E;
  --crown-deep:#A06F1F;
  --pine:#2C4435;
  --pine-line:#3D5A48;

  --ink:var(--bark);
  --paper:var(--cream);
  --rule:#ddccab;
  --rule-soft:#e7dcc4;

  --maxw:1180px;
  --gutter:clamp(20px, 5vw, 56px);

  --r-sm:8px; --r-md:12px; --r-lg:18px;
  --shadow-card:0 8px 24px rgba(46,33,24,.10);
  --shadow-pop:0 16px 40px rgba(46,33,24,.18);

  --ff-display:"Anton", system-ui, sans-serif;
  --ff-grotesk:"Archivo", system-ui, sans-serif;
  --ff-body:"Source Sans 3", system-ui, sans-serif;

  --ksg-pith:var(--crown);
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--ff-body);
  font-size:clamp(16px,1.05vw,17.5px);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:var(--crown-deep);text-decoration:none;}
a:hover{text-decoration:underline;}

h1,h2,h3,h4{font-family:var(--ff-grotesk);line-height:1.1;color:var(--ink);margin:0 0 .5em;}
.display{font-family:var(--ff-display);font-weight:400;letter-spacing:.01em;line-height:.95;}
p{margin:0 0 1em;text-wrap:pretty;}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter);}
.eyebrow{font-family:var(--ff-grotesk);font-weight:700;letter-spacing:.18em;text-transform:uppercase;font-size:.78rem;color:var(--crown-deep);}
/* trust strip — replaces the H1-echoing eyebrow on inner pages with credibility signals */
.trust-strip{display:flex;flex-wrap:wrap;gap:.5rem 1.15rem;list-style:none;margin:0 0 1rem;padding:0;font-family:var(--ff-grotesk);font-weight:700;font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;color:var(--crown-deep);}
.trust-strip li{display:inline-flex;align-items:center;gap:.4em;}
.trust-strip li::before{content:"✓";color:var(--crown);font-weight:900;font-size:1.05em;}
.lede{font-size:1.2rem;line-height:1.55;color:var(--heartwood);}

/* ---------- logo mark ---------- */
.ksg-mark{display:block;width:100%;height:100%;color:inherit;}
.ksg-logo{display:flex;align-items:center;gap:.7rem;text-decoration:none;}
.ksg-logo:hover{text-decoration:none;}
.ksg-logo .mark-box{flex:none;}
.site-logo{display:block;height:64px;width:auto;}
.site-footer .site-logo{height:64px;}
.logo-mark{display:none;}
.ksg-logo .word .k{font-family:var(--ff-display);font-size:1.5rem;line-height:.82;letter-spacing:.04em;color:var(--bark);}
.ksg-logo .word .s{font-family:var(--ff-grotesk);font-weight:700;letter-spacing:.12em;font-size:.62rem;color:var(--heartwood);}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--ff-grotesk);font-weight:800;font-size:1rem;letter-spacing:.01em;
  border:none;border-radius:var(--r-sm);padding:.92em 1.4em;cursor:pointer;
  text-decoration:none;transition:transform .14s ease, box-shadow .18s ease, filter .15s ease;
}
.btn:hover{text-decoration:none;}
.btn:active{transform:translateY(0);}
.btn .arrow{transition:transform .16s ease;}
.btn:hover .arrow{transform:translateX(3px);}

/* Primary CTA — bright marigold, pressable, warm glow */
.btn-gold{
  background:linear-gradient(177deg,#F0B23F 0%,#E09A2A 52%,#CE8A1E 100%);
  color:#2C1D0E;
  box-shadow:0 2px 0 #9A661A, 0 7px 18px rgba(214,150,46,.36);
}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 4px 0 #9A661A, 0 13px 28px rgba(214,150,46,.48);filter:saturate(1.06) brightness(1.03);}
.btn-gold:active{transform:translateY(0);box-shadow:0 1px 0 #9A661A, 0 4px 10px rgba(214,150,46,.3);}
.btn-gold:focus-visible{outline:3px solid #2C1D0E;outline-offset:2px;}

/* Pine CTA — also gets lift + depth */
.btn-pine{background:var(--pine);color:var(--cream);box-shadow:0 2px 0 #1d2f23, 0 7px 16px rgba(44,68,53,.28);}
.btn-pine:hover{transform:translateY(-2px);box-shadow:0 4px 0 #1d2f23, 0 12px 24px rgba(44,68,53,.4);filter:brightness(1.08);}
.btn-pine:active{transform:translateY(0);box-shadow:0 1px 0 #1d2f23;}

.btn-ghost{background:transparent;color:var(--bark);border:2px solid var(--bark);padding:.78em 1.25em;}
.btn-ghost:hover{background:var(--bark);color:var(--cream);}
.btn-ghost-light{background:transparent;color:var(--cream);border:2px solid var(--sawdust);padding:.78em 1.25em;}
.btn-ghost-light:hover{background:var(--sawdust);color:var(--bark);}

@media (prefers-reduced-motion:reduce){
  .btn,.btn .arrow{transition:none;}
  .btn-gold:hover,.btn-pine:hover{transform:none;}
}

/* ---------- trust chips ---------- */
.chips{display:flex;flex-wrap:wrap;gap:.55rem;list-style:none;margin:0;padding:0;}
.chip{
  font-family:var(--ff-grotesk);font-weight:700;font-size:.82rem;letter-spacing:.03em;
  color:var(--pine);background:#fff;border:1px solid var(--sawdust);border-radius:999px;
  padding:.42em .85em;display:inline-flex;gap:.4em;align-items:center;
}
.chip::before{content:"✓";color:var(--crown-deep);font-weight:900;}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:var(--cream);border-bottom:1px solid var(--rule);}
.site-header .wrap{position:relative;display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:74px;}
.nav{display:flex;align-items:center;gap:1.6rem;}
.nav a{font-family:var(--ff-grotesk);font-weight:600;font-size:.98rem;color:var(--bark);}
.nav a:hover{color:var(--crown-deep);text-decoration:none;}
.header-cta{display:flex;align-items:center;gap:1rem;}
.header-phone{font-family:var(--ff-grotesk);font-weight:800;color:var(--bark);white-space:nowrap;}
/* hamburger — hidden on desktop, 44px tap target on mobile */
.nav-toggle{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:44px;height:44px;background:transparent;border:none;cursor:pointer;padding:0;flex:none;}
.nav-toggle span{display:block;width:24px;height:2.5px;border-radius:2px;background:var(--bark);transition:transform .2s ease, opacity .2s ease;}
.site-header.menu-open .nav-toggle span:nth-child(1){transform:translateY(7.5px) rotate(45deg);}
.site-header.menu-open .nav-toggle span:nth-child(2){opacity:0;}
.site-header.menu-open .nav-toggle span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;background:var(--bark);color:var(--cream);}
.hero .bg-mark{position:absolute;right:-6%;bottom:-22%;width:min(56vw,640px);aspect-ratio:1;color:var(--cream);opacity:.10;pointer-events:none;}
.hero .wrap{position:relative;padding-block:clamp(48px,8vw,104px);}
.hero .eyebrow{color:var(--sawdust);}
.hero h1{font-family:var(--ff-display);font-weight:400;font-size:clamp(2.6rem,6.6vw,5rem);line-height:.94;color:var(--cream);max-width:16ch;margin-top:.35em;}
.hero h1 .gold{color:var(--crown);}
.hero .lede{color:var(--sawdust);max-width:48ch;margin-block:1.1em 1.8em;}
.hero .cta-row{display:flex;flex-wrap:wrap;gap:.9rem;align-items:center;}
.hero .hero-chips{margin-top:1.9rem;}
.hero .hero-chips .chip{background:rgba(255,255,255,.06);border-color:var(--pine-line);color:var(--sawdust);}
.hero .hero-chips .chip::before{color:var(--crown);}

/* ---------- secondary-category blocks (homepage) ---------- */
.secondary-cats{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4.5vw,60px);margin-top:1.5rem;}
.secondary-cats > *{min-width:0;}
.sec-cat h2{font-family:var(--ff-grotesk);font-weight:800;font-size:clamp(1.45rem,2.6vw,2.05rem);color:var(--cream);margin:0 0 .65rem;}
.sec-cat h2 a{color:inherit;text-decoration:none;}
.sec-cat h2 a:hover{color:var(--crown);text-decoration:none;}
.sec-cat p{color:var(--sawdust);margin:0 0 1rem;}
.sec-cat .more{font-family:var(--ff-grotesk);font-weight:800;color:var(--crown);font-size:1rem;}
.sec-cat .more:hover{color:var(--cream);text-decoration:none;}

/* ---------- generic section ---------- */
.section{padding-block:clamp(48px,7vw,92px);}
.section-head{max-width:62ch;margin-bottom:clamp(28px,4vw,48px);}
.section-head h2{font-family:var(--ff-grotesk);font-weight:800;font-size:clamp(1.8rem,3.4vw,2.6rem);}
.section.pine{background:var(--pine);color:var(--sawdust);}
.section.pine h2,.section.pine h3{color:var(--cream);}
.section.pine .eyebrow{color:var(--crown);}
.section.sawdust{background:var(--sawdust);}

/* ---------- cluster banner (homepage H2) ---------- */
.cluster{border-top:1px solid var(--rule);}
.cluster .wrap{padding-block:clamp(40px,5.5vw,72px);}
.cluster-head{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:1rem;}
.cluster-head h2{font-family:var(--ff-grotesk);font-weight:800;font-size:clamp(1.6rem,3vw,2.3rem);margin:0;}
.cluster-head .count{font-family:var(--ff-grotesk);font-weight:700;color:var(--heartwood);font-size:.95rem;}
.cluster-intro{max-width:66ch;color:var(--heartwood);font-size:1.06rem;line-height:1.55;margin:0 0 1.9rem;}
.cluster-intro a{color:var(--crown-deep);font-weight:600;}

/* ---------- service grid + card ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,290px),1fr));gap:1.2rem;}
.svc-card{
  display:flex;flex-direction:column;background:var(--cream);border:1px solid var(--rule);
  border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-card);
  transition:transform .12s ease, box-shadow .15s ease;
}
.svc-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-pop);}
.svc-card .cap{
  position:relative;height:128px;overflow:hidden;
  background:linear-gradient(142deg,#3a5845 0%,#2c4435 52%,#21382a 100%);
  display:flex;align-items:center;justify-content:center;color:var(--sawdust);
}
.svc-card .cap::after{content:"";position:absolute;inset:0;background:radial-gradient(85% 70% at 22% 12%,rgba(231,217,191,.13),transparent 55%);pointer-events:none;}
.svc-card .cap .mb{width:62px;height:62px;opacity:.95;position:relative;filter:drop-shadow(0 3px 8px rgba(0,0,0,.25));}
.svc-card .flag{
  position:absolute;top:11px;left:11px;z-index:1;
  font-family:var(--ff-grotesk);font-weight:800;font-size:.62rem;letter-spacing:.1em;
  color:#2C1D0E;background:var(--crown);border-radius:999px;padding:.32em .72em;
  box-shadow:0 2px 6px rgba(0,0,0,.18);
}
.svc-card .body{padding:1.1rem 1.15rem 1.25rem;display:flex;flex-direction:column;flex:1;}
.svc-card h3{font-family:var(--ff-grotesk);font-weight:800;font-size:1.18rem;line-height:1.12;margin:0 0 .5rem;}
.svc-card h3 a{color:inherit;}
.svc-card h3 a:hover{color:var(--crown-deep);text-decoration:none;}
.svc-card p{font-size:.95rem;color:var(--heartwood);margin:0 0 1rem;}
.svc-card .more{margin-top:auto;font-family:var(--ff-grotesk);font-weight:800;font-size:.95rem;color:var(--crown-deep);}

/* ---------- breadcrumbs ---------- */
.crumbs{background:var(--sawdust);border-bottom:1px solid var(--rule);}
.crumbs ol{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;list-style:none;margin:0;padding:.85rem 0;font-family:var(--ff-grotesk);font-size:.86rem;font-weight:600;}
.crumbs li{display:flex;align-items:center;gap:.5rem;color:var(--heartwood);}
.crumbs li+li::before{content:"›";color:var(--crown-deep);}
.crumbs a{color:var(--heartwood);}
.crumbs a:hover{color:var(--bark);}
.crumbs [aria-current]{color:var(--bark);}

/* ---------- page hero (inner pages) ---------- */
.page-hero{background:var(--cream);border-bottom:1px solid var(--rule);}
.page-hero .wrap{padding-block:clamp(36px,5vw,64px);display:grid;grid-template-columns:1.4fr .9fr;gap:clamp(24px,4vw,56px);align-items:center;}
.page-hero h1{font-family:var(--ff-display);font-weight:400;font-size:clamp(2.2rem,4.8vw,3.5rem);line-height:.98;}
.page-hero .lede{margin-top:.6em;}
.page-hero .ph-card{background:var(--pine);color:var(--sawdust);border-radius:var(--r-lg);padding:1.5rem 1.5rem 1.6rem;box-shadow:var(--shadow-card);}
.page-hero .ph-card h2{font-family:var(--ff-grotesk);font-weight:800;font-size:1.1rem;color:var(--cream);margin:0 0 .9rem;}
.page-hero .ph-card .row{display:flex;justify-content:space-between;gap:1rem;padding:.55rem 0;border-bottom:1px solid var(--pine-line);font-size:.95rem;}
.page-hero .ph-card .row:last-of-type{border-bottom:none;}
.page-hero .ph-card .row b{color:var(--cream);font-family:var(--ff-grotesk);}
.page-hero .ph-card .btn{margin-top:1.1rem;width:100%;justify-content:center;}

/* colored inner-page heroes — category = pine · service = midnight; echoes the homepage Midnight/Bold look */
.page-hero.hero-dark{background:#191310;border-bottom-color:#3a2a1c;}
.page-hero.hero-pine{background:#22382B;border-bottom-color:#35513f;}
.page-hero.hero-dark h1,.page-hero.hero-pine h1{color:var(--cream);}
.page-hero.hero-dark .lede,.page-hero.hero-pine .lede{color:var(--sawdust);}
.page-hero.hero-dark .trust-strip,.page-hero.hero-pine .trust-strip{color:var(--sawdust);}
.page-hero.hero-dark .trust-strip li::before,.page-hero.hero-pine .trust-strip li::before{color:var(--crown);}
.page-hero h1 .gold{color:var(--crown);}
.page-hero.hero-dark .ph-card{background:var(--pine);}
.page-hero.hero-pine .ph-card{background:var(--bark);}
.page-hero.hero-pine .ph-card .row{border-bottom-color:#4a3526;}
/* secondary ghost CTA flips to light on colored heroes (dark-on-dark fix) */
.page-hero.hero-dark .btn-ghost,.page-hero.hero-pine .btn-ghost{color:var(--cream);border-color:var(--sawdust);}
.page-hero.hero-dark .btn-ghost:hover,.page-hero.hero-pine .btn-ghost:hover{background:var(--sawdust);color:var(--bark);}

/* ---------- photo slots (labeled placeholders until real job photos land; swap inner for <img>) ---------- */
.photo-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:1.7em 0;}
.photo-row .photo-slot{margin:0;}
.photo-slot{margin:1.7em 0;border-radius:var(--r-md);overflow:hidden;background:var(--sawdust);border:1.5px dashed #b89b6e;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:1.3rem;aspect-ratio:4/3;}
.photo-slot.tall{aspect-ratio:16/9;}
.photo-slot svg{width:32px;height:32px;color:var(--crown-deep);opacity:.85;margin-bottom:.55rem;}
.photo-slot .ps-tag{font-family:var(--ff-grotesk);font-weight:800;font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--crown-deep);}
.photo-slot .ps-subject{font-family:var(--ff-grotesk);font-weight:600;font-size:.93rem;line-height:1.35;color:var(--bark);margin-top:.3rem;max-width:28ch;}
.photo-slot img{width:100%;height:100%;object-fit:cover;}
@media (max-width:640px){.photo-row{grid-template-columns:1fr;}}

/* ---------- image-slot (drag-and-drop photo upload; brand the empty state) ---------- */
image-slot.photo{display:block;width:100%;height:auto;aspect-ratio:4/3;margin:1.7em 0;}
image-slot.photo.tall{aspect-ratio:16/9;}
.photo-row image-slot.photo{margin:0;}
image-slot.photo::part(frame){background:var(--sawdust);border-radius:var(--r-md);}
image-slot.photo::part(ring){border-color:#b89b6e;border-radius:var(--r-md);}

/* ---------- content grid (article + aside) ---------- */
.content-grid{display:grid;grid-template-columns:1.6fr .9fr;gap:clamp(28px,4.5vw,64px);align-items:start;}
.content-grid > *{min-width:0;}
.prose h2{font-family:var(--ff-grotesk);font-weight:800;font-size:clamp(1.5rem,2.8vw,2rem);margin-top:1.8em;}
.prose h2:first-child{margin-top:0;}
.prose h3{font-family:var(--ff-grotesk);font-weight:700;font-size:1.2rem;margin-top:1.4em;}
.prose ul{padding-left:1.2em;}
.prose li{margin:.35em 0;}
.prose li::marker{color:var(--crown-deep);}
.aside{position:sticky;top:92px;display:flex;flex-direction:column;gap:1.2rem;}
.aside .box{background:var(--cream);border:1px solid var(--rule);border-radius:var(--r-md);padding:1.3rem 1.35rem;box-shadow:0 5px 16px rgba(46,33,24,.07);}
.aside .box h3{font-family:var(--ff-grotesk);font-weight:800;font-size:1.05rem;margin:0 0 .7rem;}
.aside .box.gold{background:linear-gradient(163deg,#F1B340 0%,#DD982C 55%,#CC8A20 100%);border:none;position:relative;overflow:hidden;box-shadow:0 12px 28px rgba(204,138,32,.34);}
.aside .box.gold::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 85% at 100% 0%,rgba(255,255,255,.32),transparent 58%);pointer-events:none;}
.aside .box.gold > *{position:relative;}
.aside .box.gold h3,.aside .box.gold p{color:#2C1D0E;}
.aside .linklist{list-style:none;margin:0;padding:0;}
.aside .linklist li{padding:.4rem 0;border-bottom:1px solid var(--rule-soft);font-family:var(--ff-grotesk);font-weight:600;font-size:.95rem;}
.aside .linklist li:last-child{border-bottom:none;}

/* ---------- spec table ---------- */
.spec-table{width:100%;border-collapse:collapse;margin:1.2em 0;font-size:.97rem;background:var(--cream);border:1px solid var(--rule);border-radius:var(--r-md);display:block;overflow-x:auto;}
.spec-table caption{caption-side:top;text-align:left;font-family:var(--ff-grotesk);font-weight:800;color:var(--heartwood);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:.6em;}
.spec-table th,.spec-table td{text-align:left;padding:.7rem .95rem;border-bottom:1px solid var(--rule-soft);vertical-align:top;}
.spec-table thead th{background:#efe3cc;font-family:var(--ff-grotesk);font-weight:800;font-size:.82rem;letter-spacing:.03em;}
.spec-table tbody tr:last-child td{border-bottom:none;}
.spec-table td:first-child{font-family:var(--ff-grotesk);font-weight:700;color:var(--bark);white-space:nowrap;}

/* ---------- steps ---------- */
.steps{counter-reset:step;display:grid;gap:1rem;list-style:none;padding:0;margin:1.2em 0;}
.steps li{position:relative;padding-left:3.2rem;}
.steps li::before{counter-increment:step;content:counter(step);position:absolute;left:0;top:-.1em;width:2.3rem;height:2.3rem;border-radius:50%;background:var(--crown);color:var(--bark);font-family:var(--ff-grotesk);font-weight:800;display:flex;align-items:center;justify-content:center;}
.steps li b{font-family:var(--ff-grotesk);display:block;}

/* ---------- FAQ ---------- */
.faq{display:grid;gap:.8rem;}
.faq-item{background:var(--cream);border:1px solid var(--rule);border-radius:var(--r-md);padding:1rem 1.2rem;}
.faq-item summary{font-family:var(--ff-grotesk);font-weight:700;font-size:1.08rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:1rem;align-items:center;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{content:"–";color:var(--crown-deep);font-weight:900;font-size:1.3em;}
.faq-item p{margin:.8rem 0 0;color:var(--heartwood);}

/* ---------- external backlink ---------- */
.backlink{font-family:var(--ff-grotesk);font-weight:700;font-size:.92rem;display:inline-flex;align-items:center;gap:.4em;}
.backlink::after{content:"↗";}

/* ---------- quote section (homepage conversion block) ---------- */
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}
.quote{background:var(--bark);color:var(--cream);scroll-margin-top:84px;}
.quote .wrap{padding-block:clamp(48px,7vw,92px);}
.quote-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px);align-items:start;}
.quote-grid > *{min-width:0;}

/* left rail — value prop + what-happens-next + phone path */
.quote-intro .eyebrow{color:var(--crown);}
.quote-intro h2{font-family:var(--ff-display);font-weight:400;font-size:clamp(2.1rem,4.4vw,3.2rem);line-height:.96;color:var(--cream);margin:.3em 0 .5em;}
.quote-intro .lede{color:var(--sawdust);max-width:42ch;}
.quote-steps{counter-reset:qs;list-style:none;margin:1.7rem 0 0;padding:0;display:grid;gap:1.05rem;}
.quote-steps li{position:relative;padding-left:3.1rem;min-height:2.3rem;display:flex;flex-direction:column;justify-content:center;}
.quote-steps li::before{counter-increment:qs;content:counter(qs);position:absolute;left:0;top:0;width:2.3rem;height:2.3rem;border-radius:50%;background:var(--crown);color:#2C1D0E;font-family:var(--ff-grotesk);font-weight:800;display:flex;align-items:center;justify-content:center;}
.quote-steps li b{font-family:var(--ff-grotesk);font-weight:800;color:var(--cream);display:block;font-size:1.02rem;}
.quote-steps li span{color:var(--sawdust);font-size:.95rem;line-height:1.45;}
.quote-phone{margin-top:1.9rem;padding-top:1.5rem;border-top:1px solid var(--pine-line);}
.quote-phone .pp-label{font-family:var(--ff-grotesk);font-weight:700;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sawdust);margin:0 0 .5rem;}
.quote-phone a.tel{font-family:var(--ff-display);font-weight:400;font-size:clamp(1.7rem,3vw,2.2rem);color:var(--crown);letter-spacing:.01em;}
.quote-phone a.tel:hover{color:var(--cream);text-decoration:none;}
.quote-phone .pp-note{font-size:.92rem;color:var(--sawdust);margin:.45rem 0 0;}

/* right rail — the form card */
.quote-card{background:var(--cream);color:var(--ink);border-radius:var(--r-lg);padding:clamp(1.4rem,3vw,2rem);box-shadow:var(--shadow-pop);position:relative;}
.quote-card h3{font-family:var(--ff-grotesk);font-weight:800;font-size:1.3rem;margin:0 0 .25rem;color:var(--bark);}
.quote-card .card-sub{font-size:.95rem;color:var(--heartwood);margin:0 0 1.3rem;}
.qform{display:grid;gap:1rem;}
.qform .field{display:flex;flex-direction:column;gap:.35rem;}
.qform .row-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.qform label{font-family:var(--ff-grotesk);font-weight:700;font-size:.86rem;color:var(--bark);}
.qform label .opt{font-weight:600;color:var(--heartwood);letter-spacing:0;text-transform:none;font-size:.82rem;}
.qform label .req{color:var(--crown-deep);}
.qform input,.qform select,.qform textarea{
  font-family:var(--ff-body);font-size:1rem;color:var(--ink);
  background:#fff;border:1.5px solid var(--rule);border-radius:var(--r-sm);
  padding:.7rem .85rem;min-height:48px;width:100%;
  transition:border-color .14s ease, box-shadow .14s ease;
}
.qform textarea{min-height:88px;resize:vertical;line-height:1.5;}
.qform select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23A06F1F' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .85rem center;padding-right:2.4rem;}
.qform input::placeholder,.qform textarea::placeholder{color:#a99a82;}
.qform input:focus,.qform select:focus,.qform textarea:focus{outline:none;border-color:var(--crown);box-shadow:0 0 0 3px rgba(198,138,46,.28);}
.qform input:user-invalid,.qform select:user-invalid{border-color:var(--crown-deep);}
.qform .hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;}
.qform .btn{width:100%;justify-content:center;font-size:1.06rem;padding:1.02em 1.4em;}
.qform .consent{font-size:.8rem;line-height:1.45;color:var(--heartwood);margin:0;}
.qform .consent a{color:var(--crown-deep);text-decoration:underline;}
.form-error{display:none;font-size:.9rem;font-weight:700;font-family:var(--ff-grotesk);color:#fff;background:#9a3324;border-radius:var(--r-sm);padding:.7rem .9rem;}
.qform.has-error .form-error{display:block;}
/* success state */
.quote-success{display:none;text-align:center;padding:1.5rem .5rem 1rem;}
.quote-card.is-done .qform{display:none;}
.quote-card.is-done .quote-success{display:block;}
.quote-success .check{width:64px;height:64px;border-radius:50%;background:var(--pine);color:var(--cream);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-size:2rem;font-weight:900;}
.quote-success h3{font-size:1.45rem;margin-bottom:.4rem;}
.quote-success p{color:var(--heartwood);max-width:34ch;margin-inline:auto;}
.quote-success .tel{font-family:var(--ff-grotesk);font-weight:800;color:var(--crown-deep);}

@media (max-width:1024px){
  .quote-grid{grid-template-columns:1fr;gap:36px;}
}
@media (max-width:640px){
  .qform .row-2{grid-template-columns:1fr;}
}

/* ---------- final CTA ---------- */
.final-cta{background:var(--bark);color:var(--cream);text-align:center;}
.final-cta .wrap{padding-block:clamp(48px,7vw,88px);}
.final-cta h2{font-family:var(--ff-display);font-weight:400;font-size:clamp(2rem,4.5vw,3.3rem);color:var(--cream);}
.final-cta p{color:var(--sawdust);max-width:46ch;margin-inline:auto;}
.final-cta .cta-row{display:flex;flex-wrap:wrap;gap:.9rem;justify-content:center;margin-top:1.6rem;}

/* ---------- footer ---------- */
.site-footer{background:#241a12;color:var(--sawdust);}
.site-footer .wrap{padding-block:clamp(40px,5.5vw,68px);}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(24px,4vw,56px);}
.footer-top .ksg-logo .k{color:var(--cream);}
.footer-top .ksg-logo .s{color:var(--sawdust);}
.site-footer h4{font-family:var(--ff-grotesk);font-weight:800;font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;color:var(--crown);margin:0 0 .9rem;}
.site-footer ul{list-style:none;margin:0;padding:0;}
.site-footer li{padding:.3rem 0;}
.site-footer a{color:var(--sawdust);font-size:.96rem;}
.site-footer a:hover{color:var(--cream);}
.footer-nap{font-size:.96rem;line-height:1.7;margin-top:1rem;color:var(--sawdust);}
.footer-bottom{border-top:1px solid #3a2c1f;margin-top:2.2rem;padding-top:1.3rem;display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;font-size:.85rem;color:#a8967c;}
.footer-bottom span{color:#a8967c;}
.placeholder{color:var(--crown);font-style:italic;}

/* ---------- responsive ---------- */
@media (max-width:1024px){
  .page-hero .wrap{grid-template-columns:1fr;}
  .content-grid{grid-template-columns:1fr;}
  .aside{position:static;}
  .footer-top{grid-template-columns:1fr 1fr;}
  /* collapse nav to hamburger on tablet & below (full desktop nav needs >1024) */
  .header-phone{display:none;}
  .nav-toggle{display:inline-flex;}
  .nav{
    display:none;position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:var(--cream);border-bottom:1px solid var(--rule);
    box-shadow:0 14px 28px rgba(46,33,24,.14);padding:.4rem 0;
  }
  .site-header.menu-open .nav{display:flex;}
  .nav a{padding:.9rem var(--gutter);border-bottom:1px solid var(--rule-soft);font-size:1.05rem;}
  .nav a:last-child{border-bottom:none;}
}
@media (max-width:640px){
  .footer-top{grid-template-columns:1fr;}
  .hero h1{font-size:clamp(2.4rem,11vw,3.4rem);}
  .page-hero .wrap,.content-grid{gap:28px;}
  .secondary-cats{grid-template-columns:1fr;}
  /* header fits small screens: full lockup down to 520px, then mark only */
  .site-logo{height:56px;}
  .site-footer .site-logo{height:58px;}
  .site-header .wrap{gap:.5rem;}
  .header-cta{gap:.5rem;}
  .header-cta .btn-gold{padding:.72em 1.05em;font-size:.92rem;}
  /* spec-table labels wrap on mobile so the grid track can shrink */
  .spec-table td:first-child{white-space:normal;}
}

@media (max-width:520px){
  /* tightest phones: swap the wordmark lockup for the mark alone */
  .logo-full{display:none;}
  .logo-mark{display:block;height:50px;width:50px;}
}

@media (prefers-reduced-motion:no-preference){
  .svc-card{transition:transform .12s ease, box-shadow .15s ease;}
}

/* =====================================================================
   TWEAKS — expressive controls (index.html only; attrs live on <html>)
   Defaults (bark / editorial / confident) = base styles above, no override.
   ===================================================================== */

/* 1 · Surface mood — recolor the warm dark surfaces */
[data-mood="pine"] .hero,
[data-mood="pine"] .quote,
[data-mood="pine"] .site-footer{background:#22382B;}
[data-mood="midnight"] .hero,
[data-mood="midnight"] .quote,
[data-mood="midnight"] .site-footer{background:#191310;}
[data-mood="midnight"] .hero .bg-mark{opacity:.075;}

/* 2 · Headline impact — Billboard cranks scale / case / leading */
[data-impact="billboard"] .hero .eyebrow{letter-spacing:.3em;}
[data-impact="billboard"] .hero h1{font-size:clamp(2.7rem,7vw,5.4rem);line-height:1;letter-spacing:.006em;text-transform:uppercase;max-width:20ch;margin-bottom:.3em;}
[data-impact="billboard"] .hero h1 .gold{display:block;}
[data-impact="billboard"] .cluster-head h2,
[data-impact="billboard"] .section-head h2,
[data-impact="billboard"] .quote-intro h2{font-family:var(--ff-display);font-weight:400;letter-spacing:.012em;text-transform:uppercase;line-height:.96;}
[data-impact="billboard"] .section-head h2{font-size:clamp(2rem,4.3vw,3.1rem);}
[data-impact="billboard"] .cluster-head h2{font-size:clamp(1.9rem,3.6vw,2.8rem);}

/* 3 · Gold accent — Restrained pulls gold back; Bold pushes it forward */
[data-accent="restrained"] .hero h1 .gold{color:var(--cream);}
[data-accent="restrained"] .eyebrow{color:var(--heartwood);}
[data-accent="restrained"] .hero .eyebrow,
[data-accent="restrained"] .section.pine .eyebrow{color:var(--sawdust);}
[data-accent="restrained"] .trust-strip,
[data-accent="restrained"] .trust-strip li::before,
[data-accent="restrained"] .chip::before{color:var(--heartwood);}

[data-accent="bold"] .hero h1 .gold{text-decoration:underline;text-decoration-color:var(--crown);text-decoration-thickness:5px;text-underline-offset:7px;}
[data-accent="bold"] .section-head h2{border-left:5px solid var(--crown);padding-left:.5em;}
[data-accent="bold"] .cluster-head .count{color:var(--crown-deep);}
[data-accent="bold"] .svc-card .more{color:var(--crown-deep);}
[data-accent="bold"] .cluster-intro a{text-decoration:underline;text-decoration-color:var(--crown);}

/* ---- the Tweaks panel itself ---- */
#tweaks-panel{position:fixed;right:18px;bottom:18px;z-index:1000;width:270px;background:var(--bark);color:var(--cream);border:1px solid var(--pine-line);border-radius:14px;box-shadow:0 18px 50px rgba(0,0,0,.42);padding:14px 15px 16px;font-family:var(--ff-grotesk);}
#tweaks-panel[hidden]{display:none;}
#tweaks-panel .tw-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:13px;}
#tweaks-panel .tw-head span{font-weight:800;letter-spacing:.04em;font-size:1rem;}
#tw-close{background:transparent;border:none;color:var(--sawdust);font-size:1rem;cursor:pointer;width:30px;height:30px;border-radius:7px;line-height:1;}
#tw-close:hover{background:rgba(255,255,255,.08);color:var(--cream);}
#tweaks-panel .tw-group{margin-bottom:13px;}
#tweaks-panel .tw-group:last-child{margin-bottom:0;}
#tweaks-panel .tw-label{display:block;font-size:.7rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--sawdust);margin-bottom:7px;}
#tweaks-panel .tw-seg{display:flex;gap:4px;background:rgba(0,0,0,.26);border-radius:9px;padding:3px;}
#tweaks-panel .tw-seg button{flex:1;min-width:0;font-family:var(--ff-grotesk);font-weight:700;font-size:.78rem;color:var(--sawdust);background:transparent;border:none;border-radius:6px;padding:8px 4px;cursor:pointer;transition:background .12s ease,color .12s ease;}
#tweaks-panel .tw-seg button:hover{color:var(--cream);}
#tweaks-panel .tw-seg button[aria-pressed="true"]{background:var(--crown);color:#2C1D0E;}
@media (max-width:520px){
  #tweaks-panel{right:10px;left:10px;bottom:10px;width:auto;}
}
