/* ============================================================
   Tree Removal Permit Hub — Design System
   Field Guide / Forest Service aesthetic
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400&family=Source+Sans+3:wght@300;400;600;700&family=Source+Code+Pro:wght@400;600&display=swap');

/* ── Variables ──────────────────────────────────────────── */
:root {
  --bg:          #F4EFE4;
  --bg-dark:     #EAE3CF;
  --bg-card:     #FDFAF4;
  --forest:      #1C3829;
  --forest-mid:  #2D5540;
  --forest-lite: #3D6B50;
  --green:       #3D8B5E;
  --sage:        #7CB999;
  --sage-lite:   #B8DEC9;
  --gold:        #C8882A;
  --gold-lite:   #E8A84A;
  --bark:        #6B4C2A;
  --text:        #2A2222;
  --text-mid:    #4A3F3F;
  --text-lite:   #7A6F6F;
  --border:      #D4C4A0;
  --border-lite: #E8DFC5;
  --white:       #FFFFFF;
  --red-warn:    #C0392B;

  --font-head: 'Playfair Display', Georgia, serif;
  --font-body: 'Source Sans 3', system-ui, sans-serif;
  --font-mono: 'Source Code Pro', monospace;

  --r-sm: 4px;
  --r-md: 8px;
  --r-lg: 14px;

  --shadow-sm: 0 1px 4px rgba(28,56,41,.08);
  --shadow-md: 0 4px 16px rgba(28,56,41,.12);
  --shadow-lg: 0 8px 32px rgba(28,56,41,.16);

  --max-w: 1080px;
  --content-w: 760px;
  --sidebar-w: 280px;
}

/* ── Reset ──────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--text);
  line-height: 1.7;
  min-height: 100vh;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--green); text-decoration: underline; text-underline-offset: 3px; }
a:hover { color: var(--forest); }
ul, ol { padding-left: 1.4em; }
li { margin-bottom: .35em; }

/* ── Typography ─────────────────────────────────────────── */
h1, h2, h3, h4, h5 {
  font-family: var(--font-head);
  line-height: 1.25;
  color: var(--forest);
}
h1 { font-size: clamp(1.8rem, 4vw, 2.6rem); font-weight: 700; margin-bottom: .6rem; }
h2 { font-size: clamp(1.4rem, 3vw, 1.9rem); font-weight: 600; margin: 2rem 0 .8rem; }
h3 { font-size: clamp(1.1rem, 2.5vw, 1.35rem); font-weight: 600; margin: 1.6rem 0 .5rem; }
h4 { font-size: 1.05rem; font-weight: 600; margin: 1.2rem 0 .4rem; }
p  { margin-bottom: 1rem; }
strong { font-weight: 700; color: var(--text); }

/* ── Header ─────────────────────────────────────────────── */
#site-header {
  background: var(--forest);
  padding: 0;
  position: sticky;
  top: 0;
  z-index: 100;
  box-shadow: 0 2px 12px rgba(0,0,0,.25);
}
.header-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
  gap: 1rem;
}
.site-logo {
  display: flex;
  align-items: center;
  gap: .65rem;
  text-decoration: none;
  flex-shrink: 0;
}
.logo-icon {
  width: 38px;
  height: 38px;
  flex-shrink: 0;
}
.logo-text {
  font-family: var(--font-head);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--bg);
  line-height: 1.2;
  letter-spacing: -.01em;
}
.logo-text span {
  display: block;
  font-weight: 300;
  font-size: .75rem;
  color: var(--sage);
  letter-spacing: .06em;
  font-family: var(--font-body);
  text-transform: uppercase;
}
#site-nav {
  display: flex;
  align-items: center;
  gap: .15rem;
}
#site-nav a {
  color: var(--sage-lite);
  text-decoration: none;
  font-size: .875rem;
  font-weight: 600;
  letter-spacing: .02em;
  padding: .45rem .75rem;
  border-radius: var(--r-sm);
  transition: background .15s, color .15s;
  white-space: nowrap;
}
#site-nav a:hover, #site-nav a.active {
  background: var(--forest-lite);
  color: var(--white);
}
#site-nav .nav-cta {
  background: var(--gold);
  color: var(--white) !important;
  padding: .45rem .9rem;
  border-radius: var(--r-sm);
  margin-left: .35rem;
}
#site-nav .nav-cta:hover { background: var(--gold-lite); }

.hamburger {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: .4rem;
  flex-direction: column;
  gap: 5px;
}
.hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--sage-lite);
  transition: .2s;
}

