:root{
  --color-primary:#5C5A3D;
  --color-secondary:#E8DFC9;
  --color-accent:#A04A2E;
  --color-neutral-dark:#2A2818;
  --color-neutral-light:#F7F2E5;
  --font-heading:'Lora', serif;
  --font-body:'Inter', sans-serif;
  --maxw:1180px;
  --radius-lg:24px;
  --radius-md:14px;
  --shadow-card:0 30px 60px -30px rgba(42,40,24,0.25);
  --shadow-soft:0 14px 34px -18px rgba(42,40,24,0.18);
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);font-size:1rem;line-height:1.65;color:var(--color-neutral-dark);background:var(--color-secondary);-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block;height:auto}
a{color:var(--color-accent);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{font-family:var(--font-heading);color:var(--color-neutral-dark);letter-spacing:-0.01em;font-weight:600;margin:0 0 .8rem}
h1{font-size:clamp(2.25rem,5vw,3.75rem);line-height:1.1}
h2{font-size:clamp(1.75rem,3.4vw,2.5rem);line-height:1.15}
h3{font-size:clamp(1.2rem,2vw,1.4rem);line-height:1.25}
p{margin:0 0 1rem}

/* === Header === */
.site-header{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.25rem 1.25rem;max-width:var(--maxw);margin:0 auto}
.logo{display:inline-block;line-height:0}
.logo img{height:72px;width:auto}
.primary-nav{display:flex;align-items:center}
.nav-toggle{font-family:var(--font-body);font-size:.95rem;background:transparent;border:1px solid var(--color-neutral-dark);color:var(--color-neutral-dark);padding:.5rem .9rem;border-radius:999px;cursor:pointer}
.nav-list{display:none;list-style:none;margin:0;padding:0;gap:1.75rem}
.nav-list a{color:var(--color-neutral-dark);font-weight:500;font-size:.98rem}
.nav-list a[aria-current="page"]{color:var(--color-accent)}
.primary-nav.is-open .nav-list{display:flex;flex-direction:column;position:absolute;top:100px;left:1rem;right:1rem;background:var(--color-neutral-light);padding:1.25rem 1.5rem;border-radius:var(--radius-md);box-shadow:var(--shadow-soft);gap:1rem;z-index:50}

@media (min-width:768px){
  .logo img{height:96px}
  .nav-toggle{display:none}
  .nav-list{display:flex;flex-direction:row}
}

/* === Hero card === */
.hero{padding:1.5rem 1rem 3rem;background:var(--color-secondary)}
.hero-card__inner{max-width:880px;margin:0 auto;background:var(--color-neutral-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:2.5rem 1.75rem;text-align:center}
.eyebrow{font-family:var(--font-body);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--color-primary);margin-bottom:1rem}
.hero h1{max-width:18ch;margin-left:auto;margin-right:auto}
.hero__sub{font-size:1.1rem;color:var(--color-primary);max-width:52ch;margin:0 auto 1.75rem}
.hero-card__figure{margin:2rem 0 0;overflow:hidden;border-radius:var(--radius-md)}
.hero-card__figure img{aspect-ratio:16/10;object-fit:cover;width:100%}
@media (min-width:768px){
  .hero{padding:3rem 2rem 5rem}
  .hero-card__inner{padding:4rem 4rem 3.5rem}
  .hero-card__figure img{aspect-ratio:21/9}
}

/* === Buttons === */
.btn{display:inline-block;font-family:var(--font-body);font-weight:500;font-size:1rem;padding:.95rem 1.6rem;border-radius:999px;border:1px solid transparent;cursor:pointer;text-decoration:none;letter-spacing:.01em;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}
.btn--primary{background:var(--color-neutral-dark);color:var(--color-neutral-light)}
.btn--primary:hover{background:var(--color-accent);text-decoration:none;transform:translateY(-1px)}
.btn--accent{background:var(--color-accent);color:var(--color-neutral-light)}
.btn--accent:hover{background:var(--color-neutral-dark);text-decoration:none;transform:translateY(-1px)}

/* === Sections === */
.section{max-width:var(--maxw);margin:0 auto;padding:3.5rem 1.25rem}
@media (min-width:768px){.section{padding:5.5rem 2rem}}
.section-head{text-align:center;max-width:60ch;margin:0 auto 2.5rem}
.section-head__sub{color:var(--color-primary);font-size:1.05rem}

/* === Intro grid === */
.intro-grid{display:grid;grid-template-columns:1fr;gap:2rem;align-items:center}
@media (min-width:900px){.intro-grid{grid-template-columns:1fr 1fr;gap:4rem}}
.intro-grid--single{grid-template-columns:1fr;max-width:65ch;margin:0 auto;text-align:center}
.intro-grid__figure{margin:0;overflow:hidden;border-radius:var(--radius-md);box-shadow:var(--shadow-soft)}
.intro-grid__figure img{aspect-ratio:4/5;object-fit:cover;width:100%}
.intro-grid__text p{font-size:1.05rem;color:var(--color-neutral-dark)}

/* === Cards === */
.cards{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media (min-width:640px){.cards--2,.cards--3,.cards--4{grid-template-columns:repeat(2,1fr)}}
@media (min-width:980px){
  .cards--3{grid-template-columns:repeat(3,1fr)}
  .cards--4{grid-template-columns:repeat(4,1fr)}
}
.card{background:var(--color-neutral-light);border-radius:var(--radius-md);padding:2rem 1.75rem;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:.4rem}
.card h3{color:var(--color-primary);margin-bottom:.5rem}
.card p{font-size:.98rem;color:var(--color-neutral-dark);margin:0}

/* === Quote === */
.section--quote{max-width:820px}
.quote{margin:0;text-align:center;font-family:var(--font-heading);font-size:clamp(1.2rem,2.2vw,1.55rem);line-height:1.5;color:var(--color-neutral-dark);position:relative;padding:1.5rem 1rem}
.quote p{margin:0 0 1.25rem;font-style:italic}
.quote cite{display:block;font-family:var(--font-body);font-style:normal;font-size:.92rem;color:var(--color-primary);letter-spacing:.04em;text-transform:uppercase}

/* === CTA band === */
.cta-band{background:var(--color-primary);color:var(--color-neutral-light);margin:0}
.cta-band__inner{max-width:780px;margin:0 auto;padding:4rem 1.5rem;text-align:center}
.cta-band h2{color:var(--color-neutral-light)}
.cta-band p{color:var(--color-neutral-light);opacity:.9;max-width:50ch;margin:0 auto 1.75rem}

/* === Stats === */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;max-width:var(--maxw);margin:0 auto;text-align:center}
@media (min-width:900px){.stats{grid-template-columns:repeat(4,1fr)}}
.stat{display:flex;flex-direction:column;gap:.5rem}
.stat__num{font-family:var(--font-heading);font-size:clamp(2.5rem,5vw,3.5rem);color:var(--color-accent);font-weight:600;line-height:1}
.stat__label{font-size:.95rem;color:var(--color-primary)}

/* === FAQ === */
.faq{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:.75rem}
.faq details{background:var(--color-neutral-light);border-radius:var(--radius-md);padding:1.25rem 1.5rem;box-shadow:var(--shadow-soft)}
.faq summary{cursor:pointer;font-family:var(--font-heading);font-size:1.1rem;color:var(--color-neutral-dark);font-weight:600;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';float:right;color:var(--color-accent);font-weight:400}
.faq details[open] summary::after{content:'−'}
.faq details p{margin:1rem 0 0;color:var(--color-neutral-dark);font-size:.98rem}

/* === Contact form === */
.contact-form{max-width:620px;margin:0 auto;display:flex;flex-direction:column;gap:1.25rem;background:var(--color-neutral-light);padding:2.25rem;border-radius:var(--radius-md);box-shadow:var(--shadow-soft)}
.form-row{display:flex;flex-direction:column;gap:.4rem}
.form-row label{font-size:.9rem;color:var(--color-primary);font-weight:500}
.form-row input,.form-row textarea{font-family:var(--font-body);font-size:1rem;padding:.8rem 1rem;border:1px solid rgba(92,90,61,0.25);border-radius:10px;background:var(--color-neutral-light);color:var(--color-neutral-dark);resize:vertical}
.form-row input:focus,.form-row textarea:focus{outline:2px solid var(--color-accent);outline-offset:1px;border-color:var(--color-accent)}
.contact-form .btn{align-self:flex-start}

/* === Footer === */
.site-footer{background:var(--color-neutral-dark);color:var(--color-neutral-light);padding:3.5rem 1.25rem 2rem;margin-top:4rem}
.footer-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr;gap:2.5rem}
@media (min-width:768px){.footer-grid{grid-template-columns:1.2fr 1fr 1.2fr}}
.site-footer h3{color:var(--color-neutral-light);font-size:1rem;letter-spacing:.04em;text-transform:uppercase;margin-bottom:1rem}
.site-footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem}
.site-footer a{color:var(--color-neutral-light);opacity:.85}
.site-footer a:hover{opacity:1;color:var(--color-secondary)}
.site-footer address{font-style:normal;line-height:1.6;color:var(--color-neutral-light);opacity:.85;margin-bottom:.75rem}
.footer-tagline{font-family:var(--font-heading);font-size:1.1rem;color:var(--color-secondary);max-width:24ch;margin-top:.75rem}
.logo--footer img{height:64px;filter:brightness(0) invert(1)}
.legal-links{margin-top:1rem;font-size:.88rem}
.copyright{max-width:var(--maxw);margin:2.5rem auto 0;font-size:.85rem;color:var(--color-neutral-light);opacity:.6;text-align:center;padding-top:1.5rem;border-top:1px solid rgba(247,242,229,0.12)}

/* === 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:var(--radius-md);box-shadow:0 18px 40px -12px rgba(0,0,0,0.4);display:flex;flex-direction:column;gap:.75rem;align-items:flex-start;z-index:100;max-width:560px;margin-inline:auto}
.cookie-banner p{margin:0;font-size:.92rem;line-height:1.5}
.cookie-banner button{background:var(--color-accent);color:var(--color-neutral-light);border:none;padding:.6rem 1.2rem;border-radius:999px;font-family:var(--font-body);font-size:.92rem;cursor:pointer}
.cookie-banner button:hover{background:var(--color-secondary);color:var(--color-neutral-dark)}
body.cookies-accepted .cookie-banner{display:none}
@media (min-width:600px){.cookie-banner{flex-direction:row;align-items:center;justify-content:space-between}}
