/* ========== BASIS / RESET ========== */
*{ box-sizing:border-box; }

:root{
  /* fonts */
  --font-body:'Montserrat', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --font-title:'Cinzel', Georgia, 'Times New Roman', serif;

  /* layout */
  --header-h: 64px;
  --max:1200px;
  --pad:1rem;

  /* hero */
  --hero-bg: url("images/taureau.jpg");
  --overlay-a: .25;  /* links */
  --overlay-b: .65;  /* rechts */

  /* kleuren */
  --bg-900:#0f0f10;
  --bg-800:#171718;
  --line:#2a2a2a;
  --text:#ffffff;
  --muted:#cfcfcf;

  /* primary accent */
  --gold:#b9935a;
}

html,body{
  margin:0;
  background:var(--bg-900);
  color:var(--text);
  font:16px/1.6 var(--font-body);
  overflow-x: hidden;
}

html{ scroll-behavior:smooth; }
:focus-visible{ outline:2px solid var(--gold); outline-offset:2px; }

img{ max-width:100%; display:block; }


/* ========== LANGUAGE MODAL ========== */
.lang-modal{
  position: fixed;
  inset: 0;
  display: none;
  background: rgba(0,0,0,0.75);
  align-items: center;
  justify-content: center;
  z-index: 9999;
}
.lang-modal.show{ display:flex; }

.lang-card{
  background: #111;
  color: #fff;
  padding: 25px;
  border-radius: 16px;
  text-align: center;
  max-width: 400px;
  width: 100%;
}

.lang-buttons{
  display: flex;
  gap: 12px;
  justify-content: center;
  margin-top: 20px;
}

.lang-buttons button{
  padding: 10px 16px;
  border-radius: 10px;
  border: none;
  background: #1e1e1e;
  color: #fff;
  cursor: pointer;
  font-size: 15px;
}
.lang-buttons button:hover{ background:#333; }


/* ===== NAV LANGUAGE SWITCHER ===== */
.nav{
  display:flex;
  align-items:center;
  gap:18px;
}

.nav-lang{
  position:relative;
  margin-left:10px;
}

.nav-lang__btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.18);
  background:rgba(0,0,0,0.25);
  color:#fff;
  cursor:pointer;
  font:inherit;
}
.nav-lang__btn:hover{ background:rgba(0,0,0,0.35); }

.nav-lang__code{
  font-weight:700;
  letter-spacing:.06em;
}

.nav-lang__menu{
  position:absolute;
  right:0;
  top:calc(100% + 10px);
  min-width:170px;
  padding:8px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(18,18,18,0.92);
  backdrop-filter: blur(10px);
  box-shadow:0 18px 40px rgba(0,0,0,0.35);
  display:none;
  z-index:9999;
}
.nav-lang.is-open .nav-lang__menu{
  display:grid;
  gap:6px;
}

.nav-lang__menu button{
  width:100%;
  text-align:left;
  padding:10px 10px;
  border-radius:10px;
  border:0;
  background:transparent;
  color:#fff;
  cursor:pointer;
  font:inherit;

  display:flex;
  align-items:center;
  gap:10px;
  font-size:15px;
}
.nav-lang__menu button:hover{ background:rgba(255,255,255,0.10); }

.nav-lang__flag{
  font-size:18px;
  line-height:1;
}


/* ========== HEADER ========== */
.site-header{
  position:fixed; top:0; left:0; right:0;
  height:var(--header-h);
  background:rgba(23,23,24,.72);
  backdrop-filter: blur(6px);
  border-bottom:1px solid rgba(42,42,42,.5);
  display:flex;
  align-items:center;
  z-index:1000;
}

.header-inner{
  max-width:var(--max);
  width:100%;
  margin:0 auto;
  padding:0 1.5rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
}

.nav{ display:flex; gap:2rem; align-items:center; }

.nav a{
  position:relative;
  color:#fff;
  text-decoration:none;
  font-weight:600;
  letter-spacing:.04em;
  opacity:.92;
  padding:.25rem 0;
}

.nav a::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:-6px;
  height:2px;
  background:var(--gold);
  transform:scaleX(0);
  transform-origin:left;
  transition:.25s;
}

.nav a:hover{ opacity:1; color:#fff; }
.nav a:hover::after{ transform:scaleX(1); }

.nav a.active{ color:var(--gold); opacity:1; }
.nav a.active::after{ transform:scaleX(1); }


.container{
  max-width:1200px;
  margin-inline:auto;
  padding:0 1rem;
  width:100%;
}

.brand{
  display:flex;
  align-items:center;
  text-decoration:none;
}

.brand__logo{ 
  height:32px;
  width:auto;
  filter: drop-shadow(0 0 4px rgba(0,0,0,.4));
  transition: transform .25s ease;
}
.brand__logo:hover{ transform:scale(1.04); }


/* ========== HERO (fullscreen achtergrond + content rechts) ========== */
.hero{
  position:relative;
  height:100vh;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  color:#fff;
}

.hero::before{
  content:"";
  position:absolute; inset:0;
  background:var(--hero-bg) center center/cover no-repeat;
  transform:scale(1.02);
  animation: kenburns 28s ease-out forwards;
  z-index:0;
}

.hero::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(90deg,
    rgba(0,0,0,var(--overlay-a)) 25%,
    rgba(0,0,0,var(--overlay-b)) 75%);
  z-index:1;
}

.hero__content{
  position:relative;
  z-index:2;
  text-align:right;
  max-width:42%;
  margin-right:8%;
  margin-top:var(--header-h);
}

.hero__logo{
  width:min(260px, 60%);
  margin:0 0 1rem auto;
  filter:drop-shadow(0 0 8px rgba(0,0,0,.45));
}

.hero__title{
  margin:0 0 .6rem;
  font:700 clamp(2.2rem, 5vw, 3.2rem)/1.1 var(--font-title);
  letter-spacing:.02em;
  color:#fff;
}

.hero__tagline{
  margin:0 0 1.8rem;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.15em;
  font-weight:600;
}

.hero__buttons{
  display:flex;
  gap:1rem;
  justify-content:flex-end;
}

.btn{
  display:inline-block;
  padding:.9rem 1.6rem;
  border-radius:999px;
  background:var(--gold);
  color:#000;
  text-decoration:none;
  font:700 1rem/1 var(--font-body);
  transition:.25s ease;
  border:1px solid transparent;
  box-shadow:0 6px 18px rgba(0,0,0,.25);
}
.btn:hover{
  transform: translateY(-3px);
  box-shadow:0 10px 26px rgba(0,0,0,.35);
}
.btn:focus-visible{
  outline:2px solid #fff;
  outline-offset:3px;
}

.btn--outline{
  background:transparent;
  color:var(--gold);
  border:1px solid var(--gold);
}
.btn--outline:hover{
  background:var(--gold);
  color:#000;
}

/* HERO anim */
@keyframes kenburns{
  from{ transform: scale(1.02); }
  to  { transform: scale(1.00); }
}

@keyframes fadeUp {
  from { opacity:0; transform: translateY(18px); }
  to   { opacity:1; transform: translateY(0); }
}
.hero__content > *{
  opacity:0;
  animation: fadeUp .8s ease forwards;
}
.hero__content > *:nth-child(1){ animation-delay: .15s; }
.hero__content > *:nth-child(2){ animation-delay: .30s; }
.hero__content > *:nth-child(3){ animation-delay: .45s; }

@media (prefers-reduced-motion: reduce){
  .hero::before,
  .hero__content > *{
    animation:none !important;
    transform:none !important;
    opacity:1 !important;
  }
}

/* ========== RESPONSIVE HERO ========== */
@media (max-width: 992px){
  .hero{
    height:82vh;
    justify-content:center;
  }
  .hero__content{
    max-width:88%;
    margin-right:0;
    text-align:center;
  }
  .hero__logo{ margin-inline:auto; }
  .hero__buttons{ justify-content:center; flex-wrap:wrap; }
}


/* ---------- Intro layout ---------- */
.section{ padding:72px 0; }
.section[id]{ scroll-margin-top: calc(var(--header-h) + 12px); }

.intro{
  position:relative;
  background:var(--bg-900);
  border-top:1px solid #222;
  border-bottom:1px solid #222;
}

.intro__inner{ max-width:var(--max); margin:0 auto; padding:0 1.5rem; }
.intro__header{ text-align:center; margin-bottom:2.25rem; }

.eyebrow{
  display:inline-block;
  letter-spacing:.18em;
  color:var(--gold);
  font-weight:700;
  font-size:.85rem;
  opacity:.9;
}

.intro__header h2{
  font-family:var(--font-title);
  margin:.4rem 0;
  font-size:clamp(1.9rem,3.2vw,2.6rem);
}

