/* ============================================================
   CADEAUBON — pagina-stijl (bovenop css/style.css huisstijl)
   Alle tokens (--goud, --grijs-*, fonts) komen uit style.css
   ============================================================ */
.cb-page { background: var(--wit); }

/* ---- Hero (gecentreerde container, gelijke breedte als de bestel-sectie) ---- */
.cb-hero {
  max-width: 1240px;
  margin: 0 auto;
  /* Eerste sectie moet onder de vaste header (var(--header-height)) vallen,
     anders snijdt de header de eyebrow + bovenkant van de h1 af. */
  padding: calc(var(--header-height) + clamp(1.5rem, 4vw, 3rem)) clamp(1.25rem, 5vw, 3rem) clamp(2.5rem, 5vw, 5rem);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 4vw, 4rem);
  align-items: center;
}
.cb-hero-text {
  padding: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.cb-eyebrow {
  font-family: var(--font-body);
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--goud-donker);
  margin: 0 0 1.4rem;
}
.cb-hero-text h1 {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(2.6rem, 5vw, 4.2rem);
  line-height: 1.04;
  color: var(--grijs-tekst);
  margin: 0 0 1.5rem;
}
.cb-hero-text h1 em {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic;
  font-weight: 500;
  color: var(--goud-donker);
}
.cb-lede {
  font-family: 'Manrope', system-ui, sans-serif;
  font-size: 1.08rem;
  line-height: 1.75;
  color: #5a5249;
  max-width: 30rem;
  margin: 0 0 2rem;
}
.cb-hero-points { list-style: none; margin: 0; padding: 0; display: grid; gap: 0.7rem; }
.cb-hero-points li {
  display: flex; align-items: center; gap: 0.7rem;
  font-family: var(--font-body); font-size: 0.95rem; color: var(--grijs-tekst);
}
.cb-hero-points svg { flex: 0 0 auto; color: var(--goud-donker); }
.cb-hero-img {
  background-image: url('../img/proeverij-inschenken.jpg');
  background-size: cover; background-position: center;
  min-height: 460px; border-radius: 6px;
}

/* ---- Bestel-sectie ---- */
.cb-order {
  background: var(--grijs-licht);
  padding: clamp(3.5rem, 6vw, 6rem) clamp(1.25rem, 5vw, 5rem);
}
.cb-order-inner {
  max-width: 1180px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 0.82fr; gap: clamp(2rem, 4vw, 4rem);
  align-items: start;
}
.cb-section-label {
  font-family: var(--font-body); font-size: 0.72rem; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--grijs-body);
  margin: 0 0 0.5rem;
}
.cb-card {
  background: var(--wit);
  border: 1px solid var(--grijs-lijn);
  border-radius: 8px;
  padding: clamp(1.75rem, 3vw, 2.75rem);
  box-shadow: 0 1px 2px rgba(0,0,0,0.02);
}
.cb-card h2 {
  font-family: var(--font-heading); font-weight: 400; font-size: 1.9rem;
  color: var(--grijs-tekst); margin: 0 0 1.75rem; line-height: 1.1;
}
.cb-block { margin-bottom: 1.9rem; }
.cb-block > .lbl {
  display: block; font-family: var(--font-body); font-size: 0.82rem; font-weight: 600;
  color: var(--grijs-tekst); margin-bottom: 0.75rem; letter-spacing: 0.01em;
}

/* personen-keuze pills */
.cb-people { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.6rem; }
.cb-person {
  border: 1px solid var(--grijs-lijn); border-radius: 6px; background: var(--wit);
  padding: 0.95rem 0.4rem 0.8rem; text-align: center; cursor: pointer;
  transition: border-color 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}
.cb-person .n { font-family: var(--font-heading); font-size: 1.55rem; color: var(--grijs-tekst); line-height: 1; }
.cb-person .u { font-family: var(--font-sub); font-size: 0.68rem; color: var(--grijs-body); text-transform: uppercase; letter-spacing: 0.08em; margin-top: 4px; }
.cb-person:hover { border-color: var(--goud-line); }
.cb-person.active {
  border-color: var(--goud); background: var(--goud-soft);
  box-shadow: 0 0 0 1px var(--goud);
}
.cb-person.active .n { color: var(--goud-donker); }
.cb-people-hint { font-family: var(--font-sub); font-size: 0.78rem; color: var(--grijs-body); margin: 0.7rem 0 0; }

/* subtiele schakel naar 'eigen aantal' + de slider-variant */
.cb-custom-toggle {
  margin-top: 0.85rem; background: none; border: 0; cursor: pointer; padding: 0;
  font-family: var(--font-body); font-size: 0.82rem; font-weight: 600; color: var(--goud-donker);
  display: inline-flex; align-items: center; gap: 0.35rem;
}
.cb-custom-toggle:hover { text-decoration: underline; }
.cb-slider-demo { margin-top: 1rem; padding: 1.1rem 1.2rem; border: 1px dashed var(--goud-line); border-radius: 6px; background: #fffdf6; }
.cb-slider-demo .dl { font-family: var(--font-sub); font-size: 0.66rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--grijs-body); margin: 0 0 0.85rem; }
.cb-slider-row { display: flex; align-items: center; gap: 1.4rem; }
.cb-slider { flex: 1; accent-color: var(--goud); height: 5px; cursor: pointer; }
.cb-slider-val { text-align: right; min-width: 96px; }
.cb-slider-val .num { font-family: var(--font-heading); font-size: 1.5rem; color: var(--grijs-tekst); line-height: 1; }
.cb-slider-val .un { font-family: var(--font-sub); font-size: 0.72rem; color: var(--grijs-body); }
.cb-slider-val .amt { font-family: var(--font-heading); font-size: 1.05rem; color: var(--goud-donker); margin-top: 3px; }

