/* ═══════════════════════════════════════════════════════════════════════════
   DEW GARDENS — PAGE COMPONENT STYLES
   Extends tokens.css. All business-specific, page-level components.
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── INNER PAGE HERO ─────────────────────────────────────────────────────── */
.inner-hero {
  padding-top: 110px;
  padding-bottom: var(--s8);
  border-bottom: 1px solid var(--border-dark);
  position: relative;
  overflow: hidden;
}
.inner-hero::before {
  content: '';
  position: absolute; top: 0; right: 0;
  width: 50%; height: 100%;
  background: linear-gradient(135deg, transparent 40%, rgba(212,165,32,0.04) 100%);
  pointer-events: none;
}

/* ── HOMEPAGE HERO ───────────────────────────────────────────────────────── */
.hero {
  min-height: 100vh;
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  overflow: hidden;
}
/* Full-bleed bg image layer */
.hero__bg {
  position: absolute; inset: 0;
  z-index: 0;
}
.hero__bg img {
  width: 100%; height: 100%; object-fit: cover;
  filter: brightness(0.32) saturate(0.7);
}
/* Diagonal overlay for text legibility */
.hero__bg::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(110deg, rgba(26,18,8,0.95) 48%, rgba(26,18,8,0.5) 72%, transparent 100%);
}
/* Grid pattern overlay */
.hero__grid-overlay {
  position: absolute; inset: 0; z-index: 1;
  background-image:
    linear-gradient(rgba(212,165,32,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(212,165,32,0.03) 1px, transparent 1px);
  background-size: 60px 60px;
}
.hero__content {
  position: relative; z-index: 2;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: var(--s10) var(--gutter) var(--s9);
  padding-top: 140px;
  max-width: 920px;
  gap: var(--s4);
}
.hero__badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s2);
  margin-bottom: var(--s2);
}
.hero__display {
  font-family: var(--font-display);
  font-size: clamp(3rem, 8vw, 5rem);
  line-height: 0.96;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--parchment);
  margin-bottom: var(--s4);
}
.hero__display-em { color: var(--brand-primary); font-size: 0.72em; line-height: 1; display: inline-block; }
.hero__sub {
  font-size: var(--t-lg);
  color: var(--fog-400);
  line-height: var(--lh-body);
  max-width: 640px;
  margin-bottom: var(--s6);
}
.hero__ctas { display: flex; gap: var(--s3); flex-wrap: wrap; margin-bottom: var(--s8); }
.hero__bar {
  display: grid;
  grid-template-columns: repeat(4, minmax(170px, 1fr));
  gap: var(--s4);
  padding-top: var(--s6);
  border-top: 1px solid var(--border-dark);
}
.hero__stat {
  display: flex;
  flex-direction: column;
  gap: var(--s1);
  align-items: flex-start;
}
.hero__stat strong {
  font-family: var(--font-display);
  font-size: var(--t-3xl);
  color: var(--wheat-400);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  line-height: 1;
  display: block;
}
.hero__stat span {
  font-family: var(--font-mono);
  font-size: var(--t-2xs);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--fog-600);
}
/* Scroll indicator */
.hero__scroll {
  position: absolute; bottom: var(--s5); right: var(--gutter);
  z-index: 3;
  writing-mode: vertical-rl;
  font-family: var(--font-mono);
  font-size: var(--t-2xs);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--fog-800);
  display: flex; align-items: center; gap: var(--s2);
}

/* ── FEATURE CALLOUT STRIP ───────────────────────────────────────────────── */
.feature-strip {
  background: var(--earth-800);
  border-block: 1px solid var(--border-dark);
  padding-block: var(--s6);
}
.feature-strip__inner {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
.fs-item {
  display: flex;
  flex-direction: column;
  gap: var(--s2);
  padding: var(--s4) var(--s5);
  border-right: 1px solid var(--border-dark);
  transition: background var(--dur-base);
}
.fs-item:last-child { border-right: none; }
.fs-item:hover { background: rgba(212,165,32,0.04); }
.fs-icon { font-size: 1.6rem; }
.fs-h {
  font-family: var(--font-display);
  font-size: var(--t-2xl);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--parchment);
  line-height: 1;
}
.fs-p { font-size: var(--t-xs); color: var(--fog-600); line-height: var(--lh-body); }

