:root{
  --color-primary:#3D5A3A;
  --color-secondary:#EFE9D9;
  --color-accent:#C09356;
  --color-neutral-dark:#1F1F1F;
  --color-neutral-light:#FAF7EF;
  --font-heading:'Montserrat',sans-serif;
  --font-body:'Source Sans 3',sans-serif;
  --max-read:65ch;
}

/* === Base === */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);color:var(--color-neutral-dark);background:var(--color-neutral-light);line-height:1.6;font-size:1.0625rem}
img{max-width:100%;display:block;height:auto}
a{color:var(--color-primary);text-decoration:underline;text-underline-offset:3px}
a:hover{color:var(--color-accent)}
h1,h2,h3{font-family:var(--font-heading);color:var(--color-primary);line-height:1.2;margin:0 0 1rem}
h1{font-size:clamp(2.25rem,5vw,3.75rem);font-weight:700;letter-spacing:-0.01em}
h2{font-size:clamp(1.6rem,3vw,2.25rem);font-weight:600}
h3{font-size:1.2rem;font-weight:600}
p{margin:0 0 1rem}
.eyebrow{font-family:var(--font-heading);font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--color-accent);margin-bottom:1rem}
.section-sub{color:#555;font-size:1.1rem;max-width:60ch;margin-bottom:2rem}

/* === Logo === */
.logo{display:inline-block}
.logo img{height:72px;width:auto}
@media (min-width:768px){.logo img{height:96px}}
.logo--footer img{height:60px}

/* === Buttons === */
.btn{display:inline-block;font-family:var(--font-heading);font-weight:600;font-size:1rem;padding:.85rem 1.6rem;border-radius:6px;text-decoration:none;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}
.btn--primary{background:var(--color-primary);color:var(--color-neutral-light)}
.btn--primary:hover{background:#2d4429;color:var(--color-neutral-light);transform:translateY(-2px)}
.btn--accent{background:var(--color-accent);color:var(--color-neutral-dark)}
.btn--accent:hover{background:#a87a3f;color:var(--color-neutral-light);transform:translateY(-2px)}

/* === Layout: sidebar nav === */
.layout{display:block}
.sidebar{background:var(--color-primary);color:var(--color-neutral-light);padding:1.25rem 1.25rem}
.sidebar__top{display:flex;align-items:center;justify-content:space-between}
.sidebar .logo img{filter:brightness(0) invert(1)}
.nav-toggle{background:transparent;border:1px solid var(--color-neutral-light);color:var(--color-neutral-light);font-family:var(--font-heading);padding:.5rem .9rem;border-radius:4px;cursor:pointer;font-size:.9rem}
.sidebar__nav{display:none;margin-top:1rem}
.sidebar__nav.is-open{display:block}
.sidebar__nav ul{list-style:none;margin:0;padding:0}
.sidebar__nav li{margin:.25rem 0}
.sidebar__nav a{display:block;color:var(--color-neutral-light);text-decoration:none;font-family:var(--font-heading);font-weight:500;padding:.65rem .25rem;border-bottom:1px solid rgba(255,255,255,.12)}
.sidebar__nav a:hover{color:var(--color-accent)}
.sidebar__foot{display:none;font-size:.8rem;opacity:.7;margin-top:1rem}

.content{padding:2rem 1.25rem}

@media (min-width:900px){
  .layout{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
  .sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;padding:2rem 1.5rem}
  .nav-toggle{display:none}
  .sidebar__nav{display:block;margin-top:2.5rem;flex:1}
  .sidebar__nav a{border-bottom:none;padding:.5rem 0;font-size:1rem}
  .sidebar__foot{display:block}
  .content{padding:4rem 3rem}
}

/* === Hero === */
.hero{padding:1rem 0 3rem;max-width:880px}
.hero__sub{font-size:1.2rem;color:#444;max-width:54ch;margin-bottom:1.75rem}
.hero__cta{margin-bottom:2.5rem}
.hero__media img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:12px}
@media (min-width:900px){.hero{padding:2rem 0 5rem}}

/* === Intro (text + media) === */
.intro{display:grid;gap:2rem;padding:3rem 0;border-top:1px solid #e6e0cf}
.intro__media img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:12px}
@media (min-width:900px){
  .intro{grid-template-columns:1.2fr 1fr;align-items:center;gap:4rem;padding:5rem 0}
  .intro--reverse .intro__text{order:2}
  .intro--reverse .intro__media{order:1}
}

/* === Grid sections (cards) === */
.grid-section{padding:3rem 0;border-top:1px solid #e6e0cf}
.cards{list-style:none;margin:0;padding:0;display:grid;gap:1.25rem;grid-template-columns:1fr}
@media (min-width:600px){.cards{grid-template-columns:1fr 1fr}}
@media (min-width:1100px){.cards{grid-template-columns:1fr 1fr}.cards--three{grid-template-columns:1fr 1fr 1fr}}
.card{background:var(--color-secondary);padding:1.75rem;border-radius:12px;border:1px solid rgba(61,90,58,.12)}
.card__icon{display:inline-block;font-size:1.6rem;margin-bottom:.75rem}
.card h3{margin-bottom:.5rem}
.card p{margin:0;color:#333;font-size:1rem}

/* === Quote === */
.quote-section{padding:3.5rem 0;border-top:1px solid #e6e0cf}
.quote-section blockquote{margin:0;max-width:60ch;border-left:4px solid var(--color-accent);padding-left:1.5rem}
.quote-section blockquote p{font-family:var(--font-heading);font-weight:500;font-size:1.3rem;line-height:1.5;color:var(--color-primary);margin-bottom:1rem}
.quote-section cite{font-style:normal;font-size:.95rem;color:#555}
@media (min-width:900px){.quote-section blockquote p{font-size:1.5rem}}

/* === CTA band === */
.cta-band{margin:4rem 0 0;padding:3rem 1.5rem;background:var(--color-primary);color:var(--color-neutral-light);border-radius:16px;text-align:center}
.cta-band h2{color:var(--color-neutral-light);margin-bottom:1rem}
.cta-band p{max-width:54ch;margin-inline:auto;color:rgba(255,255,255,.9);margin-bottom:1.5rem}
@media (min-width:900px){.cta-band{padding:5rem 2rem}}

/* === Footer === */
.site-footer{margin-top:4rem;padding:3rem 0 2rem;border-top:1px solid #e6e0cf;color:#333;font-size:.95rem}
.site-footer__cols{display:grid;gap:2.5rem;grid-template-columns:1fr}
.site-footer h3{font-size:1rem;margin-bottom:.75rem}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin-bottom:.4rem}
.site-footer address{font-style:normal;line-height:1.6;margin-bottom:1rem}
.legal-links{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1rem}
.site-footer__copy{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid #e6e0cf;font-size:.85rem;color:#666}
@media (min-width:768px){.site-footer__cols{grid-template-columns:1.2fr 1fr 1.4fr}}

/* === Cookie banner === */
.cookie-banner{position:fixed;left:1rem;right:1rem;bottom:1rem;background:var(--color-neutral-dark);color:var(--color-neutral-light);padding:1rem 1.25rem;border-radius:10px;display:flex;flex-direction:column;gap:.75rem;align-items:flex-start;box-shadow:0 20px 40px -20px rgba(0,0,0,.5);z-index:50;font-size:.95rem;max-width:520px}
.cookie-banner p{margin:0}
.cookie-banner button{background:var(--color-accent);color:var(--color-neutral-dark);border:0;font-family:var(--font-heading);font-weight:600;padding:.55rem 1.1rem;border-radius:6px;cursor:pointer}
.cookie-banner button:hover{background:#a87a3f;color:var(--color-neutral-light)}
body.cookies-accepted .cookie-banner{display:none}
@media (min-width:600px){.cookie-banner{flex-direction:row;align-items:center;gap:1.25rem}}
