:root{
  --color-primary:#7A2E1F;
  --color-secondary:#E8D9B2;
  --color-accent:#1F3A2E;
  --color-neutral-dark:#1B1B1B;
  --color-neutral-light:#FAF6EE;
  --font-heading:'Inter',sans-serif;
  --font-body:'Inter',sans-serif;
  --radius:12px;
  --max-content:920px;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);background:var(--color-neutral-light);color:var(--color-neutral-dark);line-height:1.6;font-size:17px}
img{max-width:100%;display:block;height:auto}
a{color:var(--color-primary);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{font-family:var(--font-heading);font-weight:600;line-height:1.18;color:var(--color-neutral-dark);margin:0 0 .75rem}
h1{font-size:clamp(2.25rem,5vw,3.75rem);letter-spacing:-.02em}
h2{font-size:clamp(1.6rem,3vw,2.25rem);letter-spacing:-.01em}
h3{font-size:1.2rem}
p{margin:0 0 1rem}

/* === Layout: sidebar + content === */
.layout{display:block;min-height:100vh}
.sidebar{background:var(--color-primary);color:var(--color-neutral-light);padding:1.5rem 1.25rem;display:flex;flex-direction:row;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.sidebar .logo{display:inline-block}
.sidebar .logo img{height:72px;width:auto}
.sidebar-foot{font-size:.8rem;opacity:.85;margin:0;width:100%;order:3}
.primary-nav{flex:1}
.primary-nav ul{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.25rem 1rem;justify-content:flex-end}
.primary-nav a{color:var(--color-neutral-light);font-weight:500;padding:.4rem .6rem;border-radius:6px;display:inline-block}
.primary-nav a:hover{background:rgba(250,246,238,.12);text-decoration:none}
.primary-nav a[aria-current="page"]{background:var(--color-accent);color:var(--color-neutral-light)}

.content{padding:2rem 1.25rem 0}

@media (min-width:900px){
  .layout{display:grid;grid-template-columns:240px 1fr}
  .sidebar{position:sticky;top:0;height:100vh;flex-direction:column;align-items:flex-start;justify-content:flex-start;padding:2rem 1.5rem;gap:2rem}
  .sidebar .logo img{height:96px}
  .primary-nav{width:100%;flex:none}
  .primary-nav ul{flex-direction:column;align-items:stretch;gap:.25rem;justify-content:flex-start}
  .primary-nav a{padding:.6rem .75rem;font-size:1rem}
  .sidebar-foot{margin-top:auto;order:0;width:auto}
  .content{padding:3rem 3rem 0}
}

/* === Common === */
.eyebrow{font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--color-primary);margin:0 0 .75rem}
.section{max-width:var(--max-content);margin:0 auto;padding:3rem 0}
.section__sub{font-size:1.1rem;color:#4a4a4a;margin-bottom:1.5rem;max-width:60ch}

/* === Buttons === */
.btn{display:inline-block;padding:.85rem 1.6rem;border-radius:8px;font-weight:600;font-family:var(--font-heading);letter-spacing:.01em;transition:transform .15s ease,box-shadow .15s ease,background .15s ease;border:none;cursor:pointer;font-size:1rem}
.btn:hover{text-decoration:none;transform:translateY(-1px);box-shadow:0 8px 20px -8px rgba(122,46,31,.4)}
.btn--primary{background:var(--color-primary);color:var(--color-neutral-light)}
.btn--accent{background:var(--color-accent);color:var(--color-neutral-light)}

/* === Hero === */
.hero{max-width:var(--max-content);margin:0 auto;padding:2rem 0 3rem}
.hero h1{margin-bottom:1rem}
.hero__sub{font-size:1.2rem;color:#3d3d3d;max-width:55ch;margin-bottom:1.75rem}
.hero__media{margin:2.5rem 0 0;border-radius:var(--radius);overflow:hidden;background:var(--color-secondary)}
.hero__media img{width:100%;aspect-ratio:16/9;object-fit:cover}

/* === Intro grid (image+text) === */
.section--intro{}
.intro-grid{display:grid;gap:2rem;align-items:center}
.intro-grid__media{margin:0;border-radius:var(--radius);overflow:hidden;background:var(--color-secondary)}
.intro-grid__media img{aspect-ratio:4/3;object-fit:cover;width:100%}
@media (min-width:768px){
  .intro-grid{grid-template-columns:1.1fr 1fr;gap:3rem}
}

/* === Cards === */
.cards{display:grid;grid-template-columns:1fr;gap:1.25rem}
@media (min-width:640px){.cards{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1100px){.cards{grid-template-columns:repeat(2,1fr)}}
.card{background:var(--color-neutral-light);border:1px solid rgba(27,27,27,.1);border-radius:var(--radius);padding:1.75rem;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}
.card:hover{border-color:var(--color-primary);box-shadow:0 12px 30px -18px rgba(27,27,27,.25)}
.card__icon{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:8px;background:var(--color-secondary);color:var(--color-primary);font-size:1.25rem;margin-bottom:.85rem}
.card h3{margin-bottom:.5rem;color:var(--color-primary)}
.card p{margin:0;font-size:.97rem;color:#2c2c2c}
.cards--contact .card p{font-size:1rem}

/* === Testimonial === */
.section--quote{max-width:760px}
.quote{margin:0;padding:2.5rem 1.5rem;text-align:center;border-top:1px solid rgba(122,46,31,.2);border-bottom:1px solid rgba(122,46,31,.2)}
.quote p{font-family:var(--font-heading);font-size:clamp(1.15rem,2vw,1.5rem);line-height:1.5;color:var(--color-neutral-dark);margin-bottom:1.25rem;font-weight:500}
.quote cite{font-style:normal;font-size:.92rem;color:var(--color-primary);font-weight:600;letter-spacing:.02em}

/* === CTA band === */
.cta-band{background:var(--color-primary);color:var(--color-neutral-light);border-radius:var(--radius);padding:3rem 2rem;text-align:center;margin:3rem auto;max-width:var(--max-content)}
.cta-band h2{color:var(--color-neutral-light);margin-bottom:.75rem}
.cta-band p{color:rgba(250,246,238,.9);max-width:50ch;margin-left:auto;margin-right:auto}
.cta-band .btn--accent{background:var(--color-secondary);color:var(--color-primary)}

/* === Contact form === */
.contact-form{max-width:560px;display:grid;gap:1rem}
.form-row{display:flex;flex-direction:column;gap:.4rem}
.form-row label{font-weight:600;font-size:.92rem;color:var(--color-neutral-dark)}
.form-row input,.form-row textarea{padding:.7rem .85rem;border:1px solid rgba(27,27,27,.2);border-radius:8px;font:inherit;background:var(--color-neutral-light);color:var(--color-neutral-dark)}
.form-row input:focus,.form-row textarea:focus{outline:2px solid var(--color-primary);outline-offset:1px;border-color:var(--color-primary)}

/* === FAQ === */
.faq{display:grid;gap:.6rem;max-width:780px}
.faq details{background:var(--color-neutral-light);border:1px solid rgba(27,27,27,.1);border-radius:10px;padding:1rem 1.25rem}
.faq details[open]{border-color:var(--color-primary)}
.faq summary{font-weight:600;cursor:pointer;font-family:var(--font-heading);font-size:1.02rem;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--color-primary);font-weight:700;margin-left:1rem}
.faq details[open] summary::after{content:"−"}
.faq details p{margin:.85rem 0 0;color:#2c2c2c}

/* === Footer === */
.site-footer{margin-top:4rem;background:var(--color-neutral-dark);color:var(--color-neutral-light);padding:3rem 1.5rem 2rem;border-top-left-radius:var(--radius);border-top-right-radius:var(--radius)}
.footer-grid{display:grid;grid-template-columns:1fr;gap:2rem;max-width:var(--max-content);margin:0 auto}
@media (min-width:768px){.footer-grid{grid-template-columns:repeat(3,1fr)}}
.site-footer a{color:var(--color-secondary)}
.footer__brand{font-family:var(--font-heading);font-weight:700;font-size:1.1rem;margin-bottom:.5rem;color:var(--color-neutral-light)}
.site-footer nav ul,.legal-links{list-style:none;margin:0;padding:0;display:grid;gap:.4rem}
.site-footer address{font-style:normal;margin-bottom:1rem;line-height:1.7}
.legal-links{margin-top:1rem;font-size:.9rem}
.vat{margin-top:1rem;font-size:.85rem;opacity:.7}
.copyright{text-align:center;font-size:.85rem;opacity:.7;margin:2rem 0 0;border-top:1px solid rgba(250,246,238,.12);padding-top:1.5rem;max-width:var(--max-content);margin-left:auto;margin-right:auto}

/* === 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);box-shadow:0 20px 50px -15px rgba(0,0,0,.4);display:flex;flex-direction:column;gap:.75rem;z-index:1000;max-width:560px;margin-left:auto;margin-right:auto}
.cookie-banner p{margin:0;font-size:.92rem}
.cookie-banner button{align-self:flex-end;background:var(--color-accent);color:var(--color-neutral-light);border:none;padding:.55rem 1.1rem;border-radius:6px;font-weight:600;cursor:pointer;font-family:inherit}
.cookie-banner button:hover{filter:brightness(1.15)}
body.cookies-accepted .cookie-banner{display:none}
@media (min-width:560px){.cookie-banner{flex-direction:row;align-items:center;justify-content:space-between}.cookie-banner button{align-self:auto}}