/* ── SERVICE CARD ────────────────────────────────────────────────────────── */
.svc-card {
  background: var(--earth-800);
  border: 1px solid var(--border-dark);
  border-radius: var(--r-md);
  padding: var(--s6);
  display: flex; flex-direction: column;
  position: relative; overflow: hidden;
  transition: border-color var(--dur-slow), transform var(--dur-slow) var(--ease-organic), box-shadow var(--dur-slow);
}
.svc-card::after {
  content: '';
  position: absolute; top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--wheat-700), transparent);
  opacity: 0;
  transition: opacity var(--dur-slow);
}
.svc-card:hover { border-color: var(--border-light); transform: translateY(-5px); box-shadow: var(--shadow-md), var(--shadow-wheat); }
.svc-card:hover::after { opacity: 1; }
.svc-num {
  font-family: var(--font-mono); font-size: var(--t-2xs);
  letter-spacing: var(--ls-widest); text-transform: uppercase;
  color: var(--fog-800); margin-bottom: var(--s3);
}
.svc-icon { font-size: 2.2rem; margin-bottom: var(--s4); display: block; transition: transform var(--dur-slow) var(--ease-spring); }
.svc-card:hover .svc-icon { transform: scale(1.12) rotate(-5deg); }
.svc-h {
  font-family: var(--font-display);
  font-size: var(--t-3xl);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--parchment);
  line-height: var(--lh-snug);
  margin-bottom: var(--s3);
}
.svc-p { font-size: var(--t-sm); color: var(--fog-600); line-height: var(--lh-body); flex: 1; }
.svc-link {
  display: inline-flex; align-items: center; gap: var(--s2);
  font-family: var(--font-mono); font-size: var(--t-xs);
  letter-spacing: var(--ls-wider); text-transform: uppercase;
  color: var(--wheat-500); text-decoration: none;
  margin-top: var(--s5);
  transition: gap var(--dur-slow) var(--ease-spring), color var(--dur-base);
}
.svc-link:hover { gap: var(--s3); color: var(--wheat-400); }

/* ── PROJECT GRID ────────────────────────────────────────────────────────── */
.proj-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--s3);
}
.pj { position: relative; overflow: hidden; border-radius: var(--r-md); cursor: pointer; }
.pj img {
  width: 100%; height: 100%; object-fit: cover;
  filter: saturate(0.65) brightness(0.8);
  transition: transform var(--dur-xslow) var(--ease-organic), filter var(--dur-slow);
}
.pj:hover img { transform: scale(1.09); filter: saturate(0.95) brightness(0.75); }
.pj--a { grid-column: span 7; aspect-ratio: 4/3; }
.pj--b { grid-column: span 5; aspect-ratio: 4/3; }
.pj--c { grid-column: span 4; aspect-ratio: 1; }
.pj--d { grid-column: span 4; aspect-ratio: 1; }
.pj--e { grid-column: span 4; aspect-ratio: 1; }
.pj--f { grid-column: span 8; aspect-ratio: 16/9; }
.pj--g { grid-column: span 4; aspect-ratio: 4/5; }

.pj__caption {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(10,8,3,0.92) 100%);
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: var(--s5);
  opacity: 0;
  transition: opacity var(--dur-slow) var(--ease-out);
}
.pj:hover .pj__caption { opacity: 1; }
.pj__title {
  font-family: var(--font-display);
  font-size: var(--t-2xl);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--parchment);
  line-height: var(--lh-snug);
  margin-bottom: 4px;
}
.pj__label {
  font-family: var(--font-mono); font-size: var(--t-2xs);
  letter-spacing: var(--ls-widest); text-transform: uppercase;
  color: var(--wheat-400);
}

/* ── PLANT PALETTE CARD ──────────────────────────────────────────────────── */
.plant-card {
  background: var(--cream);
  border: 1px solid var(--fog-200);
  border-radius: var(--r-md);
  overflow: hidden;
  color: var(--text-on-light);
  transition: border-color var(--dur-slow), box-shadow var(--dur-slow), transform var(--dur-slow) var(--ease-organic);
}
.plant-card:hover {
  border-color: var(--wheat-300);
  box-shadow: 0 8px 30px rgba(10,8,3,0.14);
  transform: translateY(-3px);
}
.plant-card__img {
  aspect-ratio: 3/2; overflow: hidden;
}
.plant-card__img img {
  width: 100%; height: 100%; object-fit: cover;
  filter: saturate(0.78);
  transition: transform var(--dur-xslow) var(--ease-organic), filter var(--dur-slow);
}
.plant-card:hover .plant-card__img img { transform: scale(1.07); filter: saturate(0.95); }
.plant-card__body { padding: var(--s4); }
.plant-name {
  font-family: var(--font-display);
  font-size: var(--t-2xl);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--earth-900);
  margin-bottom: var(--s1);
  line-height: var(--lh-snug);
}
.plant-latin {
  font-family: var(--font-body);
  font-style: italic;
  font-size: var(--t-xs);
  color: var(--earth-400);
  margin-bottom: var(--s3);
}
.plant-attr {
  display: flex; gap: var(--s2); flex-wrap: wrap;
}
.plant-attr span {
  font-family: var(--font-mono);
  font-size: var(--t-2xs);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: var(--r-full);
  background: var(--sage-100);
  color: var(--sage-800);
}