.lead{ color:#dcdcdc; max-width:720px; margin:.25rem auto 0; }

.intro__grid{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:2rem;
  max-width:900px;
  margin:0 auto;
}

.intro__text{ max-width:900px; margin-inline:auto; }
.intro__text p{ font-size:1.05rem; line-height:1.75; }

.intro .lead{
  max-width:780px;
  margin:.35rem auto 1.2rem;
  line-height:1.7;
  color:#d9d9d9;
}

.intro__photos{
  display:grid;
  grid-template-columns: 0.9fr 1.1fr 0.9fr;
  gap:1.5rem;
  max-width:1200px;
  margin:2rem auto 0;
  padding:0 1rem;
}

.intro__photos img{
  width:100%;
  aspect-ratio: 4 / 5;
  object-fit:cover;
  border-radius:16px;
  box-shadow:0 10px 28px rgba(0,0,0,.35);
  transition: transform .5s ease, opacity .5s ease;
}
.intro__photos img:hover{
  transform: translateY(-6px) scale(1.03);
  opacity:.96;
}

.reveal.from-left, .reveal.from-right, .reveal.from-center{
  opacity:0;
  transform: translateY(20px) scale(.98);
  transition: opacity .9s ease, transform .9s ease;
}
.reveal.from-left{ transform: translateX(-60px) scale(.98); }
.reveal.from-right{ transform: translateX(60px) scale(.98); }

.reveal.in{
  opacity:1;
  transform: translateX(0) translateY(0) scale(1);
}

@media (max-width: 1100px){
  .intro__photos{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 900px){
  .intro__photos img{ aspect-ratio: 4 / 3; }
}
@media (max-width: 680px){
  .intro__photos{ grid-template-columns: 1fr; }
}


/* ========== ABOUT — Premium versie ========== */
.about{
  position:relative;
  background:var(--bg-900);
  padding:4.5rem 1.2rem 4rem;
  overflow:hidden;
}

.about::before{
  content:"";
  position:absolute;
  inset:-10% -10%;
  background:
    radial-gradient(1200px 500px at 50% -10%, color-mix(in srgb, var(--gold) 14%, transparent), transparent 60%),
    radial-gradient(800px 400px at 100% 120%, color-mix(in srgb, var(--gold) 10%, transparent), transparent 60%);
  pointer-events:none;
}

.about__inner{ max-width:1200px; margin:0 auto; }

.about__intro{ text-align:center; margin-bottom:1.6rem; }
.about__eyebrow{
  font-family:var(--font-title);
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--gold);
  font-size:.85rem;
}

.about__heading{
  font-family:var(--font-title);
  font-size:clamp(1.9rem, 4vw, 2.6rem);
  margin:.3rem 0 .8rem;
}

.about__heading img.about__logo{
  width: clamp(180px, 26vw, 300px);
  height:auto;
  display:inline-block;
  margin:.5rem auto .9rem;
  filter: drop-shadow(0 4px 8px rgba(0,0,0,.35));
  transition: transform .35s ease;
}
.about__heading img.about__logo:hover{ transform: scale(1.03); }

.about__divider{ opacity:.9; margin:.4rem auto 0; }

.about__grid{
  display:grid;
  grid-template-columns: 1fr minmax(320px, 640px) 1fr;
  gap:2rem;
  align-items:center;
  margin-top:1.8rem;
}

.about__card{
  position:relative;
  background: radial-gradient(circle at top left, #1f1810 0, #141414 45%, #0d0d0d 100%);
  color:#eaeaea;
  border-radius:18px;
  padding:1.9rem 1.9rem 1.6rem;
  border:1px solid color-mix(in srgb, var(--gold) 22%, transparent);
  box-shadow:0 12px 32px rgba(0,0,0,.55);
  backdrop-filter: blur(4px);
}

.about__card--right{ padding:1.9rem 1.6rem; }

.about__card-title{
  font-family:var(--font-title);
  font-size:clamp(1.3rem, 2.4vw, 1.7rem);
  letter-spacing:.04em;
  margin:0 0 .9rem;
  color:#fff;
}

.about__card p{ margin:0; color:#d4d4d4; }
.about__bullets li{ color:#f0f0f0; font-size:.98rem; }

.about__badge{
  position:absolute;
  top:-12px; left:16px;
  background:linear-gradient(135deg, color-mix(in srgb, var(--gold) 75%, #fff 10%), var(--gold));
  color:#0f0f10;
  font-weight:700;
  font-size:.74rem;
  padding:.28rem .55rem;
  border-radius:6px;
  box-shadow:0 6px 16px rgba(0,0,0,.25);
}

.about__bullets{
  margin:.8rem 0 0;
  padding:0;
  list-style:none;
  display:grid;
  gap:.45rem;
}
.about__bullets .ico{
  display:inline-block;
  width:1.3rem;
  text-align:center;
  margin-right:.4rem;
  filter:grayscale(.25);
}

/* Feature photo */
.about__photo{
  position:relative;
  border-radius:18px;
  overflow:hidden;
  transform: translateZ(0);
  will-change: transform;
  transition: transform .4s ease-out;
}

.about__photo img{
  display:block;
  width:100%;
  height:auto;
  object-fit:cover;
  transform:scale(1.05);
  transition: transform .4s ease-out;
}

.about__photo::before{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(
    to bottom,
    rgba(0, 0, 0, 0.4) 10%,
    rgba(0, 0, 0, 0.15) 60%,
    rgba(0, 0, 0, 0.65) 100%
  );
  pointer-events:none;
  opacity:.85;
}

.about__photo:hover img{ transform: scale(1.1); }

.about__photo::after{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(120% 140% at 50% 100%, rgba(0,0,0,.25), transparent 50%),
    linear-gradient(to bottom, transparent 70%, rgba(0,0,0,.2));
  pointer-events:none;
}

.about__stats{
  display:grid;
  grid-auto-flow:column;
  gap:1.4rem;
  justify-content:center;
  margin:2.2rem 0 .2rem;
}

.stat{ text-align:center; }

.stat__num{
  font-family:var(--font-title);
  font-size:clamp(1.6rem, 3vw, 2.2rem);
  color:#e8e5df;
  letter-spacing:.02em;
}

.stat__label{
  color:#b9b9b9;
  font-size:.92rem;
  margin-top:.15rem;
}

@media (hover:hover){
  .about__photo:hover img{ transform:scale(1.02); transition:transform .5s ease; }
}

@media (max-width: 980px){
  .about__grid{ grid-template-columns: 1fr; }
  .about__card--right{ order:3; }
  .about__photo{ order:2; }
  .about{ padding:3.6rem 1rem 3rem; }
  .about__stats{
    grid-auto-flow:row;
    grid-template-columns:repeat(3,1fr);
    max-width:560px;
    margin-left:auto;
    margin-right:auto;
  }
}


/* ========== MENU PAGE ========== */
/* ========== MENU PAGE (CLEAN + PREMIUM) ========== */

/* HERO */
.menu-page-hero{
  position: relative;
  overflow: hidden;

  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--gold) 14%, transparent), transparent 60%),
    #050506;
  border-bottom: 1px solid #181818;
  padding: 2.4rem 0 3.3rem;
}

.menu-page-hero::before{
  content:"";
  position:absolute;
  inset:-20%;
  background:
    radial-gradient(900px 520px at 20% 15%, rgba(185,147,90,.14), transparent 60%),
    radial-gradient(800px 520px at 85% 10%, rgba(255,255,255,.06), transparent 60%);
  pointer-events:none;
}

.menu-page-hero__inner{
  margin: 0 auto;
  padding: 0 1.5rem;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}



.menu-page-title{
  font-family: var(--font-title);
  margin: .35rem 0 .3rem;
  letter-spacing: .03em;
  text-transform: none;
}

.menu-page-title span{
  color: var(--gold);
  letter-spacing: .14em;
  text-transform: uppercase;
  font-size: .9em;
}

.menu-page-hero__divider{
  width: 110px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--gold) 5%, transparent),
    var(--gold),
    color-mix(in srgb, var(--gold) 5%, transparent)
  );
  margin: .45rem 0 1.4rem;
  box-shadow: 0 0 18px rgba(0,0,0,.6);
}

.menu-page-lead{
  max-width: 540px;
  color: #e3e3e3;
  font-size: .96rem;
  line-height: 1.8;
  margin: .45rem 0 .3rem;
}

.menu-page-meta{
  max-width: 540px;
  font-size: .76rem;
  line-height: 1.8;
  margin: .2rem 0 0;
  color: #a4a4a4;
  letter-spacing: .18em;
  text-transform: uppercase;
}


/* ========== MENU INTRO STRIP ========== */
.menu-intro-strip {
  background: var(--bg-900);
  padding: 2.6rem 0 0;
  text-align: center;
}
.menu-intro-strip::before {
  content: "";
  display: block;
  width: 40px;
  height: 1px;
  background: var(--gold);
  margin: 0 auto 1.4rem;
  opacity: .6;
}
.menu-intro-strip__label {
  display: inline-block;
  font-family: var(--font-body);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--gold);
  opacity: .85;
}
.menu-intro-strip__title {
  font-family: var(--font-title);
  font-size: clamp(1.5rem, 2.8vw, 2.1rem);
  letter-spacing: .06em;
  color: #fff;
  margin: .35rem 0 .65rem;
}
.menu-intro-strip__hint {
  font-family: var(--font-body);
  font-size: .8rem;
  color: rgba(255,255,255,.45);
  letter-spacing: .12em;
  margin: 0;
  font-style: italic;
}


/* ========== MENU PAGE — 3D PARALLAX SLIDER ========== */

.menu-page{
  position: relative;
  z-index: 0;
  background: var(--bg-900);
  padding: 8.5rem 0 8.9rem;
}

/* De slider is gewoon een block — geen flex, geen overflow-problemen */
.menu-3d-slider{
  --slide-w: min(28vw, 320px);
  --slide-aspect: 3 / 4;
  --transition: 700ms ease;
  width: 100%;
}

/* Wrapper: relatief zodat knoppen absoluut gepositioneerd kunnen worden */
.menu-3d-slides__wrapper{
  position: relative;
  width: 100%;
  height: calc(var(--slide-w) / 3 * 4);
  max-height: calc(100vh - var(--header-h) - 220px);
  min-height: 420px;
  overflow: visible;
}

