@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,700;1,400;1,500&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500&display=swap');

/* ── Tokens ─────────────────────────────────────────────── */
:root {
  --bark:        #2C2018;
  --forest:      #2D4A2D;
  --moss:        #4A6741;
  --sage:        #7A9E6E;
  --mist:        #B5CAA8;
  --fog:         #E8EDE3;
  --cream:       #F5F2EA;
  --paper:       #FDFBF7;
  --gold:        #C4913A;

  --txt:         #1E1A14;
  --txt2:        #5A5040;
  --txt3:        #9A8E7A;
  --border:      rgba(44,32,24,0.11);
  --border2:     rgba(44,32,24,0.22);

  --nav-h:   68px;
  --max-w:  1160px;
  --serif:  'Playfair Display', Georgia, serif;
  --sans:   'DM Sans', system-ui, sans-serif;
  --ease:    cubic-bezier(0.22,1,0.36,1);
  --r-sm: 6px; --r-md: 12px; --r-lg: 20px;
}
[data-theme="dark"] {
  --bark:    #E8DEC8; --forest: #7AB87A; --moss: #8EBA82;
  --sage:    #A8C89A; --mist:   #4A6042; --fog:  #1E2A1E;
  --cream:   #151A12; --paper:  #111510; --gold: #D4A855;
  --txt:     #EDE8DC; --txt2:   #B8AA90; --txt3: #786860;
  --border:  rgba(200,190,160,0.12); --border2: rgba(200,190,160,0.24);
}

/* ── Reset ───────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--sans);background:var(--paper);color:var(--txt);line-height:1.7;transition:background .3s,color .3s}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:var(--sans)}


/* ── Nav ─────────────────────────────────────────────────── */
#fk-nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--nav-h);
  z-index: 1000;
  display: flex;
  align-items: center;
  padding: 0 2rem;
  /* Always has bg for readability; transitions on scroll */
  background: var(--paper);
  border-bottom: .5px solid transparent;
  transition: background .25s, border-color .25s, box-shadow .25s;
}
#fk-nav.nav-scrolled {
  background: var(--paper);
  border-bottom-color: var(--border);
  box-shadow: 0 1px 12px rgba(0,0,0,.06);
}
/* Hero pages: transparent until scrolled */
#fk-nav.nav-hero {
  background: transparent;
  border-bottom-color: transparent;
  box-shadow: none;
}
#fk-nav.nav-hero.nav-scrolled {
  background: var(--paper);
  border-bottom-color: var(--border);
  box-shadow: 0 1px 12px rgba(0,0,0,.06);
}

/* ── Semantic surface tokens (constant across modes) ──── */
/* Use these for sections that always show white text */
:root {
  --surface-dark: #1E2E1A;   /* always dark green, light mode */
  --surface-dark-txt: #fff;
}
[data-theme="dark"] {
  --surface-dark: #111A0F;   /* slightly darker in dark mode */
  --surface-dark-txt: #EDE8DC;
}

[data-theme="dark"] #fk-nav { background: var(--paper); }
[data-theme="dark"] #fk-nav.nav-hero { background: transparent; }
[data-theme="dark"] #fk-nav.nav-hero.nav-scrolled { background: var(--paper); }

.nav-inner {
  max-width: var(--max-w);
  width: 100%;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* Logo */
.nav-logo-link {
  display: flex;
  align-items: center;
  gap: .6rem;
  text-decoration: none;
  flex-shrink: 0;
}
.nav-logo-img {
  height: 36px;
  width: auto;
  display: block;
}
.nav-logo-text {
  font-family: var(--serif);
  font-size: 1.05rem;
  font-weight: 500;
  color: var(--txt);
  white-space: nowrap;
}
/* On transparent hero before scroll: white text */
#fk-nav.nav-hero:not(.nav-scrolled) .nav-logo-text { color: #fff; }
#fk-nav.nav-hero:not(.nav-scrolled) .nav-logo-img { filter: brightness(0) invert(1); }

/* Links */
.nav-links {
  display: flex;
  align-items: center;
  gap: 1.75rem;
  list-style: none;
}
.nav-links a {
  font-size: 13.5px;
  font-weight: 500;
  letter-spacing: .04em;
  color: var(--txt2);
  text-decoration: none;
  transition: color .2s;
  white-space: nowrap;
}
.nav-links a:hover { color: var(--forest); }
.nav-links a.active { color: var(--forest); }
/* On transparent hero */
#fk-nav.nav-hero:not(.nav-scrolled) .nav-links a { color: rgba(255,255,255,.85); }
#fk-nav.nav-hero:not(.nav-scrolled) .nav-links a:hover,
#fk-nav.nav-hero:not(.nav-scrolled) .nav-links a.active { color: #fff; }

.nav-actions {
  display: flex;
  align-items: center;
  gap: .75rem;
}
.btn-theme {
  background: none;
  border: .5px solid var(--border2);
  border-radius: 50%;
  width: 34px; height: 34px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--txt2);
  font-size: 15px;
  transition: background .2s;
}
.btn-theme:hover { background: var(--fog); }
#fk-nav.nav-hero:not(.nav-scrolled) .btn-theme {
  border-color: rgba(255,255,255,.35);
  color: rgba(255,255,255,.8);
}

