/* =========================================================================
   Interior Note — Design System
   Forest palette · all sans-serif · modern editorial grid
   ========================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@400;500;600;700;800&family=Hanken+Grotesk:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

:root{
  /* ---- Color ---- */
  --paper:        #F1F3F0;
  --paper-2:      #E9ECE6;
  --surface:      #FFFFFF;
  --ink:          #1C2A22;
  --ink-soft:     #3C4B42;
  --green:        #2C4233;
  --green-deep:   #1F3327;
  --sage:         #5E7261;
  --sage-soft:    #8A9A8C;
  --sand:         #C7B393;
  --sand-soft:    #E4DAC7;
  --sand-bg:      #EDE6D6;
  --line:         #DEDED7;
  --line-soft:    #E9E9E3;
  --danger:       #B25B43;

  /* ---- Type ---- */
  --display: 'Archivo', system-ui, sans-serif;
  --body: 'Hanken Grotesk', system-ui, sans-serif;

  /* ---- Layout ---- */
  --maxw: 1240px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 14px;
  --radius-sm: 9px;
  --radius-lg: 22px;

  --shadow-sm: 0 1px 2px rgba(28,42,34,.05), 0 2px 8px rgba(28,42,34,.04);
  --shadow-md: 0 4px 14px rgba(28,42,34,.08), 0 1px 3px rgba(28,42,34,.05);
  --shadow-lg: 0 18px 50px rgba(28,42,34,.14);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
input,textarea{ font-family:inherit; font-size:inherit; }
::selection{ background:var(--sand); color:var(--green-deep); }

/* ---- Typography ---- */
h1,h2,h3,h4{ font-family:var(--display); font-weight:700; line-height:1.06; letter-spacing:-0.02em; color:var(--ink); }
.eyebrow{
  font-family:var(--display);
  font-size:.72rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase;
  color:var(--sage);
}
.lede{ font-size:1.22rem; line-height:1.6; color:var(--ink-soft); font-weight:400; }
.balance{ text-wrap:balance; }
.pretty{ text-wrap:pretty; }

