/* =================================================================
   ARTISAN KEUKENS — style.css
   Richting: Duitse precisie + ambachtelijke warmte.
   Warm wit · espresso · messing accent · Fraunces + Hanken Grotesk.
   ================================================================= */

/* ---------- Tokens ---------- */
:root{
  --bg:        #FBFAF7;   /* warm wit */
  --surface:   #FFFFFF;
  --surface-2: #F3EFE8;   /* warm licht grijs */
  --ink:       #1B1814;   /* espresso bijna-zwart */
  --ink-soft:  #585048;   /* zachte body-tekst */
  --line:      #E7E1D6;   /* warme haarlijn */
  --brass:     #B0863C;   /* messing accent */
  --brass-dk:  #8C6A2D;
  --brass-tint:#F4ECDC;
  --wa:        #25D366;
  --wa-dk:     #1da851;

  --font-display: "Fraunces", Georgia, "Times New Roman", serif;
  --font-body:    "Hanken Grotesk", -apple-system, "Segoe UI", sans-serif;

  --container: 1240px;
  --radius:   14px;
  --radius-sm: 9px;
  --shadow:   0 18px 50px -24px rgba(27,24,20,.30);
  --shadow-sm:0 8px 24px -14px rgba(27,24,20,.28);
  --ease:     cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset / basis ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; overflow-x:hidden; }