/* "terug naar de knoppen" — kleine schakel onder de slider */
.cb-pills-toggle {
  margin-top: 0.9rem; background: none; border: 0; cursor: pointer; padding: 0;
  font-family: var(--font-body); font-size: 0.8rem; font-weight: 600; color: var(--grijs-body);
  display: inline-flex; align-items: center; gap: 0.35rem;
}
.cb-pills-toggle:hover { text-decoration: underline; color: var(--goud-donker); }

/* form velden (spiegelt booking.css .field) */
.cb-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem 1.1rem; }
.cb-field { display: flex; flex-direction: column; gap: 0.4rem; }
.cb-field.full { grid-column: 1 / -1; }
.cb-field label {
  font-family: var(--font-body); font-size: 0.75rem; font-weight: 600;
  color: var(--grijs-tekst); letter-spacing: 0.02em;
}
.cb-field label .opt { color: var(--grijs-body); font-weight: 400; text-transform: none; }
.cb-field input, .cb-field textarea {
  font-family: var(--font-body); font-size: 16px; background: var(--wit);
  border: 1px solid #ddd; padding: 0.75rem 0.9rem; color: var(--zwart);
  border-radius: 4px; transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.cb-field input:focus, .cb-field textarea:focus {
  outline: 0; border-color: var(--goud); box-shadow: 0 0 0 3px var(--goud-soft);
}
.cb-field textarea { resize: vertical; min-height: 84px; line-height: 1.5; }

/* foutmeldingen op een veld — spiegelt booking.css .err-msg / input.err */
.cb-field input.err, .cb-field textarea.err {
  border-color: #c0392b; box-shadow: 0 0 0 3px rgba(192,57,43,0.10);
}
.cb-err-msg {
  display: none; font-family: var(--font-sub); font-size: 0.78rem;
  color: #c0392b; margin-top: 0.1rem;
}

.cb-subhead {
  font-family: var(--font-body); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--grijs-body); font-weight: 600; margin: 1.9rem 0 1rem;
  padding-bottom: 0.5rem; border-bottom: 1px solid var(--grijs-lijn-licht);
}
.cb-consent {
  margin-top: 1.1rem; display: flex; gap: 0.7rem; align-items: flex-start;
  padding: 0.85rem 1rem; background: var(--grijs-licht); border-radius: 4px;
  cursor: pointer;
}
.cb-consent input { accent-color: var(--goud); margin-top: 2px; }
.cb-consent label { font-family: var(--font-sub); font-size: 0.85rem; color: var(--grijs-tekst); line-height: 1.5; cursor: pointer; }

.cb-cta {
  width: 100%; margin-top: 1.9rem; border: 0; cursor: pointer;
  background: var(--goud); color: #fff; border-radius: 5px;
  font-family: var(--font-body); font-weight: 600; font-size: 1rem;
  padding: 1.05rem 1.5rem; letter-spacing: 0.01em;
  display: flex; align-items: center; justify-content: center; gap: 0.6rem;
  transition: background 0.2s ease;
}
.cb-cta:hover { background: var(--goud-donker); }
.cb-cta:disabled { opacity: 0.7; cursor: progress; }

/* spinner in de CTA-knop tijdens het starten van de betaling */
.cb-spinner {
  width: 17px; height: 17px; flex: 0 0 auto;
  border: 2px solid rgba(255,255,255,0.4); border-top-color: #fff;
  border-radius: 50%; animation: cb-spin 0.7s linear infinite;
}
@keyframes cb-spin { to { transform: rotate(360deg); } }

/* algemene foutmelding onder de knop (bv. server onbereikbaar) */
.cb-form-error {
  display: none; margin-top: 1rem; padding: 0.8rem 1rem;
  background: rgba(192,57,43,0.08); border: 1px solid rgba(192,57,43,0.25);
  border-radius: 4px; font-family: var(--font-sub); font-size: 0.85rem;
  color: #c0392b; line-height: 1.5; text-align: center;
}

.cb-trust {
  display: flex; align-items: center; justify-content: center; gap: 1.4rem;
  margin-top: 1.1rem; font-family: var(--font-sub); font-size: 0.76rem; color: var(--grijs-body);
}
.cb-trust span { display: inline-flex; align-items: center; gap: 0.35rem; }

