:root{
  --color-primary:#7A2E1F;
  --color-secondary:#E8D9B2;
  --color-accent:#1F3A2E;
  --color-neutral-dark:#1B1B1B;
  --color-neutral-light:#FAF6EE;
  --font-heading:'Playfair Display', serif;
  --font-body:'Inter', sans-serif;
  --container:1180px;
}

/* === Base === */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);font-size:17px;line-height:1.65;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-neutral-dark);margin:0 0 .6em}
h1{font-size:clamp(2.25rem,5.2vw,4rem)}
h2{font-size:clamp(1.75rem,3.4vw,2.5rem)}
h3{font-size:1.25rem}
p{margin:0 0 1em}
a{color:var(--color-primary);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block;height:auto}
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:1.25rem}

/* === Buttons === */
.btn{display:inline-block;padding:.95rem 1.6rem;border-radius:4px;font-weight:600;font-size:.98rem;letter-spacing:.02em;transition:transform .15s ease,box-shadow .15s ease;border:1px solid transparent}
.btn-primary{background:var(--color-primary);color:var(--color-neutral-light)}
.btn-primary:hover{background:#5e2317;text-decoration:none;transform:translateY(-1px);box-shadow:0 8px 20px -10px rgba(122,46,31,.55)}
.btn-light{background:var(--color-neutral-light);color:var(--color-primary)}
.btn-light:hover{text-decoration:none;transform:translateY(-1px)}

/* === Header === */
.site-header{background:var(--color-neutral-light);border-bottom:1px solid rgba(27,27,27,.08);position:sticky;top:0;z-index:50}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:.85rem}
.logo{display:inline-block}
.logo img{height:72px;width:auto;display:block}
.nav-toggle{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;background:transparent;border:1px solid rgba(27,27,27,.15);border-radius:4px;cursor:pointer;padding:0 10px}
.nav-toggle span{display:block;height:2px;background:var(--color-neutral-dark);border-radius:2px}
.primary-nav{display:none}
.primary-nav ul{list-style:none;margin:0;padding:0;display:flex;gap:1.75rem}
.primary-nav a{color:var(--color-neutral-dark);font-weight:500;font-size:.97rem}
.primary-nav a:hover{color:var(--color-primary);text-decoration:none}
.primary-nav.is-open{display:block;position:absolute;left:0;right:0;top:100%;background:var(--color-neutral-light);border-bottom:1px solid rgba(27,27,27,.08);padding:1rem 1.25rem}
.primary-nav.is-open ul{flex-direction:column;gap:1rem}