/* ── REVIEW CARD ─────────────────────────────────────────────────────────── */
.review-card {
  background: var(--earth-800);
  border: 1px solid var(--border-dark);
  border-radius: var(--r-md);
  padding: var(--s6);
  position: relative;
  transition: border-color var(--dur-slow), box-shadow var(--dur-slow), transform var(--dur-slow) var(--ease-organic);
}
.review-card:hover { border-color: var(--border-light); box-shadow: var(--shadow-wheat); transform: translateY(-3px); }
.review-card::before {
  content: '"';
  position: absolute; top: var(--s3); right: var(--s5);
  font-family: var(--font-display);
  font-size: 6rem; letter-spacing: 0;
  color: rgba(212,165,32,0.08);
  line-height: 1;
}
.stars { display: flex; gap: 3px; margin-bottom: var(--s3); }
.stars span { font-size: 0.85rem; color: var(--wheat-500); }
.review-q {
  font-size: var(--t-lg);
  font-style: italic;
  color: var(--fog-200);
  line-height: var(--lh-body);
  margin-bottom: var(--s5);
}
.review-by { font-weight: var(--w-semibold); font-size: var(--t-sm); color: var(--parchment); }
.review-loc { font-family: var(--font-mono); font-size: var(--t-2xs); letter-spacing: var(--ls-wider); text-transform: uppercase; color: var(--fog-800); margin-top: 3px; }

/* ── BLOG CARD ───────────────────────────────────────────────────────────── */
.blog-card {
  background: var(--earth-800);
  border: 1px solid var(--border-dark);
  border-radius: var(--r-md);
  overflow: hidden;
  text-decoration: none; color: inherit;
  display: block;
  transition: border-color var(--dur-slow), transform var(--dur-slow) var(--ease-organic), box-shadow var(--dur-slow);
}
.blog-card:hover { border-color: var(--border-light); transform: translateY(-4px); box-shadow: var(--shadow-md), var(--shadow-wheat); }
.blog-card__img { aspect-ratio: 16/10; overflow: hidden; }
.blog-card__img img {
  width: 100%; height: 100%; object-fit: cover;
  filter: saturate(0.65) brightness(0.8);
  transition: transform var(--dur-xslow) var(--ease-organic), filter var(--dur-slow);
}
.blog-card:hover .blog-card__img img { transform: scale(1.07); filter: saturate(0.85) brightness(0.85); }
.blog-card__body { padding: var(--s5); }
.blog-cat {
  font-family: var(--font-mono); font-size: var(--t-2xs);
  letter-spacing: var(--ls-widest); text-transform: uppercase;
  color: var(--wheat-500); display: block; margin-bottom: var(--s2);
}
.blog-h {
  font-family: var(--font-body);
  font-size: var(--t-xl);
  font-weight: var(--w-semibold);
  color: var(--parchment);
  line-height: var(--lh-heading);
  margin-bottom: var(--s2);
}
.blog-excerpt { font-size: var(--t-sm); color: var(--fog-600); line-height: var(--lh-body); }
.blog-meta {
  font-family: var(--font-mono); font-size: var(--t-2xs);
  letter-spacing: var(--ls-wider); text-transform: uppercase;
  color: var(--fog-800); margin-top: var(--s4);
  display: flex; align-items: center; gap: var(--s2);
}
.blog-meta::before { content: '//'; color: var(--wheat-700); }