/* ── Page hero ──────────────────────────────────────────── */
.hero {
  background: linear-gradient(135deg, var(--forest) 0%, var(--forest-mid) 60%, var(--forest-lite) 100%);
  padding: 4rem 1.5rem 3.5rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 20% 80%, rgba(61,139,94,.18) 0%, transparent 50%),
    radial-gradient(circle at 80% 20%, rgba(124,185,153,.12) 0%, transparent 40%);
}
.hero > * { position: relative; }
.hero h1 { color: var(--white); margin-bottom: .75rem; }
.hero .subtitle {
  color: var(--sage-lite);
  font-size: 1.15rem;
  max-width: 580px;
  margin: 0 auto 2rem;
  font-weight: 300;
}
.hero-badges {
  display: flex;
  gap: .5rem;
  justify-content: center;
  flex-wrap: wrap;
}
.badge {
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.2);
  color: var(--sage-lite);
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
  padding: .3rem .75rem;
  border-radius: 20px;
}

/* ── Breadcrumb ─────────────────────────────────────────── */
.breadcrumb-bar {
  background: var(--bg-dark);
  border-bottom: 1px solid var(--border);
  padding: .55rem 1.5rem;
}
.breadcrumb {
  max-width: var(--max-w);
  margin: 0 auto;
  font-size: .82rem;
  color: var(--text-lite);
  display: flex;
  gap: .4rem;
  align-items: center;
  flex-wrap: wrap;
}
.breadcrumb a { color: var(--green); text-decoration: none; }
.breadcrumb a:hover { text-decoration: underline; }
.breadcrumb .sep { color: var(--border); }

/* ── Quick Answer Box ───────────────────────────────────── */
.quick-answer {
  background: var(--forest);
  color: var(--white);
  border-radius: var(--r-lg);
  padding: 1.4rem 1.8rem;
  margin: 1.5rem 0 2rem;
  border-left: 5px solid var(--gold);
}
.quick-answer .qa-label {
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--gold-lite);
  margin-bottom: .4rem;
}
.quick-answer p {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 600;
  line-height: 1.5;
  color: var(--sage-lite);
}
.quick-answer p strong { color: var(--white); }

/* ── Main layout ────────────────────────────────────────── */
.page-wrap {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 2.5rem 1.5rem 4rem;
}
.content-with-sidebar {
  display: grid;
  grid-template-columns: 1fr var(--sidebar-w);
  gap: 3rem;
  align-items: start;
}
.main-content { min-width: 0; }
.sidebar { position: sticky; top: 80px; }

/* ── Cards ──────────────────────────────────────────────── */
.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1.25rem;
  margin: 1.5rem 0 2rem;
}
.card {
  background: var(--bg-card);
  border: 1px solid var(--border-lite);
  border-radius: var(--r-lg);
  padding: 1.4rem 1.6rem;
  text-decoration: none;
  color: var(--text);
  transition: box-shadow .2s, transform .2s, border-color .2s;
  display: block;
  box-shadow: var(--shadow-sm);
}
.card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
  border-color: var(--sage);
  color: var(--text);
  text-decoration: none;
}
.card-icon {
  font-size: 1.6rem;
  margin-bottom: .6rem;
  display: block;
}
.card h3 {
  font-size: 1rem;
  margin: 0 0 .4rem;
  color: var(--forest);
}
.card p {
  font-size: .88rem;
  color: var(--text-mid);
  margin: 0;
  line-height: 1.5;
}
.card .card-meta {
  font-size: .75rem;
  color: var(--sage);
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  margin-top: .75rem;
  display: flex;
  align-items: center;
  gap: .3rem;
}