body{
  margin:0;
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.65;
  color:var(--ink-soft);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
/* fijne korrel voor warmte/diepte */
body::before{
  content:"";
  position:fixed; inset:0; z-index:9999; pointer-events:none;
  opacity:.022;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4{ font-family:var(--font-display); color:var(--ink); font-weight:500; line-height:1.1; margin:0; letter-spacing:-.01em; overflow-wrap:break-word; }
p{ margin:0 0 1em; }
:focus-visible{ outline:2px solid var(--brass); outline-offset:3px; border-radius:3px; }

/* ---------- Layout ---------- */
.container{ width:100%; max-width:var(--container); margin:0 auto; padding:0 28px; }
.section{ padding:clamp(64px,8vw,120px) 0; }
.section--tint{ background:var(--surface-2); }
.section--ink{ background:var(--ink); color:#D9CFC2; }
.section--ink h2{ color:#fff; }

.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-body); font-weight:600; font-size:12.5px;
  letter-spacing:.18em; text-transform:uppercase; color:var(--brass);
  margin:0 0 18px;
}
.eyebrow::before{ content:""; width:26px; height:1.5px; background:var(--brass); display:inline-block; }
.section__head{ max-width:680px; margin:0 0 clamp(38px,5vw,60px); }
.section__head--center{ margin-left:auto; margin-right:auto; text-align:center; }
.section__head h2{ font-size:clamp(30px,4.2vw,46px); }
.section__head p{ margin-top:16px; font-size:18px; }
.lead{ font-size:19px; color:var(--ink-soft); }

/* ---------- Knoppen ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:15px 28px; border-radius:var(--radius-sm); border:1.5px solid transparent;
  font-weight:600; font-size:15.5px; letter-spacing:.01em;
  transition:transform .25s var(--ease), background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
  will-change:transform;
}
.btn svg{ transition:transform .25s var(--ease); }
.btn--primary{ background:var(--ink); color:#fff; }
.btn--primary:hover{ background:#000; transform:translateY(-2px); }
.btn--brass{ background:var(--brass); color:#fff; }
.btn--brass:hover{ background:var(--brass-dk); transform:translateY(-2px); }
.btn--ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn--ghost:hover{ border-color:var(--ink); transform:translateY(-2px); }
.btn--light{ background:#fff; color:var(--ink); }
.btn--light:hover{ transform:translateY(-2px); }
.btn--ghost-light{ background:transparent; color:#fff; border-color:rgba(255,255,255,.35); }
.btn--ghost-light:hover{ border-color:#fff; transform:translateY(-2px); }
.btn:hover svg{ transform:translateX(3px); }

.btn-row{ display:flex; flex-wrap:wrap; gap:14px; }

/* ---------- Placeholder-beeld ----------
   .media = beeldvlak. Geef een echte foto via inline style:
   style="background-image:url('/assets/img/...jpg')"
   Mist het bestand? Dan zie je dit nette vlak (geen kapot icoon). */
.media{
  background-color:#E9E2D6;
  background-image:
    linear-gradient(135deg, rgba(176,134,60,.10), rgba(27,24,20,.06)),
    repeating-linear-gradient(45deg, transparent 0 22px, rgba(27,24,20,.025) 22px 44px);
  background-size:cover; background-position:center;
  position:relative;
}

/* =================================================================
   TOPBALK
   ================================================================= */
.topbar{ background:var(--ink); color:#CDC3B5; font-size:13.5px; }
.topbar__inner{ display:flex; align-items:center; justify-content:space-between; min-height:42px; }
.topbar__phone{ display:inline-flex; align-items:center; gap:8px; font-weight:600; color:#EDE5D8; }
.topbar__phone:hover{ color:#fff; }
.topbar__phone svg{ color:var(--brass); }
.topbar__right{ display:flex; align-items:center; gap:22px; }
.topbar__hours{ color:#A89C8B; }
.topbar__cta{ display:inline-flex; align-items:center; gap:7px; font-weight:600; color:#EDE5D8; }
.topbar__cta::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--brass); }
.topbar__cta:hover{ color:#fff; }

/* =================================================================
   HOOFDNAVIGATIE
   ================================================================= */
.site-header{
  position:sticky; top:0; z-index:200;
  background:rgba(251,250,247,.86); backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .3s var(--ease), background .3s var(--ease);
}
.site-header.is-stuck{ box-shadow:0 10px 30px -22px rgba(27,24,20,.4); background:rgba(251,250,247,.95); }
.site-header__inner{ display:flex; align-items:center; justify-content:space-between; min-height:74px; gap:20px; }

.brand{ display:inline-flex; align-items:center; gap:12px; }
.brand__mark{
  display:grid; place-items:center; width:38px; height:38px; border-radius:9px;
  background:var(--brass); color:#fff; font-family:var(--font-display);
  font-weight:600; font-size:21px; line-height:1; flex-shrink:0;
}
.brand__name{ font-family:var(--font-display); font-size:22px; color:var(--ink); letter-spacing:-.01em; }
.brand__name strong{ font-weight:600; color:var(--brass); }
.brand--light .brand__name{ color:#fff; }

.nav{ display:flex; align-items:center; gap:5px; }
.nav>a{
  position:relative; padding:9px 13px; border-radius:8px;
  font-size:15px; font-weight:500; color:var(--ink);
  transition:color .2s var(--ease), background .2s var(--ease);
}
.nav>a::after{
  content:""; position:absolute; left:13px; right:13px; bottom:4px; height:1.5px;
  background:var(--brass); transform:scaleX(0); transform-origin:left; transition:transform .25s var(--ease);
}
.nav>a:hover{ color:var(--brass); }
.nav>a:hover::after,.nav>a.is-active::after{ transform:scaleX(1); }
.nav>a.is-active{ color:var(--brass); }
.nav__cta{
  margin-left:8px; background:var(--ink); color:#fff !important; padding:10px 20px !important;
  border-radius:8px; transition:background .25s var(--ease), transform .25s var(--ease);
}
.nav__cta::after{ display:none; }
.nav__cta:hover{ background:#000; transform:translateY(-1px); }

.nav-toggle{ display:none; flex-direction:column; gap:5px; width:44px; height:44px; align-items:center; justify-content:center; background:transparent; border:1px solid var(--line); border-radius:9px; }
.nav-toggle span{ width:20px; height:2px; background:var(--ink); border-radius:2px; transition:transform .3s var(--ease), opacity .2s var(--ease); }
.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); }

/* =================================================================
   HERO
   ================================================================= */
.hero{ position:relative; min-height:clamp(560px,82vh,820px); display:flex; align-items:flex-end; background:#2A251F; overflow:hidden; }
.hero__media{ position:absolute; inset:0; z-index:0; }
.hero__media video,.hero__media .media{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero__media::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(20,17,13,.30) 0%, rgba(20,17,13,.15) 40%, rgba(20,17,13,.82) 100%);
}
.hero__inner{ position:relative; z-index:2; padding:clamp(48px,7vw,96px) 0; max-width:760px; }
.hero h1{ color:#fff; font-size:clamp(38px,6vw,72px); line-height:1.03; letter-spacing:-.02em; }
.hero h1 em{ font-style:italic; color:#EBC987; }
.hero__sub{ color:#E7DECF; font-size:clamp(17px,2vw,21px); max-width:560px; margin:22px 0 32px; }
.hero__usps{ display:flex; flex-wrap:wrap; gap:10px 22px; margin-top:30px; }
.hero__usps li{ display:flex; align-items:center; gap:9px; color:#E7DECF; font-size:14.5px; font-weight:500; list-style:none; }
.hero__usps svg{ color:var(--brass); flex-shrink:0; }
.hero__usps ul{ display:contents; }

/* =================================================================
   USP-STRIP
   ================================================================= */
.usps{ background:var(--surface); border-bottom:1px solid var(--line); }
.usps__grid{ display:grid; grid-template-columns:repeat(3,1fr); }
.usp{ display:flex; gap:18px; padding:clamp(34px,4vw,48px) 34px; align-items:flex-start; }
.usp:not(:last-child){ border-right:1px solid var(--line); }
.usp__icon{ display:grid; place-items:center; width:50px; height:50px; border-radius:12px; background:var(--brass-tint); color:var(--brass-dk); flex-shrink:0; }
.usp h3{ font-size:19px; margin-bottom:6px; }
.usp p{ margin:0; font-size:15px; }

/* =================================================================
   STATS / BEWIJSCIJFERS
   ================================================================= */
.stats__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:30px; }
.stat{ text-align:center; }
.stat__num{ font-family:var(--font-display); font-size:clamp(40px,5vw,58px); color:var(--ink); line-height:1; }
.stat__num span{ color:var(--brass); }
.stat__label{ margin-top:10px; font-size:14.5px; letter-spacing:.02em; }
.section--ink .stat__num{ color:#fff; }
.section--ink .stat__label{ color:#A89C8B; }

/* =================================================================
   SHOWCASE (Top 10 modellen)
   ================================================================= */
.show__grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:26px; }
.card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; display:flex; flex-direction:column;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
}
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:transparent; }
.card__media{ aspect-ratio:4/3; }
.card__media .badge{
  position:absolute; top:14px; left:14px; background:rgba(27,24,20,.82); color:#fff;
  font-size:11.5px; font-weight:600; letter-spacing:.04em; padding:6px 11px; border-radius:50px; backdrop-filter:blur(4px);
}
.card__body{ padding:22px 22px 24px; display:flex; flex-direction:column; gap:6px; flex:1; }
.card__rank{ font-family:var(--font-display); font-size:14px; color:var(--brass); }
.card__body h3{ font-size:21px; }
.card__body p{ margin:0; font-size:14.5px; flex:1; }
.card__link{ display:inline-flex; align-items:center; gap:8px; margin-top:12px; font-weight:600; font-size:14.5px; color:var(--ink); }
.card__link svg{ transition:transform .25s var(--ease); }
.card:hover .card__link{ color:var(--brass); }
.card:hover .card__link svg{ transform:translateX(4px); }

/* =================================================================
   MERKEN-STRIP
   ================================================================= */
.brands__strip{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:18px; }
.brand-item{
  display:grid; place-items:center; height:78px; padding:0 30px; min-width:150px;
  background:var(--surface); border:1px solid var(--line); border-radius:12px;
  font-family:var(--font-display); font-size:21px; font-weight:600; color:var(--ink-soft);
  letter-spacing:.02em;
  transition:transform .3s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease);
}
.brand-item img{ max-height:36px; width:auto; }
.brand-item:hover{ transform:translateY(-3px); border-color:var(--brass); box-shadow:var(--shadow-sm); }

/* =================================================================
   PROJECTEN
   ================================================================= */
.proj__grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(330px,1fr)); gap:24px; }
.proj{ position:relative; border-radius:var(--radius); overflow:hidden; aspect-ratio:3/2.4; display:flex; align-items:flex-end; }
.proj .media{ position:absolute; inset:0; transition:transform .6s var(--ease); }
.proj:hover .media{ transform:scale(1.06); }
.proj::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 35%, rgba(20,17,13,.78) 100%); }
.proj__caption{ position:relative; z-index:2; padding:24px; color:#fff; }
.proj__cat{ display:inline-block; font-size:11.5px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:#EBC987; margin-bottom:8px; }
.proj__caption h3{ color:#fff; font-size:22px; }

/* =================================================================
   REVIEWS / KEURMERKEN
   ================================================================= */
.reviews__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.review{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:30px 28px; display:flex; flex-direction:column; gap:14px; }
.stars{ display:flex; gap:3px; color:var(--brass); }
.review__text{ margin:0; color:var(--ink); font-size:16.5px; line-height:1.55; }
.review__by{ display:flex; align-items:center; gap:12px; margin-top:auto; padding-top:6px; }
.review__avatar{ width:42px; height:42px; border-radius:50%; background:var(--brass-tint); color:var(--brass-dk); display:grid; place-items:center; font-family:var(--font-display); font-weight:600; }
.review__name{ font-weight:600; color:var(--ink); font-size:15px; }
.review__meta{ font-size:13px; color:var(--ink-soft); }
.keurmerken{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:14px 34px; margin-top:50px; padding-top:40px; border-top:1px solid var(--line); }
.keurmerk{ display:flex; align-items:center; gap:10px; color:var(--ink-soft); font-weight:600; font-size:14.5px; }
.keurmerk svg{ color:var(--brass); }

/* =================================================================
   OBJECTPLANNING-BAND
   ================================================================= */
.object__inner{ display:grid; grid-template-columns:1.2fr .8fr; gap:40px; align-items:center; }
.object__inner .lead{ color:#D9CFC2; margin-top:14px; }
.object__list{ display:flex; flex-wrap:wrap; gap:12px 26px; margin:22px 0 0; padding:0; }
.object__list li{ display:flex; align-items:center; gap:9px; list-style:none; color:#EDE5D8; font-size:15px; }
.object__list svg{ color:var(--brass); flex-shrink:0; }
.object__card{ background:#221E18; border:1px solid rgba(255,255,255,.1); border-radius:var(--radius); padding:34px; }
.object__card h3{ color:#fff; font-size:24px; margin-bottom:8px; }
.object__card p{ color:#B7AC9B; font-size:15px; }

/* =================================================================
   CTA-BAND
   ================================================================= */
.cta-band{ text-align:center; }
.cta-band h2{ font-size:clamp(30px,4.5vw,50px); max-width:720px; margin:0 auto 16px; }
.cta-band p{ max-width:560px; margin:0 auto 30px; font-size:18px; }
.cta-band .btn-row{ justify-content:center; }

/* =================================================================
   FOOTER
   ================================================================= */
.site-footer{ background:var(--ink); color:#A89C8B; padding-top:clamp(56px,7vw,84px); }
.site-footer__grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.3fr; gap:40px; padding-bottom:54px; }
.site-footer__brandcol .brand{ margin-bottom:18px; }
.site-footer__tag{ font-size:15px; max-width:330px; line-height:1.6; }
.site-footer__socials{ display:flex; gap:10px; margin-top:20px; }
.site-footer__socials a{ display:grid; place-items:center; width:40px; height:40px; border-radius:10px; border:1px solid rgba(255,255,255,.14); color:#CDC3B5; transition:background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease); }
.site-footer__socials a:hover{ background:var(--brass); color:#fff; border-color:var(--brass); }
.site-footer__col h4{ color:#fff; font-size:16px; margin-bottom:16px; font-family:var(--font-body); font-weight:600; letter-spacing:.02em; }
.site-footer__col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; }
.site-footer__col a{ color:#B7AC9B; font-size:15px; transition:color .2s var(--ease); }
.site-footer__col a:hover{ color:#fff; }
.site-footer__nap{ font-style:normal; font-size:15px; line-height:1.7; }
.site-footer__nap a:hover{ color:#fff; }
.site-footer__hours{ color:#857a6a; }
.site-footer__bar{ border-top:1px solid rgba(255,255,255,.1); }
.site-footer__barinner{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:10px; padding:22px 0; font-size:13.5px; }
.site-footer__bar p{ margin:0; }
.site-footer__links a{ color:#B7AC9B; transition:color .2s var(--ease); }
.site-footer__links a:hover{ color:var(--brass); }
.site-footer__links span{ color:#5b5347; margin:0 4px; }

/* =================================================================
   STICKY ACTIES
   ================================================================= */
.sticky-cta{ position:fixed; right:18px; top:50%; transform:translateY(-50%); z-index:300; display:flex; flex-direction:column; gap:10px; }
.sticky-cta__btn{
  display:flex; flex-direction:column; align-items:center; gap:3px; width:62px; padding:11px 6px;
  background:var(--surface); border:1px solid var(--line); border-radius:14px; color:var(--ink);
  box-shadow:var(--shadow-sm); transition:transform .25s var(--ease), background .25s var(--ease), color .25s var(--ease);
}
.sticky-cta__btn span{ font-size:11px; font-weight:600; letter-spacing:.01em; }
.sticky-cta__btn:hover{ transform:translateX(-4px); }
.sticky-cta__btn--wa{ background:var(--wa); border-color:var(--wa); color:#fff; }
.sticky-cta__btn--wa:hover{ background:var(--wa-dk); }
.sticky-cta__btn--brass{ background:var(--brass); border-color:var(--brass); color:#fff; }
.sticky-cta__btn--brass:hover{ background:var(--brass-dk); }

/* =================================================================
   MOTION (scroll-reveal)
   ================================================================= */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; }
.reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; }
.hero .reveal{ transition-duration:.9s; }

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
}

/* =================================================================
   RESPONSIVE
   ================================================================= */
@media (max-width:1080px){
  .stats__grid{ grid-template-columns:repeat(2,1fr); gap:34px 20px; }
  .object__inner{ grid-template-columns:1fr; }
  .reviews__grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:900px){
  .topbar__hours{ display:none; }
  .nav-toggle{ display:flex; }
  .nav{
    position:fixed; inset:0 0 0 auto; width:min(86vw,360px); flex-direction:column; align-items:stretch;
    gap:4px; padding:96px 22px 30px; background:var(--bg); border-left:1px solid var(--line);
    box-shadow:-30px 0 60px -30px rgba(0,0,0,.4); z-index:150; overflow-y:auto;
    display:none;
  }
  .nav.is-open{ display:flex; animation:navfade .3s var(--ease); }
  .nav>a{ padding:14px 16px; font-size:17px; border-radius:10px; }
  .nav>a::after{ display:none; }
  .nav>a:hover,.nav>a.is-active{ background:var(--surface-2); }
  .nav__cta{ margin:10px 0 0; text-align:center; padding:15px !important; }
  .usps__grid{ grid-template-columns:1fr; }
  .usp:not(:last-child){ border-right:none; border-bottom:1px solid var(--line); }
}
@media (max-width:680px){
  body{ font-size:16px; }
  .container{ padding:0 20px; }
  .reviews__grid{ grid-template-columns:1fr; }
  .proj__grid{ grid-template-columns:1fr; }
  .show__grid{ grid-template-columns:1fr; }
  .stats__grid{ grid-template-columns:1fr 1fr; gap:30px 16px; }
  .btn{ width:100%; }
  .btn-row .btn{ width:100%; }
  .hero__inner{ padding-bottom:64px; }
  /* sticky acties → balk onderaan, beter voor de duim */
  .sticky-cta{ right:0; left:0; top:auto; bottom:0; transform:none; flex-direction:row; gap:0; border-top:1px solid var(--line); }
  .sticky-cta__btn{ flex:1; width:auto; border-radius:0; border:none; border-right:1px solid rgba(255,255,255,.18); box-shadow:0 -8px 24px -16px rgba(0,0,0,.4); padding:10px 4px; }
  .sticky-cta__btn:last-child{ border-right:none; }
  .sticky-cta__btn:hover{ transform:none; }
  body{ padding-bottom:60px; } /* ruimte voor de onderbalk */
}

/* =================================================================
   TOPBAR STATUS + FOOTER (openingstijden, reviews, route)
   ================================================================= */

/* --- Topbar: live open/dicht-status --- */
.topbar__status{ display:inline-flex; align-items:center; gap:8px; color:#A89C8B; font-weight:500; }
.topbar__dot{ width:8px; height:8px; border-radius:50%; background:#A89C8B; flex-shrink:0; }
.topbar__status.is-open{ color:#E7DECF; }
.topbar__status.is-open .topbar__dot{ background:var(--wa); box-shadow:0 0 0 3px rgba(37,211,102,.2); }
.topbar__status.is-dicht .topbar__dot{ background:#C0392B; box-shadow:0 0 0 3px rgba(192,57,43,.2); }

/* --- Footer: Google-beoordeling --- */
.site-footer__rating{ display:inline-flex; align-items:center; gap:8px; margin-top:16px; color:#CDC3B5; font-size:14px; }
.site-footer__rating svg{ color:var(--brass); flex-shrink:0; }
.site-footer__rating strong{ color:#fff; }
.site-footer__rating:hover{ color:#fff; }

/* --- Footer: route-link --- */
.site-footer__route{ color:var(--brass); font-weight:600; }
.site-footer__route:hover{ color:#fff; }

/* --- Footer: open/dicht-status --- */
.site-footer__status{ display:inline-flex; align-items:center; gap:8px; margin-top:4px; font-size:14px; color:#CDC3B5; font-weight:500; }
.site-footer__status.is-open{ color:#E7DECF; }
.site-footer__status.is-open .topbar__dot{ background:var(--wa); box-shadow:0 0 0 3px rgba(37,211,102,.2); }
.site-footer__status.is-dicht .topbar__dot{ background:#C0392B; box-shadow:0 0 0 3px rgba(192,57,43,.2); }

/* --- Footer: openingstijden-lijst --- */
.site-footer__hours-list{ list-style:none; margin:14px 0 0; padding:0; display:flex; flex-direction:column; gap:7px; }
.site-footer__hours-list li{ display:flex; justify-content:space-between; gap:18px; font-size:14px; color:#A89C8B; }
.site-footer__hours-list li span:last-child{ color:#CDC3B5; }
.site-footer__hours-list li.is-today span{ color:var(--brass); font-weight:600; }

/* --- Responsive: status in topbar verbergen op klein scherm --- */
@media (max-width:900px){
  .topbar__status{ display:none; }
}

/* fade-in voor het mobiele menu */
@keyframes navfade{ from{ opacity:0 } to{ opacity:1 } }

/* grotere tap-targets op mobiel (mobielvriendelijkheid) */
@media (max-width:900px){
  .topbar__phone, .topbar__cta{ padding:9px 0; }
  .site-footer__col a, .site-footer__links a, .site-footer__nap a, .site-footer__route{ display:inline-block; padding:6px 0; }
}