:root{
  --bg-black:#0b0b0b;
  --paper:#f4f4f1;
  --text:#111;
  --red:#fe0000;
  --cream:#ded9b4;
  --shadow:0 12px 30px rgba(0,0,0,.10);
  --max:820px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:var(--bg-black);
}

/* Header met logo + taalvlaggen */
.topbar{
  position:sticky;
  top:0;
  z-index:60;
  background:rgba(0,0,0,.72);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(255,255,255,.12);
}
.topbar-inner{
  max-width:1100px;
  margin:0 auto;
  padding:10px 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.brand img{
  display:block;
  height:34px;
  width:auto;
  filter: drop-shadow(0 6px 14px rgba(0,0,0,.25));
}

.lang{display:flex; gap:10px; align-items:center;}
.lang-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  text-decoration:none;
  font-weight:850;
  color:#fff;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
}
.lang-link:hover{background:rgba(255,255,255,.10)}
.lang-link.active{
  background:#fff;
  color:#111;
  border-color:transparent;
}
.flag{font-size:18px; line-height:1}
.lang-txt{font-size:13px; letter-spacing:.02em}

/* Zwarte balken boven/onder */
.band{height:clamp(10px,16vh,10px); background:#000;}
.band-top{}
.band-bottom{}

/* Poster / papier */
.poster{
  max-width:var(--max);
  margin:0 auto;
  background:var(--paper);
  padding:clamp(22px,4vw,44px) clamp(16px,4vw,46px);
  text-align:center;
}

/* Datum rood met witte “stroke” */
.date{
  margin: 0;
  font-family: 'Montserrat', sans-serif;
  font-weight: 900;
  font-size: clamp(60px, 8vw, 100px);
  color: #ff0000;
  letter-spacing: 2px;

  /* Perfecte witte outline */
  text-shadow:
    -4px -4px 0 #fff,
     4px -4px 0 #fff,
    -4px  4px 0 #fff,
     4px  4px 0 #fff,
    -4px  0px 0 #fff,
     4px  0px 0 #fff,
     0px -4px 0 #fff,
     0px  4px 0 #fff;
}

/* Tijd */
.time{
  margin: 6px 0 22px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: clamp(18px, 3vw, 26px);
  color: #ff0000;
  letter-spacing: 3px;

  text-shadow:
    -2px -2px 0 #fff,
     2px -2px 0 #fff,
    -2px  2px 0 #fff,
     2px  2px 0 #fff;
}

/* Beige badge met logo */
.badge{display:grid; place-items:center; margin:10px auto 18px;}
.badge-inner{
  width:clamp(220px,42vw,330px);
  aspect-ratio:1/1;
  background:var(--cream);
  border-radius:999px;
  display:grid;
  place-items:center;
  padding:18px;
}
.badge-logo img{
  width:min(86%, 270px);
  height:auto;
  display:block;
}
.badge-ornament{
  width:78%;
  height:18px;
  position:relative;
  opacity:.70;
  margin-top:6px;
}
.badge-ornament span{
  position:absolute;
  inset:50% 0 auto 0;
  height:2px;
  background:rgba(0,0,0,.45);
  transform:translateY(-50%);
  border-radius:999px;
}

/* Tekst */
.invite{
  margin:4px auto 18px;
  max-width:52ch;
  font-weight:800;
  font-size:clamp(16px,2.4vw,22px);
  line-height:1.35;
}
.invite p{margin:6px 0}

/* Schets */
.visual{margin:10px auto 16px; display:grid; place-items:center;}
.sketch{width:min(980px,100%); margin:0;}
.sketch img{width:100%; height:auto; display:block;}

/* Adres */
.address{
  margin:18px 0 10px;
  font-weight:1000;
  font-size:clamp(18px,2.6vw,26px);
}
.address-city{font-weight:1000;}

/* Buttons */
.actions{
  display:flex;
  gap:16px;
  justify-content:center;
  flex-wrap:wrap;
  margin:18px auto 0;
}
.poster-actions{margin-top:18px; padding-bottom:16px;}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:14px 22px;
  border-radius:999px;
  font-weight:850;
  font-size:16px;
  text-decoration:none;
  border:2px solid transparent;
  min-width:230px;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
  box-shadow:0 10px 22px rgba(0,0,0,.08);
  background:#fff;
  color:#111;
}
.btn:hover{transform:translateY(-1px); box-shadow:var(--shadow);}
.btn:active{transform:translateY(0); box-shadow:0 8px 16px rgba(0,0,0,.10);}

.btn-maps{
  background:#fff;
  border-color:rgba(0,0,0,.10);
}
.btn-maps:hover{
  background:rgba(0,0,0,.03);
  border-color:rgba(0,0,0,.14);
}
.btn-whatsapp{
  background:#111;
  color:#fff;
  border-color:rgba(0,0,0,.12);
}
.cta{opacity:.9}