/* Prev / Next buttons — absoluut in de wrapper, verticaal gecentreerd */
.menu-3d-btn{
  --size: 48px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: var(--size);
  height: var(--size);
  border-radius: 50%;
  border: 1px solid rgba(185,147,90,.55);
  background: rgba(0,0,0,.60);
  backdrop-filter: blur(10px);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 30;
  transition: background .25s, transform .25s, border-color .25s, box-shadow .25s;
  box-shadow: 0 8px 24px rgba(0,0,0,.7);
}
.menu-3d-btn--prev{ left: calc(50% - (var(--slide-w) * 1.7)); }
.menu-3d-btn--next{right: calc(50% - (var(--slide-w) * 1.7)); }
.menu-3d-btn:hover{
  background: var(--gold);
  color: #000;
  border-color: var(--gold);
  transform: translateY(-50%) scale(1.08);
  box-shadow: 0 0 22px rgba(185,147,90,.35), 0 12px 32px rgba(0,0,0,.9);
}
.menu-3d-btn svg{ pointer-events: none; }

/* Slides en infos: gestapeld via grid */
.menu-3d-slides,
.menu-3d-infos{
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  pointer-events: none;
}
.menu-3d-slides > *,
.menu-3d-infos > *{ grid-area: 1 / -1; }

/* Individuele slide */
.menu-3d-slide{
  width: var(--slide-w);
  aspect-ratio: var(--slide-aspect);
  border-radius: 18px;
  overflow: hidden;
  user-select: none;
  opacity: 0;
  pointer-events: none;
  transform: perspective(1000px) translateX(0) rotateY(0deg) scale(.85);
  transition: transform var(--transition), opacity var(--transition), filter var(--transition), box-shadow var(--transition);
  box-shadow: 0 20px 55px rgba(0,0,0,.7);
}

.menu-3d-slide[data-current]{
  opacity: 1;
  pointer-events: auto;
  transform: perspective(1000px) translateX(0) rotateY(0deg) scale(1.1);
  box-shadow: 0 30px 80px rgba(0,0,0,.85), 0 0 0 1px rgba(185,147,90,.18);
  z-index: 10;
}
.menu-3d-slide[data-next]{
  opacity: 1;
  transform: perspective(1000px) translateX(calc(var(--slide-w) * 1.0)) rotateY(-42deg) scale(.9);
  z-index: 5;
  filter: brightness(.5);
}
.menu-3d-slide[data-previous]{
  opacity: 1;
  transform: perspective(1000px) translateX(calc(-1 * var(--slide-w) * 1.0)) rotateY(42deg) scale(.9);
  z-index: 5;
  filter: brightness(.5);
}
.menu-3d-slide[data-hidden]{
  opacity: 0;
  pointer-events: none;
}

/* Tilt inner */
.menu-3d-slide__inner{
  width: 100%;
  height: 100%;
  transform-style: preserve-3d;
  transition: transform .1s ease;
}
.menu-3d-slide__img-wrap{
  width: 100%;
  height: 100%;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.07);
}
.menu-3d-slide__img{
  width: 100%;
  height: 100%;
  display: block;
  background: #0a0a0a;
}
.menu-3d-slide[data-current] .menu-3d-slide__img{ filter: brightness(.92); }
.menu-3d-slide:not([data-current]) .menu-3d-slide__img{ filter: brightness(.5); }

/* Slide label */
.menu-3d-infos{ z-index: 20; }
.menu-3d-info{
  width: var(--slide-w);
  aspect-ratio: var(--slide-aspect);
  position: relative;
  opacity: 0;
  transition: opacity var(--transition);
}
.menu-3d-info[data-current]{ opacity: 1; }
.menu-3d-info__inner{
  position: absolute;
  bottom: 1rem;
  left: 50%;
  transform: translateX(-50%);
}
.menu-3d-label{
  display: block;
  font-family: var(--font-title);
  font-size: .8rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(255,255,255,.88);
  white-space: nowrap;
  background: rgba(0,0,0,.5);
  padding: .32rem .8rem;
  border-radius: 999px;
  backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,.1);
}

/* DOTS nav */
.menu-slider__dots{
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .45rem;
  margin: 2rem auto 0;
  padding: .55rem .9rem;
  max-width: fit-content;
  border-radius: 999px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
  backdrop-filter: blur(12px);
  box-shadow: 0 14px 32px rgba(0,0,0,.85);
}
.menu-slider__dots::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:999px;
  background: radial-gradient(circle at center, color-mix(in srgb, var(--gold) 16%, transparent), transparent 65%);
  opacity: .45;
  pointer-events: none;
}
.menu-slider__dots .dot{
  border: 1px solid rgba(255,255,255,.05);
  background: rgba(0,0,0,.25);
  color: #cfd2d8;
  font-weight: 700;
  font-size: .72rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  padding: .45rem 1.1rem;
  border-radius: 999px;
  cursor: pointer;
  transition: background .22s, color .22s, transform .22s, box-shadow .22s, border-color .22s;
}
.menu-slider__dots .dot:hover{
  background: #111217;
  color: #fff;
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--gold) 45%, transparent);
}
.menu-slider__dots .dot.is-active{
  background: linear-gradient(135deg, color-mix(in srgb, var(--gold) 84%, transparent), var(--gold));
  color: #050506;
  border-color: rgba(0,0,0,.85);
  box-shadow: 0 0 0 1px rgba(0,0,0,.6), 0 16px 40px rgba(0,0,0,.95);
}

/* Responsive */
@media (max-width: 900px){
  .menu-3d-slider{ --slide-w: min(50vw, 280px); }
  .menu-3d-btn{ --size: 38px; }
}
@media (max-width: 600px){
  .menu-3d-slider{ --slide-w: 68vw; }
  .menu-3d-slides__wrapper{ min-height: 340px; }
  .menu-3d-slide[data-next]{
    transform: perspective(1000px) translateX(calc(var(--slide-w) * .82)) rotateY(-28deg) scale(.82);
  }
  .menu-3d-slide[data-previous]{
    transform: perspective(1000px) translateX(calc(-1 * var(--slide-w) * .82)) rotateY(28deg) scale(.82);
  }
  .menu-slider__dots .dot{ font-size: .65rem; padding: .4rem .7rem; }
}

/* ========== LIGHTBOX VOOR GROTE MENUKAART ========== */
.menu-lightbox{
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 999;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s ease;
}
.menu-lightbox.is-open{
  opacity: 1;
  pointer-events: auto;
}

.menu-lightbox__backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.85);
}

.menu-lightbox__content{
  position: relative;
  max-width: 90vw;
  max-height: 90vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.menu-lightbox__image{
  max-width: 90vw;
  max-height: 85vh;
  width: auto;
  height: auto;
  border-radius: 18px;
  box-shadow: 0 20px 60px rgba(0,0,0,.9);
  object-fit: contain;
}

.menu-lightbox__control{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 46px;
  height: 46px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--gold) 70%, transparent);
  background: rgba(10,10,10,0.9);
  color: #fff;
  font-size: 1.6rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 12px 30px rgba(0,0,0,.9);
  transition: background .25s ease, transform .25s ease, box-shadow .25s ease, color .25s ease;
}
.menu-lightbox__control--prev{ left: -60px; }
.menu-lightbox__control--next{ right: -60px; }

.menu-lightbox__control:hover{
  background: var(--gold);
  color: #000;
  transform: translateY(-50%) scale(1.05);
  box-shadow: 0 16px 40px rgba(0,0,0,.95);
}

.menu-lightbox__close{
  position: absolute;
  top: -40px;
  right: 0;
  border: none;
  background: transparent;
  color: #fff;
  font-size: 2rem;
  cursor: pointer;
}

body.no-scroll{ overflow: hidden; }

@media (max-width: 768px){
  .menu-lightbox__control--prev{ left: 10px; }
  .menu-lightbox__control--next{ right: 10px; }
  .menu-lightbox__close{ top: 10px; right: 10px; }
}

/* ========== BAR LOUNGE PAGINA ========== */
.bar-page{ background:#050506; }

.bar-hero{
  background:var(--bg-900);
  padding:3.5rem 0 3.1rem;
  border-bottom:1px solid #181818;
}

.bar-hero__inner{
  max-width:1200px;
  margin:0 auto;
  padding:0 1.5rem;
  display:grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, 1fr);
  gap:2.4rem;
  align-items:center;
}

.bar-hero__title{
  font-family:var(--font-title);
  margin:.4rem 0 .5rem;
}

.bar-hero__divider{
  width:110px;
  height:2px;
  border-radius:999px;
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--gold) 5%, transparent),
    var(--gold),
    color-mix(in srgb, var(--gold) 5%, transparent)
  );
  margin:.35rem 0 1.2rem;
  box-shadow:0 0 16px rgba(0,0,0,.6);
}

.bar-hero__lead{
  color:#e0e0e0;
  max-width:520px;
  line-height:1.8;
  font-size:.98rem;
  margin-bottom:.6rem;
}

.bar-hero__meta{
  color:#a9a9a9;
  font-size:.8rem;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.bar-hero__photo{
  position:relative;
  border-radius:20px;
  overflow:hidden;
  box-shadow:0 24px 70px rgba(0,0,0,.85);
}

.bar-hero__photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform:scale(1.04);
  transition: transform .5s ease;
}

.bar-hero__photo::before{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(to top, rgba(0,0,0,.55) 0%, rgba(0,0,0,.15) 60%);
  pointer-events:none;
}

.bar-hero__photo:hover img{ transform:scale(1.07); }


.bar-section{
  padding:3rem 0 2.8rem;
  background:var(--bg-900);
}

