:root {
  --ink: #17201d;
  --muted: #5b6761;
  --paper: #f7f5ef;
  --surface: #ffffff;
  --line: #d9ddd4;
  --green: #315c4b;
  --green-dark: #193b31;
  --gold: #b8863b;
  --terracotta: #a8583a;
  --shadow: 0 18px 45px rgba(23, 32, 29, 0.12);
  --radius: 8px;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); line-height: 1.6; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; }
.skip-link { position: absolute; left: 1rem; top: -5rem; background: var(--ink); color: white; padding: .7rem 1rem; z-index: 100; }
.skip-link:focus { top: 1rem; }
.site-header { position: sticky; top: 0; z-index: 50; display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: .85rem clamp(1rem, 4vw, 3rem); background: rgba(247,245,239,.92); backdrop-filter: blur(16px); border-bottom: 1px solid rgba(217,221,212,.85); }
.brand { display: inline-flex; align-items: center; gap: .75rem; text-decoration: none; min-width: 0; }
.brand-mark { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 50%; background: var(--green-dark); color: #fff; font-weight: 800; letter-spacing: .05em; }
.brand strong, .brand small { display: block; }
.brand strong { font-size: 1rem; line-height: 1.1; }
.brand small { color: var(--muted); font-size: .78rem; }
.site-nav { display: flex; align-items: center; gap: .35rem; }
.site-nav a { text-decoration: none; color: var(--muted); padding: .65rem .8rem; border-radius: var(--radius); font-weight: 700; font-size: .93rem; }
.site-nav a:hover, .site-nav a.is-active { color: var(--ink); background: #ebe6d9; }
.nav-toggle { display: none; width: 42px; height: 42px; border: 1px solid var(--line); background: white; border-radius: var(--radius); }
.nav-toggle span { display: block; height: 2px; margin: 5px 8px; background: var(--ink); }
.hero { min-height: min(760px, calc(100svh - 40px)); display: flex; align-items: end; padding: 7rem clamp(1rem, 5vw, 5rem) 5rem; background-image: linear-gradient(90deg, rgba(10,25,20,.82), rgba(10,25,20,.52), rgba(10,25,20,.1)), var(--hero-image); background-size: cover; background-position: center; color: white; }
.hero-inner { max-width: 820px; }
.hero h1 { font-size: clamp(3.1rem, 9vw, 7.7rem); line-height: .88; margin: 0 0 1.3rem; letter-spacing: 0; }
.hero-copy { font-size: clamp(1.08rem, 2.2vw, 1.45rem); max-width: 680px; color: rgba(255,255,255,.9); }
.eyebrow { margin: 0 0 .75rem; text-transform: uppercase; letter-spacing: .12em; font-size: .74rem; font-weight: 900; color: var(--gold); }
.hero .eyebrow { color: #f0c879; }
.button-row { display: flex; flex-wrap: wrap; gap: .75rem; margin-top: 1.4rem; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 44px; padding: .78rem 1rem; border-radius: var(--radius); border: 1px solid transparent; text-decoration: none; font-weight: 900; cursor: pointer; font-size: .94rem; }
.button.primary { background: var(--green); color: white; }
.button.primary:hover { background: var(--green-dark); }
.button.ghost { border-color: rgba(255,255,255,.48); background: rgba(255,255,255,.12); color: inherit; }
.page-hero .button.ghost, .rich-content .button.ghost { border-color: var(--line); background: white; color: var(--ink); }
.button.full { width: 100%; margin-top: 1rem; }
.intro-band, .section, .feature-split, .content-grid, .contact-section, .cta-band { padding: clamp(3rem, 7vw, 6rem) clamp(1rem, 5vw, 5rem); }
.intro-grid, .feature-split, .content-grid, .contact-section { display: grid; grid-template-columns: minmax(0, 1.25fr) minmax(280px, .75fr); gap: clamp(1.5rem, 4vw, 4rem); align-items: center; max-width: 1180px; margin: 0 auto; }
.intro-grid h2, .section-heading h2, .feature-split h2, .cta-band h2, .page-hero h1 { font-size: clamp(2rem, 4vw, 4rem); line-height: 1; letter-spacing: 0; margin: 0 0 1rem; }
.stat-list { display: grid; gap: .75rem; }
.stat-list div { background: white; border: 1px solid var(--line); border-radius: var(--radius); padding: 1rem; box-shadow: 0 8px 24px rgba(23,32,29,.06); }
.stat-list strong { display: block; font-size: 2.1rem; line-height: 1; color: var(--green); }
.stat-list span { color: var(--muted); font-weight: 700; }
.section-heading { max-width: 760px; margin: 0 auto 2rem; text-align: center; }
.cards { display: grid; gap: 1rem; max-width: 1180px; margin: 0 auto; }
.cards.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.card { background: white; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; box-shadow: 0 12px 34px rgba(23,32,29,.08); }
.card img { aspect-ratio: 16/10; width: 100%; object-fit: cover; }
.card div { padding: 1.1rem; }
.card h3 { margin: 0 0 .65rem; font-size: 1.2rem; line-height: 1.25; }
.card p { color: var(--muted); margin: 0 0 1rem; }
.text-link { display: inline-flex; color: var(--green-dark); font-weight: 900; text-decoration-thickness: 2px; text-underline-offset: 4px; margin-top: .4rem; }
.feature-split { background: #e9eee7; }
.feature-split img, .page-hero img { border-radius: var(--radius); box-shadow: var(--shadow); object-fit: cover; width: 100%; aspect-ratio: 16/11; }
.check-list { padding: 0; margin: 1rem 0 0; list-style: none; display: grid; gap: .7rem; }
.check-list li { position: relative; padding-left: 1.55rem; color: var(--muted); }
.check-list li:before { content: ""; position: absolute; left: 0; top: .55rem; width: .6rem; height: .6rem; border-radius: 50%; background: var(--gold); }
.muted { background: #efe9dd; }
.cta-band { text-align: center; background: var(--green-dark); color: white; }
.cta-band p { max-width: 680px; margin-inline: auto; color: rgba(255,255,255,.82); }
.cta-band .button-row { justify-content: center; }
.page-hero { display: grid; grid-template-columns: minmax(0, 1fr) minmax(280px, .72fr); gap: clamp(1.5rem,4vw,4rem); align-items: center; padding: clamp(3.5rem, 7vw, 6rem) clamp(1rem, 5vw, 5rem); max-width: 1220px; margin: 0 auto; }
.page-hero.text-only { display: block; text-align: center; max-width: 860px; }
.page-hero p { color: var(--muted); font-size: 1.08rem; }
.page-hero .eyebrow { color: var(--gold); }
.content-grid { align-items: start; }
.rich-content { background: white; border: 1px solid var(--line); border-radius: var(--radius); padding: clamp(1.2rem, 3vw, 2.4rem); box-shadow: 0 12px 34px rgba(23,32,29,.06); }
.rich-content h2 { font-size: clamp(1.55rem, 2.7vw, 2.25rem); line-height: 1.08; margin: 2rem 0 .65rem; }
.rich-content h2:first-child { margin-top: 0; }
.rich-content h3 { font-size: 1.2rem; margin: 1.4rem 0 .35rem; }
.rich-content p { color: #33413b; }
.rich-content a { color: var(--green-dark); font-weight: 800; }
.side-panel { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 1.2rem; position: sticky; top: 90px; box-shadow: 0 12px 34px rgba(23,32,29,.06); }
.side-panel h2 { margin-top: 0; font-size: 1.25rem; }
.side-panel .text-link { display: block; margin: .7rem 0; }
.article-shell { padding-bottom: 4rem; }
.article-hero { max-width: 980px; margin: 0 auto; padding: clamp(3.5rem, 7vw, 6rem) clamp(1rem, 5vw, 5rem) 2rem; text-align: center; }
.article-hero h1 { font-size: clamp(2.3rem, 5vw, 4.7rem); line-height: 1; letter-spacing: 0; margin: 0 0 1rem; }
.article-hero p { color: var(--muted); font-size: 1.08rem; }
.article-meta { display: flex; justify-content: center; flex-wrap: wrap; gap: .6rem; margin: 1rem 0 1.5rem; }
.article-meta span { border: 1px solid var(--line); border-radius: var(--radius); background: white; padding: .45rem .65rem; color: var(--muted); font-weight: 800; font-size: .82rem; }
.article-main-image { border-radius: var(--radius); aspect-ratio: 16/9; object-fit: cover; width: 100%; box-shadow: var(--shadow); }
.article-layout { display: grid; grid-template-columns: minmax(0, 760px) minmax(240px, 320px); gap: 1.5rem; align-items: start; max-width: 1180px; margin: 0 auto; padding: 0 clamp(1rem, 5vw, 5rem); }
.lead { font-size: 1.12rem; color: var(--ink) !important; }
figure { margin: 1.6rem 0; }
figure img { border-radius: var(--radius); aspect-ratio: 16/9; width: 100%; object-fit: cover; }
figcaption { color: var(--muted); font-size: .88rem; margin-top: .45rem; }
.note-box { border: 1px solid #d9c69f; background: #fbf3df; border-radius: var(--radius); padding: 1rem; }
.contact-section { align-items: start; }
.contact-form { background: white; border: 1px solid var(--line); border-radius: var(--radius); padding: clamp(1rem, 3vw, 2rem); box-shadow: 0 12px 34px rgba(23,32,29,.06); display: grid; gap: 1rem; }
label { display: grid; gap: .35rem; font-weight: 800; color: var(--ink); }
input, textarea, select { width: 100%; border: 1px solid var(--line); border-radius: var(--radius); padding: .85rem; font: inherit; background: #fbfaf6; color: var(--ink); }
textarea { resize: vertical; }
.site-footer { background: #111a17; color: white; padding: 3rem clamp(1rem, 5vw, 5rem); display: grid; grid-template-columns: minmax(0, 1fr) minmax(240px, .55fr); gap: 2rem; }
.site-footer h2 { margin: 0 0 .5rem; }
.site-footer p { color: rgba(255,255,255,.74); max-width: 620px; }
.site-footer nav { display: grid; gap: .55rem; }
.site-footer a { color: white; text-decoration-color: rgba(255,255,255,.35); text-underline-offset: 4px; }
.fineprint { grid-column: 1 / -1; font-size: .88rem; border-top: 1px solid rgba(255,255,255,.14); padding-top: 1rem; margin: 0; }
@media (max-width: 900px) {
  .nav-toggle { display: block; }
  .site-nav { position: absolute; left: 1rem; right: 1rem; top: calc(100% + .5rem); background: white; border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow); padding: .5rem; display: none; flex-direction: column; align-items: stretch; }
  .site-nav.is-open { display: flex; }
  .site-nav a { padding: .85rem; }
  .cards.three, .intro-grid, .feature-split, .content-grid, .contact-section, .page-hero, .article-layout, .site-footer { grid-template-columns: 1fr; }
  .hero { min-height: 680px; padding-top: 6rem; }
  .side-panel { position: static; }
}
@media (max-width: 560px) {
  .brand small { display: none; }
  .brand strong { max-width: 170px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .hero { min-height: 620px; padding-bottom: 3rem; }
  .button { width: 100%; }
  .article-meta { justify-content: stretch; }
  .article-meta span { width: 100%; }
}