/* Sticky bar mobiel */
.sticky-bar{
  position:fixed;
  left:0; right:0; bottom:0;
  z-index:55;
  background:rgba(0,0,0,.72);
  backdrop-filter:blur(10px);
  border-top:1px solid rgba(255,255,255,.12);
  padding:10px 12px max(10px, env(safe-area-inset-bottom));
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
.sticky-bar .btn{
  min-width:0;
  width:100%;
  padding:12px 14px;
  border-radius:999px;
  box-shadow:0 10px 22px rgba(0,0,0,.22);
}

/* Desktop: sticky bar uit */
@media (min-width: 900px){
  .sticky-bar{display:none;}
}

/* Extra ruimte onderaan zodat sticky niet over content valt */
@media (max-width: 899px){
  .poster{padding-bottom:96px;}
}

@media (prefers-reduced-motion: reduce){
  .btn{transition:none;}
}

/* ===== Reviews panel (stijl passend bij poster) ===== */

.reviews-panel{
  background: var(--paper);
  color: var(--text);
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 14px 34px rgba(0,0,0,.10);
  overflow: hidden;
}

/* header met rood accent */
.reviews-head{
  padding: 16px 18px 14px;
  border-bottom: 1px solid rgba(0,0,0,.06);
  background:
    linear-gradient(90deg, rgba(254,0,0,.10), rgba(254,0,0,0) 55%),
    var(--paper);
  position: relative;
}
.reviews-head::before{
  content:"";
  position:absolute;
  left:0; top:0; bottom:0;
  width: 6px;
  background: var(--red);
}
.reviews-title{
  margin:0;
  font-weight: 1000;
  letter-spacing: .02em;
  font-size: 20px;
}
.reviews-subtitle{
  margin: 6px 0 0;
  color: rgba(0,0,0,.65);
  font-weight: 700;
  font-size: 13px;
}

/* lijst */
.reviews-list{
  padding: 12px 18px 4px;
  display: grid;
  gap: 12px;
  max-height: 46vh;
  overflow: auto;
}
.reviews-list::-webkit-scrollbar{ width: 10px; }
.reviews-list::-webkit-scrollbar-thumb{
  background: rgba(0,0,0,.18);
  border-radius: 999px;
  border: 3px solid rgba(255,255,255,.60);
}

.review-item{
  background: rgba(255,255,255,.75);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 14px;
  padding: 12px 12px 10px;
  text-align: left;
}
.review-item strong{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  font-weight: 950;
  letter-spacing:.01em;
}
.review-item .stars{
  color: var(--red);
  font-size: 13px;
  letter-spacing: 1px;
  white-space: nowrap;
}
.review-item p{
  margin: 8px 0 0;
  color: rgba(0,0,0,.78);
  font-weight: 650;
  line-height: 1.35;
  font-size: 14px;
}

/* form */
.reviews-form{
  padding: 14px 18px 18px;
  border-top: 1px solid rgba(0,0,0,.06);
  background: rgba(255,255,255,.45);
}

.reviews-label{
  display:block;
  margin: 10px 0 6px;
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(0,0,0,.70);
}

.reviews-input,
.reviews-textarea,
.reviews-select{
  width: 100%;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.10);
  padding: 12px 12px;
  font: inherit;
  background: #fff;
  outline: none;
  transition: border-color .15s ease, box-shadow .15s ease;
}

.reviews-textarea{ resize: vertical; min-height: 110px; }

.reviews-input:focus,
.reviews-textarea:focus,
.reviews-select:focus{
  border-color: rgba(254,0,0,.55);
  box-shadow: 0 0 0 4px rgba(254,0,0,.12);
}

.reviews-rating{
  display:flex;
  align-items:center;
  gap: 10px;
}

.reviews-btn{
  margin-top: 12px;
  width: 100%;
  border: 0;
  border-radius: 999px;
  padding: 12px 14px;
  cursor: pointer;
  background: #111;
  color: #fff;
  font-weight: 900;
  letter-spacing: .02em;
  box-shadow: 0 14px 26px rgba(0,0,0,.18);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.reviews-btn:hover{
  background: var(--red);
  transform: translateY(-1px);
  box-shadow: 0 16px 30px rgba(0,0,0,.22);
}
.reviews-btn:active{
  transform: translateY(0);
  box-shadow: 0 10px 18px rgba(0,0,0,.18);
}

.reviews-hint{
  margin: 10px 0 0;
  font-size: 12px;
  font-weight: 700;
  color: rgba(0,0,0,.55);
}

/* ===== Layout: rechts op desktop, onderaan op mobiel =====
   Let op: dit werkt netjes als je .poster in het midden wilt houden.
   We zetten op brede schermen een 2-koloms layout rond de poster. */

@media (min-width: 1100px){
  /* Maak van poster+reviews één gecentreerd blok */
  body{
    display: grid;
    grid-template-columns: minmax(0, var(--max)) 360px; /* poster + sidebar */
    gap: 24px;
    justify-content: center; /* <<< dit is de key */
    align-items: start;
  }

  /* Deze elementen moeten over beide kolommen lopen */
  .topbar, .band, .sticky-bar{
    grid-column: 1 / -1;
  }

  /* Poster netjes in kolom 1 */
  .poster{
    grid-column: 1;
    justify-self: stretch; /* niet meer 'center' */
  }

  /* Reviews direct naast poster */
  .reviews-panel{
    grid-column: 2;
    position: sticky;
    top: 82px;
    margin: 0; /* <<< haal extra rechter-marge weg */
    width: 360px;
  }
}

/* Review stats */
.reviews-stats{
  margin-top: 10px;
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:12px;
  padding-top: 10px;
  border-top: 1px dashed rgba(0,0,0,.18);
}
.reviews-avg{
  display:flex;
  align-items:baseline;
  gap:6px;
  font-weight: 1000;
}
.reviews-avg-number{
  font-size: 26px;
  color: var(--red);
  letter-spacing: .02em;
}
.reviews-avg-outof{
  font-size: 13px;
  color: rgba(0,0,0,.55);
  font-weight: 900;
}
.reviews-count{
  font-size: 12px;
  font-weight: 900;
  color: rgba(0,0,0,.60);
  text-transform: uppercase;
  letter-spacing: .06em;
}

/* Honeypot (onzichtbaar voor mensen) */
.hp{
  position:absolute !important;
  left:-9999px !important;
  width:1px !important;
  height:1px !important;
  opacity:0 !important;
}