/* Featured blog row */
.blog-feat {
  display: grid; grid-template-columns: 1fr 1fr;
  border: 1px solid var(--border-dark);
  border-radius: var(--r-md);
  overflow: hidden;
  text-decoration: none; color: inherit;
  margin-bottom: var(--s6);
  transition: border-color var(--dur-slow), transform var(--dur-slow) var(--ease-organic), box-shadow var(--dur-slow);
}
.blog-feat:hover { border-color: var(--border-light); transform: translateY(-3px); box-shadow: var(--shadow-lg), var(--shadow-wheat); }
.blog-feat__img { overflow: hidden; }
.blog-feat__img img { width: 100%; height: 100%; object-fit: cover; filter: saturate(0.65) brightness(0.7); transition: transform var(--dur-xslow) var(--ease-organic), filter var(--dur-slow); }
.blog-feat:hover .blog-feat__img img { transform: scale(1.05); filter: saturate(0.85) brightness(0.75); }
.blog-feat__body {
  background: var(--earth-800);
  padding: var(--s7);
  display: flex; flex-direction: column; justify-content: center;
}

/* ── CONTACT INFO BLOCK ──────────────────────────────────────────────────── */
.ci-block {
  display: flex; gap: var(--s4);
  padding: var(--s4) 0;
  border-bottom: 1px solid var(--border-dark);
}
.ci-block:first-child { padding-top: 0; }
.ci-block:last-child  { border-bottom: none; }
.ci-icon {
  width: 42px; height: 42px;
  background: var(--earth-700);
  border: 1px solid var(--border-medium);
  border-radius: var(--r-sm);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.2rem; flex-shrink: 0;
  transition: background var(--dur-base), transform var(--dur-base) var(--ease-spring);
}
.ci-block:hover .ci-icon { background: var(--wheat-900); transform: scale(1.08); }
.ci-label {
  font-family: var(--font-mono); font-size: var(--t-2xs);
  letter-spacing: var(--ls-widest); text-transform: uppercase;
  color: var(--fog-600); margin-bottom: 3px;
}
.ci-val { font-weight: var(--w-semibold); font-size: var(--t-sm); color: var(--parchment); }
.ci-val a { color: inherit; }
.ci-val a:hover { color: var(--wheat-400); }
.ci-sub { font-size: var(--t-xs); color: var(--fog-800); margin-top: 2px; }

/* ── SEASONAL GARDEN CALENDAR ────────────────────────────────────────────── */
.season-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--border-dark);
  border-radius: var(--r-md);
  overflow: hidden;
}
.season-col {
  padding: var(--s5);
  border-right: 1px solid var(--border-dark);
  position: relative;
  transition: background var(--dur-base);
}
.season-col:last-child { border-right: none; }
.season-col:hover { background: rgba(212,165,32,0.03); }
.season-dot {
  width: 8px; height: 8px;
  border-radius: var(--r-full);
  margin-bottom: var(--s3);
}
.season-name {
  font-family: var(--font-display);
  font-size: var(--t-2xl);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--parchment);
  margin-bottom: var(--s3);
}
.season-tasks { display: flex; flex-direction: column; gap: var(--s1); }
.season-task {
  display: flex; align-items: flex-start; gap: var(--s2);
  font-size: var(--t-xs); color: var(--fog-600); line-height: 1.5;
}
.season-task::before { content: '→'; color: var(--wheat-700); flex-shrink: 0; }

/* ── PROCESS STEP ────────────────────────────────────────────────────────── */
.proc-step {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--s5);
  padding: var(--s5) 0;
  border-bottom: 1px solid var(--border-dark);
  position: relative;
}
.proc-step:first-child { padding-top: 0; }
.proc-step:last-child  { border-bottom: none; }
.proc-num {
  font-family: var(--font-display);
  font-size: var(--t-5xl);
  color: rgba(212,165,32,0.10);
  line-height: 1;
  letter-spacing: 0;
  width: 80px;
  flex-shrink: 0;
  transition: color var(--dur-slow);
}
.proc-step:hover .proc-num { color: rgba(212,165,32,0.25); }
.proc-h {
  font-family: var(--font-display);
  font-size: var(--t-3xl);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--parchment);
  margin-bottom: var(--s2);
  line-height: var(--lh-snug);
}
.proc-p { font-size: var(--t-sm); color: var(--fog-600); line-height: var(--lh-body); }