.nav-hamburger {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
  color: var(--txt);
}
#fk-nav.nav-hero:not(.nav-scrolled) .nav-hamburger { color: #fff; }

/* Mobile nav drawer */
#fk-nav-mobile {
  display: none;
  position: fixed;
  top: var(--nav-h);
  left: 0; right: 0;
  background: var(--paper);
  border-bottom: .5px solid var(--border);
  padding: 1.25rem 2rem 1.5rem;
  z-index: 999;
  flex-direction: column;
  gap: 0;
  box-shadow: 0 8px 24px rgba(0,0,0,.08);
}
#fk-nav-mobile.open { display: flex; }
#fk-nav-mobile a {
  font-size: 15px;
  font-weight: 500;
  color: var(--txt2);
  padding: .65rem 0;
  border-bottom: .5px solid var(--border);
  text-decoration: none;
}
#fk-nav-mobile a:last-child { border-bottom: none; }
#fk-nav-mobile a:hover { color: var(--forest); }

/* Spacer below fixed nav */
.nav-spacer { height: var(--nav-h); }


/* ── Buttons ─────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;border-radius:100px;font-size:13.5px;font-weight:500;letter-spacing:.03em;cursor:pointer;transition:all .2s var(--ease);border:none;font-family:var(--sans)}
.btn-primary{background:var(--forest);color:#fff}.btn-primary:hover{background:var(--moss);transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--txt);border:.5px solid var(--border2)}.btn-outline:hover{background:var(--fog)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:.5px solid rgba(255,255,255,.3);backdrop-filter:blur(8px)}.btn-ghost:hover{background:rgba(255,255,255,.22)}

/* ── Type ────────────────────────────────────────────────── */
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.2}
h1{font-size:clamp(2.2rem,5vw,3.8rem)}
h2{font-size:clamp(1.7rem,3vw,2.5rem)}
h3{font-size:clamp(1.2rem,2.5vw,1.6rem)}
h4{font-size:1.1rem}
.display-xl{font-family:var(--serif);font-size:clamp(2.8rem,6.5vw,5.2rem);font-weight:400;line-height:1.06}
.eyebrow{font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--sage)}
.lead{font-size:1.1rem;line-height:1.75;color:var(--txt2)}
.caption{font-size:12px;color:var(--txt3)}

/* ── Layout ──────────────────────────────────────────────── */
.container{max-width:var(--max-w);margin:0 auto;padding:0 2rem}
.section{padding:6rem 0}
.section-sm{padding:4rem 0}

/* ── Hero ────────────────────────────────────────────────── */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden}
.hero-media{position:absolute;inset:0;width:100%;height:100%}
/* The hero-media img or SVG fills the full container */
.hero-media img,.hero-media svg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(18,30,15,.25) 0%,rgba(14,24,12,.55) 55%,rgba(8,16,6,.82) 100%)}
.hero-content{position:relative;z-index:2;max-width:var(--max-w);margin:0 auto;padding:0 2rem 5rem;width:100%}
.hero-eyebrow{font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--mist);margin-bottom:1.25rem}
.hero-title{color:#fff;margin-bottom:1.5rem;max-width:700px}
.hero-title em{font-style:italic;color:var(--mist)}
.hero-desc{color:rgba(255,255,255,.72);max-width:520px;margin-bottom:2.5rem;font-size:1.05rem;line-height:1.75}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:2rem;right:2.5rem;z-index:2;display:flex;flex-direction:column;align-items:center;gap:6px;color:rgba(255,255,255,.4);font-size:10px;letter-spacing:.1em;text-transform:uppercase}
.hero-scroll-line{width:1px;height:38px;background:rgba(255,255,255,.25);animation:scrollP 2s ease-in-out infinite}
@keyframes scrollP{0%,100%{opacity:.3;transform:scaleY(1)}50%{opacity:.75;transform:scaleY(.65)}}