.bar-section__inner{
  max-width:1100px;
  margin:0 auto;
  padding:0 1.5rem;
  display:grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(260px, 1fr);
  gap:2.4rem;
  align-items:center;
}

.bar-section__title{
  font-family:var(--font-title);
  font-size:clamp(1.6rem, 3vw, 2.1rem);
  margin:0 0 .9rem;
}

.bar-section__content p{
  color:#d9d9d9;
  line-height:1.8;
  margin:0 0 .9rem;
}

.bar-section__list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:.4rem;
  color:#f0f0f0;
  font-size:.95rem;
}

.bar-section__list .dot{
  display:inline-block;
  width:.45rem;
  height:.45rem;
  border-radius:50%;
  margin-right:.5rem;
  background: radial-gradient(circle,
    color-mix(in srgb, var(--gold) 70%, #fff 10%) 0,
    var(--gold) 55%,
    #553618 100%
  );
}

.bar-section__photo{
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,.85);
}

.bar-section__photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.bar-gallery{
  padding:2.4rem 0 3.5rem;
  background:var(--bg-900);
  border-top:1px solid #181818;
}

.bar-gallery__inner{
  max-width:1200px;
  margin:0 auto;
  padding:0 1.5rem;
}

.bar-gallery__header{
  text-align:center;
  max-width:720px;
  margin:0 auto 2rem;
}

.bar-gallery__title{
  font-family:var(--font-title);
  font-size:clamp(1.7rem, 3vw, 2.1rem);
  margin:.35rem 0 .4rem;
}

.bar-gallery__text{
  color:#d7d7d7;
  font-size:.96rem;
  line-height:1.7;
}
.bar-gallery__text a{
  color:var(--gold);
  text-decoration:none;
}
.bar-gallery__text a:hover{ text-decoration:underline; }

.bar-gallery__grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap:1.4rem;
}

.bar-gallery__item{
  position:relative;
  border-radius:14px;
  overflow:hidden;
  background:#050505;
  border:1px solid color-mix(in srgb, var(--gold) 35%, transparent);
  box-shadow:0 14px 38px rgba(0,0,0,.75);
  transform: translateY(18px) scale(.98);
  opacity:0;
  transition: transform .45s ease, opacity .45s ease, box-shadow .3s ease, border-color .3s ease;
}

.bar-gallery__item.in{
  opacity:1;
  transform: translateY(0) scale(1);
}

.bar-gallery__item img{
  width:100%;
  height:170px;
  object-fit:cover;
  display:block;
}

.bar-gallery__item::before{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(to top, rgba(0,0,0,.65) 0%, rgba(0,0,0,.1) 60%);
  pointer-events:none;
}

.bar-gallery__item:hover{
  transform: translateY(-4px) scale(1.01);
  box-shadow:0 20px 50px rgba(0,0,0,.9);
  border-color: color-mix(in srgb, var(--gold) 80%, transparent);
}

.bar-gallery__item figcaption{
  position:absolute;
  left:0; right:0;
  bottom:.6rem;
  text-align:center;
  font-size:.78rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#f5f5f5;
}

@media (max-width: 992px){
  .bar-hero__inner,
  .bar-section__inner{
    grid-template-columns:1fr;
  }

  .bar-hero__photo{
    max-width:480px;
    margin:0 auto;
  }

  .bar-gallery__grid{
    grid-template-columns: repeat(2, minmax(0,1fr));
  }

  .bar-gallery__item img{ height:150px; }
}

@media (max-width: 600px){
  .bar-gallery__grid{ grid-template-columns:1fr 1fr; gap:1rem; }
  .bar-gallery__item img{ height:130px; }
}


/* ========== FOTO PAGINA — 3D STRIP GALLERY ========== */

.photo-page { background: var(--bg-900); }

/* HERO premium */
.photo-hero2{
  position: relative;
  isolation: isolate;
  padding: 3.2rem 0 2.6rem;
  border-bottom: 1px solid #181818;
  background: #050506;
  overflow: hidden;
}

.photo-hero2__bg{
  position:absolute; inset:0;
  background:
    radial-gradient(900px 520px at 20% 15%, rgba(185,147,90,.16), transparent 60%),
    radial-gradient(800px 520px at 85% 10%, rgba(255,255,255,.06), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.55), rgba(0,0,0,.85)),
    url("images/table ados.jpg") center/cover no-repeat;
  filter: saturate(1.05) contrast(1.05);
  transform: scale(1.02);
  z-index: -1;
}

.photo-hero2__inner{
  display: grid;
  grid-template-columns: 1.25fr .75fr;
  gap: 2rem;
  align-items: end;
}

.photo-hero2__title{
  font-family: var(--font-title);
  margin: .35rem 0 .3rem;
  letter-spacing: .03em;
  text-transform: none;
}
.photo-hero2__title span{ color: var(--gold); }

.photo-hero2__lead{
  max-width: 540px;
  color: #e3e3e3;
  font-size: .96rem;
  line-height: 1.8;
  margin: .45rem 0 .3rem;
}

.photo-hero2__meta{
  margin-top: 1.2rem;
  display:flex;
  flex-wrap:wrap;
  gap:.6rem;
}

.photo-chip{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  padding:.55rem .85rem;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.28);
  color:#fff;
  font-weight:600;
  font-size:.88rem;
  backdrop-filter: blur(10px);
}

.photo-chip i{ color: var(--gold); }

.photo-hero2__card{
  background: rgba(10,10,10,.55);
  border: 1px solid rgba(185,147,90,.18);
  border-radius: 18px;
  padding: 1.05rem 1.1rem 1.1rem;
  box-shadow: 0 18px 60px rgba(0,0,0,.55);
  backdrop-filter: blur(12px);
}

.photo-hero2__cardTitle{
  font-family: var(--font-title);
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: .85rem;
  color: rgba(255,255,255,.9);
  margin-bottom: .7rem;
}

.photo-hero2__stats{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: .8rem;
}

.stat2{
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  padding: .75rem .75rem .65rem;
}
.stat2__num{
  font-family: var(--font-title);
  color: #fff;
  font-size: 1.05rem;
  letter-spacing: .03em;
}
.stat2__lbl{
  margin-top: .15rem;
  font-size: .78rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.65);
}

.photo-hero2__hint{
  margin-top: .85rem;
  font-size: .85rem;
  color: rgba(255,255,255,.7);
}

/* ===== 3D STRIP GALLERY ===== */
.photo-gallery2{
  padding: 2.4rem 0 3.6rem;
  background: var(--bg-900);
}

.photo-gallery2__head{
  max-width: 820px;
  margin: 0 auto 1.4rem;
  text-align: center;
}
.photo-gallery2__title{
  font-family: var(--font-title);
  font-size: clamp(1.6rem, 2.6vw, 2.1rem);
  margin: 0 0 .35rem;
}
.photo-gallery2__sub{
  margin: 0 auto;
  max-width: 620px;
  color: rgba(255,255,255,.72);
  line-height: 1.7;
}

/* The strip container */
.photo-strip-nav{
  --hover-intensity: 120px;
  --hover-smoothness: 70ms;
  --fall-smoothness: 300ms;
  --perspective: 1800px;
  --max-p: 12;
  --max-z: 9;

  display: flex;
  align-items: flex-end;
  position: relative;
  width: 100%;
  height: clamp(320px, 52vh, 560px);
  margin-top: 1.4rem;

  perspective: var(--perspective);
  transform-style: preserve-3d;
}

/* Each strip/photo item */
.photo-strip-item{
  flex: 1;
  height: 100%;
  position: relative;
  cursor: pointer;
  transform-style: preserve-3d;

  --ts: calc(
    var(--hover-smoothness) * var(--falloff, 0) +
    var(--fall-smoothness) * (1 - var(--falloff, 0))
  );
  --fs: calc(
    .1s * var(--falloff, 0) +
    .8s * (1 - var(--falloff, 0))
  );

  transition:
    filter var(--fs),
    transform var(--ts, var(--fall-smoothness)),
    flex .3s;

  --p-n: calc((var(--i, 0)) / (var(--max-p) - 1));
  --r-n: calc((var(--r, 1) - 1) / (var(--max-z) * var(--max-p) - 1));
  --diff: calc(var(--p-n) - var(--r-n));
  --u: calc(abs(var(--diff)) / .4);
  --falloff: clamp(calc(0.5 * (1 + cos(min(var(--u), 1) * 180deg))), 0, 1);
  --tilt: calc(clamp(-1, var(--diff) * 5, 1) * var(--falloff) * 65deg);

  transform:
    translateZ(calc(var(--falloff) * var(--hover-intensity)))
    rotateY(var(--tilt));

  filter:
    brightness(max(.45, var(--falloff, 0) * 1.15))
    saturate(max(.1, var(--falloff, 0)));
}

.photo-strip-nav:has(.photo-strip-item:hover) .photo-strip-item:hover{
  flex: 4;
}

.photo-strip-img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 4px;
  pointer-events: none;
  margin-inline: 1px;
}

/* Caption overlay */
.photo-strip-item::after{
  content: attr(data-caption);
  position: absolute;
  left: 0; right: 0; bottom: 0;
  padding: .6rem .5rem .5rem;
  background: linear-gradient(to top, rgba(0,0,0,.75), transparent);
  color: rgba(255,255,255,.9);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  border-radius: 0 0 4px 4px;
  opacity: 0;
  transition: opacity var(--fs);
}
.photo-strip-item:hover::after{
  opacity: 1;
}

/* Hover zones for smooth region tracking */
.photo-strip-hover{
  position: absolute;
  inset: 0;
  inset-inline: -3px;
  display: flex;
  z-index: 10;
}
.photo-strip-hover > i{
  flex: 1;
}