/* ---- Layout helpers ---- */
.wrap{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.wrap-wide{ max-width:1480px; margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:clamp(56px,8vw,104px); }
.section-tight{ padding-block:clamp(40px,5vw,64px); }
.divider{ height:1px; background:var(--line); border:0; }

/* =========================================================================
   Header / Nav
   ========================================================================= */
.site-header{
  position:sticky; top:0; z-index:60;
  background:color-mix(in srgb, var(--paper) 82%, transparent);
  backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex; align-items:center; gap:28px;
  height:68px;
}
.brand{ display:flex; align-items:center; gap:11px; margin-right:6px; }
.brand .mark{ width:34px; height:34px; flex:none; }
.brand .wordmark{
  font-family:var(--display); font-weight:700; font-size:1.18rem;
  letter-spacing:-0.03em; color:var(--ink);
}
.brand .wordmark b{ color:var(--sage); font-weight:700; }
.nav-links{ display:flex; align-items:center; gap:4px; margin-left:6px; }
.nav-links a{
  font-size:.94rem; font-weight:500; color:var(--ink-soft);
  padding:8px 13px; border-radius:8px; transition:.18s;
}
.nav-links a:hover{ background:var(--paper-2); color:var(--ink); }
.nav-links a.active{ color:var(--ink); font-weight:600; }
.nav-right{ margin-left:auto; display:flex; align-items:center; gap:8px; }
.icon-btn{
  width:40px; height:40px; border-radius:10px; display:grid; place-items:center;
  color:var(--ink-soft); transition:.18s; position:relative;
}
.icon-btn:hover{ background:var(--paper-2); color:var(--ink); }
.icon-btn .count{
  position:absolute; top:3px; right:3px; min-width:16px; height:16px; padding:0 4px;
  background:var(--green); color:#fff; font-size:.62rem; font-weight:700;
  border-radius:9px; display:none; place-items:center; font-family:var(--display);
}
.icon-btn .count.show{ display:grid; }
.nav-toggle{ display:none; }

/* ---- Buttons ---- */
.btn{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--display); font-weight:600; font-size:.95rem;
  padding:12px 22px; border-radius:11px; transition:.18s; white-space:nowrap;
  border:1px solid transparent;
}
.btn svg{ width:18px; height:18px; }
.btn-primary{ background:var(--green); color:#fff; }
.btn-primary:hover{ background:var(--green-deep); transform:translateY(-1px); box-shadow:var(--shadow-md); }
.btn-ghost{ background:transparent; border-color:var(--line); color:var(--ink); }
.btn-ghost:hover{ background:var(--surface); border-color:var(--sage-soft); }
.btn-sand{ background:var(--sand-bg); color:var(--green-deep); }
.btn-sand:hover{ background:var(--sand-soft); }
.btn-sm{ padding:9px 16px; font-size:.85rem; border-radius:9px; }
.btn-block{ width:100%; justify-content:center; }

/* ---- Chips / pills ---- */
.chip-row{ display:flex; flex-wrap:wrap; gap:9px; }
.chip{
  display:inline-flex; align-items:center; gap:7px;
  font-size:.85rem; font-weight:500; color:var(--ink-soft);
  padding:8px 15px; border-radius:999px; background:var(--surface);
  border:1px solid var(--line); transition:.16s; cursor:pointer;
}
.chip:hover{ border-color:var(--sage-soft); color:var(--ink); }
.chip svg{ width:15px; height:15px; opacity:.8; }
.chip.active{ background:var(--green); color:#fff; border-color:var(--green); }
.chip.active svg{ opacity:1; }

/* ---- Badges ---- */
.badge{
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--display); font-size:.72rem; font-weight:600; letter-spacing:.01em;
  padding:5px 10px; border-radius:7px; white-space:nowrap;
}
.badge svg{ width:13px; height:13px; }
.badge-renter{ background:#E3EBE0; color:#3A5640; }
.badge-size{ background:var(--sand-bg); color:#7B6535; }
.badge-cat{ background:var(--paper-2); color:var(--ink-soft); }
.badge-ghost{ background:rgba(255,255,255,.85); color:var(--green-deep); border:1px solid var(--line); }

/* =========================================================================
   Placeholder imagery (mood-toned)
   ========================================================================= */
.ph{
  position:relative; overflow:hidden; background:var(--sand-bg);
  display:grid; place-items:center;
}
.ph::after{
  content:attr(data-label);
  position:absolute; bottom:12px; left:13px;
  font-family:var(--display); font-size:.68rem; font-weight:600; letter-spacing:.08em;
  text-transform:uppercase; color:rgba(28,42,34,.42);
}
.ph .ph-glyph{ width:38px; height:38px; opacity:.32; color:var(--green-deep); }
.ph.tone-a{ background:linear-gradient(140deg,#E7E2D4,#D9D2BE); }
.ph.tone-b{ background:linear-gradient(140deg,#DDE4DC,#C7D2C6); }
.ph.tone-c{ background:linear-gradient(140deg,#E9E4DA,#D7CDB8); }
.ph.tone-d{ background:linear-gradient(140deg,#D6DCD7,#BFC9BE); }
.ph.tone-e{ background:linear-gradient(140deg,#EDE7D8,#E0D6C0); }
.ph.tone-ink{ background:linear-gradient(140deg,#33433A,#243029); }
.ph.tone-ink .ph-glyph{ color:#F1F3F0; opacity:.4; }
.ph.tone-ink::after{ color:rgba(241,243,240,.5); }

/* =========================================================================
   Cards
   ========================================================================= */
.card{
  display:flex; flex-direction:column;
  background:var(--surface); border:1px solid var(--line);
  border-radius:var(--radius); overflow:hidden; transition:.2s;
}
.card:hover{ transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:var(--line-soft); }
.card .card-media{ position:relative; aspect-ratio:4/3; }
.card .card-media .badge-stack{ position:absolute; top:11px; left:11px; display:flex; gap:6px; flex-wrap:wrap; }
.card .save-btn{
  position:absolute; top:10px; right:10px; width:36px; height:36px; border-radius:10px;
  background:rgba(255,255,255,.9); backdrop-filter:blur(6px); display:grid; place-items:center;
  color:var(--ink); transition:.16s;
}
.card .save-btn:hover{ background:#fff; transform:scale(1.06); }
.card .save-btn svg{ width:18px; height:18px; }
.card .save-btn.saved{ background:var(--green); color:#fff; }
.card .card-body{ padding:17px 18px 20px; display:flex; flex-direction:column; gap:9px; flex:1; }
.card .card-cat{ font-family:var(--display); font-size:.72rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--sage); }
.card .card-title{ font-size:1.12rem; line-height:1.22; letter-spacing:-0.01em; }
.card:hover .card-title{ color:var(--green); }
.card .card-meta{ margin-top:auto; display:flex; align-items:center; gap:10px; font-size:.82rem; color:var(--sage-soft); padding-top:4px; }
.card .card-meta .dot{ width:3px; height:3px; border-radius:50%; background:currentColor; }

/* =========================================================================
   Footer
   ========================================================================= */
.site-footer{ background:var(--green-deep); color:#D6DDD4; padding-block:64px 36px; margin-top:40px; }
.site-footer a{ color:#D6DDD4; }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; }
.site-footer .brand .wordmark{ color:#fff; }
.site-footer .brand .wordmark b{ color:var(--sand); }
.footer-about{ color:#A9B6A8; font-size:.94rem; max-width:34ch; margin-top:14px; }
.footer-col h4{ color:#fff; font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; margin-bottom:14px; }
.footer-col a{ display:block; color:#A9B6A8; font-size:.92rem; padding:5px 0; transition:.15s; }
.footer-col a:hover{ color:#fff; }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; gap:16px;
  margin-top:48px; padding-top:24px; border-top:1px solid rgba(255,255,255,.12);
  color:#8B9A8B; font-size:.84rem; flex-wrap:wrap; }

/* =========================================================================
   Newsletter strip
   ========================================================================= */
.news-strip{ background:var(--green); color:#fff; border-radius:var(--radius-lg); padding:clamp(32px,5vw,56px); position:relative; overflow:hidden; }
.news-strip .eyebrow{ color:var(--sand); }
.news-strip h2{ color:#fff; font-size:clamp(1.6rem,3vw,2.3rem); margin:10px 0 12px; }
.news-strip p{ color:#C7D2C6; max-width:46ch; }
.news-form{ display:flex; gap:10px; margin-top:24px; max-width:480px; flex-wrap:wrap; }
.news-form input{
  flex:1; min-width:200px; padding:14px 18px; border-radius:11px; border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.08); color:#fff; font-size:.98rem;
}
.news-form input::placeholder{ color:rgba(255,255,255,.6); }
.news-form input:focus{ outline:none; border-color:var(--sand); background:rgba(255,255,255,.14); }
.news-strip .floorplan-bg{ position:absolute; right:-40px; bottom:-60px; width:340px; opacity:.13; color:#fff; pointer-events:none; }

/* =========================================================================
   Before / After slider
   ========================================================================= */
.ba-slider{ position:relative; aspect-ratio:16/10; border-radius:var(--radius); overflow:hidden; user-select:none; cursor:ew-resize; border:1px solid var(--line); }
.ba-slider .ba-layer{ position:absolute; inset:0; }
.ba-slider .ba-after{ clip-path:inset(0 0 0 50%); }
.ba-slider .ba-label{ position:absolute; top:14px; font-family:var(--display); font-size:.7rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase; padding:5px 11px; border-radius:7px; background:rgba(28,42,34,.7); color:#fff; backdrop-filter:blur(4px); }
.ba-slider .ba-label.before{ left:14px; }
.ba-slider .ba-label.after{ right:14px; }
.ba-slider .ba-handle{ position:absolute; top:0; bottom:0; left:50%; width:3px; background:#fff; transform:translateX(-50%); box-shadow:0 0 0 1px rgba(28,42,34,.15); }
.ba-slider .ba-knob{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:46px; height:46px; border-radius:50%; background:#fff; box-shadow:var(--shadow-md); display:grid; place-items:center; color:var(--green); }
.ba-slider .ba-knob svg{ width:22px; height:22px; }

/* =========================================================================
   Checklist
   ========================================================================= */
.checklist{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:8px; }
.checklist-head{ display:flex; align-items:center; justify-content:space-between; padding:14px 16px 12px; }
.checklist-head .eyebrow{ color:var(--sage); }
.checklist-progress{ font-family:var(--display); font-size:.82rem; font-weight:600; color:var(--ink-soft); }
.checklist-item{
  display:flex; gap:13px; align-items:flex-start; padding:13px 16px; border-radius:10px; cursor:pointer; transition:.14s;
}
.checklist-item:hover{ background:var(--paper); }
.checklist-item .box{
  width:23px; height:23px; flex:none; border-radius:7px; border:2px solid var(--sage-soft);
  display:grid; place-items:center; transition:.16s; margin-top:1px; color:#fff;
}
.checklist-item .box svg{ width:14px; height:14px; opacity:0; transition:.16s; }
.checklist-item.done .box{ background:var(--green); border-color:var(--green); }
.checklist-item.done .box svg{ opacity:1; }
.checklist-item .ci-text{ font-size:1rem; line-height:1.5; color:var(--ink); transition:.16s; }
.checklist-item.done .ci-text{ color:var(--sage-soft); text-decoration:line-through; }
.checklist-bar{ height:6px; background:var(--paper-2); border-radius:6px; margin:4px 16px 14px; overflow:hidden; }
.checklist-bar > span{ display:block; height:100%; background:var(--green); border-radius:6px; transition:.35s ease; width:0; }

/* =========================================================================
   Product / budget cards
   ========================================================================= */
.product-card{ display:flex; gap:15px; align-items:center; padding:14px; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); transition:.18s; }
.product-card:hover{ border-color:var(--sage-soft); box-shadow:var(--shadow-sm); }
.product-card .p-thumb{ width:74px; height:74px; flex:none; border-radius:10px; }
.product-card .p-info{ flex:1; min-width:0; }
.product-card .p-tag{ font-size:.72rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--sage); font-family:var(--display); }
.product-card .p-name{ font-family:var(--display); font-weight:600; font-size:1rem; margin:2px 0 3px; }
.product-card .p-note{ font-size:.85rem; color:var(--sage-soft); }
.product-card .p-price{ font-family:var(--display); font-weight:700; font-size:1.05rem; color:var(--green); white-space:nowrap; }

.budget-bar{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:20px 22px; }
.budget-row{ display:flex; align-items:center; gap:12px; margin-bottom:12px; }
.budget-row:last-child{ margin-bottom:0; }
.budget-row .b-label{ width:120px; font-size:.88rem; color:var(--ink-soft); flex:none; }
.budget-row .b-track{ flex:1; height:10px; background:var(--paper-2); border-radius:6px; overflow:hidden; }
.budget-row .b-track > span{ display:block; height:100%; border-radius:6px; }
.budget-row .b-val{ width:64px; text-align:right; font-family:var(--display); font-weight:600; font-size:.9rem; flex:none; }

/* =========================================================================
   Filter sidebar (search page)
   ========================================================================= */
.facet{ border-bottom:1px solid var(--line); padding:18px 0; }
.facet:first-child{ padding-top:0; }
.facet h4{ font-family:var(--display); font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:13px; }
.facet-opt{ display:flex; align-items:center; gap:10px; padding:7px 0; cursor:pointer; font-size:.94rem; color:var(--ink-soft); }
.facet-opt:hover{ color:var(--ink); }
.facet-check{ width:20px; height:20px; border-radius:6px; border:2px solid var(--sage-soft); display:grid; place-items:center; color:#fff; transition:.14s; flex:none; }
.facet-check svg{ width:12px; height:12px; opacity:0; }
.facet-opt.on .facet-check{ background:var(--green); border-color:var(--green); }
.facet-opt.on .facet-check svg{ opacity:1; }
.facet-opt .opt-count{ margin-left:auto; font-size:.8rem; color:var(--sage-soft); }

.switch{ display:inline-flex; align-items:center; gap:11px; cursor:pointer; }
.switch .track{ width:42px; height:24px; border-radius:14px; background:var(--line); position:relative; transition:.18s; flex:none; }
.switch .track::after{ content:''; position:absolute; top:3px; left:3px; width:18px; height:18px; border-radius:50%; background:#fff; transition:.18s; box-shadow:var(--shadow-sm); }
.switch.on .track{ background:var(--green); }
.switch.on .track::after{ transform:translateX(18px); }

/* ---- Search input ---- */
.search-field{ display:flex; align-items:center; gap:11px; background:var(--surface); border:1px solid var(--line); border-radius:12px; padding:13px 17px; }
.search-field:focus-within{ border-color:var(--sage); box-shadow:0 0 0 3px rgba(94,114,97,.12); }
.search-field svg{ width:20px; height:20px; color:var(--sage); flex:none; }
.search-field input{ border:none; background:none; outline:none; flex:1; color:var(--ink); }

/* =========================================================================
   Article body
   ========================================================================= */
.article-body{ font-size:1.12rem; line-height:1.78; color:#283A30; }
.article-body > p{ margin-bottom:1.4em; }
.article-body h2{ font-size:clamp(1.5rem,2.6vw,2rem); margin:1.8em 0 .6em; }
.article-body h3{ font-size:1.32rem; margin:1.5em 0 .5em; }
.article-body ul,.article-body ol{ margin:0 0 1.4em 1.2em; }
.article-body li{ margin-bottom:.5em; }
.article-body blockquote{ border-left:3px solid var(--sand); padding:6px 0 6px 22px; margin:1.6em 0; font-size:1.28rem; line-height:1.5; color:var(--green); font-family:var(--display); font-weight:500; }
.article-body a.inline-link{ color:var(--green); text-decoration:underline; text-underline-offset:3px; text-decoration-color:var(--sand); }
.pull-tip{ background:var(--sand-bg); border-radius:var(--radius); padding:20px 24px; margin:1.8em 0; display:flex; gap:14px; }
.pull-tip svg{ width:24px; height:24px; flex:none; color:#7B6535; margin-top:2px; }
.pull-tip .t-label{ font-family:var(--display); font-weight:700; font-size:.95rem; color:#7B6535; display:block; margin-bottom:3px; }
.pull-tip p{ margin:0; font-size:1rem; color:#5C4F30; }

/* =========================================================================
   Toast
   ========================================================================= */
.toast{
  position:fixed; bottom:26px; left:50%; transform:translate(-50%,140%);
  background:var(--ink); color:#fff; padding:13px 22px; border-radius:12px;
  font-size:.92rem; font-weight:500; z-index:200; box-shadow:var(--shadow-lg);
  display:flex; align-items:center; gap:10px; transition:transform .35s cubic-bezier(.2,.9,.3,1);
}
.toast svg{ width:18px; height:18px; color:var(--sand); }
.toast.show{ transform:translate(-50%,0); }

/* =========================================================================
   Reveal on scroll
   ========================================================================= */
.reveal{ opacity:0; transform:translateY(18px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.3,1); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

/* =========================================================================
   Responsive
   ========================================================================= */
@media (max-width:980px){
  .footer-grid{ grid-template-columns:1fr 1fr; gap:32px; }
}
@media (max-width:820px){
  .nav-links{ display:none; }
  .nav-toggle{ display:grid; }
  .mobile-menu{ display:block; }
}
@media (max-width:560px){
  body{ font-size:16px; }
  .footer-grid{ grid-template-columns:1fr; }
  .footer-bottom{ flex-direction:column; align-items:flex-start; }
  .btn{ padding:11px 18px; }
}

/* ---- Mobile menu ---- */
.mobile-menu{
  display:none; position:fixed; inset:68px 0 0; z-index:55;
  background:var(--paper); padding:24px var(--gutter);
  transform:translateY(-110%); transition:transform .32s cubic-bezier(.3,.8,.3,1);
  border-top:1px solid var(--line);
}
.mobile-menu.open{ transform:translateY(0); }
.mobile-menu a{ display:block; font-family:var(--display); font-size:1.5rem; font-weight:600; padding:14px 0; border-bottom:1px solid var(--line); color:var(--ink); }
.mobile-menu .mm-cta{ margin-top:24px; }


/* Astro integration refinements */
html{overflow-x:hidden}body{min-height:100vh;overflow-x:hidden}.min-h-screen{min-height:100vh}.flex{display:flex}.flex-col{flex-direction:column}.flex-1{flex:1}.mobile-menu{display:none}.mobile-menu.open{display:block}.progress{position:fixed;top:0;left:0;height:3px;background:var(--sand);z-index:90;width:0}.article-body{font-size:1.08rem;line-height:1.82;color:var(--ink-soft)}.article-body :where(h2,h3,h4){color:var(--ink);scroll-margin-top:96px;margin-top:2.2em;margin-bottom:.75em}.article-body h2{font-size:clamp(1.65rem,3vw,2.25rem)}.article-body h3{font-size:clamp(1.28rem,2.2vw,1.65rem)}.article-body p,.article-body ul,.article-body ol,.article-body table,.article-body figure{margin:1.15rem 0}.article-body a{color:var(--green);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:.18em}.article-body img{border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow-md);width:100%;height:auto}.article-body table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:table}.article-body th{background:var(--green);color:#fff}.article-body th,.article-body td{padding:.85rem;border:1px solid var(--line);text-align:left}.article-body blockquote{border-left:4px solid var(--sage);padding-left:1rem;color:var(--ink);background:var(--sand-bg);padding-block:.5rem}.article-body .comparison-table{font-size:.95rem}.related-grid-simple{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.meta-pill{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);border-radius:999px;padding:7px 12px;background:var(--surface);font-size:.82rem;color:var(--ink-soft);font-weight:600}.card a{display:block}.card-media img{width:100%;height:100%;object-fit:cover}.search-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(20px,3vw,32px);box-shadow:var(--shadow-sm)}.skip-link{position:absolute;left:-999px;top:10px;background:var(--green);color:#fff;padding:10px 14px;z-index:100}.skip-link:focus{left:10px}.footer-mark{width:46px;height:46px}.in-sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media(max-width:760px){.nav-toggle{display:grid}.nav-links{display:none}.site-header .btn{display:none}.mobile-menu{position:fixed;inset:68px 12px auto 12px;z-index:70;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:14px}.mobile-menu a{display:block;padding:12px 10px;border-radius:10px;color:var(--ink-soft);font-weight:700}.mobile-menu a:hover{background:var(--paper-2);color:var(--ink)}}

/* Final integration contrast fixes */
.newsletter-hero{background:var(--green-deep);color:#fff;min-height:68vh;display:flex;align-items:center}.newsletter-hero .eyebrow{color:var(--sand)}.newsletter-hero .lede{color:rgba(255,255,255,.82)!important}.footer{background:var(--green-deep);color:#fff;padding:clamp(54px,8vw,90px) 0 26px;margin-top:clamp(70px,9vw,120px);overflow:hidden}.footer .brand{color:#fff}.footer .wordmark{color:#fff}.footer .wordmark b{color:var(--sand)}.footer-grid{display:grid;grid-template-columns:minmax(260px,1.7fr) repeat(3,minmax(140px,1fr));gap:clamp(28px,5vw,68px);align-items:start}.footer h4{font-family:var(--display);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sand);margin:0 0 14px}.footer a:not(.brand){display:block;color:rgba(255,255,255,.76);margin:9px 0;line-height:1.35}.footer a:hover{color:#fff}.footer-bottom{border-top:1px solid rgba(255,255,255,.16);margin-top:clamp(36px,5vw,56px);padding-top:18px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;color:rgba(255,255,255,.58);font-size:.84rem}@media(max-width:820px){.footer-grid{grid-template-columns:1fr 1fr}.newsletter-hero .wrap{grid-template-columns:1fr!important}}@media(max-width:560px){.footer-grid{grid-template-columns:1fr}}
