:root{
  --color-primary:#6B6745;
  --color-secondary:#E5DDC5;
  --color-accent:#8E3F2A;
  --color-neutral-dark:#262316;
  --color-neutral-light:#F8F3E9;
  --font-heading:'Lora',serif;
  --font-body:'Inter',sans-serif;
}

/* === Base === */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--font-body);color:var(--color-neutral-dark);background:var(--color-neutral-light);font-size:17px;line-height:1.65;font-weight:400}
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);font-weight:600;color:var(--color-neutral-dark);line-height:1.2;margin:0 0 1rem}
h1{font-size:clamp(2rem,4.5vw,3.25rem)}
h2{font-size:clamp(1.5rem,3vw,2.25rem);margin-bottom:1.25rem}
h3{font-size:1.2rem;margin-bottom:.6rem}
p{margin:0 0 1rem}

/* === Layout === */
.layout{display:flex;flex-direction:column;min-height:100vh}
.sidebar{background:var(--color-neutral-dark);color:var(--color-neutral-light);padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1rem}
.sidebar .logo{display:inline-block}
.sidebar .logo img{height:72px;width:auto}
.sidebar-nav{display:flex;flex-direction:column;gap:.5rem}
.nav-toggle{display:inline-block;align-self:flex-start;background:transparent;border:1px solid var(--color-secondary);color:var(--color-neutral-light);padding:.45rem .9rem;font:inherit;cursor:pointer;border-radius:2px}
.sidebar-nav ul{list-style:none;margin:0;padding:0;display:none;flex-direction:column;gap:.25rem}
.sidebar-nav ul.open{display:flex}
.sidebar-nav a{display:block;color:var(--color-neutral-light);padding:.6rem 0;font-size:1.05rem;letter-spacing:.02em;border-bottom:1px solid rgba(229,221,197,.15)}
.sidebar-nav a:hover,.sidebar-nav a[aria-current="page"]{color:var(--color-secondary);text-decoration:none}
.sidebar-foot{font-size:.78rem;color:rgba(229,221,197,.55);margin:0}
.content{flex:1;padding:2rem 1.25rem 0}

/* === Hero === */
.hero{padding:1rem 0 3rem;max-width:980px}
.eyebrow{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--color-primary);margin:0 0 1.25rem;font-weight:500}
.hero-sub{font-size:1.15rem;color:var(--color-primary);max-width:56ch;margin-bottom:1.75rem}
.hero-cta{margin-bottom:2.5rem}
.hero-figure{margin:0;border-radius:6px;overflow:hidden}
.hero-figure img{width:100%;aspect-ratio:16/10;object-fit:cover}

/* === Buttons === */
.btn{display:inline-block;padding:.85rem 1.6rem;font-family:var(--font-body);font-weight:500;font-size:1rem;border-radius:2px;border:1px solid transparent;cursor:pointer;letter-spacing:.02em;transition:opacity .2s}
.btn-primary{background:var(--color-accent);color:var(--color-neutral-light)}
.btn-primary:hover{opacity:.88;text-decoration:none}
.btn-light{background:var(--color-neutral-light);color:var(--color-neutral-dark)}
.btn-light:hover{background:var(--color-secondary);text-decoration:none}

/* === Intro === */
.intro{padding:3rem 0;border-top:1px solid rgba(38,35,22,.12)}
.intro-grid{display:grid;grid-template-columns:1fr;gap:2rem;align-items:start}
.intro-text{max-width:62ch}
.intro-text--wide{max-width:72ch}
.intro-figure{margin:0;border-radius:6px;overflow:hidden}
.intro-figure img{aspect-ratio:4/3;object-fit:cover;width:100%}

/* === Highlights / cards === */
.highlights{padding:3rem 0;border-top:1px solid rgba(38,35,22,.12)}
.card-grid{display:grid;grid-template-columns:1fr;gap:1.25rem}
.card{background:var(--color-secondary);padding:1.75rem;border-radius:4px;border-left:3px solid var(--color-primary)}
.card-icon{display:inline-block;font-size:1.4rem;color:var(--color-accent);margin-bottom:.5rem}
.card h3{margin-top:0}

/* === Testimonial === */
.testimonial{padding:3.5rem 0;border-top:1px solid rgba(38,35,22,.12)}
.testimonial blockquote{margin:0;max-width:64ch}
.testimonial p{font-family:var(--font-heading);font-style:italic;font-size:1.2rem;line-height:1.55;color:var(--color-neutral-dark)}
.testimonial cite{display:block;margin-top:1rem;font-style:normal;font-size:.95rem;color:var(--color-primary)}