/* Update --r based on which zone is hovered */
.photo-strip-nav:has(.photo-strip-hover > i:nth-child(1):hover) { --z: 1; }
.photo-strip-nav:has(.photo-strip-hover > i:nth-child(2):hover) { --z: 2; }
.photo-strip-nav:has(.photo-strip-hover > i:nth-child(3):hover) { --z: 3; }
.photo-strip-nav:has(.photo-strip-hover > i:nth-child(4):hover) { --z: 4; }
.photo-strip-nav:has(.photo-strip-hover > i:nth-child(5):hover) { --z: 5; }
.photo-strip-nav:has(.photo-strip-hover > i:nth-child(6):hover) { --z: 6; }
.photo-strip-nav:has(.photo-strip-hover > i:nth-child(7):hover) { --z: 7; }
.photo-strip-nav:has(.photo-strip-hover > i:nth-child(8):hover) { --z: 8; }
.photo-strip-nav:has(.photo-strip-hover > i:nth-child(9):hover) { --z: 9; }

.photo-strip-nav:has(.photo-strip-item:nth-child(1):is(:hover,:focus-visible)) { --p: 0; }
.photo-strip-nav:has(.photo-strip-item:nth-child(2):is(:hover,:focus-visible)) { --p: 1; }
.photo-strip-nav:has(.photo-strip-item:nth-child(3):is(:hover,:focus-visible)) { --p: 2; }
.photo-strip-nav:has(.photo-strip-item:nth-child(4):is(:hover,:focus-visible)) { --p: 3; }
.photo-strip-nav:has(.photo-strip-item:nth-child(5):is(:hover,:focus-visible)) { --p: 4; }
.photo-strip-nav:has(.photo-strip-item:nth-child(6):is(:hover,:focus-visible)) { --p: 5; }
.photo-strip-nav:has(.photo-strip-item:nth-child(7):is(:hover,:focus-visible)) { --p: 6; }
.photo-strip-nav:has(.photo-strip-item:nth-child(8):is(:hover,:focus-visible)) { --p: 7; }
.photo-strip-nav:has(.photo-strip-item:nth-child(9):is(:hover,:focus-visible)) { --p: 8; }
.photo-strip-nav:has(.photo-strip-item:nth-child(10):is(:hover,:focus-visible)) { --p: 9; }
.photo-strip-nav:has(.photo-strip-item:nth-child(11):is(:hover,:focus-visible)) { --p: 10; }
.photo-strip-nav:has(.photo-strip-item:nth-child(12):is(:hover,:focus-visible)) { --p: 11; }

/* recalc --r for each item */
.photo-strip-item { --r: calc(var(--max-z, 9) * (var(--p, 0)) + var(--z, 1)); }

/* Lightbox */
.photo-lightbox{
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
}
.photo-lightbox.is-open{ display:block; }

.photo-lightbox__backdrop{
  position:absolute; inset:0;
  background: rgba(0,0,0,.88);
}

.photo-lightbox__dialog{
  position: relative;
  width: min(980px, calc(100% - 28px));
  margin: 6vh auto;
  background: rgba(12,12,12,.92);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 18px;
  box-shadow: 0 30px 90px rgba(0,0,0,.85);
  padding: 14px 14px 12px;
}

.photo-lightbox__img{
  width: 100%;
  max-height: 74vh;
  object-fit: contain;
  border-radius: 14px;
  display:block;
  background: #0a0a0b;
}

.photo-lightbox__cap{
  margin-top: .65rem;
  color: rgba(255,255,255,.78);
  font-size: .9rem;
  line-height: 1.5;
  padding: 0 .25rem;
}

.photo-lightbox__close{
  position:absolute;
  right: 12px;
  top: 10px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color:#fff;
  border-radius: 12px;
  padding: 8px 10px;
  cursor:pointer;
}

.photo-lightbox__nav{
  position:absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 46px;
  height: 46px;
  border-radius: 999px;
  border: 1px solid rgba(185,147,90,.7);
  background: rgba(0,0,0,.55);
  color:#fff;
  font-size: 1.8rem;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition: transform .2s ease, background .2s ease;
}
.photo-lightbox__nav:hover{
  background: var(--gold);
  color:#000;
  transform: translateY(-50%) scale(1.05);
}

.photo-lightbox__nav--prev{ left: -60px; }
.photo-lightbox__nav--next{ right: -60px; }

@media (max-width: 820px){
  .photo-lightbox__nav--prev{ left: 10px; }
  .photo-lightbox__nav--next{ right: 10px; }
}

/* Responsive */
@media (max-width: 900px){
  .photo-strip-nav{ height: clamp(220px, 40vw, 380px); }
  .photo-hero2__inner{ grid-template-columns: 1fr; }
  .photo-hero2__card{ display: none; }
}
@media (max-width: 600px){
  .photo-strip-nav{ height: 200px; }
}

/* body lock */
body.no-scroll{ overflow: hidden; }


/* ========== FOOTER ========== */
.site-footer{
  background: radial-gradient(circle at top right, color-mix(in srgb, var(--gold) 14%, transparent), transparent 60%),
              #050506;
  border-top:1px solid #181818;
  padding:3.2rem 0 0;
  color:#f5f5f5;
}

.site-footer__inner{
  max-width:1200px;
  margin:0 auto;
  padding:0 1.5rem;
}

.site-footer__top{
  display:grid;
  grid-template-columns: 1.1fr 1fr 1.1fr;
  gap:2.4rem;
  align-items:flex-start;
  margin-bottom:2.4rem;
}

.footer-col__title{
  font-family:var(--font-title);
  font-size:1.05rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#fff;
  margin:0 0 .9rem;
}

.footer-col__text{
  margin:0 0 .6rem;
  color:#d3d3d3;
  font-size:.95rem;
  line-height:1.7;
}

.footer-col__text a{
  color:var(--gold);
  text-decoration:none;
}
.footer-col__text a:hover{ text-decoration:underline; }

.footer-col--cta{ text-align:left; }

.footer-cta__btn{
  margin-top:.3rem;
  padding:.85rem 1.8rem;
  border-radius:999px;
  font-size:.9rem;
}

/* Social icons */
.footer-social{ margin-top:2rem; }

.footer-social__title{
  color:#d5d5d5;
  letter-spacing:4px;
  font-size:.85rem;
  margin-bottom:1rem;
}

.footer-social__icons{
  display:flex;
  gap:1.2rem;
}

.footer-social__icons a{
  text-decoration:none !important;
}

.footer-social__icons .social{
  width:48px;
  height:48px;
  border-radius:50%;
  background:var(--gold);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  font-size:1.25rem;
  transition:.3s ease;
  border:none;
}

.footer-social__icons .social:hover{
  background: color-mix(in srgb, var(--gold) 70%, #fff 25%);
  transform: translateY(-3px);
  box-shadow:0 10px 25px rgba(0,0,0,.7);
}

/* Onderste balk */
.site-footer__bottom{
  border-top:1px solid #171717;
  padding-top:1.4rem;
  padding-bottom:.3rem;
  display:flex;
  flex-wrap:wrap;
  gap:.6rem;
  justify-content:space-between;
  font-size:.8rem;
  color:#9b9b9b;
}
.site-footer__bottom p{ margin:0; padding:0; }

.footer-made{ opacity:.9; }

@media (max-width: 900px){
  .site-footer__top{ grid-template-columns: 1fr 1fr; }
  .footer-col--cta{ grid-column:1 / -1; }
}
@media (max-width: 640px){
  .site-footer__top{ grid-template-columns: 1fr; }
  .site-footer__bottom{
    flex-direction:column;
    align-items:flex-start;
  }
}


/* ========== CONTACTPAGINA ========== */
.contact-hero {
  position: relative;
  overflow: hidden;
  background: radial-gradient(circle at top left, 
    color-mix(in srgb, var(--gold) 14%, transparent), transparent 60%), #050506;
  border-bottom: 1px solid #181818;
  padding: 2.4rem 0 2rem;

}


.contact-hero::before{
  content:"";
  position:absolute;
  inset:-20%;
  background:
    radial-gradient(900px 520px at 20% 15%, rgba(185,147,90,.14), transparent 60%),
    radial-gradient(800px 520px at 85% 10%, rgba(255,255,255,.06), transparent 60%);
  pointer-events:none;
}

.contact-hero__inner {
    margin:0 auto;
  padding:0 1.5rem;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
}

.contact-hero__title {
  font-family:var(--font-title);
  margin:.35rem 0 .3rem;
  letter-spacing:.03em;
  text-transform:none;
}

.contact-hero__title span {
    color:var(--gold);
  letter-spacing:.14em;
  text-transform:uppercase;
  font-size:.9em;
}

.contact-hero__divider{
  width:110px;
  height:2px;
  border-radius:999px;
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--gold) 5%, transparent),
    var(--gold),
    color-mix(in srgb, var(--gold) 5%, transparent)
  );
  margin:.45rem 0 1.4rem;
  box-shadow:0 0 18px rgba(0,0,0,.6);
}


.contact-hero__lead {
    max-width: 540px;
    color: #e3e3e3;
    font-size: .96rem;
    line-height: 1.8;
    margin: .45rem 0 .3rem;

}

.contact-hero__items {
  margin-top: 1.4rem;
  display: flex;
  flex-wrap: wrap;
  gap: 1.4rem 2.2rem;
}

.contact-hero__item {
  display: flex;
  align-items: center;
  gap: .7rem;
}