/* ── CHECKLIST ───────────────────────────────────────────────────────────── */
.ck-list { display: flex; flex-direction: column; gap: 0; }
.ck-item {
  display: flex; gap: var(--s3);
  padding: var(--s3) 0;
  border-bottom: 1px solid var(--border-dark);
}
.ck-item:first-child { padding-top: 0; }
.ck-item:last-child  { border-bottom: none; }
.ck-dot {
  width: 20px; height: 20px;
  background: var(--wheat-900);
  border: 1px solid var(--wheat-700);
  border-radius: var(--r-full);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; margin-top: 2px;
  font-size: 0.6rem; color: var(--wheat-400);
  transition: background var(--dur-base), transform var(--dur-base) var(--ease-spring);
}
.ck-item:hover .ck-dot { background: var(--wheat-500); color: var(--earth-900); transform: scale(1.1); }
.ck-h { font-weight: var(--w-semibold); font-size: var(--t-md); color: var(--parchment); margin-bottom: 2px; }
.ck-p { font-size: var(--t-sm); color: var(--fog-600); line-height: var(--lh-body); }

/* ── TEAM CARD ───────────────────────────────────────────────────────────── */
.team-card {
  background: var(--earth-800);
  border: 1px solid var(--border-dark);
  border-radius: var(--r-md);
  overflow: hidden;
  transition: border-color var(--dur-slow), transform var(--dur-slow) var(--ease-organic), box-shadow var(--dur-slow);
}
.team-card:hover { border-color: var(--border-light); transform: translateY(-4px); box-shadow: var(--shadow-md); }
.team-card__img { aspect-ratio: 3/4; overflow: hidden; }
.team-card__img img { width: 100%; height: 100%; object-fit: cover; filter: saturate(0.65) brightness(0.8); transition: transform var(--dur-xslow) var(--ease-organic), filter var(--dur-slow); }
.team-card:hover .team-card__img img { transform: scale(1.06); filter: saturate(0.85) brightness(0.85); }
.team-card__body { padding: var(--s5); }
.team-name { font-family: var(--font-display); font-size: var(--t-2xl); letter-spacing: var(--ls-wide); text-transform: uppercase; color: var(--parchment); margin-bottom: 3px; }
.team-role { font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: var(--ls-wider); text-transform: uppercase; color: var(--wheat-500); margin-bottom: var(--s3); }
.team-bio { font-size: var(--t-sm); color: var(--fog-600); line-height: var(--lh-body); }

/* ── NEWSLETTER STRIP ────────────────────────────────────────────────────── */
.newsletter-strip {
  background: var(--earth-800);
  border: 1px solid var(--border-medium);
  border-radius: var(--r-lg);
  padding: var(--s7) var(--s8);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--s7);
  align-items: center;
}
.newsletter-form {
  display: flex; gap: var(--s2);
}
.newsletter-input {
  flex: 1;
  background: var(--earth-900);
  border: 1px solid var(--border-medium);
  border-radius: var(--r-sm);
  padding: 12px 16px;
  color: var(--parchment);
  font-family: var(--font-body);
  font-size: var(--t-md);
  outline: none;
  transition: border-color var(--dur-base), box-shadow var(--dur-base);
}
.newsletter-input::placeholder { color: var(--fog-800); }
.newsletter-input:focus { border-color: var(--wheat-500); box-shadow: 0 0 0 3px rgba(212,165,32,0.12); }

/* ── CTA BOX ─────────────────────────────────────────────────────────────── */
.cta-box {
  background: var(--earth-800);
  border: 1px solid var(--border-medium);
  border-radius: var(--r-lg);
  padding: var(--s9) var(--s9);
  position: relative;
  overflow: hidden;
}
.cta-box::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--sage-700), var(--wheat-500), var(--rust-500));
}
.cta-box::after {
  content: 'GROW';
  position: absolute; right: var(--s5); bottom: -10px;
  font-family: var(--font-display);
  font-size: 12rem;
  letter-spacing: 0.04em;
  color: rgba(255,255,255,0.02);
  line-height: 1;
  pointer-events: none;
  user-select: none;
}

/* ── HARVEST TAG (service area chips) ───────────────────────────────────── */
.area-tags { display: flex; flex-wrap: wrap; gap: var(--s2); }
.area-tag {
  padding: 4px 14px;
  background: var(--earth-700);
  border: 1px solid var(--border-dark);
  border-radius: var(--r-full);
  font-family: var(--font-mono);
  font-size: var(--t-2xs);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--fog-600);
  transition: all var(--dur-base);
}
.area-tag::before { content: '◆ '; color: var(--wheat-700); }
.area-tag:hover { background: var(--wheat-900); border-color: var(--wheat-700); color: var(--wheat-400); }