/* === Hero (stacked) === */
.hero{padding-block:3rem 4rem;background:var(--color-neutral-light)}
.hero-inner{max-width:780px;margin-inline:auto}
.eyebrow{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;color:var(--color-primary);font-weight:600;margin:0 0 1rem}
.hero h1{margin-bottom:2rem}
.hero-figure{margin:0 0 2rem;border-radius:8px;overflow:hidden;aspect-ratio:16/9;background:var(--color-secondary)}
.hero-figure img{width:100%;height:100%;object-fit:cover}
.hero-sub{font-size:1.18rem;color:#3a3a3a;margin-bottom:1.75rem;max-width:62ch}
.hero-cta{margin:0}

/* === Intro === */
.intro{padding-block:4rem;background:var(--color-secondary)}
.intro-alt{background:var(--color-neutral-light)}
.intro-inner{display:grid;gap:2.5rem;align-items:center}
.intro-text p{font-size:1.05rem;max-width:60ch}
.intro-figure{margin:0;border-radius:8px;overflow:hidden;aspect-ratio:4/3;background:var(--color-neutral-light)}
.intro-figure img{width:100%;height:100%;object-fit:cover}

/* === Section heads === */
.section-head{text-align:center;max-width:62ch;margin:0 auto 2.5rem}
.section-head p{color:#444;font-size:1.05rem}

/* === Highlights grid === */
.highlights{padding-block:5rem;background:var(--color-neutral-light)}
.grid{display:grid;gap:1.25rem}
.grid-2{grid-template-columns:1fr}
.grid-3{grid-template-columns:1fr}
.card{background:#fff;border:1px solid rgba(27,27,27,.07);border-radius:8px;padding:1.75rem;transition:transform .18s ease,box-shadow .18s ease}
.card:hover{transform:translateY(-2px);box-shadow:0 18px 40px -25px rgba(27,27,27,.25)}
.card h3{color:var(--color-primary);margin-bottom:.6em}
.card p{margin:0;color:#333;font-size:.97rem}

/* === Testimonial === */
.testimonial{padding-block:4.5rem;background:var(--color-secondary)}
.testimonial blockquote{margin:0 auto;max-width:64ch;text-align:center;position:relative}
.testimonial blockquote::before{content:'„';font-family:var(--font-heading);font-size:5rem;line-height:1;color:var(--color-primary);display:block;margin-bottom:-1rem}
.testimonial p{font-family:var(--font-heading);font-size:clamp(1.15rem,2vw,1.45rem);line-height:1.5;color:var(--color-neutral-dark);font-style:italic}
.testimonial cite{display:block;margin-top:1.25rem;font-style:normal;font-size:.95rem;color:var(--color-accent);font-weight:500;font-family:var(--font-body)}

/* === CTA band === */
.cta-band{padding-block:4.5rem;background:var(--color-primary);color:var(--color-neutral-light)}
.cta-inner{text-align:center;max-width:62ch;margin-inline:auto}
.cta-band h2{color:var(--color-neutral-light)}
.cta-band p{color:rgba(250,246,238,.92);font-size:1.05rem}

/* === FAQ === */
.faq{padding-block:5rem;background:var(--color-neutral-light)}
.faq-list{max-width:780px;margin-inline:auto}
.faq details{border-top:1px solid rgba(27,27,27,.12);padding:1.1rem 0}
.faq details:last-child{border-bottom:1px solid rgba(27,27,27,.12)}
.faq summary{cursor:pointer;font-family:var(--font-heading);font-size:1.15rem;font-weight:600;color:var(--color-neutral-dark);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';font-size:1.6rem;color:var(--color-primary);font-weight:400;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{margin:.9rem 0 0;color:#333;font-size:.98rem}

/* === Footer === */
.site-footer{background:var(--color-neutral-dark);color:var(--color-neutral-light);padding-block:3.5rem 1.5rem;margin-top:0}
.footer-inner{display:grid;gap:2.5rem;grid-template-columns:1fr}
.footer-col h2{font-size:1rem;font-family:var(--font-body);text-transform:uppercase;letter-spacing:.14em;color:var(--color-secondary);margin:0 0 1rem}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.55rem}
.footer-col a{color:var(--color-neutral-light)}
.footer-col a:hover{color:var(--color-secondary);text-decoration:none}
.footer-col address{font-style:normal;color:rgba(250,246,238,.85);font-size:.95rem;line-height:1.7;margin:0 0 1rem}
.legal-links{margin-top:1rem!important;font-size:.9rem}
.tagline{color:rgba(250,246,238,.75);font-size:.95rem;max-width:30ch}
.vat{font-size:.85rem;color:rgba(250,246,238,.6);margin-top:.75rem}
.logo-footer img{height:60px;filter:brightness(0) invert(1)}
.footer-bottom{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid rgba(250,246,238,.12);font-size:.88rem;color:rgba(250,246,238,.65)}
.footer-bottom p{margin:0}

/* === Cookie banner === */
.cookie-banner{position:fixed;left:1rem;right:1rem;bottom:1rem;background:var(--color-neutral-dark);color:var(--color-neutral-light);padding:1.1rem 1.25rem;border-radius:8px;display:flex;flex-direction:column;gap:.75rem;align-items:flex-start;box-shadow:0 20px 50px -20px rgba(0,0,0,.5);z-index:100;font-size:.92rem}
.cookie-banner p{margin:0}
.cookie-banner button{background:var(--color-primary);color:var(--color-neutral-light);border:0;padding:.6rem 1.1rem;border-radius:4px;font:inherit;font-weight:600;cursor:pointer}
.cookie-banner button:hover{background:#5e2317}
body.cookies-accepted .cookie-banner{display:none}

/* === Responsive === */
@media (min-width:640px){
  .grid-2{grid-template-columns:repeat(2,1fr)}
  .cookie-banner{flex-direction:row;align-items:center;left:auto;right:1rem;max-width:520px}
}
@media (min-width:768px){
  body{font-size:18px}
  .logo img{height:96px}
  .logo-footer img{height:72px}
  .nav-toggle{display:none}
  .primary-nav{display:block!important;position:static;background:transparent;border:0;padding:0}
  .primary-nav ul{flex-direction:row}
  .hero{padding-block:4.5rem 5.5rem}
  .intro{padding-block:5.5rem}
  .intro-inner{grid-template-columns:1fr 1fr;gap:4rem}
  .intro-inner-reverse .intro-text{order:2}
  .intro-inner-reverse .intro-figure{order:1}
  .grid-3{grid-template-columns:repeat(3,1fr);gap:1.75rem}
  .grid-2{gap:1.75rem}
  .footer-inner{grid-template-columns:1.2fr 1fr 1.4fr}
}
@media (min-width:1024px){
  .hero h1{margin-bottom:2.5rem}
  .hero-figure{aspect-ratio:21/9}
}