.contact-hero__icon {
  width: 38px;
  height: 38px;
  border-radius: 999px;
  border: 1px solid rgba(185,147,90,.55);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(5,5,6,.92);
  box-shadow: 0 10px 26px rgba(0,0,0,.8);
  font-size: .9rem;
  color: var(--gold);
}

.contact-hero__label {
  font-size: .75rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: #a7a7a7;
  margin-bottom: .08rem;
}

.contact-hero__link {
  color: #fff;
  text-decoration: none;
  font-weight: 600;
}

.contact-hero__link:hover {
  color: var(--gold);
}

/* MAIN CONTACT SECTION */
.contact-main{
  background:var(--bg-900);
  padding:6rem 0 3.5rem;
}

.contact-grid{
  display:grid;
  grid-template-columns: minmax(0, 3fr) minmax(0, 2.4fr);
  gap:2.3rem;
  align-items:flex-start;
}

/* Cards */
.contact-card{
  background: radial-gradient(circle at top left, rgba(255,255,255,.03), transparent 55%);
  border-radius:24px;
  padding:2.1rem 2rem 2.3rem;
  border:1px solid rgba(255,255,255,.04);
  box-shadow:0 26px 60px rgba(0,0,0,.75);
  backdrop-filter: blur(10px);
}

.contact-card__title{
  font-size:1.1rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  margin:0 0 .9rem;
}

.contact-card__text{
  font-size:.95rem;
  color:#d8d8d8;
  margin:0 0 1.6rem;
}

/* FORM */
.contact-form{
  display:flex;
  flex-direction:column;
  gap:1.1rem;
}

.contact-form__row{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:1rem;
}

.field{
  display:flex;
  flex-direction:column;
  gap:.35rem;
}

.field label{
  font-size:.78rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#bfbfbf;
}

.field input,
.field textarea{
  background:#0a0a0b;
  border-radius:10px;
  border:1px solid #232323;
  padding:.7rem .85rem;
  color:#fff;
  font-family:var(--font-body);
  font-size:.92rem;
  outline:none;
  transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

.field textarea{
  resize:vertical;
  min-height:130px;
}

.field input::placeholder,
.field textarea::placeholder{ color:#6d6d6d; }

.field input:focus,
.field textarea:focus{
  border-color:var(--gold);
  box-shadow:0 0 0 1px color-mix(in srgb, var(--gold) 55%, transparent);
  background:#101012;
}

.contact-form__submit{
  margin-top:.5rem;
  align-self:flex-start;
}

.contact-form__note{
  margin-top:.6rem;
  font-size:.78rem;
  color:#a2a2a2;
  max-width:420px;
}

/* INFO LIST */
.contact-info-list{
  display:flex;
  flex-direction:column;
  gap:1.3rem;
}

.contact-info-item{
  display:flex;
  gap:.85rem;
}

.contact-info-item__icon{
  width:40px;
  height:40px;
  border-radius:999px;
  border:1px solid color-mix(in srgb, var(--gold) 45%, transparent);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  margin-top:.15rem;
}

.contact-info-item__icon i{
  color:var(--gold);
  font-size:.95rem;
}

.contact-info-item__body h3{
  font-size:.9rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  margin:0 0 .3rem;
}

.contact-info-item__body p{
  margin:0;
  font-size:.9rem;
  color:#d5d5d5;
}

.contact-info-item__hint{
  margin-top:.25rem;
  font-size:.8rem;
  color:#a8a8a8;
}

/* MAP */
.contact-map{
  background:var(--bg-900);
  padding:0 0 3rem;
}

.contact-map__inner{
  position:relative;
  max-width:1200px;
  margin:0 auto;
  border-radius:24px;
  overflow:hidden;
  box-shadow:0 26px 70px rgba(0,0,0,.9);
}

.contact-map__frame{
  display:block;
  width:100%;
  height:420px;
}

.contact-map__card{
  position:absolute;
  right:2.2rem;
  top:2.2rem;
  max-width:280px;
  background:rgba(5,5,6,.94);
  border-radius:18px;
  padding:1.3rem 1.4rem 1.5rem;
  border:1px solid color-mix(in srgb, var(--gold) 55%, transparent);
  box-shadow:0 18px 40px rgba(0,0,0,.9);
}

.contact-map__label{
  font-size:.75rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--gold);
  margin:0 0 .3rem;
}

.contact-map__title{
  font-size:1rem;
  margin:0 0 .55rem;
}

.contact-map__text{
  font-size:.88rem;
  color:#e1e1e1;
  margin:0 0 .85rem;
}

.contact-map__btn{
  width:100%;
  text-align:center;
}

/* RESPONSIVE CONTACT */
@media (max-width: 900px){
  .contact-grid{ grid-template-columns: minmax(0,1fr); }
  .contact-card{ padding:1.8rem 1.4rem 2rem; }
  .contact-form__row{ grid-template-columns: minmax(0,1fr); }

  .contact-map__card{
    position:static;
    max-width:none;
    border-left:none;
    border-right:none;
    border-bottom:none;
    border-radius:0 0 18px 18px;
  }
}

/* CONTACT – forceer link styling (geen blauw/paars) */
.contact-main a,
.contact-hero a,
.contact-card a,
.contact-info-item a{
  color: var(--gold) !important;
  text-decoration: none !important;
  font-weight: 700;
}

.contact-main a:hover,
.contact-hero a:hover,
.contact-card a:hover,
.contact-info-item a:hover{
  color: color-mix(in srgb, var(--gold) 70%, #fff 25%) !important;
}

.contact-main a:visited,
.contact-hero a:visited,
.contact-card a:visited,
.contact-info-item a:visited{
  color: var(--gold) !important;
}

@media (max-width: 768px){
  .contact-hero__inner{ padding:3.2rem 1.3rem 2.4rem; }
  .contact-hero__meta{ flex-direction:column; gap:.4rem; }
}


/* ========== EVENTS (FullCalendar) ========== */
.events-page{
  background:transparent;
  color:inherit;
}

.events-hero{
  background: radial-gradient(circle at top left, color-mix(in srgb, var(--gold) 14%, transparent), transparent 60%),
              #050506;
  border-bottom:1px solid #181818;
  padding:2.5rem 0 2.5rem;
  position:relative;
}


.events-hero::before{
  content:"";
  position:absolute;
  inset:-20%;
  background:
    radial-gradient(900px 520px at 20% 15%, rgba(185,147,90,.14), transparent 60%),
    radial-gradient(800px 520px at 85% 10%, rgba(255,255,255,.06), transparent 60%);
  pointer-events:none;
}

.events-hero__inner{
  margin:0 auto;
  padding:0 var(--pad);
}


.events-hero__divider{
  width: 110px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--gold) 5%, transparent),
    var(--gold),
    color-mix(in srgb, var(--gold) 5%, transparent)
  );
  margin: .45rem 0 1.4rem;
  box-shadow: 0 0 18px rgba(0,0,0,.6);
}

/* subtiele “smoke” overlay */
.events-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(50% 60% at 70% 20%, rgba(255,255,255,0.06), transparent 60%);
  pointer-events:none;
}

.events-hero .container{ position:relative; z-index:1; }

.events-hero__kicker{
  margin:0 0 14px;
  font-family: var(--font-body);
  letter-spacing:.18em;
  text-transform:uppercase;
  font-size:12px;
  color: color-mix(in srgb, var(--gold) 90%, transparent);
}

.events-hero__title{
    font-family: var(--font-title);
    margin: .35rem 0 .3rem;
    letter-spacing: .03em;
    text-transform: none;
}

.events-hero__title span{ color:var(--gold); }

.events-hero__lead{
    max-width: 540px;
    color: #e3e3e3;
    font-size: .96rem;
    line-height: 1.8;
    margin: .45rem 0 .3rem;
}

.events-hero__meta{
    max-width: 540px;
    font-size: .76rem;
    line-height: 1.8;
    margin: .2rem 0 0;
    color: #a4a4a4;
    letter-spacing: .18em;
    text-transform: uppercase;
}

.events-main{ padding:40px 0 70px; }

.events-page .card{
  background: rgba(20, 20, 20, 0.78);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:20px;
  box-shadow:0 20px 55px rgba(0,0,0,0.35);
  overflow:hidden;
  margin-top:22px;
}

.events-page .card-head{
  padding:18px 22px;
  border-bottom:1px solid rgba(255,255,255,0.08);
}

.events-page .card-head h2{
  margin:0 0 6px;
  font-family: var(--font-body);
  font-weight:700;
  color:#fff;
  font-size:18px;
}

.events-page .muted,
.events-page .card-head .muted{ color: rgba(255,255,255,0.70); }

.events-page .muted.small{ font-size:13px; }

.events-page .card-body{ padding:18px 22px 22px; }

.events-page #calendar{ min-height:540px; }

/* FullCalendar theme */
.events-page .fc{
  --fc-border-color: rgba(255,255,255,0.10);
  --fc-page-bg-color: transparent;
  --fc-neutral-bg-color: rgba(255,255,255,0.03);
  --fc-today-bg-color: color-mix(in srgb, var(--gold) 12%, transparent);
  color: rgba(255,255,255,0.90);
}

.events-page .fc .fc-toolbar-title{
  font-family: var(--font-body);
  font-size:18px;
  font-weight:700;
  color:#fff;
}

.events-page .fc .fc-button{
  border:1px solid rgba(255,255,255,0.14) !important;
  background: rgba(255,255,255,0.03) !important;
  color: rgba(255,255,255,0.90) !important;
  border-radius:12px !important;
  padding:8px 12px !important;
  box-shadow:none !important;
  transition: transform .08s, background .2s, border-color .2s;
}