/* ── Stats strip ─────────────────────────────────────────── */
.stats{background:var(--forest);padding:0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat-item{padding:2.5rem 2rem;text-align:center;border-right:.5px solid rgba(255,255,255,.14);position:relative;overflow:hidden}
.stat-item:last-child{border-right:none}
.stat-icon{width:44px;height:44px;margin:0 auto 1rem;opacity:.8}
.stat-num{font-family:var(--serif);font-size:2rem;font-weight:500;color:#fff;line-height:1;margin-bottom:.3rem}
.stat-label{font-size:11.5px;letter-spacing:.07em;color:var(--mist);text-transform:uppercase}

/* ── Cards ───────────────────────────────────────────────── */
.card{background:var(--paper);border:.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s}
.card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(44,32,24,.1)}
.card-img{width:100%;height:220px;object-fit:cover}
.card-body{padding:1.5rem}
.card-tag{font-size:10.5px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--moss);margin-bottom:.6rem}
.card-title{font-family:var(--serif);font-size:1.2rem;font-weight:500;margin-bottom:.5rem;line-height:1.3}
.card-excerpt{font-size:14px;color:var(--txt2);line-height:1.65;margin-bottom:.75rem}
.card-link{font-size:13px;font-weight:500;color:var(--forest);display:inline-flex;align-items:center;gap:4px;transition:gap .2s}
.card-link:hover{gap:8px}

/* ── Section header ──────────────────────────────────────── */
.section-header{margin-bottom:3rem}
.section-header h2{margin-top:.5rem}
.divider{width:44px;height:2px;background:var(--sage);margin-top:1rem;border-radius:2px}

/* ── Grids ───────────────────────────────────────────────── */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}

/* ── Quote ───────────────────────────────────────────────── */
.quote-block{background:var(--cream);border-left:3px solid var(--sage);padding:1.75rem 2rem;border-radius:0 var(--r-md) var(--r-md) 0;margin:2rem 0}
[data-theme="dark"] .quote-block{background:var(--fog)}
.quote-block blockquote{font-family:var(--serif);font-style:italic;font-size:1.15rem;color:var(--txt);line-height:1.6;margin-bottom:.6rem}
.quote-attr{font-size:12px;color:var(--txt3)}

/* ── Timeline ───────────────────────────────────────────── */
.timeline{position:relative;padding-left:2rem}
.timeline::before{content:'';position:absolute;left:0;top:8px;bottom:8px;width:1px;background:var(--border2)}
.timeline-item{position:relative;padding-bottom:2.25rem}
.timeline-dot{position:absolute;left:-2.35rem;top:7px;width:10px;height:10px;border-radius:50%;background:var(--sage);border:2px solid var(--paper);box-shadow:0 0 0 2px var(--sage)}
.timeline-year{font-size:11px;font-weight:500;letter-spacing:.1em;color:var(--sage);text-transform:uppercase;margin-bottom:.25rem}
.timeline-item h4{margin-bottom:.35rem;font-size:1rem}
.timeline-item p{font-size:13.5px;color:var(--txt2);line-height:1.6}

/* ── Newsletter ──────────────────────────────────────────── */
.newsletter{background:var(--cream);padding:4rem 0;text-align:center}
[data-theme="dark"] .newsletter{background:var(--fog)}
.newsletter h3{margin-bottom:.6rem}
.newsletter p{color:var(--txt2);margin-bottom:1.75rem}
.nl-form{display:flex;gap:.75rem;max-width:400px;margin:0 auto}
.nl-form input{flex:1;padding:10px 16px;border:.5px solid var(--border2);border-radius:100px;background:var(--paper);color:var(--txt);font-family:var(--sans);font-size:14px;outline:none;transition:border-color .2s}
.nl-form input:focus{border-color:var(--sage)}
.nl-form input::placeholder{color:var(--txt3)}