/* ── Info boxes ─────────────────────────────────────────── */
.info-box {
  border-radius: var(--r-md);
  padding: 1.2rem 1.5rem;
  margin: 1.5rem 0;
}
.info-box.green  { background: #EAF5EE; border-left: 4px solid var(--green); }
.info-box.gold   { background: #FBF3E4; border-left: 4px solid var(--gold); }
.info-box.red    { background: #FBE9E7; border-left: 4px solid var(--red-warn); }
.info-box.bark   { background: #F5EDE4; border-left: 4px solid var(--bark); }
.info-box p { margin: 0; font-size: .95rem; }
.info-box .box-label {
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-bottom: .4rem;
}
.info-box.green  .box-label { color: var(--green); }
.info-box.gold   .box-label { color: var(--gold); }
.info-box.red    .box-label { color: var(--red-warn); }
.info-box.bark   .box-label { color: var(--bark); }

/* ── Tables ─────────────────────────────────────────────── */
.data-table-wrap { overflow-x: auto; margin: 1.5rem 0; border-radius: var(--r-md); box-shadow: var(--shadow-sm); }
.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .9rem;
  background: var(--bg-card);
  border-radius: var(--r-md);
  overflow: hidden;
}
.data-table th {
  background: var(--forest);
  color: var(--white);
  font-family: var(--font-body);
  font-weight: 700;
  font-size: .8rem;
  letter-spacing: .05em;
  text-transform: uppercase;
  text-align: left;
  padding: .75rem 1rem;
}
.data-table td {
  padding: .7rem 1rem;
  border-bottom: 1px solid var(--border-lite);
  vertical-align: top;
}
.data-table tr:last-child td { border-bottom: none; }
.data-table tr:nth-child(even) td { background: var(--bg); }
.data-table .yes { color: var(--green); font-weight: 700; }
.data-table .no  { color: var(--text-lite); }
.data-table .varies { color: var(--gold); font-weight: 600; }

/* ── FAQ ─────────────────────────────────────────────────── */
.faq-section { margin: 2.5rem 0; }
.faq-section > h2 { margin-bottom: 1rem; }
.faq-item {
  border: 1px solid var(--border-lite);
  border-radius: var(--r-md);
  margin-bottom: .6rem;
  background: var(--bg-card);
  overflow: hidden;
}
.faq-q {
  width: 100%;
  text-align: left;
  background: none;
  border: none;
  padding: 1rem 1.2rem;
  font-family: var(--font-head);
  font-size: 1rem;
  font-weight: 600;
  color: var(--forest);
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  transition: background .15s;
}
.faq-q:hover { background: var(--bg-dark); }
.faq-q .faq-arrow {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  border-radius: 50%;
  background: var(--sage-lite);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .8rem;
  transition: transform .25s, background .15s;
  color: var(--forest);
}
.faq-q.open .faq-arrow { transform: rotate(180deg); background: var(--green); color: var(--white); }
.faq-a {
  display: none;
  padding: 0 1.2rem 1.1rem;
  font-size: .95rem;
  color: var(--text-mid);
  border-top: 1px solid var(--border-lite);
}
.faq-a p { margin-bottom: .5rem; }
.faq-a p:last-child { margin-bottom: 0; }
.faq-a.open { display: block; }

/* ── Sidebar widgets ─────────────────────────────────────── */
.sidebar-widget {
  background: var(--bg-card);
  border: 1px solid var(--border-lite);
  border-radius: var(--r-lg);
  padding: 1.25rem 1.35rem;
  margin-bottom: 1.5rem;
  box-shadow: var(--shadow-sm);
}
.sidebar-widget h4 {
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--text-lite);
  margin: 0 0 .9rem;
  padding-bottom: .6rem;
  border-bottom: 1px solid var(--border-lite);
}
.sidebar-widget ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.sidebar-widget ul li {
  margin: 0;
  border-bottom: 1px solid var(--border-lite);
}
.sidebar-widget ul li:last-child { border-bottom: none; }
.sidebar-widget ul li a {
  display: block;
  padding: .45rem 0;
  font-size: .9rem;
  color: var(--text-mid);
  text-decoration: none;
  transition: color .15s;
}
.sidebar-widget ul li a:hover { color: var(--green); }
.sidebar-tool-cta {
  background: var(--forest);
  color: var(--white);
  border-radius: var(--r-lg);
  padding: 1.4rem 1.35rem;
  margin-bottom: 1.5rem;
  text-align: center;
}
.sidebar-tool-cta p {
  color: var(--sage-lite);
  font-size: .9rem;
  margin-bottom: 1rem;
}
.btn {
  display: inline-block;
  padding: .65rem 1.4rem;
  border-radius: var(--r-sm);
  font-weight: 700;
  font-size: .9rem;
  text-decoration: none;
  text-align: center;
  cursor: pointer;
  border: none;
  transition: background .15s, transform .1s;
  letter-spacing: .02em;
}
.btn:active { transform: scale(.98); }
.btn-primary   { background: var(--green); color: var(--white); }
.btn-primary:hover { background: var(--forest-lite); color: var(--white); text-decoration: none; }
.btn-gold      { background: var(--gold); color: var(--white); }
.btn-gold:hover { background: var(--gold-lite); color: var(--white); text-decoration: none; }
.btn-outline   { background: transparent; border: 2px solid var(--green); color: var(--green); }
.btn-outline:hover { background: var(--green); color: var(--white); text-decoration: none; }
.btn-white     { background: var(--white); color: var(--forest); }
.btn-white:hover { background: var(--sage-lite); color: var(--forest); text-decoration: none; }
.btn-block { display: block; width: 100%; }

/* ── Step list ───────────────────────────────────────────── */
.step-list { list-style: none; padding: 0; counter-reset: steps; }
.step-list li {
  counter-increment: steps;
  display: flex;
  gap: 1rem;
  margin-bottom: 1.25rem;
  align-items: flex-start;
}
.step-list li::before {
  content: counter(steps);
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--forest);
  color: var(--white);
  font-weight: 700;
  font-size: .9rem;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: .1rem;
}
.step-list li .step-content { flex: 1; }
.step-list li strong { display: block; margin-bottom: .2rem; color: var(--forest); }

/* ── Cost table / spec grid ──────────────────────────────── */
.spec-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--border-lite);
  border-radius: var(--r-md);
  overflow: hidden;
  margin: 1.5rem 0;
  box-shadow: var(--shadow-sm);
}
.spec-item {
  background: var(--bg-card);
  padding: .9rem 1.2rem;
}
.spec-label {
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--text-lite);
  margin-bottom: .3rem;
}
.spec-value {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--forest);
}
.spec-value.good  { color: var(--green); }
.spec-value.warn  { color: var(--gold); }
.spec-value.alert { color: var(--red-warn); }

