:root{
  --cream:#f7f1e6;
  --cream-2:#efe6d5;
  --ink:#2a2018;
  --ink-soft:#5b4d3f;
  --espresso:#3a2a1c;
  --crust:#b8702f;
  --crust-dark:#9a5a22;
  --gold:#c9962e;
  --line:rgba(58,42,28,.14);
  --white:#fffdf9;
  --shadow-sm:0 2px 14px rgba(58,42,28,.08);
  --shadow:0 18px 50px -18px rgba(58,42,28,.30);
  --r:18px;
  --maxw:1180px;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Jost',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:86px}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  font-weight:300;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.08;color:var(--espresso);letter-spacing:.2px}
h2{font-size:clamp(2rem,4.4vw,3.2rem)}
h3{font-size:1.5rem;font-weight:600}
p{font-size:1.02rem}

.section{max-width:var(--maxw);margin:0 auto;padding:clamp(64px,9vw,120px) clamp(20px,5vw,40px)}
.eyebrow{
  font-size:.8rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--crust);font-weight:500;margin-bottom:.9rem;
}
.section-head{margin-bottom:clamp(36px,5vw,60px);max-width:640px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-lead{color:var(--ink-soft);margin-top:1rem;font-size:1.1rem}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-sm)}

/* Boutons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--sans);font-weight:500;font-size:.95rem;letter-spacing:.04em;
  padding:.9rem 1.7rem;border-radius:999px;cursor:pointer;border:1px solid transparent;
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease,color .25s ease;
  text-transform:uppercase;
}
.btn-primary{background:var(--crust);color:#fff;box-shadow:0 10px 26px -10px rgba(184,112,47,.7)}
.btn-primary:hover{background:var(--crust-dark);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn-ghost:hover{background:rgba(255,255,255,.14);transform:translateY(-2px)}
.btn-pill{background:var(--espresso);color:var(--cream);padding:.6rem 1.2rem;font-size:.78rem}
.btn-pill:hover{background:var(--crust)}
.btn.full{width:100%;margin-top:.4rem}
.link-arrow{color:var(--crust);font-weight:500;letter-spacing:.04em;display:inline-flex;align-items:center;gap:.4rem;border-bottom:1px solid transparent;transition:.25s}
.link-arrow::after{content:"\2192";transition:transform .25s}
.link-arrow:hover{border-color:var(--crust)}
.link-arrow:hover::after{transform:translateX(4px)}

/* Topbar */
.topbar{background:var(--espresso);color:var(--cream);font-size:.8rem}
.topbar-inner{max-width:var(--maxw);margin:0 auto;padding:.45rem clamp(20px,5vw,40px);display:flex;justify-content:space-between;align-items:center;letter-spacing:.05em}
.topbar-status{display:inline-flex;align-items:center;gap:.5rem}
.topbar-phone{font-weight:500}
.dot{width:8px;height:8px;border-radius:50%;background:var(--gold);display:inline-block}
.dot.open{background:#5fbf6a;box-shadow:0 0 0 3px rgba(95,191,106,.25)}
.dot.closed{background:#d9755a;box-shadow:0 0 0 3px rgba(217,117,90,.25)}

/* Header */
.header{position:sticky;top:0;z-index:50;background:rgba(247,241,230,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transition:box-shadow .3s}
.header.scrolled{box-shadow:var(--shadow-sm)}
.header-inner{max-width:var(--maxw);margin:0 auto;padding:.7rem clamp(20px,5vw,40px);display:flex;align-items:center;gap:2rem}
.brand{display:flex;align-items:center;gap:.7rem;margin-right:auto}
.brand-mark{
  width:44px;height:44px;border-radius:50%;display:grid;place-items:center;
  background:var(--crust);color:#fff;font-family:var(--serif);font-weight:700;font-size:1.2rem;letter-spacing:.5px;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.25);
}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-name{font-family:var(--serif);font-size:1.35rem;font-weight:600;color:var(--espresso)}
.brand-year{font-size:.72rem;letter-spacing:.4em;color:var(--crust)}
.nav{display:flex;gap:1.7rem}
.nav a{font-size:.92rem;color:var(--ink-soft);font-weight:400;letter-spacing:.02em;position:relative;padding:.2rem 0}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--crust);transition:width .25s}
.nav a:hover{color:var(--espresso)}
.nav a:hover::after{width:100%}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.burger span{width:24px;height:2px;background:var(--espresso);transition:.3s}
.burger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.active span:nth-child(2){opacity:0}
.burger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Hero */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-image:url('https://images.unsplash.com/photo-1608198093002-ad4e005484ec?w=1600&q=80&auto=format&fit=crop');background-size:cover;background-position:center;transform:scale(1.05);animation:slowzoom 18s ease-in-out infinite alternate}
@keyframes slowzoom{to{transform:scale(1.14)}}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(110deg,rgba(34,24,15,.82) 0%,rgba(34,24,15,.55) 45%,rgba(34,24,15,.25) 100%)}
.hero-content{position:relative;z-index:2;max-width:var(--maxw);width:100%;margin:0 auto;padding:0 clamp(20px,5vw,40px)}
.hero-eyebrow{font-size:.82rem;letter-spacing:.34em;text-transform:uppercase;color:var(--cream-2);margin-bottom:1.3rem}
.hero-title{font-size:clamp(2.7rem,7vw,5.4rem);color:#fff;font-weight:600;line-height:1.02;text-shadow:0 2px 30px rgba(0,0,0,.3)}
.hero-sub{max-width:540px;margin:1.5rem 0 2.2rem;font-size:1.18rem;color:#f4ece0;font-weight:300}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero-meta{display:flex;align-items:center;gap:1.6rem;margin-top:2.4rem;flex-wrap:wrap}
.hero-badge{display:inline-flex;align-items:center;gap:.6rem;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);padding:.5rem 1rem;border-radius:999px;font-size:.85rem;backdrop-filter:blur(6px)}
.hero-call{font-size:.95rem;color:#f4ece0;border-bottom:1px solid rgba(255,255,255,.4);padding-bottom:2px}
.hero-scroll{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;color:#fff;font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;opacity:.85}
.hero-scroll::after{content:"";display:block;width:1px;height:34px;background:#fff;margin:.6rem auto 0;animation:scrollpulse 2s ease-in-out infinite}
@keyframes scrollpulse{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

.nav a.active{color:var(--espresso);font-weight:500}
.nav a.active::after{width:100%}

/* Page hero (pages internes) */
.page-hero{position:relative;min-height:48vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.page-hero .ph-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.04)}
.page-hero .ph-overlay{position:absolute;inset:0;background:linear-gradient(110deg,rgba(34,24,15,.84),rgba(34,24,15,.45))}
.page-hero-content{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;width:100%;padding:0 clamp(20px,5vw,40px) clamp(40px,5vw,62px)}
.page-hero h1{font-size:clamp(2.3rem,6vw,4rem);color:#fff;text-shadow:0 2px 26px rgba(0,0,0,.3)}
.page-hero .ph-sub{max-width:560px;margin-top:1rem;color:#f4ece0;font-size:1.12rem;font-weight:300}
.breadcrumb{font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;color:var(--cream-2);margin-bottom:1rem}
.breadcrumb a{opacity:.85}
.breadcrumb a:hover{opacity:1}

/* CTA band */
.cta-band{background:var(--crust);color:#fff;text-align:center}
.cta-band-inner{max-width:720px;margin:0 auto;padding:clamp(56px,7vw,92px) clamp(20px,5vw,40px)}
.cta-band h2{color:#fff;margin-bottom:1rem}
.cta-band p{color:#fbeede;margin-bottom:1.8rem;font-size:1.1rem}
.cta-band .btn-primary{background:#fff;color:var(--crust)}
.cta-band .btn-primary:hover{background:var(--espresso);color:#fff}
.cta-band .btn-ghost{border-color:rgba(255,255,255,.7)}

/* Aperçu maison sur accueil */
.apercu{background:var(--cream-2)}
.apercu-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,72px);align-items:center}

/* Bandeau */
.bandeau{background:var(--espresso);color:var(--cream)}
.bandeau-inner{max-width:var(--maxw);margin:0 auto;padding:clamp(48px,6vw,72px) clamp(20px,5vw,40px);display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(24px,3vw,44px)}
.value h3{color:#fff;font-size:1.45rem;margin-bottom:.6rem;position:relative;padding-bottom:.7rem}
.value h3::after{content:"";position:absolute;left:0;bottom:0;width:34px;height:2px;background:var(--gold)}
.value p{color:#d8cab5;font-size:.96rem}

/* Maison */
.maison-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,72px);align-items:center}
.maison-images{position:relative;min-height:440px}
.maison-img-main{position:absolute;width:78%;height:88%;object-fit:cover;border-radius:var(--r);box-shadow:var(--shadow);top:0;left:0}
.maison-img-sub{position:absolute;width:46%;height:46%;object-fit:cover;border-radius:var(--r);box-shadow:var(--shadow);bottom:0;right:0;border:6px solid var(--cream)}
.maison-text h2{margin-bottom:1.2rem}
.maison-text p{color:var(--ink-soft);margin-bottom:1rem}
.maison-points{list-style:none;margin:1.4rem 0;display:grid;gap:.7rem}
.maison-points li{padding-left:1.7rem;position:relative;color:var(--ink);font-size:1rem}
.maison-points li::before{content:"";position:absolute;left:0;top:.55em;width:9px;height:9px;border-radius:50%;background:var(--crust)}

/* Specialites */
.spec-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.5vw,32px)}
.spec-card{background:var(--white);border-radius:var(--r);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);transition:transform .35s ease,box-shadow .35s ease}
.spec-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.spec-img{height:230px;background-size:cover;background-position:center;transition:transform .5s ease}
.spec-card:hover .spec-img{transform:scale(1.05)}
.spec-body{padding:1.6rem 1.6rem 1.9rem}
.spec-body h3{margin-bottom:.6rem}
.spec-body p{color:var(--ink-soft);font-size:.97rem}

/* Carte */
.carte-tabs{display:flex;justify-content:center;flex-wrap:wrap;gap:.6rem;margin-bottom:2.4rem}
.tab{
  font-family:var(--sans);font-size:.92rem;letter-spacing:.04em;padding:.6rem 1.4rem;border-radius:999px;
  background:transparent;border:1px solid var(--line);color:var(--ink-soft);cursor:pointer;transition:.25s;
}
.tab:hover{border-color:var(--crust);color:var(--crust)}
.tab.active{background:var(--crust);border-color:var(--crust);color:#fff}
.menu-list{display:none;max-width:760px;margin:0 auto;animation:fade .4s ease}
.menu-list.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.menu-item{display:flex;align-items:baseline;gap:1rem;padding:1.05rem 0;border-bottom:1px dashed var(--line)}
.menu-item:last-child{border-bottom:none}
.mi-name{font-family:var(--serif);font-size:1.3rem;font-weight:600;color:var(--espresso);white-space:nowrap}
.mi-desc{color:var(--ink-soft);font-size:.92rem;flex:1}
.mi-dots{flex:1;border-bottom:1px dotted var(--line);transform:translateY(-4px)}
.mi-price{font-weight:500;color:var(--crust);white-space:nowrap;font-size:1.05rem}
.carte-note{text-align:center;color:var(--ink-soft);font-size:.9rem;margin-top:2.4rem;font-style:italic}

/* Commande */
.commande{background:var(--cream-2)}
.commande-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,64px);align-items:start}
.commande-info h2{margin-bottom:1.1rem}
.commande-info p{color:var(--ink-soft)}
.commande-points{list-style:none;margin:1.4rem 0;display:grid;gap:.7rem}
.commande-points li{padding-left:1.7rem;position:relative;font-size:1rem}
.commande-points li::before{content:"\2713";position:absolute;left:0;color:var(--crust);font-weight:600}
.commande-call{margin-top:1.8rem;display:flex;flex-direction:column;gap:.3rem}
.commande-call span{color:var(--ink-soft);font-size:.92rem}
.commande-call .link-arrow{font-size:1.3rem;font-family:var(--serif)}
.commande-call .link-arrow::after{content:""}

/* Forms */
.form{padding:0}
.form.card{padding:2rem}
.form h3{margin-bottom:1.3rem}
.field{margin-bottom:1rem;display:flex;flex-direction:column}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
label{font-size:.82rem;letter-spacing:.04em;color:var(--ink-soft);margin-bottom:.4rem;font-weight:400}
input,select,textarea{
  font-family:var(--sans);font-size:.98rem;font-weight:300;color:var(--ink);
  padding:.8rem .95rem;border:1px solid var(--line);border-radius:12px;background:var(--white);
  transition:border-color .2s,box-shadow .2s;width:100%;
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--crust);box-shadow:0 0 0 3px rgba(184,112,47,.12)}
textarea{resize:vertical}
.form-feedback{margin-top:.9rem;font-size:.92rem;min-height:1.2em}
.form-feedback.ok{color:#2f7d3c}
.form-feedback.err{color:#c0492b}

/* Galerie */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
.g-item{background-size:cover;background-position:center;border-radius:14px;transition:transform .5s ease,filter .5s ease;filter:saturate(1.02)}
.g-item:hover{transform:scale(1.02);filter:saturate(1.15) brightness(1.03)}
.g-tall{grid-row:span 2}
.g-wide{grid-column:span 2}

/* Avis */
.avis{background:var(--espresso);color:var(--cream)}
.avis h2{color:#fff}
.avis .eyebrow{color:var(--gold)}
.avis-rating{display:inline-flex;align-items:center;gap:.7rem;margin-top:1rem}
.stars{color:var(--gold);letter-spacing:2px;font-size:1.1rem}
.avis-rating-text{color:#d8cab5;font-size:.95rem}
.avis-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.5vw,28px)}
.avis-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:var(--r);padding:1.8rem}
.avis-card .ac-stars{color:var(--gold);letter-spacing:2px;margin-bottom:.9rem}
.avis-card p{color:#ece2d2;font-style:italic;font-family:var(--serif);font-size:1.18rem;line-height:1.5}
.avis-card .ac-meta{margin-top:1.2rem;display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:#c3b49c}
.avis-card .ac-name{font-weight:500;color:#fff;font-family:var(--sans);font-style:normal}

/* Acces */
.acces-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,60px);align-items:stretch}
.acces-info h2{margin-bottom:1.5rem}
.hours{padding:1.6rem 1.8rem;margin-bottom:1.6rem}
.hours-row{display:flex;justify-content:space-between;padding:.55rem 0;border-bottom:1px solid var(--line);font-size:.98rem}
.hours-row:last-child{border-bottom:none}
.hours-row.today{font-weight:500;color:var(--crust)}
.hours-row .hr-day{color:var(--ink-soft)}
.hours-row.today .hr-day{color:var(--crust)}
.contact-blocks{display:grid;gap:1.1rem}
.contact-block{display:flex;flex-direction:column}
.contact-label{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--crust);margin-bottom:.2rem}
.contact-value{font-size:1.08rem;color:var(--espresso)}
.acces-map{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);min-height:420px;position:relative;border:1px solid var(--line)}
.acces-map iframe{width:100%;height:100%;min-height:420px;border:0;display:block;filter:sepia(.12) saturate(1.05)}
.map-link{position:absolute;bottom:14px;left:14px;background:var(--white);color:var(--espresso);padding:.6rem 1.1rem;border-radius:999px;font-size:.85rem;font-weight:500;box-shadow:var(--shadow-sm)}
.map-link:hover{background:var(--crust);color:#fff}

/* Contact */
.contact-inner{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(32px,4vw,56px);padding:clamp(32px,4vw,56px);align-items:center}
.contact-text h2{margin-bottom:1rem}
.contact-text p{color:var(--ink-soft)}

/* Footer */
.footer{background:#241810;color:#cdbfa9}
.footer-inner{max-width:var(--maxw);margin:0 auto;padding:clamp(40px,5vw,64px) clamp(20px,5vw,40px);display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between;align-items:center}
.footer-brand{display:flex;align-items:center;gap:.9rem}
.footer-name{font-family:var(--serif);font-size:1.4rem;color:#fff;font-weight:600}
.footer-tag{font-size:.82rem;letter-spacing:.05em}
.footer-nav{display:flex;gap:1.5rem;flex-wrap:wrap}
.footer-nav a{font-size:.92rem}
.footer-nav a:hover,.footer-contact a:hover{color:var(--gold)}
.footer-contact{display:flex;flex-direction:column;gap:.3rem;text-align:right}
.footer-contact a{font-size:.95rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:1.2rem clamp(20px,5vw,40px);max-width:var(--maxw);margin:0 auto;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;font-size:.82rem;color:#9c8d76}

/* Reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* Responsive */
@media(max-width:900px){
  .bandeau-inner{grid-template-columns:repeat(2,1fr)}
  .maison-grid,.commande-grid,.acces-grid,.contact-inner,.apercu-grid{grid-template-columns:1fr}
  .spec-grid{grid-template-columns:1fr}
  .avis-grid{grid-template-columns:1fr}
  .maison-images{min-height:360px;order:-1}
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .footer-contact{text-align:left}
  .footer-inner{flex-direction:column;align-items:flex-start}
}
@media(max-width:760px){
  .nav,.nav-cta{display:none}
  .burger{display:flex}
  .nav.open{
    display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;
    background:var(--cream);border-bottom:1px solid var(--line);padding:1rem clamp(20px,5vw,40px) 1.4rem;gap:0;box-shadow:var(--shadow-sm);
  }
  .nav.open a{padding:.9rem 0;border-bottom:1px solid var(--line);font-size:1rem}
  .header-inner{position:relative}
  .field-row{grid-template-columns:1fr}
  .menu-item{flex-wrap:wrap}
  .mi-dots{display:none}
  .mi-desc{flex-basis:100%;order:3}
  .hero{min-height:88vh}
}
@media(max-width:430px){
  .gallery{grid-template-columns:1fr;grid-auto-rows:200px}
  .g-wide{grid-column:span 1}
  .g-tall{grid-row:span 1}
  .topbar-inner{font-size:.72rem}
}

/* Bestelkanalen (commander) */
.commande-channels{margin-top:1.8rem}
.cc-label{display:block;color:var(--ink-soft);font-size:.95rem;margin-bottom:.8rem}
.cc-btns{display:flex;gap:.7rem;flex-wrap:wrap}
.btn-outline{background:transparent;border:1px solid var(--crust);color:var(--crust);padding:.7rem 1.4rem}
.btn-outline:hover{background:var(--crust);color:#fff;transform:translateY(-2px)}
.btn-whatsapp{background:#25D366;color:#fff;padding:.7rem 1.4rem}
.btn-whatsapp:hover{background:#1da851;transform:translateY(-2px)}

/* --- Ronde 2: UX & toegankelijkheid --- */
.center{text-align:center}
:focus-visible{outline:2px solid var(--crust);outline-offset:3px;border-radius:4px}
.btn:focus-visible,.nav a:focus-visible{outline-offset:4px}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  .hero-bg{transform:none}
  .reveal{opacity:1 !important;transform:none !important}
}