/* ── Footer ──────────────────────────────────────────────── */
.footer{background:var(--bark);color:rgba(255,255,255,.7);padding:4rem 0 2rem}
[data-theme="dark"] .footer{background:#0D110B}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-brand p{font-size:13.5px;line-height:1.7;color:rgba(255,255,255,.5);max-width:260px;margin-top:1rem}
.footer-col h5{font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:1rem}
.footer-col li{margin-bottom:.45rem}
.footer-col a{font-size:14px;color:rgba(255,255,255,.6);transition:color .2s}
.footer-col a:hover{color:var(--mist)}
.footer-bottom{border-top:.5px solid rgba(255,255,255,.1);padding-top:1.5rem;display:flex;justify-content:space-between;align-items:center;font-size:12px;color:rgba(255,255,255,.28)}

/* ── Map ─────────────────────────────────────────────────── */
.map-wrap{border-radius:var(--r-lg);overflow:hidden;border:.5px solid var(--border);height:400px}
.map-wrap iframe{width:100%;height:100%;border:none}

/* ── Tag / pill ──────────────────────────────────────────── */
.tag{display:inline-block;padding:3px 10px;background:var(--fog);border-radius:100px;font-size:11px;font-weight:500;color:var(--txt2)}

/* ── Video embed ─────────────────────────────────────────── */
.video-wrap{border-radius:var(--r-md);overflow:hidden;aspect-ratio:16/9;background:#000}
.video-wrap iframe{width:100%;height:100%;border:none;display:block}

/* ── Fade-up animation ───────────────────────────────────── */
.fade-up{opacity:0;transform:translateY(20px);transition:opacity .65s var(--ease),transform .65s var(--ease)}
.fade-up.visible{opacity:1;transform:none}

/* ── Post card ───────────────────────────────────────────── */
.post-card{background:var(--paper);border:.5px solid var(--border);border-radius:var(--r-md);overflow:hidden;transition:transform .25s var(--ease)}
.post-card:hover{transform:translateY(-3px)}
.post-card-img{width:100%;height:180px;object-fit:cover;background:var(--fog);display:block}
.post-card-body{padding:1.25rem 1.5rem 1.5rem}
.post-card-tag{font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--moss);margin-bottom:.4rem}
.post-card-title{font-family:var(--serif);font-size:1.05rem;line-height:1.35;margin-bottom:.4rem}
.post-card-date{font-size:12px;color:var(--txt3)}

/* Old responsive block merged into mobile section below */

/* ── Logo placeholder ─────────────────────────────────────── */
.nav-home-link { display:flex; align-items:center; gap:.6rem; text-decoration:none; }
.logo { height:38px; width:auto; display:block; }
.logo-text { font-family:var(--serif); font-size:1.1rem; font-weight:500; color:var(--txt); white-space:nowrap; }
.logo-dark { display:block; }
.logo-light { display:none; }
.nav-transparent .logo-dark { display:none; }
.nav-transparent .logo-light { display:block; }
.nav-transparent .logo-text { color:#fff; }
[data-theme="dark"] .logo-dark { display:none; }
[data-theme="dark"] .logo-light { display:block; }
[data-theme="dark"] .nav-transparent .logo-light { display:block; }

/* ── Blog icon system ─────────────────────────────────────── */
.post-icon { width:52px; height:52px; border-radius:var(--r-md); display:flex; align-items:center; justify-content:center; font-size:1.6rem; flex-shrink:0; background:var(--fog); }
[data-theme="dark"] .post-icon { background:var(--cream); }
.post-row { display:flex; align-items:flex-start; gap:1rem; padding:1.25rem 0; border-bottom:.5px solid var(--border); }
.post-row:last-child { border-bottom:none; }
.post-row-body { flex:1; min-width:0; }
.post-row-tag { font-size:10px; font-weight:500; letter-spacing:.12em; text-transform:uppercase; color:var(--moss); margin-bottom:.3rem; }
.post-row-title { font-family:var(--serif); font-size:1.05rem; line-height:1.35; margin-bottom:.3rem; }
.post-row-meta { font-size:12px; color:var(--txt3); display:flex; gap:.75rem; flex-wrap:wrap; align-items:center; }
.post-row-excerpt { font-size:13.5px; color:var(--txt2); line-height:1.6; margin-top:.4rem; }
.post-row-link { font-size:12.5px; font-weight:500; color:var(--forest); display:inline-flex; align-items:center; gap:3px; margin-top:.5rem; transition:gap .2s; }
.post-row-link:hover { gap:7px; }

/* ── Filter tabs ─────────────────────────────────────────── */
.filter-tabs { display:flex; gap:0; overflow-x:auto; -webkit-overflow-scrolling:touch; border-bottom:.5px solid var(--border); }
.filter-tab { padding:.875rem 1.25rem; font-size:13px; font-weight:500; background:none; border:none; border-bottom:2px solid transparent; color:var(--txt2); cursor:pointer; white-space:nowrap; font-family:var(--sans); transition:color .2s, border-color .2s; }
.filter-tab.active { color:var(--forest); border-bottom-color:var(--forest); }
.filter-tab:hover { color:var(--txt); }

/* ── Page header ─────────────────────────────────────────── */
.page-header { padding-top:calc(var(--nav-h) + 4rem); padding-bottom:3rem; }
.page-header .container { max-width:var(--max-w); margin:0 auto; padding:0 2rem; }

/* ════════════════════════════════════════════════════════════
   MOBILE RESPONSIVE — Full overhaul
   Breakpoints: 900px (tablet), 600px (phone)
   ════════════════════════════════════════════════════════════ */

/* ── Nav: use padding that works at all widths ──────────── */
/* Remove the hardcoded 13rem; let nav-inner + max-width handle centering */
#fk-nav {
  padding: 0 1.5rem;
}

/* ── Responsive utility: col-2 layout ───────────────────── */
/* Use class="col-2" instead of inline grid styles for 2-col layouts */
.col-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}
.col-2-start { align-items: start; }
.col-2-wide  { grid-template-columns: 1.5fr 1fr; }
.col-2-sidebar { grid-template-columns: 2fr 1fr; }
.col-2-map  { grid-template-columns: 1fr 1.6fr; }
.col-2-plans { grid-template-columns: 1fr 1.6fr; }