/* ── Tool / Wizard ───────────────────────────────────────── */
.tool-wrap {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  margin: 2rem 0;
}
.tool-header {
  background: var(--forest);
  padding: 1.4rem 2rem;
  color: var(--white);
}
.tool-header h2 { color: var(--white); margin: 0 0 .3rem; font-size: 1.3rem; }
.tool-header p  { color: var(--sage-lite); margin: 0; font-size: .9rem; }
.tool-body { padding: 2rem; }
.wizard-step { display: none; }
.wizard-step.active { display: block; }
.wizard-progress {
  display: flex;
  gap: .4rem;
  margin-bottom: 2rem;
}
.wizard-progress .pip {
  flex: 1;
  height: 4px;
  background: var(--border);
  border-radius: 2px;
  transition: background .3s;
}
.wizard-progress .pip.done { background: var(--green); }
.wizard-progress .pip.active { background: var(--gold); }
.wizard-label {
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--text-lite);
  margin-bottom: .6rem;
}
.wizard-q {
  font-family: var(--font-head);
  font-size: 1.2rem;
  color: var(--forest);
  margin-bottom: 1.4rem;
  font-weight: 600;
}
.option-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: .75rem;
  margin-bottom: 1.5rem;
}
.option-btn {
  background: var(--bg);
  border: 2px solid var(--border);
  border-radius: var(--r-md);
  padding: .9rem 1rem;
  text-align: left;
  cursor: pointer;
  font-family: var(--font-body);
  font-size: .9rem;
  color: var(--text);
  transition: border-color .15s, background .15s;
  font-weight: 600;
}
.option-btn:hover, .option-btn.selected {
  border-color: var(--green);
  background: #EAF5EE;
  color: var(--forest);
}
.option-btn .opt-sub {
  display: block;
  font-weight: 400;
  font-size: .8rem;
  color: var(--text-lite);
  margin-top: .2rem;
}
.wizard-result {
  background: var(--bg);
  border-radius: var(--r-lg);
  padding: 1.6rem 2rem;
  border: 2px solid var(--border);
}
.result-verdict {
  font-family: var(--font-head);
  font-size: 1.5rem;
  font-weight: 700;
  margin-bottom: .5rem;
}
.result-verdict.likely-yes  { color: var(--red-warn); }
.result-verdict.likely-no   { color: var(--green); }
.result-verdict.depends     { color: var(--gold); }
.wizard-nav { display: flex; gap: .75rem; justify-content: flex-end; margin-top: 1.5rem; }
select.wizard-select {
  width: 100%;
  padding: .7rem 1rem;
  border: 2px solid var(--border);
  border-radius: var(--r-md);
  background: var(--bg);
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--text);
  margin-bottom: 1.2rem;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%233D8B5E' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  cursor: pointer;
}
select.wizard-select:focus { outline: none; border-color: var(--green); }

