/* === Reset === */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body,h1,h2,h3,h4,p,figure,blockquote,dl,dd,ul,ol{margin:0}
ul{padding:0;list-style:none}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}

/* === Tokens === */
:root{
  --color-primary:#1A1F2E;
  --color-secondary:#F5E8DD;
  --color-accent:#E07A5F;
  --color-neutral-dark:#0F1320;
  --color-neutral-light:#FAF0E8;
  --font-heading:'Playfair Display',serif;
  --font-body:'Inter',sans-serif;
  --maxw:1180px;
  --radius:10px;
}

body{
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  color:var(--color-neutral-dark);
  background:var(--color-neutral-light);
  -webkit-font-smoothing:antialiased;
}

h1,h2,h3{font-family:var(--font-heading);font-weight:600;line-height:1.18;color:var(--color-primary)}
h1{font-size:clamp(2rem,5vw,3.4rem)}
h2{font-size:clamp(1.6rem,3.2vw,2.4rem);margin-bottom:1rem}
h3{font-size:1.2rem;margin-bottom:.5rem}
p{margin:.5rem 0}

/* === Header === */
.site-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.25rem 1.25rem;
  max-width:var(--maxw);margin:0 auto;
  position:relative;
}
.logo img{height:72px;width:auto;display:block}
.nav-toggle{display:flex;flex-direction:column;gap:5px;padding:.5rem;z-index:20}
.nav-toggle span{width:26px;height:2px;background:var(--color-primary);display:block;transition:transform .2s,opacity .2s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.primary-nav{
  position:absolute;top:100%;left:0;right:0;
  background:var(--color-neutral-light);
  border-top:1px solid rgba(15,19,32,.08);
  display:none;
}
.primary-nav[data-open="true"]{display:block}
.primary-nav ul{display:flex;flex-direction:column;padding:1rem 1.25rem}
.primary-nav a{display:block;padding:.75rem 0;font-weight:500;color:var(--color-primary)}
.primary-nav a[aria-current="page"]{color:var(--color-accent)}

@media (min-width:768px){
  .logo img{height:96px}
  .nav-toggle{display:none}
  .primary-nav{position:static;display:block;background:transparent;border:0}
  .primary-nav ul{flex-direction:row;gap:2rem;padding:0}
  .primary-nav a{padding:0}
}

/* === Layout === */
main{display:block}
section{padding:3.5rem 1.25rem;max-width:var(--maxw);margin:0 auto}
@media (min-width:768px){section{padding:5rem 2rem}}

/* === Hero stacked === */
.hero{max-width:780px;margin:0 auto;text-align:left}
.hero .eyebrow{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;color:var(--color-accent);font-weight:600;margin-bottom:1rem}
.hero h1{margin-bottom:2rem;max-width:24ch}
.hero__image{margin:2.5rem 0}
.hero__image img{aspect-ratio:16/9;object-fit:cover;width:100%;border-radius:var(--radius)}
.hero__sub{font-size:1.15rem;color:var(--color-neutral-dark);max-width:54ch;margin:2rem 0 1.5rem}
.hero__cta{margin-top:1.5rem}

/* === Buttons === */
.btn{display:inline-block;padding:.95rem 1.75rem;font-weight:600;border-radius:6px;letter-spacing:.02em;transition:transform .15s,background .15s}
.btn-primary{background:var(--color-primary);color:var(--color-neutral-light)}
.btn-primary:hover{background:var(--color-accent)}
.btn-accent{background:var(--color-accent);color:var(--color-neutral-light)}
.btn-accent:hover{background:var(--color-primary)}

/* === Intro / two-column === */
.intro{display:grid;grid-template-columns:1fr;gap:2rem;align-items:center}
.intro__media img{aspect-ratio:4/5;object-fit:cover;width:100%;border-radius:var(--radius)}
.intro__text p{font-size:1.02rem;line-height:1.75}
@media (min-width:768px){
  .intro{grid-template-columns:1fr 1.1fr;gap:3.5rem}
  .intro--reverse .intro__media{order:2}
}

/* === Highlights grid === */
.highlights h2{text-align:center;margin-bottom:2.5rem}
.grid{display:grid;gap:1.5rem;grid-template-columns:1fr}
@media (min-width:640px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (min-width:960px){.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}}
.card{
  background:var(--color-secondary);
  padding:1.75rem;
  border-radius:var(--radius);
  border:1px solid rgba(15,19,32,.06);
}
.card__icon{display:inline-block;font-size:1.5rem;margin-bottom:.75rem}
.card p{font-size:.96rem;line-height:1.65}

/* === Testimonial === */
.testimonial{text-align:center;max-width:780px}
.testimonial blockquote{position:relative;padding:1rem}
.testimonial p{font-family:var(--font-heading);font-size:clamp(1.2rem,2.5vw,1.55rem);line-height:1.5;color:var(--color-primary)}
.testimonial cite{display:block;margin-top:1.5rem;font-style:normal;font-size:.95rem;color:var(--color-accent);font-weight:600}

/* === CTA band === */
.cta-band{background:var(--color-primary);color:var(--color-neutral-light);text-align:center;border-radius:var(--radius);padding:3.5rem 1.5rem}
.cta-band h2{color:var(--color-neutral-light)}
.cta-band p{max-width:55ch;margin:.75rem auto}

/* === FAQ === */
.faq{max-width:840px}
.faq h2{text-align:center;margin-bottom:2rem}
.faq details{border-bottom:1px solid rgba(15,19,32,.12);padding:1.1rem 0}
.faq summary{font-weight:600;font-size:1.05rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:1rem;color:var(--color-primary)}
.faq summary::after{content:"+";color:var(--color-accent);font-size:1.4rem;line-height:1}
.faq details[open] summary::after{content:"−"}
.faq details p{margin-top:.75rem;line-height:1.7}

/* === Contact form === */
.contact-form-section{max-width:680px}
.contact-form-section h2{text-align:center;margin-bottom:2rem}
.contact-form label{display:block;font-size:.9rem;font-weight:600;margin-bottom:.4rem;color:var(--color-primary)}
.contact-form input,.contact-form textarea{
  width:100%;padding:.85rem 1rem;
  border:1px solid rgba(15,19,32,.18);
  border-radius:6px;background:#fff;
  font:inherit;color:var(--color-neutral-dark);
}
.contact-form input:focus,.contact-form textarea:focus{outline:2px solid var(--color-accent);outline-offset:1px;border-color:var(--color-accent)}
.contact-form p{margin:1rem 0}

/* === Footer === */
.site-footer{background:var(--color-neutral-dark);color:var(--color-neutral-light);padding:3.5rem 1.25rem 2rem;margin-top:3rem}
.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.4fr;gap:3rem}}
.site-footer .logo img{height:64px;filter:brightness(0) invert(1)}
.site-footer h3{color:var(--color-neutral-light);font-family:var(--font-body);font-size:.85rem;text-transform:uppercase;letter-spacing:.16em;margin-bottom:1rem}
.site-footer a{color:var(--color-secondary)}
.site-footer a:hover{color:var(--color-accent)}
.site-footer ul li{margin:.45rem 0}
.site-footer address{font-style:normal;line-height:1.7;margin-bottom:1.25rem}
.legal-links{font-size:.88rem}
.copyright{max-width:var(--maxw);margin:2.5rem auto 0;padding-top:1.5rem;border-top:1px solid rgba(250,240,232,.12);font-size:.82rem;color:rgba(250,240,232,.6);text-align:center}

/* === 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);
  display:flex;flex-direction:column;gap:.75rem;align-items:flex-start;
  box-shadow:0 20px 50px -20px rgba(0,0,0,.5);
  z-index:50;
  font-size:.92rem;
}
.cookie-banner p{margin:0;flex:1}
.cookie-banner button{
  background:var(--color-accent);color:var(--color-neutral-light);
  padding:.6rem 1.2rem;border-radius:6px;font-weight:600;
}
.cookie-banner button:hover{background:var(--color-secondary);color:var(--color-primary)}
body.cookies-accepted .cookie-banner{display:none}
@media (min-width:640px){
  .cookie-banner{flex-direction:row;align-items:center;left:auto;right:1.5rem;bottom:1.5rem;max-width:480px}
}