/* ── Tablet ─────────────────────────────────────────────── */
@media (max-width: 900px) {
  /* Nav */
  #fk-nav { padding: 0 1.25rem; }
  .nav-links { display: none; }
  .nav-hamburger { display: block; }

  /* Utility cols → single col on tablet */
  .col-2,
  .col-2-start,
  .col-2-wide,
  .col-2-sidebar,
  .col-2-map,
  .col-2-plans { grid-template-columns: 1fr !important; gap: 2.5rem; }

  /* Grids */
  .grid-3 { grid-template-columns: 1fr 1fr; }
  .grid-4 { grid-template-columns: 1fr 1fr; }

  /* Stats: 2×2 on tablet */
  .stats-grid { grid-template-columns: 1fr 1fr; }

  /* Footer */
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }

  /* History sidebar: unstick and show below content */
  .sidebar-sticky { position: static !important; top: auto !important; }

  /* Hero */
  .hero-content { padding: 0 1.5rem 4rem; }
  .display-xl { font-size: clamp(2.4rem, 8vw, 3.8rem); }
}

/* ── Phone ──────────────────────────────────────────────── */
@media (max-width: 600px) {
  /* Nav */
  #fk-nav { padding: 0 1rem; }
  .nav-logo-img { height: 28px; }

  /* Container */
  .container { padding: 0 1rem; }

  /* Sections */
  .section { padding: 3rem 0; }
  .section-sm { padding: 2.5rem 0; }
  .n-section { padding: 3rem 0; }

  /* Typography */
  h1 { font-size: clamp(1.9rem, 7vw, 2.8rem); }
  h2 { font-size: clamp(1.5rem, 5vw, 2rem); }
  .display-xl { font-size: clamp(2rem, 8vw, 3rem); }

  /* All multi-col → single col */
  .col-2,
  .col-2-start,
  .col-2-wide,
  .col-2-sidebar,
  .col-2-map,
  .col-2-plans,
  .grid-3,
  .grid-2 { grid-template-columns: 1fr !important; gap: 1.5rem; }

  /* Keep 2-col for small things */
  .grid-4 { grid-template-columns: 1fr 1fr; gap: 1rem; }
  .stats-grid { grid-template-columns: 1fr 1fr; }

  /* Footer */
  .footer-grid { grid-template-columns: 1fr; gap: 2rem; }
  .footer-bottom { flex-direction: column; gap: .5rem; text-align: center; }

  /* Hero */
  .hero-content { padding: 0 1rem 3rem; }
  .hero-ctas { flex-direction: column; align-items: flex-start; }
  .hero-scroll { display: none; }

  /* Plans band mini-cards: keep 2 col on phone */
  .plans-grid-2 { grid-template-columns: 1fr 1fr !important; gap: .75rem; }

  /* Nature microclimate stats: keep 2×2 on phone */
  .micro-stats { grid-template-columns: 1fr 1fr !important; gap: .75rem; }

  /* Trail cards, wildlife cards: single col */
  .trail-card, .wildlife-card { width: 100%; }

  /* Map */
  .map-wrap { height: 280px; }

  /* Post rows on blog */
  .post-row { gap: .75rem; }
  .post-icon { width: 40px; height: 40px; font-size: 1.25rem; }

  /* Filter tabs */
  .filter-tabs { gap: 0; }
  .filter-tab { padding: .75rem .875rem; font-size: 12px; }

  /* Quote block */
  .quote-block { padding: 1.25rem 1.25rem; }
  .quote-block blockquote { font-size: 1rem; }

  /* Form */
  .nl-form { flex-direction: column; }

  /* Page headers */
  .page-header { padding-top: 2rem; padding-bottom: 2rem; }

  /* Inline grids inside page content — catch any remaining */
  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns: 1fr 1fr"],
  [style*="grid-template-columns:2fr 1fr"],
  [style*="grid-template-columns: 2fr 1fr"],
  [style*="grid-template-columns:1fr 1.6fr"],
  [style*="grid-template-columns: 1fr 1.6fr"],
  [style*="grid-template-columns:1.5fr 1fr"],
  [style*="grid-template-columns: 1.5fr 1fr"] {
    grid-template-columns: 1fr !important;
    gap: 1.5rem !important;
  }

  /* Sub-nav scroll */
  .sub-nav-row a { padding: .75rem .875rem; font-size: 12px; }

  /* Gallery grid */
  .gallery-grid { grid-template-columns: 1fr 1fr !important; gap: 8px; }
  .gallery-item.tall { grid-row: span 1; }
  .gallery-item.wide { grid-column: span 1; }
}