/* ── Homepage feature strips ─────────────────────────────── */
.section-label {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: .4rem;
  display: block;
}
.feature-strip {
  background: var(--forest);
  padding: 3rem 1.5rem;
  text-align: center;
  color: var(--white);
  margin: 3rem 0;
}
.feature-strip h2 { color: var(--white); }
.feature-strip p  { color: var(--sage-lite); max-width: 540px; margin: .5rem auto 1.5rem; }
.stat-row {
  display: flex;
  justify-content: center;
  gap: 3rem;
  flex-wrap: wrap;
  margin: 2rem 0 0;
}
.stat-item { text-align: center; }
.stat-num {
  font-family: var(--font-head);
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--gold-lite);
  line-height: 1;
}
.stat-label {
  font-size: .82rem;
  color: var(--sage-lite);
  margin-top: .25rem;
}

/* ── Disclaimer ─────────────────────────────────────────── */
.disclaimer {
  background: var(--bg-dark);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 1rem 1.3rem;
  font-size: .82rem;
  color: var(--text-lite);
  margin: 2rem 0;
  line-height: 1.5;
}
.disclaimer strong { color: var(--text-mid); }

/* ── Footer ─────────────────────────────────────────────── */
#site-footer {
  background: var(--forest);
  color: var(--sage-lite);
  padding: 3rem 1.5rem 1.5rem;
  margin-top: 4rem;
}
.footer-inner {
  max-width: var(--max-w);
  margin: 0 auto;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 2.5rem;
  margin-bottom: 2rem;
}
.footer-brand .logo-text { color: var(--bg); }
.footer-brand .logo-text span { color: var(--sage); }
.footer-brand p {
  font-size: .85rem;
  color: rgba(180,215,196,.7);
  margin-top: .8rem;
  line-height: 1.6;
}
.footer-col h5 {
  font-family: var(--font-body);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--sage);
  margin-bottom: .9rem;
}
.footer-col ul { list-style: none; padding: 0; }
.footer-col li { margin-bottom: .4rem; }
.footer-col a {
  color: rgba(180,215,196,.7);
  text-decoration: none;
  font-size: .875rem;
  transition: color .15s;
}
.footer-col a:hover { color: var(--white); }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.1);
  padding-top: 1.2rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: .75rem;
  font-size: .78rem;
  color: rgba(180,215,196,.5);
}
.footer-bottom a { color: rgba(180,215,196,.7); text-decoration: none; }
.footer-bottom a:hover { color: var(--white); }

/* ── Utility classes ─────────────────────────────────────── */
.text-center { text-align: center; }
.text-sm     { font-size: .875rem; }
.text-xs     { font-size: .78rem; }
.text-lite   { color: var(--text-lite); }
.text-gold   { color: var(--gold); }
.text-green  { color: var(--green); }
.mt-0 { margin-top: 0; }
.mb-0 { margin-bottom: 0; }
.mb-1 { margin-bottom: 1rem; }
.mb-2 { margin-bottom: 2rem; }
.tag {
  display: inline-block;
  background: var(--sage-lite);
  color: var(--forest);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  padding: .2rem .6rem;
  border-radius: 3px;
  margin-right: .3rem;
}
.tag.gold { background: #FDEBC7; color: var(--bark); }

/* ── Ads placeholder ─────────────────────────────────────── */
.ad-slot {
  display: block;
  background: var(--bg-dark);
  border: 1px dashed var(--border);
  border-radius: var(--r-sm);
  text-align: center;
  padding: 1rem;
  font-size: .75rem;
  color: var(--text-lite);
  margin: 1.5rem 0;
  min-height: 90px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 900px) {
  .content-with-sidebar {
    grid-template-columns: 1fr;
  }
  .sidebar { position: static; }
  .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
  }
}
@media (max-width: 640px) {
  #site-nav { display: none; flex-direction: column; position: absolute; top: 64px; left: 0; right: 0; background: var(--forest-mid); padding: 1rem 1.5rem; gap: .25rem; }
  #site-nav.open { display: flex; }
  #site-nav a { padding: .6rem .75rem; }
  .hamburger { display: flex; }
  .spec-grid { grid-template-columns: 1fr; }
  .option-grid { grid-template-columns: 1fr; }
  .stat-row { gap: 1.5rem; }
  .footer-grid { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; text-align: center; }
  .hero { padding: 2.5rem 1rem 2rem; }
  .page-wrap { padding: 1.5rem 1rem 3rem; }
}