/* ---- het bon-voorbeeld (gedeelde voucher-look) ---- */
.cb-preview-wrap { position: sticky; top: 130px; }
.cb-preview-label {
  font-family: var(--font-body); font-size: 0.72rem; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--grijs-body);
  margin: 0 0 0.9rem; text-align: center;
}
.voucher {
  position: relative; background: #fffdf6;
  border: 1px solid var(--goud-line); border-radius: 10px; overflow: hidden;
  box-shadow: 0 24px 60px -28px rgba(120,95,10,0.45);
}
.voucher-top {
  background-image: linear-gradient(180deg, rgba(26,22,16,0.12), rgba(26,22,16,0.55)), url('../img/proeverij-tafel.jpg');
  background-size: cover; background-position: center; height: 150px;
  display: flex; align-items: flex-end; padding: 1.1rem 1.4rem;
}
.voucher-top .kicker {
  font-family: var(--font-body); font-size: 0.7rem; font-weight: 600;
  letter-spacing: 0.22em; text-transform: uppercase; color: #fff;
  background: rgba(227,187,17,0.92); padding: 0.32rem 0.7rem; border-radius: 3px;
}
.voucher-body { padding: 1.6rem 1.6rem 1.8rem; text-align: center; }
.voucher-body .brand {
  font-family: var(--font-heading); font-size: 0.85rem; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--goud-donker); margin: 0 0 0.8rem;
}
.voucher-body h3 {
  font-family: var(--font-heading); font-weight: 400; font-size: 1.85rem;
  color: var(--grijs-tekst); margin: 0 0 0.2rem; line-height: 1.1;
}
.voucher-body .sub { font-family: var(--font-sub); font-size: 0.9rem; color: var(--grijs-body); margin: 0 0 1.3rem; }
.voucher-code {
  border: 1px dashed var(--goud-line); border-radius: 6px; background: var(--goud-soft);
  padding: 0.85rem 0.5rem; margin: 0 0 1.3rem;
}
.voucher-code .c-lbl { font-family: var(--font-sub); font-size: 0.64rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--grijs-body); }
.voucher-code .c-val {
  font-family: 'Overpass', monospace; font-weight: 700; font-size: 1.35rem;
  letter-spacing: 0.18em; color: var(--grijs-tekst); margin-top: 3px;
}
.voucher-meta {
  display: flex; justify-content: space-between; gap: 1rem;
  border-top: 1px solid var(--grijs-lijn-licht); padding-top: 1rem; text-align: left;
}
.voucher-meta .m-lbl { font-family: var(--font-sub); font-size: 0.66rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--grijs-body); }
.voucher-meta .m-val { font-family: var(--font-body); font-size: 0.95rem; font-weight: 600; color: var(--grijs-tekst); margin-top: 2px; }
.voucher-message {
  margin-top: 1.2rem; padding: 0.9rem 1rem; background: #faf6e8; border-radius: 6px;
  font-family: 'Cormorant Garamond', Georgia, serif; font-style: italic; font-size: 1.05rem;
  color: #6a5f3e; line-height: 1.5;
}
.cb-preview-note { font-family: var(--font-sub); font-size: 0.76rem; color: var(--grijs-body); text-align: center; margin: 1rem 0 0; line-height: 1.5; }

/* ---- Bevestigingssectie (na betaling, ?bon=…&status=success) ---- */
.cb-success {
  max-width: 720px; margin: 0 auto;
  padding: clamp(3rem, 7vw, 6rem) clamp(1.25rem, 5vw, 3rem);
  text-align: center;
}
.cb-success-badge {
  width: 64px; height: 64px; margin: 0 auto 1.6rem;
  border-radius: 50%; background: var(--goud-soft);
  display: flex; align-items: center; justify-content: center;
  color: var(--goud-donker);
}
.cb-success .cb-eyebrow { text-align: center; }
.cb-success h1 {
  font-family: var(--font-heading); font-weight: 400;
  font-size: clamp(2.2rem, 4.5vw, 3.2rem); line-height: 1.08;
  color: var(--grijs-tekst); margin: 0 0 1rem;
}
.cb-success-lede {
  font-family: 'Manrope', system-ui, sans-serif; font-size: 1.05rem; line-height: 1.7;
  color: #5a5249; max-width: 34rem; margin: 0 auto 2.5rem;
}
.cb-success .voucher { max-width: 420px; margin: 0 auto 2.5rem; text-align: left; }
.cb-success-actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

@media (max-width: 900px) {
  .cb-hero { grid-template-columns: 1fr; }
  .cb-hero-img { min-height: 280px; order: -1; }
  /* minmax(0,1fr) i.p.v. 1fr: voorkomt dat een breed kind (bv. de pills) de
     kolom breder dan de viewport maakt en zo de kaart buiten beeld duwt. */
  .cb-order-inner { grid-template-columns: minmax(0, 1fr); }
  .cb-preview-wrap { position: static; max-width: 420px; margin: 0 auto; }
}
@media (max-width: 520px) {
  /* 4 pills naast elkaar passen niet op smalle telefoons (de 'PERSONEN'-labels
     kunnen niet krimpen) → 2×2 raster. */
  .cb-people { grid-template-columns: repeat(2, 1fr); }
  .cb-grid { grid-template-columns: 1fr; }
}