/* ── LEGAL TEXT ──────────────────────────────────────────────────────────── */
.legal-meta {
  font-family: var(--font-mono); font-size: var(--t-sm);
  color: var(--fog-600); line-height: var(--lh-body);
  margin-bottom: var(--s7);
  padding-bottom: var(--s6);
  border-bottom: 1px solid var(--border-dark);
}
.legal h2 {
  font-family: var(--font-display);
  font-size: var(--t-3xl);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--parchment);
  margin-top: var(--s8);
  margin-bottom: var(--s4);
  padding-bottom: var(--s3);
  border-bottom: 1px solid var(--border-dark);
}
.legal h2:first-child { margin-top: 0; }
.legal p { font-size: var(--t-md); color: var(--fog-400); line-height: var(--lh-body); margin-bottom: var(--s4); }
.legal ul { margin: var(--s4) 0 var(--s4) var(--s5); }
.legal li { font-size: var(--t-md); color: var(--fog-400); line-height: var(--lh-body); list-style: disc; margin-bottom: var(--s2); }
.legal a { color: var(--wheat-400); }
.legal strong { color: var(--parchment); }

/* ── ARTICLE CONTENT ─────────────────────────────────────────────────────── */
.art h2 { font-family: var(--font-display); font-size: var(--t-4xl); letter-spacing: var(--ls-wide); text-transform: uppercase; color: var(--parchment); margin-top: var(--s9); margin-bottom: var(--s5); line-height: var(--lh-snug); }
.art h2:first-child { margin-top: 0; }
.art p  { font-size: var(--t-lg); color: var(--fog-400); line-height: var(--lh-body); margin-bottom: var(--s5); }
.art ul { margin: var(--s4) 0 var(--s5) var(--s5); }
.art li { font-size: var(--t-lg); color: var(--fog-400); line-height: var(--lh-body); list-style: disc; margin-bottom: var(--s3); }
.art blockquote {
  border-left: 3px solid var(--wheat-500);
  padding: var(--s4) var(--s6);
  margin: var(--s7) 0;
  background: var(--earth-800);
  border-radius: 0 var(--r-sm) var(--r-sm) 0;
}
.art blockquote p { font-style: italic; font-size: var(--t-xl); color: var(--parchment); }

/* ── MAP PLACEHOLDER ─────────────────────────────────────────────────────── */
.map-box {
  background: var(--earth-800);
  border: 1px solid var(--border-dark);
  border-radius: var(--r-md);
  aspect-ratio: 4/3;
  display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
}
.map-box::before {
  content: '';
  position: absolute; inset: 0;
  background-image: linear-gradient(var(--border-dark) 1px, transparent 1px), linear-gradient(90deg, var(--border-dark) 1px, transparent 1px);
  background-size: 28px 28px;
}

/* ── RESPONSIVE ──────────────────────────────────────────────────────────── */
@media (max-width: 1100px) {
  .feature-strip__inner { grid-template-columns: repeat(2, 1fr); }
  .fs-item:nth-child(2) { border-right: none; }
  .season-grid { grid-template-columns: repeat(2, 1fr); }
  .season-col:nth-child(2) { border-right: none; }
  .newsletter-strip { grid-template-columns: 1fr; }
}
@media (max-width: 900px) {
  .hero__bar { grid-template-columns: repeat(2, minmax(160px, 1fr)); }
  .proj-grid { display: grid; grid-template-columns: 1fr 1fr; }
  .pj--a,.pj--b,.pj--c,.pj--d,.pj--e,.pj--f,.pj--g { grid-column: span 1; aspect-ratio: 4/3; }
  .blog-feat { grid-template-columns: 1fr; }
  .blog-feat__img { min-height: 250px; }
}
@media (max-width: 768px) {
  .hero__display { font-size: clamp(2.8rem, 10vw, 5rem); }
  .hero__bar { grid-template-columns: 1fr; }
  .hero__stat strong { font-size: clamp(1.6rem, 2.4vw, 2rem); }
  .hero__stat span { font-size: clamp(0.55rem, 1vw, 0.75rem); }
  .season-grid { grid-template-columns: 1fr; }
  .season-col { border-right: none; border-bottom: 1px solid var(--border-dark); }
  .proc-step { grid-template-columns: 1fr; }
  .proc-num { font-size: var(--t-3xl); width: auto; }
  .proj-grid { grid-template-columns: 1fr; }
  .cta-box { padding: var(--s7) var(--s5); }
  .newsletter-form { flex-direction: column; }
}