.events-page .fc .fc-button:hover{
  background: rgba(255,255,255,0.06) !important;
  border-color: color-mix(in srgb, var(--gold) 35%, transparent) !important;
}

.events-page .fc .fc-button:active{ transform: translateY(1px); }

.events-page .fc .fc-button-primary:not(:disabled).fc-button-active{
  background: color-mix(in srgb, var(--gold) 22%, transparent) !important;
  border-color: color-mix(in srgb, var(--gold) 55%, transparent) !important;
  color:#fff !important;
}

.events-page .fc .fc-col-header-cell-cushion,
.events-page .fc .fc-daygrid-day-number{
  color: rgba(255,255,255,0.85);
  text-decoration:none;
}

.events-page .fc .fc-event{
  border-radius:999px;
  border:1px solid color-mix(in srgb, var(--gold) 35%, transparent);
  background: color-mix(in srgb, var(--gold) 18%, transparent);
  color:#fff;
  padding:2px 10px;
  font-weight:700;
}

.events-page .events-list{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:16px;
}

@media (max-width: 820px){
  .events-page .events-list{ grid-template-columns:1fr; }
  .events-page #calendar{ min-height:480px; }
}

.events-page .event-item{
  border:1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.03);
  border-radius:18px;
  padding:16px 16px 14px;
  box-shadow:0 16px 40px rgba(0,0,0,0.25);
  transition: transform .12s, border-color .2s, background .2s;
}

.events-page .event-item:hover{
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--gold) 35%, transparent);
  background: rgba(255,255,255,0.05);
}

.events-page .event-item h3{
  margin:0 0 10px;
  font-size:16px;
  color:#fff;
  font-family: var(--font-body);
}

.events-page .event-item .date{
  font-size:13px;
  color: rgba(255,255,255,0.70);
  margin-bottom:10px;
}

.events-page .event-item .desc{
  margin:0;
  color: rgba(255,255,255,0.85);
  line-height:1.5;
}

/* Modal */
.events-page .modal{
  position:fixed;
  inset:0;
  display:none;
  z-index:999;
}
.events-page .modal.is-open{ display:block; }

.events-page .modal-backdrop{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,0.65);
}

.events-page .modal-card{
  position:relative;
  width: min(720px, calc(100% - 24px));
  margin: 10vh auto;
  background: rgba(18,18,18,0.96);
  border-radius:20px;
  border:1px solid rgba(255,255,255,0.12);
  box-shadow:0 25px 80px rgba(0,0,0,0.6);
  padding:18px 18px 16px;
  color:#fff;
}

.events-page .modal-close{
  position:absolute;
  right:12px;
  top:10px;
  border:1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04);
  color:#fff;
  border-radius:12px;
  padding:8px 10px;
  cursor:pointer;
}

.events-page .modal-card h3{
  margin:0 0 6px;
  font-size:22px;
  font-family: var(--font-title);
}

.events-page .modal-image{
  width:100%;
  max-height:320px;
  object-fit:cover;
  border-radius:16px;
  margin:12px 0;
  border:1px solid rgba(255,255,255,0.10);
}

.events-page .modal-desc{
  margin:10px 0 0;
  line-height:1.6;
  color: rgba(255,255,255,0.85);
}

/* ============================================================
   IMPROVEMENTS — added 2025
   Keep existing rules above intact; these extend the system.
   ============================================================ */

/* ---- 1. MOBILE NAV (hamburger) ---- */
.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: 40px;
  gap: 5px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 10px;
  background: rgba(0,0,0,.25);
  cursor: pointer;
  z-index: 1100;
  flex-shrink: 0;
}

.nav-toggle__bar {
  display: block;
  width: 20px;
  height: 2px;
  background: #fff;
  border-radius: 2px;
  transition: transform .3s ease, opacity .2s ease;
  transform-origin: center;
}

.nav-toggle.is-open .nav-toggle__bar:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.nav-toggle.is-open .nav-toggle__bar:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}
.nav-toggle.is-open .nav-toggle__bar:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

@media (max-width: 900px) {
  .nav-toggle { display: flex; }

  .nav {
    position: fixed;
    top: var(--header-h);
    left: 0;
    right: 0;
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    background: rgba(15,15,16,.97);
    backdrop-filter: blur(18px);
    border-bottom: 1px solid rgba(42,42,42,.6);
    padding: 1.2rem 1.5rem 1.8rem;
    transform: translateY(-110%);
    transition: transform .35s cubic-bezier(.4,0,.2,1);
    z-index: 999;
    pointer-events: none;
  }

  .nav.is-open {
    transform: translateY(0);
    pointer-events: auto;
  }

  .nav a {
    padding: .85rem 0;
    border-bottom: 1px solid rgba(255,255,255,.06);
    width: 100%;
    font-size: 1.05rem;
  }

  .nav a::after { display: none; }
  .nav a.active { color: var(--gold); }

  .nav-lang {
    margin-left: 0;
    margin-top: 1rem;
    width: 100%;
  }

  .nav-lang__menu {
    position: static;
    display: none !important;
    background: transparent;
    border: 0;
    box-shadow: none;
    backdrop-filter: none;
    padding: .5rem 0 0;
    min-width: auto;
    gap: .3rem;
  }

  .nav-lang.is-open .nav-lang__menu {
    display: grid !important;
  }

  .nav-lang__btn {
    width: 100%;
    justify-content: space-between;
    border-radius: 10px;
    border-color: rgba(255,255,255,.14);
  }
}


/* ---- 2. SCROLL-TO-TOP BUTTON ---- */
#scrollTop {
  position: fixed;
  bottom: 2rem;
  right: 1.5rem;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--gold);
  color: #000;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  box-shadow: 0 8px 24px rgba(0,0,0,.55);
  opacity: 0;
  transform: translateY(12px) scale(.9);
  transition: opacity .3s ease, transform .3s ease;
  z-index: 800;
  pointer-events: none;
}

#scrollTop.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

#scrollTop:hover {
  transform: translateY(-3px) scale(1.06);
  box-shadow: 0 12px 30px rgba(0,0,0,.7);
}

@media (max-width: 600px) {
  #scrollTop { bottom: 1.2rem; right: 1rem; }
}


/* ---- 3. HEADER: subtle scroll-darkening ---- */
.site-header {
  transition: background .3s ease, box-shadow .3s ease;
}

.site-header.scrolled {
  background: rgba(10,10,11,.92);
  box-shadow: 0 2px 18px rgba(0,0,0,.45);
}


/* ---- 4. ACTIVE NAV LINK: smoother indicator ---- */
.nav a::after {
  transition: transform .3s cubic-bezier(.4,0,.2,1);
}


/* ---- 5. CONTACT FORM: focus / error states ---- */
.contact-form input,
.contact-form textarea {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.12);
  color: #fff;
  border-radius: 10px;
  padding: .75rem 1rem;
  width: 100%;
  font: inherit;
  font-size: .95rem;
  transition: border-color .2s ease, box-shadow .2s ease;
  box-sizing: border-box;
  outline: none;
}

.contact-form input:focus,
.contact-form textarea:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(185,147,90,.15);
}

.contact-form input.has-error,
.contact-form textarea.has-error {
  border-color: #e05252;
  box-shadow: 0 0 0 3px rgba(224,82,82,.12);
}

.contact-form__field-error {
  display: none;
  color: #e05252;
  font-size: .8rem;
  margin-top: .3rem;
}
.contact-form input.has-error ~ .contact-form__field-error,
.contact-form textarea.has-error ~ .contact-form__field-error {
  display: block;
}

.contact-form__success {
  display: none;
  padding: 1rem 1.2rem;
  border-radius: 12px;
  background: rgba(52,199,89,.1);
  border: 1px solid rgba(52,199,89,.3);
  color: #6edb89;
  font-size: .95rem;
  margin-top: 1rem;
}

.contact-form__success.is-visible { display: block; }


/* ---- 6. SMOOTH hover on gallery images (foto page) ---- */
.photo-strip-item {
  outline: none;
}

.photo-strip-item:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
  z-index: 20;
}


/* ---- 7. FOOTER: refined bottom padding ---- */
.site-footer {
  padding-bottom: .6rem;
}


/* ---- 8. BUTTON: active press feedback ---- */
.btn:active {
  transform: translateY(1px) scale(.99);
}


/* ---- 9. EVENT ITEMS: gold left-border accent ---- */
.events-page .event-item {
  border-left: 3px solid color-mix(in srgb, var(--gold) 60%, transparent);
}


/* ---- 10. MODAL: smooth open animation ---- */
.events-page .modal-card {
  animation: modalIn .22s ease forwards;
}

@keyframes modalIn {
  from { opacity: 0; transform: scale(.96) translateY(8px); }
  to   { opacity: 1; transform: scale(1)   translateY(0); }
}


/* ---- 11. NAV LANG: keyboard accessibility ---- */
.nav-lang__menu button:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 2px;
}


/* ---- 12. SKIP-LINK (accessibility) ---- */
.skip-link {
  position: fixed;
  top: -999px;
  left: 1rem;
  background: var(--gold);
  color: #000;
  font-weight: 700;
  padding: .6rem 1.1rem;
  border-radius: 8px;
  z-index: 9999;
  text-decoration: none;
  transition: top .2s ease;
}

.skip-link:focus {
  top: .5rem;
}


/* ---- 13. MENU PAGE STRIP LABEL: no-JS fallback ---- */
.menu-intro-strip__label,
.menu-intro-strip__title,
.menu-intro-strip__hint {
  text-rendering: optimizeLegibility;
}