/* ── Very small phones (< 380px) ─────────────────────────── */
@media (max-width: 380px) {
  .stats-grid { grid-template-columns: 1fr; }
  .grid-4 { grid-template-columns: 1fr; }
  .plans-grid-2 { grid-template-columns: 1fr !important; }
}

/* ── Responsive image frame heights ─────────────────────── */
@media (max-width: 600px) {
  /* Nature page img-frames: reduce height */
  .img-frame[style*="height:400px"],
  .img-frame[style*="height: 400px"] { height: 240px !important; }
  .img-frame[style*="height:340px"],
  .img-frame[style*="height: 340px"] { height: 220px !important; }
  .img-frame[style*="height:280px"],
  .img-frame[style*="height: 280px"] { height: 200px !important; }

  /* History page photo-blocks */
  .photo-block[style*="height:300px"],
  .photo-block[style*="height: 300px"] { height: 200px !important; }
  .photo-block[style*="height:280px"],
  .photo-block[style*="height: 280px"] { height: 180px !important; }
  .photo-block[style*="height:260px"],
  .photo-block[style*="height: 260px"] { height: 180px !important; }
  .photo-block[style*="height:240px"],
  .photo-block[style*="height: 240px"] { height: 160px !important; }
  .photo-block[style*="height:220px"],
  .photo-block[style*="height: 220px"] { height: 160px !important; }

  /* Map */
  .map-wrap { height: 240px !important; }

  /* Hero min-height */
  .hero { min-height: 85vh; }

  /* Page header padding */
  [style*="padding:3rem 0 3.5rem"] { padding: 2rem 0 2rem !important; }
  [style*="padding:3rem 0"] { padding: 2rem 0 !important; }
}