/* === CTA band === */
.cta-band{margin:3rem 0;padding:3rem 1.75rem;background:var(--color-primary);color:var(--color-neutral-light);border-radius:6px}
.cta-band h2{color:var(--color-neutral-light);margin-bottom:.75rem}
.cta-band p{color:rgba(248,243,233,.9);max-width:60ch;margin-bottom:1.5rem}

/* === Project / gallery === */
.project{padding:3rem 0;border-top:1px solid rgba(38,35,22,.12);max-width:1000px}
.project p{max-width:68ch}
.gallery{display:grid;grid-template-columns:1fr;gap:1rem;margin-top:1.5rem}
.gallery figure{margin:0;border-radius:4px;overflow:hidden}
.gallery img{aspect-ratio:4/3;object-fit:cover;width:100%}
.gallery--single{max-width:680px}

/* === FAQ === */
.faq{padding:3rem 0;border-top:1px solid rgba(38,35,22,.12);max-width:780px}
.faq details{border-bottom:1px solid rgba(38,35,22,.15);padding:1rem 0}
.faq summary{cursor:pointer;font-family:var(--font-heading);font-size:1.1rem;font-weight:500;color:var(--color-neutral-dark)}
.faq details[open] summary{color:var(--color-accent)}
.faq details p{margin-top:.75rem;color:var(--color-primary)}

/* === Contact === */
.contact-block{padding:3rem 0;border-top:1px solid rgba(38,35,22,.12);max-width:1000px}
.contact-grid{display:grid;grid-template-columns:1fr;gap:2rem;margin-bottom:2.5rem}
.contact-grid address{font-style:normal;line-height:1.8}
.hours{border-collapse:collapse;width:100%;max-width:320px;font-size:.95rem}
.hours th,.hours td{text-align:left;padding:.45rem .5rem;border-bottom:1px solid rgba(38,35,22,.1)}
.hours th{font-weight:500;color:var(--color-primary)}
.contact-form{background:var(--color-secondary);padding:1.75rem;border-radius:4px;max-width:560px}
.contact-form h3{margin-top:0}
.contact-form label{display:block;font-size:.88rem;font-weight:500;margin-bottom:.35rem;color:var(--color-neutral-dark)}
.contact-form input,.contact-form textarea{width:100%;padding:.65rem .75rem;border:1px solid rgba(38,35,22,.2);border-radius:2px;font:inherit;background:var(--color-neutral-light)}
.contact-form input:focus,.contact-form textarea:focus{outline:2px solid var(--color-accent);outline-offset:1px}

/* === Footer === */
.site-footer{margin-top:4rem;padding:2.5rem 0 2rem;border-top:1px solid rgba(38,35,22,.15);color:var(--color-primary);font-size:.93rem}
.footer-grid{display:grid;grid-template-columns:1fr;gap:1.75rem}
.footer-brand{font-family:var(--font-heading);font-size:1.15rem;color:var(--color-neutral-dark);margin-bottom:.4rem}
.site-footer nav ul{list-style:none;margin:0;padding:0}
.site-footer nav li{margin-bottom:.4rem}
.site-footer nav a{color:var(--color-primary)}
.site-footer address{font-style:normal;line-height:1.7}
.vat{display:inline-block;margin:.4rem 0;font-size:.82rem;color:rgba(38,35,22,.55)}
.copyright{margin:2rem 0 0;font-size:.82rem;color:rgba(38,35,22,.55)}

/* === 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:4px;box-shadow:0 12px 32px rgba(0,0,0,.25);display:flex;flex-direction:column;gap:.75rem;z-index:50;font-size:.92rem}
.cookie-banner p{margin:0}
.cookie-banner button{align-self:flex-start;background:var(--color-accent);color:var(--color-neutral-light);border:none;padding:.55rem 1.1rem;font:inherit;cursor:pointer;border-radius:2px}
body.cookies-accepted .cookie-banner{display:none}

/* === Desktop === */
@media (min-width:900px){
  .layout{flex-direction:row}
  .sidebar{width:240px;min-height:100vh;position:sticky;top:0;height:100vh;padding:2rem 1.75rem;justify-content:flex-start;gap:2rem;flex-shrink:0}
  .sidebar .logo img{height:96px}
  .nav-toggle{display:none}
  .sidebar-nav ul{display:flex !important}
  .sidebar-foot{margin-top:auto}
  .content{padding:3.5rem 3rem 0;max-width:none}
  .hero{padding:1rem 0 4rem}
  .intro-grid{grid-template-columns:3fr 2fr;gap:3rem}
  .card-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1.4fr 1fr 1.4fr;gap:3rem}
  .cookie-banner{flex-direction:row;align-items:center;left:auto;right:1.5rem;bottom:1.5rem;max-width:520px}
  .cookie-banner button{align-self:auto;flex-shrink:0}
}
@media (min-width:1200px){
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .content{padding-left:4rem;padding-right:4rem;max-width:1180px}
}