/* ---- 14. IMAGE LOADING SKELETON ---- */
img[loading="lazy"] {
  background: rgba(255,255,255,.04);
}


/* ---- 15. REDUCED MOTION: extend to gallery + modal ---- */
@media (prefers-reduced-motion: reduce) {
  .reveal,
  .reveal.from-left,
  .reveal.from-right,
  .reveal.from-center {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }

  .bar-gallery__item {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }

  .events-page .modal-card {
    animation: none !important;
  }

  .photo-strip-item {
    transition: none !important;
  }

  #scrollTop {
    transition: none !important;
  }

  .nav {
    transition: none !important;
  }
}

/* ---- 16. LANG MODAL: enter animation ---- */
.lang-modal.show .lang-card {
  animation: cardIn .28s ease forwards;
}

@keyframes cardIn {
  from { opacity: 0; transform: scale(.94) translateY(12px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

.lang-card { border: 1px solid rgba(255,255,255,.1); }

.lang-buttons button {
  transition: background .2s ease, transform .15s ease;
}

.lang-buttons button:hover {
  transform: translateY(-2px);
}


/* ============================================================
   MOBILE RESPONSIVE FIXES — iPhone 13 Pro Max & alle mobiel
   ============================================================ */

/* ---- Lang modal buttons: stack op kleine schermen ---- */
@media (max-width: 420px) {
  .lang-buttons {
    flex-direction: column;
    align-items: stretch;
  }
  .lang-buttons button {
    width: 100%;
    text-align: center;
  }
  .lang-card {
    padding: 20px 16px;
    margin: 0 12px;
  }
}

/* ---- Hero: betere hoogte & tekst op iPhone ---- */
@media (max-width: 480px) {
  .hero {
    height: 100svh; /* safe area aware */
    min-height: 580px;
  }
  .hero__content {
    max-width: 92%;
    padding: 0 1rem;
  }
  .hero__logo {
    width: min(200px, 55vw);
  }
  .hero__tagline {
    font-size: .78rem;
    letter-spacing: .1em;
  }
  .hero__buttons {
    flex-direction: column;
    align-items: center;
    gap: .75rem;
  }
  .hero__buttons .btn {
    width: 100%;
    max-width: 260px;
    text-align: center;
  }
}

/* ---- Intro photos: 1 kolom op klein scherm ---- */
@media (max-width: 480px) {
  .intro__photos {
    grid-template-columns: 1fr;
    padding: 0 .5rem;
    gap: 1rem;
  }
  .intro__photos img {
    aspect-ratio: 16 / 9;
  }
  .section {
    padding: 48px 0;
  }
}

/* ---- About stats: 3 naast elkaar ook op klein ---- */
@media (max-width: 480px) {
  .about__stats {
    grid-template-columns: repeat(3, 1fr);
    gap: .6rem;
  }
  .stat__num {
    font-size: 1.2rem;
  }
  .stat__label {
    font-size: .78rem;
  }
  .about {
    padding: 2.8rem .75rem 2.5rem;
  }
  .about__card {
    padding: 1.4rem 1.2rem 1.2rem;
  }
}

/* ---- Menu 3D slider op iPhone ---- */
@media (max-width: 480px) {
  .menu-3d-slider { --slide-w: 72vw; }
  .menu-3d-slides__wrapper {
    min-height: 300px;
  }
  .menu-page {
    padding: 5rem 0 5rem;
  }
  .menu-3d-btn {
    --size: 34px;
  }
  /* Buttons niet buiten scherm */
  .menu-3d-btn--prev { left: calc(50% - (var(--slide-w) * 1.5)); }
  .menu-3d-btn--next { right: calc(50% - (var(--slide-w) * 1.5)); }

  .menu-slider__dots {
    gap: .3rem;
    padding: .45rem .6rem;
  }
  .menu-slider__dots .dot {
    font-size: .6rem;
    padding: .35rem .55rem;
    letter-spacing: .1em;
  }
  .menu-intro-strip {
    padding: 2rem .75rem 0;
  }
}

/* ---- Bar pagina op mobiel ---- */
@media (max-width: 480px) {
  .bar-hero {
    padding: 2rem 0 2rem;
  }
  .bar-hero__inner {
    padding: 0 1rem;
    gap: 1.4rem;
  }
  .bar-hero__photo {
    max-width: 100%;
  }
  .bar-section__inner {
    padding: 0 1rem;
    gap: 1.4rem;
  }
  .bar-gallery__grid {
    grid-template-columns: 1fr 1fr;
    gap: .75rem;
  }
  .bar-gallery__item img {
    height: 110px;
  }
  .bar-gallery__inner {
    padding: 0 1rem;
  }
}

/* ---- Foto pagina: strip gallery op mobiel ---- */
@media (max-width: 480px) {
  .photo-hero2 {
    padding: 2rem 0 1.6rem;
  }
  .photo-hero2__inner {
    padding: 0 1rem;
  }
  .photo-strip-nav {
    height: 170px;
  }
  .photo-gallery2 {
    padding: 1.6rem 0 2.4rem;
  }
  .photo-gallery2__head {
    padding: 0 1rem;
  }
  /* Lightbox navigatiepijlen niet buiten scherm */
  .photo-lightbox__nav--prev { left: 6px; }
  .photo-lightbox__nav--next { right: 6px; }
  .photo-lightbox__dialog {
    margin: 3vh auto;
    padding: 10px;
  }
  .photo-lightbox__img {
    max-height: 65vh;
  }
}

/* ---- Contact pagina op mobiel ---- */
@media (max-width: 480px) {
  .contact-hero {
    padding: 1.8rem 0 1.6rem;
  }
  .contact-hero__inner {
    padding: 0 1rem;
  }
  .contact-hero__items {
    flex-direction: column;
    gap: 1rem;
  }
  .contact-main {
    padding: 3rem 0 2.5rem;
  }
  .contact-card {
    padding: 1.4rem 1.1rem 1.6rem;
    border-radius: 16px;
  }
  .contact-form__row {
    grid-template-columns: 1fr;
  }
  .contact-form__submit {
    align-self: stretch;
    text-align: center;
  }
  .contact-map__frame {
    height: 280px;
  }
  .contact-map__card {
    border-radius: 0 0 14px 14px;
    padding: 1rem 1.1rem 1.2rem;
  }
  .contact-map__inner {
    border-radius: 14px;
  }
}

/* ---- Events pagina op mobiel ---- */
@media (max-width: 480px) {
  .events-hero {
    padding: 1.8rem 0 1.8rem;
  }
  .events-main {
    padding: 24px 0 48px;
  }
  .events-page .card-body {
    padding: 12px 14px 16px;
  }
  .events-page .card-head {
    padding: 14px 16px;
  }
  /* FullCalendar toolbar compact */
  .events-page .fc .fc-toolbar {
    flex-wrap: wrap;
    gap: .5rem;
  }
  .events-page .fc .fc-toolbar-title {
    font-size: 15px;
  }
  .events-page .fc .fc-button {
    padding: 6px 9px !important;
    font-size: .8rem !important;
  }
  .events-page #calendar {
    min-height: 380px;
  }
  .events-page .events-list {
    grid-template-columns: 1fr;
  }
  /* Modal op klein scherm */
  .events-page .modal-card {
    margin: 5vh auto;
    padding: 14px 14px 12px;
    width: calc(100% - 16px);
    border-radius: 16px;
  }
  .events-page .modal-card h3 {
    font-size: 18px;
    padding-right: 2rem;
  }
}

/* ---- Footer op klein scherm ---- */
@media (max-width: 480px) {
  .site-footer {
    padding: 2.4rem 0 0;
  }
  .site-footer__inner {
    padding: 0 1rem;
  }
  .footer-col--cta .btn {
    display: block;
    text-align: center;
    width: 100%;
  }
}

/* ---- Admin login op mobiel ---- */
@media (max-width: 480px) {
  #loginScreen {
    margin: 5vh 1rem 0;
    padding: 20px 16px;
  }
}

/* ---- Lightbox menu: pijlen op mobiel ---- */
@media (max-width: 480px) {
  .menu-lightbox__control--prev { left: 6px; }
  .menu-lightbox__control--next { right: 6px; }
  .menu-lightbox__close {
    top: 8px;
    right: 8px;
    font-size: 1.6rem;
  }
  .menu-lightbox__image {
    max-height: 80vh;
    border-radius: 12px;
  }
}

/* ---- Algemeen: minimale touch targets (Apple HIG = 44px) ---- */
@media (max-width: 900px) {
  .btn,
  .nav a,
  .nav-lang__btn,
  .menu-3d-btn,
  .photo-lightbox__nav,
  .menu-lightbox__control {
    min-height: 44px;
  }
  /* Geen hover-effecten op touch apparaten */
  .intro__photos img:hover,
  .about__photo:hover img,
  .bar-hero__photo:hover img,
  .bar-gallery__item:hover {
    transform: none;
  }
}

/* ---- Safe area insets voor iPhone notch/Dynamic Island ---- */
@supports (padding: env(safe-area-inset-bottom)) {
  .site-footer {
    padding-bottom: env(safe-area-inset-bottom);
  }
  .site-header {
    padding-left: env(safe-area-inset-left);
    padding-right: env(safe-area-inset-right);
  }
  #scrollTop {
    bottom: calc(1.2rem + env(safe-area-inset-bottom));
  }
}

/* ---- Scrollbar verbergen op mobiel voor sliders ---- */
@media (max-width: 900px) {
  .menu-slider__dots {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    max-width: 100%;
    border-radius: 999px;
  }
  .menu-slider__dots::-webkit-scrollbar {
    display: none;
  }
}
