/* KidsBaas — fresh homepage */
@import url('./colors_and_type.css');

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-body);
  color: var(--fg-1);
  background: var(--bg-page);
  overflow-x: hidden;
}
button { font-family: inherit; cursor: pointer; }
img { display: block; max-width: 100%; }
a { color: inherit; }

/* The active theme drives a few global custom props that ripple everywhere */
:root {
  --t-bg:    var(--theme-pink-bg);
  --t-tent:  var(--theme-pink-tent);
  --t-text:  var(--theme-pink-text);
  --t-accent:var(--theme-pink-accent);
}
[data-theme="beauty"] { --t-bg: var(--theme-beauty-bg); --t-tent: var(--theme-beauty-tent); --t-text: var(--theme-beauty-text); --t-accent: var(--theme-beauty-accent); }
[data-theme="pink"]   { --t-bg: var(--theme-pink-bg);   --t-tent: var(--theme-pink-tent);   --t-text: var(--theme-pink-text);   --t-accent: var(--theme-pink-accent); }
[data-theme="jungle"] { --t-bg: var(--theme-jungle-bg); --t-tent: var(--theme-jungle-tent); --t-text: var(--theme-jungle-text); --t-accent: var(--theme-jungle-accent); }
[data-theme="movie"]  { --t-bg: var(--theme-movie-bg);  --t-tent: var(--theme-movie-tent);  --t-text: var(--theme-movie-text);  --t-accent: var(--theme-movie-accent); }
[data-theme="neon"]   { --t-bg: var(--theme-neon-bg);   --t-tent: var(--theme-neon-pink);   --t-text: var(--theme-neon-cyan);   --t-accent: var(--theme-neon-green); }

/* ========================================================
   PROMO BAR
   ======================================================== */
.promo {
  background: var(--kb-night-500);
  color: var(--kb-cream-50);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.02em;
  text-align: center;
  padding: 10px 16px;
  position: relative;
  overflow: hidden;
}
.promo-track {
  display: inline-flex;
  gap: 56px;
  animation: marquee 32s linear infinite;
  white-space: nowrap;
}
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.promo-track span { display: inline-block; }

/* ========================================================
   HEADER
   ======================================================== */
.hdr {
  position: sticky; top: 0; z-index: 50;
  background: rgba(251, 247, 241, 0.86);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--border-soft);
  transition: background var(--dur-base) var(--ease-out);
}
.hdr-row {
  max-width: 1240px; margin: 0 auto; padding: 14px 28px;
  display: flex; align-items: center; gap: 28px;
}
.mark {
  font-family: var(--font-display);
  font-weight: 700; font-size: 26px; letter-spacing: -0.02em;
  color: var(--kb-night-500); text-decoration: none;
  display: inline-flex; align-items: baseline; gap: 2px;
}
.mark .nl { color: var(--kb-rose-400); font-weight: 600; font-size: 22px; }
.mark .star { color: var(--kb-gold-400); margin-right: 4px; }
.hdr-nav { display: flex; gap: 4px; margin-left: auto; align-items: center; }
.hdr-nav a {
  font-family: var(--font-display);
  font-weight: 600; font-size: 14px;
  color: var(--kb-night-500); text-decoration: none;
  padding: 8px 14px; border-radius: 999px;
  transition: background var(--dur-fast) var(--ease-out);
}
.hdr-nav a:hover { background: rgba(33,21,56,0.06); }
.hdr-cta {
  background: var(--kb-rose-400); color: #fff;
  padding: 10px 18px; border-radius: 999px;
  font-family: var(--font-display); font-weight: 700; font-size: 14px;
  border: none; box-shadow: var(--shadow-sm);
  transition: all var(--dur-base) var(--ease-out);
}
.hdr-cta:hover { background: var(--kb-rose-500); transform: translateY(-1px); box-shadow: var(--shadow-md); }

/* ========================================================
   HERO — theme picker stage
   ======================================================== */
.hero {
  position: relative;
  padding: 64px 28px 64px;
  overflow: hidden;
  background:
    radial-gradient(120% 70% at 50% -10%, color-mix(in oklab, var(--t-bg) 75%, white) 0%, var(--bg-page) 65%);
  transition: background var(--dur-slow) var(--ease-out);
}
[data-theme="movie"] .hero,
[data-theme="neon"]  .hero {
  background: radial-gradient(120% 70% at 50% -10%, var(--t-bg) 0%, color-mix(in oklab, var(--t-bg) 70%, black) 100%);
  color: var(--t-text);
}

.hero-inner {
  max-width: 1280px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr; gap: 32px;
  position: relative; z-index: 2;
}
.hero-head {
  text-align: center; margin: 8px auto 0; max-width: 920px;
}
.hero-eyebrow {
  font-family: var(--font-display);
  font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.22em; font-size: 12px;
  color: var(--kb-rose-500);
  display: inline-flex; gap: 12px; align-items: center;
}
[data-theme="movie"] .hero-eyebrow,
[data-theme="neon"]  .hero-eyebrow { color: var(--kb-gold-400); }
.hero-eyebrow::before, .hero-eyebrow::after {
  content: ''; width: 32px; height: 1px;
  background: currentColor; opacity: 0.4;
}
.hero-script {
  font-family: var(--font-script);
  font-weight: 500; font-size: 56px; line-height: 0.9;
  color: var(--kb-rose-500);
  display: inline-block; transform: rotate(-3deg);
  margin: 22px 0 -8px;
}
[data-theme="movie"] .hero-script,
[data-theme="neon"]  .hero-script { color: var(--kb-gold-300); }
.hero h1 {
  font-family: var(--font-display);
  font-weight: 700; font-size: clamp(48px, 7vw, 96px);
  line-height: 0.98; letter-spacing: -0.025em;
  color: var(--kb-night-500); margin: 0;
}
[data-theme="movie"] .hero h1,
[data-theme="neon"]  .hero h1 { color: var(--kb-cream-50); }
.hero h1 em { font-style: normal; color: var(--kb-rose-500); }
[data-theme="beauty"] .hero h1 em { color: #B85572; }
[data-theme="jungle"] .hero h1 em { color: #2E5C3E; }
[data-theme="movie"]  .hero h1 em { color: var(--kb-gold-400); }
[data-theme="neon"]   .hero h1 em { color: var(--theme-neon-pink); text-shadow: 0 0 24px var(--theme-neon-pink); }
.hero-sub {
  font-family: var(--font-body);
  font-size: 19px; line-height: 1.55; color: var(--fg-2);
  margin: 18px auto 0; max-width: 580px;
}
[data-theme="movie"] .hero-sub,
[data-theme="neon"]  .hero-sub { color: rgba(251,247,241,0.78); }

/* ----- Tipi picker ----- */
.tipi-row {
  position: relative;
  z-index: 2;
  margin: 32px auto 0;
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 10px;
  max-width: 1080px;
}
.tipi-tile {
  position: relative;
  background: transparent;
  border: none; padding: 0; margin: 0;
  cursor: pointer;
  display: flex; flex-direction: column; align-items: center;
  transition: transform var(--dur-base) var(--ease-out);
  min-width: 0; /* allow grid track to actually shrink under content */
}
.tipi-label { min-width: 0; max-width: 100%; }
.tipi-tile:hover { transform: translateY(-6px); }
.tipi-tile .tipi-svg {
  width: 100%; max-width: 200px; height: auto;
  filter: drop-shadow(0 12px 24px rgba(33,21,56,0.12));
  transition: filter var(--dur-base) var(--ease-out);
}
.tipi-tile.active .tipi-svg {
  filter: drop-shadow(0 18px 36px rgba(33,21,56,0.22)) drop-shadow(0 0 24px rgba(230,187,76,0.45));
}
.tipi-label {
  font-family: var(--font-display);
  font-weight: 700; font-size: 15px;
  letter-spacing: 0.18em; text-transform: uppercase;
  margin-top: 14px;
  color: var(--kb-night-500);
  display: flex; align-items: center; gap: 8px;
  opacity: 0.55; transition: opacity var(--dur-base) var(--ease-out);
}
.tipi-tile:hover .tipi-label,
.tipi-tile.active .tipi-label { opacity: 1; }
[data-theme="movie"] .tipi-label,
[data-theme="neon"]  .tipi-label { color: var(--kb-cream-50); }
.tipi-tile.active .tipi-label {
  color: var(--kb-rose-500);
}
[data-theme="jungle"] .tipi-tile.active .tipi-label { color: #2E5C3E; }
[data-theme="movie"]  .tipi-tile.active .tipi-label { color: var(--kb-gold-400); }
[data-theme="neon"]   .tipi-tile.active .tipi-label { color: var(--theme-neon-pink); }
.tipi-tile.active .tipi-label::after {
  content: '✦'; color: var(--kb-gold-400); font-size: 14px;
}

/* ----- Active theme stage (polaroid + description) ----- */
.stage {
  margin: 64px auto 0;
  max-width: 1180px;
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 64px;
  align-items: center;
}
.stage-photo {
  position: relative;
  aspect-ratio: 4/5;
  background: #fff;
  padding: 14px 14px 56px;
  border-radius: 6px;
  box-shadow: var(--shadow-lg);
  transform: rotate(-3deg);
  transition: transform var(--dur-slow) var(--ease-out);
}
.stage-photo:hover { transform: rotate(-1deg) scale(1.01); }
.stage-photo::after {
  content: attr(data-caption);
  position: absolute; left: 0; right: 0; bottom: 18px;
  text-align: center;
  font-family: var(--font-script);
  font-size: 26px; color: var(--kb-night-500);
  transform: rotate(-1deg);
}
.stage-photo .img {
  width: 100%; height: 100%; border-radius: 4px;
  background-size: cover; background-position: center;
  display: block;
}
/* When the .img IS the image-slot custom element, give it block size */
image-slot.img {
  width: 100%; height: 100%; border-radius: 4px;
}
.stage-photo .tape {
  position: absolute; top: -14px; left: 50%; transform: translateX(-50%) rotate(-2deg);
  width: 120px; height: 22px;
  background: rgba(230, 187, 76, 0.55);
  border: 1px dashed rgba(33,21,56,0.18);
  border-radius: 2px;
}
.stage-photo .badge {
  position: absolute; top: -22px; right: -22px;
  width: 92px; height: 92px;
  background: var(--kb-gold-400);
  border-radius: 999px;
  display: grid; place-items: center;
  font-family: var(--font-script); font-size: 22px; line-height: 1;
  color: var(--kb-night-500);
  transform: rotate(12deg);
  box-shadow: var(--shadow-glow-gold);
  text-align: center; padding: 8px;
}

.stage-copy .eyebrow {
  font-family: var(--font-display);
  font-weight: 600; text-transform: uppercase; letter-spacing: 0.2em;
  font-size: 12px; color: var(--kb-rose-500);
  display: inline-flex; gap: 8px; align-items: center;
}
[data-theme="movie"] .stage-copy .eyebrow,
[data-theme="neon"]  .stage-copy .eyebrow { color: var(--kb-gold-400); }
.stage-copy h2 {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(36px, 4vw, 56px); line-height: 1.02;
  letter-spacing: -0.02em; margin: 10px 0 14px;
  color: var(--kb-night-500);
}
[data-theme="movie"] .stage-copy h2,
[data-theme="neon"]  .stage-copy h2 { color: var(--kb-cream-50); }
.stage-copy p {
  font-size: 17px; line-height: 1.6; color: var(--fg-2);
  max-width: 460px; margin: 0 0 22px;
}
[data-theme="movie"] .stage-copy p,
[data-theme="neon"]  .stage-copy p { color: rgba(251,247,241,0.78); }
.stage-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 28px; }
.stage-chip {
  font-family: var(--font-display); font-weight: 600; font-size: 13px;
  padding: 8px 14px; border-radius: 999px;
  background: rgba(33,21,56,0.06); color: var(--fg-1);
}
[data-theme="movie"] .stage-chip,
[data-theme="neon"]  .stage-chip { background: rgba(255,255,255,0.1); color: var(--kb-cream-50); }
.stage-ctas { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.btn-primary {
  background: var(--kb-rose-400); color: #fff; padding: 16px 28px;
  font-family: var(--font-display); font-weight: 700; font-size: 16px;
  border-radius: 999px; border: none;
  box-shadow: var(--shadow-md);
  transition: all var(--dur-base) var(--ease-out);
  display: inline-flex; align-items: center; gap: 8px;
}
.btn-primary:hover { background: var(--kb-rose-500); transform: translateY(-2px); box-shadow: var(--shadow-lg); }
[data-theme="jungle"] .btn-primary { background: #2E5C3E; }
[data-theme="jungle"] .btn-primary:hover { background: #1E3A28; }
[data-theme="movie"]  .btn-primary { background: var(--kb-gold-400); color: var(--kb-night-500); }
[data-theme="movie"]  .btn-primary:hover { background: var(--kb-gold-500); }
[data-theme="neon"]   .btn-primary {
  background: var(--theme-neon-pink); color: #fff;
  box-shadow: 0 0 24px rgba(255,61,171,0.6);
}
.btn-ghost {
  background: transparent; color: var(--kb-night-500);
  padding: 16px 22px; font-family: var(--font-display);
  font-weight: 600; font-size: 16px;
  border-radius: 999px;
  border: 1.5px solid currentColor;
}
[data-theme="movie"] .btn-ghost,
[data-theme="neon"]  .btn-ghost { color: var(--kb-cream-50); }

/* ----- Stars (decorative) ----- */
.stars {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
}
.stars span {
  position: absolute;
  color: var(--kb-gold-400);
  font-size: 18px;
  opacity: 0;
  animation: twinkle 4s ease-in-out infinite;
}
[data-theme="movie"] .stars span,
[data-theme="neon"]  .stars span { color: var(--kb-cream-50); }
@keyframes twinkle {
  0%, 100% { opacity: 0; transform: scale(0.6); }
  50%      { opacity: 0.9; transform: scale(1); }
}

/* fairy-light garland */
.garland {
  position: absolute; top: 12px; left: -40px; right: -40px;
  height: 60px; z-index: 1; pointer-events: none;
}
.garland svg { width: 100%; height: 100%; display: block; }

/* ========================================================
   RAIL — Alles erbij geregeld
   ======================================================== */
.rail-section {
  padding: 96px 28px 64px;
  position: relative;
}
.section-head {
  max-width: 1180px; margin: 0 auto 40px;
  text-align: center;
}
.section-head .script {
  font-family: var(--font-script); font-size: 36px;
  color: var(--kb-rose-500); display: inline-block;
  transform: rotate(-2deg); margin-bottom: -6px;
}
.section-head h2 {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(36px, 4.5vw, 56px);
  letter-spacing: -0.02em; line-height: 1.04;
  color: var(--kb-night-500); margin: 0;
}
.section-head p {
  max-width: 560px; margin: 14px auto 0;
  font-size: 17px; line-height: 1.6; color: var(--fg-2);
}

.rail {
  display: grid; grid-auto-flow: column;
  grid-auto-columns: 280px;
  gap: 28px;
  padding: 32px 28px 48px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
}
.rail::-webkit-scrollbar { display: none; }
.rail-item {
  scroll-snap-align: start;
  background: #fff;
  border-radius: 6px;
  padding: 14px 14px 18px;
  box-shadow: var(--shadow-md);
  transition: transform var(--dur-base) var(--ease-out);
}
.rail-item:nth-child(odd) { transform: rotate(-2deg); }
.rail-item:nth-child(even){ transform: rotate(2deg); }
.rail-item:hover { transform: rotate(0deg) translateY(-6px); box-shadow: var(--shadow-lg); }
.rail-item .pic {
  height: 220px; border-radius: 4px;
  background: linear-gradient(135deg, var(--kb-rose-100), var(--kb-cream-100));
  display: grid; place-items: center; font-size: 86px; line-height: 1;
}
.rail-item h4 {
  font-family: var(--font-script); font-weight: 500;
  font-size: 28px; color: var(--kb-night-500);
  margin: 14px 0 0; text-align: center;
}
.rail-item p {
  margin: 4px 0 0; text-align: center;
  font-family: var(--font-body); font-size: 13px;
  color: var(--fg-2); line-height: 1.5;
}

/* ========================================================
   HOW IT WORKS — polaroid storyboard
   ======================================================== */
.how {
  background: var(--bg-soft);
  padding: 96px 28px;
  position: relative;
}
.how-grid {
  max-width: 1240px; margin: 48px auto 0;
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 28px;
}
.how-step {
  background: #fff;
  border-radius: 6px;
  padding: 16px 16px 22px;
  box-shadow: var(--shadow-md);
}
.how-step:nth-child(1) { transform: rotate(-1.5deg); }
.how-step:nth-child(2) { transform: rotate(1deg) translateY(12px); }
.how-step:nth-child(3) { transform: rotate(-0.5deg) translateY(-6px); }
.how-step:nth-child(4) { transform: rotate(2deg); }
.how-step .pic {
  aspect-ratio: 4/5; border-radius: 4px;
  background-color: var(--kb-rose-100);
  background-size: cover; background-position: center;
  display: grid; place-items: center;
  font-size: 96px; line-height: 1;
  position: relative; overflow: hidden;
}
.how-step .num {
  position: absolute; top: 12px; left: 12px;
  width: 36px; height: 36px; border-radius: 999px;
  background: var(--kb-night-500); color: var(--kb-cream-50);
  display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 700; font-size: 15px;
  box-shadow: var(--shadow-sm);
}
.how-step h4 {
  font-family: var(--font-script); font-weight: 500;
  font-size: 30px; color: var(--kb-night-500);
  margin: 14px 8px 4px; text-align: center; line-height: 1;
}
.how-step p {
  margin: 6px 8px 0; text-align: center;
  font-size: 13.5px; line-height: 1.55; color: var(--fg-2);
}

/* ========================================================
   PACKAGES
   ======================================================== */
.packages {
  padding: 96px 28px;
}
.pack-grid {
  max-width: 1180px; margin: 48px auto 0;
  display: grid; grid-template-columns: 1fr 1fr; gap: 28px;
}
.pack {
  position: relative;
  background: #fff;
  border-radius: 32px;
  padding: 40px 36px 36px;
  box-shadow: var(--shadow-md);
  transition: transform var(--dur-base) var(--ease-out);
}
.pack:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.pack.deluxe {
  background: var(--kb-night-500);
  color: var(--kb-cream-50);
}
.pack-eyebrow {
  font-family: var(--font-display); font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.2em;
  font-size: 12px; color: var(--kb-rose-500); margin-bottom: 6px;
}
.pack.deluxe .pack-eyebrow { color: var(--kb-gold-400); }
.pack h3 {
  font-family: var(--font-display); font-weight: 700;
  font-size: 38px; letter-spacing: -0.02em; line-height: 1;
  margin: 0 0 8px;
}
.pack .price-row {
  display: flex; align-items: baseline; gap: 8px; margin-top: 18px;
}
.pack .price {
  font-family: var(--font-display); font-weight: 700;
  font-size: 56px; letter-spacing: -0.02em; line-height: 1;
}
.pack .per { font-size: 14px; color: var(--fg-3); }
.pack.deluxe .per { color: rgba(251,247,241,0.7); }
.pack ul {
  list-style: none; padding: 0; margin: 22px 0 28px;
  display: grid; gap: 10px;
}
.pack ul li {
  font-family: var(--font-body); font-size: 15px;
  display: flex; gap: 10px; align-items: flex-start;
  line-height: 1.5;
}
.pack ul li::before {
  content: '✓'; flex: 0 0 auto;
  color: var(--kb-rose-500); font-weight: 800;
  margin-top: 1px;
}
.pack.deluxe ul li::before { color: var(--kb-gold-400); }
.pack .btn-primary { width: 100%; justify-content: center; }
.pack.deluxe .btn-primary {
  background: var(--kb-gold-400); color: var(--kb-night-500);
}
.pack.deluxe .btn-primary:hover { background: var(--kb-gold-500); }
.pack .ribbon {
  position: absolute; top: -14px; right: 28px;
  background: var(--kb-rose-400); color: #fff;
  font-family: var(--font-display); font-weight: 700;
  font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase;
  padding: 8px 14px; border-radius: 999px;
  box-shadow: var(--shadow-sm);
}
.pack.deluxe .ribbon { background: var(--kb-gold-400); color: var(--kb-night-500); }

/* ========================================================
   GALLERY — Instagram-style polaroid wall
   ======================================================== */
.gallery {
  padding: 96px 28px;
  background: var(--bg-page);
}
.gal-grid {
  max-width: 1240px; margin: 48px auto 0;
  display: grid; grid-template-columns: repeat(5, 1fr);
  gap: 16px;
}
.gal-item {
  aspect-ratio: 1;
  border-radius: 24px;
  background-size: cover; background-position: center;
  background-color: var(--kb-rose-100);
  position: relative; overflow: hidden;
  transition: transform var(--dur-base) var(--ease-out);
  cursor: pointer;
}
.gal-item:hover { transform: scale(1.02); }
.gal-item.tall { grid-row: span 2; aspect-ratio: 1/2.07; }
.gal-item::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(33,21,56,0.55), transparent 50%);
  opacity: 0; transition: opacity var(--dur-base);
}
.gal-item:hover::after { opacity: 1; }
.gal-tag {
  position: absolute; bottom: 12px; left: 14px;
  font-family: var(--font-script); font-size: 22px;
  color: #fff; z-index: 2;
  opacity: 0; transform: translateY(8px);
  transition: all var(--dur-base) var(--ease-out);
}
.gal-item:hover .gal-tag { opacity: 1; transform: translateY(0); }

/* ========================================================
   CTA FOOTER
   ======================================================== */
.cta-band {
  padding: 96px 28px;
  background: var(--kb-night-500);
  color: var(--kb-cream-50);
  position: relative;
  overflow: hidden;
  text-align: center;
}
.cta-band .stars span { color: var(--kb-gold-300); }
.cta-band .script {
  font-family: var(--font-script); font-size: 48px;
  color: var(--kb-gold-300); display: inline-block;
  transform: rotate(-2deg);
}
.cta-band h2 {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(40px, 6vw, 80px);
  letter-spacing: -0.02em; line-height: 1; margin: 8px 0 18px;
  color: var(--kb-cream-50);
}
.cta-band p {
  font-size: 18px; max-width: 520px; margin: 0 auto 32px;
  color: rgba(251,247,241,0.78);
}
.cta-band .btn-primary { font-size: 18px; padding: 18px 32px; }
.cta-band .btn-primary { background: var(--kb-rose-400); color: #fff; }

/* ========================================================
   FOOTER
   ======================================================== */
.ftr {
  background: var(--kb-night-600); color: var(--kb-cream-50);
  padding: 64px 28px 32px;
}
.ftr-grid {
  max-width: 1240px; margin: 0 auto;
  display: grid; grid-template-columns: 2fr 1fr 1fr 1.4fr; gap: 40px;
}
.ftr h4 {
  font-family: var(--font-display); font-weight: 700;
  font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--kb-rose-300); margin: 0 0 14px;
}
.ftr ul { list-style: none; padding: 0; margin: 0; }
.ftr li, .ftr a, .ftr p {
  font-family: var(--font-body); font-size: 14px; line-height: 1.7;
  color: rgba(251,247,241,0.78); text-decoration: none;
  margin: 0 0 4px;
}
.ftr a:hover { color: #fff; }
.ftr .mark { font-size: 30px; color: #fff; margin-bottom: 8px; }
.ftr .mark .nl { color: var(--kb-rose-300); }
.ftr .script { font-family: var(--font-script); color: var(--kb-rose-300); font-size: 26px; line-height: 1; margin-bottom: 4px; display: block; }
.subbox {
  margin-top: 12px; display: flex; gap: 8px;
  background: rgba(255,255,255,0.06);
  padding: 6px; border-radius: 999px;
}
.subbox input {
  flex: 1; background: transparent; border: none; outline: none; color: #fff;
  font-family: var(--font-body); font-size: 14px; padding: 8px 14px;
}
.subbox input::placeholder { color: rgba(255,255,255,0.45); }
.subbox button {
  background: var(--kb-rose-400); color: #fff; border: none;
  font-family: var(--font-display); font-weight: 700; font-size: 13px;
  padding: 10px 18px; border-radius: 999px;
}
.legal {
  margin: 48px auto 0; padding-top: 22px;
  border-top: 1px solid rgba(255,255,255,0.08);
  max-width: 1240px;
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px;
  font-size: 12px; color: rgba(255,255,255,0.5);
}

/* ========================================================
   MOBILE
   ======================================================== */
@media (max-width: 920px) {
  .hdr-nav a:not(.hdr-cta) { display: none; }
  .hero { padding: 40px 20px 32px; }
  .hero h1 { font-size: 44px; }
  .hero-script { font-size: 36px; }
  .tipi-row {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 4px;
    padding: 0 4px;
  }
  .tipi-tile .tipi-svg { max-width: 100%; }
  .tipi-label {
    font-size: 10px; letter-spacing: 0.08em;
    margin-top: 8px; gap: 3px;
    white-space: nowrap; overflow: hidden;
  }
  /* hide the decorative emojis around the label on phones —
     they're flex children, take width, and were causing overflow */
  .tipi-label > .lbl-icon { display: none; }
  .tipi-label::after { display: none; }
  .stage { grid-template-columns: 1fr; gap: 32px; margin-top: 40px; }
  .stage-photo {
    max-width: 300px;
    margin: 28px auto 0;
    transform: rotate(-2deg);
    overflow: visible;
  }
  /* Hide the decorative tape on phones — it collides with the badge */
  .stage-photo .tape { display: none; }
  /* Move the price badge above-right, smaller, fully outside the photo */
  .stage-photo .badge {
    width: 78px; height: 78px;
    top: -28px; right: -14px;
    font-size: 13px;
    padding: 8px 6px;
  }
  .stage-photo .badge strong {
    font-size: 18px !important;
  }
  .rail { grid-auto-columns: 230px; gap: 18px; padding: 24px 20px 32px; }
  .how-grid { grid-template-columns: 1fr 1fr; gap: 20px; }
  .pack-grid { grid-template-columns: 1fr; }
  .gal-grid { grid-template-columns: repeat(3, 1fr); }
  .gal-item.tall { grid-row: span 1; aspect-ratio: 1; }
  .ftr-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .section-head h2 { font-size: 32px; }
  .rail-section, .how, .packages, .gallery, .cta-band { padding: 64px 20px; }
}
@media (max-width: 520px) {
  .tipi-label { font-size: 9px; letter-spacing: 0.06em; }
  .gal-grid { grid-template-columns: 1fr 1fr; }
  .ftr-grid { grid-template-columns: 1fr; }
  /* compact polaroid stage on small phones */
  .stage-photo {
    max-width: 250px;
    padding: 10px 10px 44px;
  }
  .stage-photo::after { font-size: 20px; bottom: 14px; }
  .stage-photo .badge {
    width: 64px; height: 64px;
    top: -22px; right: -10px;
    font-size: 11px; padding: 6px 4px;
  }
  .stage-photo .badge strong { font-size: 15px !important; }
  .stage-photo .tape { display: none; }
}

/* ========================================================
   ANIMATED THEME REVEAL (#10)
   ======================================================== */
@keyframes reveal-photo {
  from { opacity: 0; transform: rotate(0deg) translateY(20px) scale(0.96); }
  to   { opacity: 1; transform: rotate(-3deg) translateY(0) scale(1); }
}
@keyframes reveal-copy {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}
.stage-photo {
  animation: reveal-photo 520ms var(--ease-out) both;
}
.stage-copy {
  animation: reveal-copy 520ms var(--ease-out) 80ms both;
}

/* ========================================================
   MODE TOGGLES (night + kid)  — top-right floating
   ======================================================== */
.modes {
  position: fixed;
  top: calc(76px + env(safe-area-inset-top, 0px));
  right: max(18px, env(safe-area-inset-right));
  z-index: 45;
  display: flex; gap: 6px;
  background: rgba(251, 247, 241, 0.86);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  padding: 4px;
  border-radius: 999px;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border-soft);
}
[data-night] .modes {
  background: rgba(33, 21, 56, 0.7);
  border-color: rgba(255,255,255,0.1);
}
.mode-btn {
  background: transparent; border: none;
  font-family: var(--font-display); font-weight: 700;
  font-size: 13px; letter-spacing: 0.02em;
  color: var(--kb-night-500);
  padding: 8px 12px; border-radius: 999px;
  display: inline-flex; align-items: center; gap: 6px;
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
}
.mode-btn:hover { background: rgba(33,21,56,0.06); }
.mode-btn.on {
  background: var(--kb-night-500); color: var(--kb-cream-50);
}
[data-night] .mode-btn { color: var(--kb-cream-50); }
[data-night] .mode-btn:hover { background: rgba(255,255,255,0.1); }
[data-night] .mode-btn.on {
  background: var(--kb-gold-400); color: var(--kb-night-500);
}
.mode-emoji { font-size: 15px; }
@media (max-width: 520px) {
  .modes {
    top: auto;
    bottom: calc(14px + env(safe-area-inset-bottom, 0px));
    left: max(12px, env(safe-area-inset-left));
    right: auto;
  }
  .mode-label { display: none; }
  .mode-btn { padding: 10px; width: 38px; height: 38px; justify-content: center; }
}

/* ========================================================
   NIGHT MODE (#12)
   Forces dark sleepover-sky regardless of active theme.
   ======================================================== */
[data-night] {
  --bg-page: #0F0A1E;
  --bg-soft: #16102A;
  --bg-surface: #1A1432;
  --fg-1: var(--kb-cream-50);
  --fg-2: rgba(251, 247, 241, 0.78);
  --fg-3: rgba(251, 247, 241, 0.55);
  --border-soft: rgba(255,255,255,0.08);
  --border: rgba(255,255,255,0.14);
}
[data-night] body { background: var(--bg-page); color: var(--fg-1); }
[data-night] .hdr {
  background: rgba(15, 10, 30, 0.72);
  border-bottom-color: rgba(255,255,255,0.08);
}
[data-night] .mark, [data-night] .hdr-nav a { color: var(--kb-cream-50); }
[data-night] .hero {
  background:
    radial-gradient(120% 70% at 50% -10%, #2A1F4F 0%, #0F0A1E 70%) !important;
  color: var(--kb-cream-50);
}
[data-night] .hero h1 { color: var(--kb-cream-50); }
[data-night] .hero h1 em { color: var(--kb-gold-300); }
[data-night] .hero-sub { color: rgba(251,247,241,0.78); }
[data-night] .hero-script { color: var(--kb-gold-300); }
[data-night] .hero-eyebrow { color: var(--kb-gold-400); }
[data-night] .stars span { color: var(--kb-cream-50); }
[data-night] .tipi-label { color: rgba(251,247,241,0.7); }
[data-night] .tipi-tile.active .tipi-label { color: var(--kb-gold-300); }
[data-night] .section-head h2 { color: var(--kb-cream-50); }
[data-night] .section-head .script { color: var(--kb-gold-300); }
[data-night] .section-head p { color: rgba(251,247,241,0.7); }
[data-night] .rail-item { background: var(--bg-surface); color: var(--kb-cream-50); }
[data-night] .rail-item p { color: rgba(251,247,241,0.7); }
[data-night] .rail-item h4 { color: var(--kb-cream-50); }
[data-night] .rail-item .pic { background: linear-gradient(135deg, #2A1F4F, #1A1432); }
[data-night] .how { background: #0B0716; }
[data-night] .how-step { background: var(--bg-surface); color: var(--kb-cream-50); }
[data-night] .how-step h4 { color: var(--kb-cream-50); }
[data-night] .how-step p { color: rgba(251,247,241,0.65); }
[data-night] .pack { background: var(--bg-surface); color: var(--kb-cream-50); }
[data-night] .pack h3 { color: var(--kb-cream-50); }
[data-night] .pack .per { color: rgba(251,247,241,0.5); }
[data-night] .gallery { background: #0F0A1E; }
[data-night] .stage-copy h2 { color: var(--kb-cream-50); }

/* ========================================================
   KID MODE (#14)
   Larger type, bouncier, more emoji moments.
   ======================================================== */
[data-kid] {
  --fs-base: 18px;
}
[data-kid] body { font-size: 18px; }
[data-kid] .hero h1 { font-size: clamp(56px, 9vw, 110px); }
[data-kid] .hero-script { font-size: 72px; }
[data-kid] .section-head h2 { font-size: clamp(40px, 5.5vw, 64px); }
[data-kid] .btn-primary { font-size: 18px; padding: 18px 32px; }
[data-kid] .hdr-cta { font-size: 15px; padding: 12px 22px; }
[data-kid] .tipi-tile { animation: wiggle 4s ease-in-out infinite; }
[data-kid] .tipi-tile:nth-child(2) { animation-delay: 0.4s; }
[data-kid] .tipi-tile:nth-child(3) { animation-delay: 0.8s; }
[data-kid] .tipi-tile:nth-child(4) { animation-delay: 1.2s; }
[data-kid] .tipi-tile:nth-child(5) { animation-delay: 1.6s; }
[data-kid] .tipi-tile.active { animation: bounce 1.2s ease-in-out infinite; }
[data-kid] .tipi-label { font-size: 14px; letter-spacing: 0.12em; }
[data-kid] .rail-item:hover { transform: rotate(0) translateY(-10px) scale(1.04); }
[data-kid] .how-step:hover { transform: rotate(0deg) scale(1.03); }
[data-kid] .stars span { font-size: 22px; }
@keyframes wiggle {
  0%, 100% { transform: rotate(0deg); }
  25%      { transform: rotate(-2deg); }
  75%      { transform: rotate(2deg); }
}
@keyframes bounce {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-8px); }
}

/* ========================================================
   TRUST STRIP (#19)
   ======================================================== */
.trust {
  background: var(--bg-page);
  padding: 28px 28px 0;
  position: relative;
}
[data-night] .trust { background: var(--bg-page); }
.trust-inner {
  max-width: 1180px; margin: 0 auto;
  display: flex; flex-wrap: wrap; justify-content: center;
  gap: 32px 48px;
  padding: 22px 32px;
  background: rgba(255,255,255,0.6);
  border-radius: 999px;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border-soft);
}
[data-night] .trust-inner {
  background: rgba(255,255,255,0.05);
  border-color: rgba(255,255,255,0.08);
}
.trust-item {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-display); font-weight: 600; font-size: 14px;
  color: var(--kb-night-500); letter-spacing: 0.01em;
}
[data-night] .trust-item { color: var(--kb-cream-50); }
.trust-emoji { font-size: 22px; line-height: 1; }
@media (max-width: 700px) {
  .trust-inner {
    border-radius: 24px; padding: 18px 22px;
    gap: 14px 24px;
  }
  .trust-item { font-size: 13px; }
}

/* ========================================================
   CONFIGURATOR (#4 + #6)
   ======================================================== */
.cfg {
  padding: 96px 28px;
  background:
    radial-gradient(60% 60% at 80% 0%, var(--brand-soft) 0%, transparent 60%),
    var(--bg-page);
}
[data-night] .cfg {
  background: radial-gradient(60% 60% at 80% 0%, rgba(228,139,160,0.18) 0%, transparent 60%), var(--bg-page);
}
.cfg-grid {
  max-width: 1240px; margin: 48px auto 0;
  display: grid; grid-template-columns: 1.3fr 1fr;
  gap: 40px;
  align-items: start;
}
.cfg-controls {
  display: grid; gap: 22px;
}
.cfg-block {
  background: #fff;
  border-radius: 28px;
  padding: 22px 24px 24px;
  box-shadow: var(--shadow-sm);
}
[data-night] .cfg-block { background: var(--bg-surface); }
.cfg-block-label {
  font-family: var(--font-display); font-weight: 700;
  font-size: 13px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--fg-3); margin-bottom: 14px;
  display: flex; justify-content: space-between; align-items: baseline;
}
.cfg-block-value {
  font-family: var(--font-display); font-weight: 700;
  text-transform: none; letter-spacing: 0;
  font-size: 16px; color: var(--kb-night-500);
}
[data-night] .cfg-block-value { color: var(--kb-cream-50); }

.cfg-pack-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.cfg-pack {
  background: rgba(33,21,56,0.04);
  border: 2px solid transparent;
  border-radius: 20px;
  padding: 16px 18px;
  text-align: left;
  cursor: pointer;
  font-family: var(--font-body);
  transition: all var(--dur-base) var(--ease-out);
}
.cfg-pack:hover { background: rgba(33,21,56,0.08); }
.cfg-pack.active {
  background: var(--brand-soft);
  border-color: var(--kb-rose-400);
}
[data-night] .cfg-pack { background: rgba(255,255,255,0.04); }
[data-night] .cfg-pack:hover { background: rgba(255,255,255,0.08); }
[data-night] .cfg-pack.active { background: rgba(228,139,160,0.22); border-color: var(--kb-rose-400); }
.cfg-pack-name {
  font-family: var(--font-display); font-weight: 700; font-size: 16px;
  color: var(--kb-night-500); margin-bottom: 2px;
}
[data-night] .cfg-pack-name { color: var(--kb-cream-50); }
.cfg-pack-sub { font-size: 13px; color: var(--fg-3); }

/* slider */
.cfg-slider {
  -webkit-appearance: none; appearance: none;
  width: 100%; height: 8px; background: rgba(33,21,56,0.08);
  border-radius: 999px; outline: none;
  margin-top: 4px;
}
[data-night] .cfg-slider { background: rgba(255,255,255,0.1); }
.cfg-slider::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 28px; height: 28px; border-radius: 999px;
  background: var(--kb-rose-400);
  border: 4px solid #fff;
  box-shadow: var(--shadow-md);
  cursor: pointer;
  transition: transform var(--dur-fast);
}
.cfg-slider::-webkit-slider-thumb:hover { transform: scale(1.1); }
.cfg-slider::-moz-range-thumb {
  width: 28px; height: 28px; border-radius: 999px;
  background: var(--kb-rose-400); border: 4px solid #fff;
  box-shadow: var(--shadow-md); cursor: pointer;
}
.cfg-slider-marks {
  display: flex; justify-content: space-between;
  margin-top: 10px; padding: 0 6px;
  font-family: var(--font-display); font-weight: 600; font-size: 13px;
  color: var(--fg-3);
}
.cfg-slider-marks span.on { color: var(--kb-rose-500); font-weight: 700; }

.cfg-theme-reminder {
  display: flex; align-items: center; gap: 14px;
}
.cfg-theme-dot {
  width: 44px; height: 44px; border-radius: 999px; flex-shrink: 0;
  box-shadow: inset 0 0 0 4px #fff, 0 0 0 1px var(--border);
}
[data-night] .cfg-theme-dot { box-shadow: inset 0 0 0 4px var(--bg-surface), 0 0 0 1px rgba(255,255,255,0.1); }

.cfg-extras {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
}
.cfg-extra {
  display: flex; align-items: center; gap: 12px;
  background: rgba(33,21,56,0.04);
  border: 2px solid transparent;
  border-radius: 18px;
  padding: 12px 14px;
  text-align: left;
  cursor: pointer;
  font-family: var(--font-body);
  transition: all var(--dur-fast) var(--ease-out);
}
.cfg-extra:hover { background: rgba(33,21,56,0.08); }
.cfg-extra.on {
  background: var(--brand-soft);
  border-color: var(--kb-rose-400);
}
[data-night] .cfg-extra { background: rgba(255,255,255,0.04); }
[data-night] .cfg-extra:hover { background: rgba(255,255,255,0.08); }
[data-night] .cfg-extra.on { background: rgba(228,139,160,0.22); border-color: var(--kb-rose-400); }
.cfg-extra-emoji { font-size: 26px; line-height: 1; }
.cfg-extra-body {
  flex: 1; display: grid; gap: 1px;
  font-family: var(--font-body);
}
.cfg-extra-name {
  font-family: var(--font-display); font-weight: 700; font-size: 14px;
  color: var(--kb-night-500);
}
[data-night] .cfg-extra-name { color: var(--kb-cream-50); }
.cfg-extra-desc { font-size: 12px; color: var(--fg-3); line-height: 1.4; }
.cfg-extra-price {
  font-family: var(--font-display); font-weight: 700; font-size: 14px;
  color: var(--kb-rose-500);
}
.cfg-extra.on .cfg-extra-price { color: var(--kb-rose-500); }

/* summary */
.cfg-summary { position: sticky; top: 90px; }
.cfg-summary-card {
  background: var(--kb-night-500); color: var(--kb-cream-50);
  border-radius: 28px;
  padding: 28px 28px 26px;
  box-shadow: var(--shadow-lg);
  position: relative;
  overflow: hidden;
}
.cfg-summary-card::before {
  content: ''; position: absolute; top: -40px; right: -40px;
  width: 140px; height: 140px; border-radius: 999px;
  background: radial-gradient(circle, rgba(230,187,76,0.45) 0%, transparent 70%);
  pointer-events: none;
}
.cfg-summary-tag {
  font-family: var(--font-display); font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.2em; font-size: 12px;
  color: var(--kb-gold-300);
}
.cfg-summary-total {
  display: flex; align-items: flex-start; gap: 4px;
  margin: 8px 0 2px;
}
.cfg-summary-prefix {
  font-family: var(--font-display); font-weight: 600; font-size: 28px;
  color: var(--kb-cream-50); margin-top: 10px;
}
.cfg-summary-amount {
  font-family: var(--font-display); font-weight: 700;
  font-size: 72px; line-height: 1; letter-spacing: -0.03em;
  color: var(--kb-cream-50);
}
.cfg-summary-sub { font-size: 13px; color: rgba(251,247,241,0.55); }
.cfg-summary-lines {
  margin: 20px 0 22px;
  padding: 18px 0;
  border-top: 1px solid rgba(255,255,255,0.1);
  border-bottom: 1px solid rgba(255,255,255,0.1);
  display: grid; gap: 8px;
}
.cfg-line {
  display: flex; justify-content: space-between;
  font-family: var(--font-body); font-size: 14px;
  color: rgba(251,247,241,0.85);
}
.cfg-cta {
  width: 100%; justify-content: center;
  background: var(--kb-gold-400); color: var(--kb-night-500);
}
.cfg-cta:hover { background: var(--kb-gold-500); }
.cfg-summary-foot {
  margin-top: 12px; text-align: center;
  font-size: 12px; color: rgba(251,247,241,0.55);
}

@media (max-width: 920px) {
  .cfg-grid { grid-template-columns: 1fr; }
  .cfg-summary { position: static; }
  .cfg-extras { grid-template-columns: 1fr; }
  .cfg-summary-amount { font-size: 56px; }
}

/* ========================================================
   FAQ (#2)
   ======================================================== */
.faq {
  padding: 96px 28px;
  background: var(--bg-soft);
}
.faq-list {
  max-width: 820px; margin: 48px auto 0;
  display: grid; gap: 12px;
}
.faq-item {
  background: #fff;
  border-radius: 22px;
  box-shadow: var(--shadow-xs);
  border: 1px solid var(--border-soft);
  overflow: hidden;
  transition: box-shadow var(--dur-base);
}
[data-night] .faq-item { background: var(--bg-surface); border-color: var(--border-soft); }
.faq-item.open { box-shadow: var(--shadow-md); }
.faq-q {
  width: 100%; background: transparent; border: none;
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  padding: 22px 26px;
  font-family: var(--font-display); font-weight: 700; font-size: 17px;
  color: var(--kb-night-500);
  text-align: left;
  cursor: pointer;
}
[data-night] .faq-q { color: var(--kb-cream-50); }
.faq-icon {
  width: 32px; height: 32px; border-radius: 999px;
  background: var(--brand-soft); color: var(--kb-rose-500);
  display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 700; font-size: 22px; line-height: 1;
  flex-shrink: 0;
  transition: all var(--dur-base) var(--ease-out);
}
.faq-item.open .faq-icon {
  background: var(--kb-rose-400); color: #fff;
  transform: rotate(180deg);
}
.faq-a {
  max-height: 0; overflow: hidden;
  transition: max-height 380ms var(--ease-out);
}
.faq-item.open .faq-a { max-height: 240px; }
.faq-a p {
  margin: 0; padding: 0 26px 24px;
  font-size: 15px; line-height: 1.7;
  color: var(--fg-2);
  max-width: 640px;
}

/* ========================================================
   STICKY CTA pill (#18)
   ======================================================== */
.sticky-cta {
  position: fixed;
  right: max(22px, env(safe-area-inset-right));
  bottom: calc(22px + env(safe-area-inset-bottom, 0px));
  z-index: 90;
  background: var(--kb-rose-400); color: #fff;
  border: none;
  font-family: var(--font-display); font-weight: 700; font-size: 15px;
  padding: 14px 22px;
  border-radius: 999px;
  box-shadow: var(--shadow-lg), 0 0 0 6px rgba(228,139,160,0.18);
  display: inline-flex; align-items: center; gap: 10px;
  opacity: 0; pointer-events: none;
  transform: translateY(20px) scale(0.94);
  transition: all 380ms var(--ease-bounce);
}
.sticky-cta.visible {
  opacity: 1; pointer-events: auto;
  transform: translateY(0) scale(1);
}
.sticky-cta:hover {
  background: var(--kb-rose-500);
  transform: translateY(-2px) scale(1.02);
}
.sticky-cta-emoji { font-size: 18px; }
[data-night] .sticky-cta {
  background: var(--kb-gold-400); color: var(--kb-night-500);
  box-shadow: var(--shadow-lg), 0 0 24px rgba(230,187,76,0.45);
}
[data-night] .sticky-cta:hover { background: var(--kb-gold-500); }

/* ========================================================
   MOBILE BOTTOM-SHEET MODAL (#20)
   ======================================================== */
@media (max-width: 640px) {
  .kb-modal-shell { padding: 0 !important; place-items: end center !important; }
  .kb-modal-panel {
    max-width: 100% !important;
    border-radius: 28px 28px 0 0 !important;
    padding: 28px 22px 24px !important;
    max-height: 92vh; overflow-y: auto;
    animation: sheet-up 320ms var(--ease-out) !important;
  }
  .kb-modal-panel::before {
    content: ''; position: absolute; top: 10px; left: 50%;
    transform: translateX(-50%);
    width: 44px; height: 4px; border-radius: 999px;
    background: rgba(33,21,56,0.18);
  }
  .sticky-cta {
    right: max(12px, env(safe-area-inset-right));
    bottom: calc(12px + env(safe-area-inset-bottom, 0px));
    font-size: 14px; padding: 12px 18px;
  }
}
@keyframes sheet-up {
  from { transform: translateY(100%); }
  to   { transform: translateY(0); }
}

/* ========================================================
   PER-THEME HERO BACKDROPS
   ======================================================== */
.hero-backdrop {
  position: absolute; inset: 0;
  z-index: 0; pointer-events: none;
  overflow: hidden;
  animation: bd-fade 600ms var(--ease-out) both;
}
@keyframes bd-fade {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.bd { position: absolute; inset: 0; pointer-events: none; }
.bd-bg { position: absolute; inset: 0; }

/* ---------- BEAUTY ---------- */
.bd-beauty .bd-bg {
  background:
    radial-gradient(60% 50% at 50% -10%, #FBD5DC 0%, transparent 70%),
    linear-gradient(180deg, #FDF3F4 0%, #FBEAEC 60%, #F4D6DE 100%);
}
.bd-heart {
  position: absolute; bottom: -40px;
  color: #E48BA0; opacity: 0;
  text-shadow: 0 0 8px rgba(228,139,160,0.5);
  animation: heart-rise linear infinite;
}
@keyframes heart-rise {
  0%   { transform: translateY(0) rotate(-6deg); opacity: 0; }
  12%  { opacity: 0.7; }
  88%  { opacity: 0.55; }
  100% { transform: translateY(-110vh) rotate(20deg); opacity: 0; }
}
.bd-sparkle {
  position: absolute; color: var(--kb-gold-400);
  font-size: 14px; opacity: 0;
  animation: bd-twinkle 4s ease-in-out infinite;
}
@keyframes bd-twinkle {
  0%, 100% { opacity: 0; transform: scale(0.6); }
  50%      { opacity: 0.95; transform: scale(1); }
}
.bd-kiss {
  position: absolute; font-size: 36px;
  opacity: 0.25; transform: rotate(-12deg);
}
.bd-kiss-1 { top: 18%; left: 6%; }
.bd-kiss-2 { bottom: 14%; right: 8%; transform: rotate(8deg); }

/* ---------- PINK ---------- */
.bd-pink .bd-bg {
  background:
    radial-gradient(80% 55% at 50% 0%, #FBD7E1 0%, transparent 70%),
    linear-gradient(180deg, #FCE4EC 0%, #FBF3F5 70%, #FBF7F1 100%);
}
.bd-petal {
  position: absolute; top: -40px;
  opacity: 0; line-height: 1;
  animation: petal-drift linear infinite;
}
@keyframes petal-drift {
  0%   { transform: translateY(0) translateX(0) rotate(0deg); opacity: 0; }
  10%  { opacity: 0.85; }
  90%  { opacity: 0.75; }
  100% { transform: translateY(110vh) translateX(var(--drift, 30px)) rotate(360deg); opacity: 0; }
}
.bd-pampas {
  position: absolute; bottom: 0;
  width: 260px; height: 320px;
  opacity: 0.55;
  pointer-events: none;
}
.bd-pampas-left  { left: -40px; }
.bd-pampas-right { right: -40px; transform: scaleX(-1); }

/* ---------- JUNGLE ---------- */
.bd-jungle .bd-bg {
  background:
    radial-gradient(70% 50% at 50% 0%, #C9D8AC 0%, transparent 70%),
    linear-gradient(180deg, #DDE8C0 0%, #A8C088 70%, #6E8A53 100%);
}
.bd-leaf {
  position: absolute;
  filter: drop-shadow(0 12px 24px rgba(30,58,40,0.4));
}
.bd-leaf-tl  { top: -90px;   left: -90px;   width: 280px; animation: sway-tl  7s ease-in-out infinite; }
.bd-leaf-tr  { top: -100px;  right: -100px; width: 300px; animation: sway-tr  7s -2s ease-in-out infinite; }
.bd-leaf-bl  { bottom: -110px; left: -80px;  width: 260px; animation: sway-bl 7s -3.5s ease-in-out infinite; }
.bd-leaf-br  { bottom: -120px; right: -90px; width: 280px; animation: sway-br 7s -1s ease-in-out infinite; }
.bd-leaf-mid { top: -180px;  left: 42%;     width: 220px; opacity: 0.5; animation: sway-mid 7s -4.5s ease-in-out infinite; }

@keyframes sway-tl  { 0%, 100% { transform: rotate(135deg); }  50% { transform: rotate(142deg); } }
@keyframes sway-tr  { 0%, 100% { transform: rotate(-135deg); } 50% { transform: rotate(-142deg); } }
@keyframes sway-bl  { 0%, 100% { transform: rotate(45deg); }   50% { transform: rotate(52deg); } }
@keyframes sway-br  { 0%, 100% { transform: rotate(-45deg); }  50% { transform: rotate(-52deg); } }
@keyframes sway-mid { 0%, 100% { transform: rotate(180deg); }  50% { transform: rotate(184deg); } }

.bd-monkey {
  position: absolute; top: 38%; right: 6%;
  font-size: 56px; transform: rotate(-12deg);
  opacity: 0.85;
  filter: drop-shadow(0 6px 12px rgba(30,58,40,0.3));
}
.bd-fly {
  position: absolute; left: -20px;
  font-size: 26px; opacity: 0;
  animation: fly-cross linear infinite;
}
@keyframes fly-cross {
  0%   { transform: translateX(0) translateY(0); opacity: 0; }
  10%  { opacity: 0.85; }
  50%  { transform: translateX(50vw) translateY(-20px); }
  90%  { opacity: 0.85; }
  100% { transform: translateX(110vw) translateY(0); opacity: 0; }
}

/* ---------- MOVIE ---------- */
.bd-movie .bd-bg {
  background:
    radial-gradient(70% 60% at 50% 0%, #2E2750 0%, transparent 70%),
    linear-gradient(180deg, #1B1730 0%, #0E0A20 70%, #08030F 100%);
}
.bd-spotlight {
  position: absolute; top: -10%; left: 50%;
  width: 600px; height: 120%;
  background: radial-gradient(ellipse 50% 50% at 50% 0%, rgba(230,187,76,0.22) 0%, transparent 70%);
  transform: translateX(-50%);
  filter: blur(20px);
  animation: spot-sway 12s ease-in-out infinite;
}
@keyframes spot-sway {
  0%, 100% { transform: translateX(-55%) skewX(-2deg); }
  50%      { transform: translateX(-45%) skewX(2deg); }
}
.bd-film {
  position: absolute; top: 0; bottom: 0;
  width: 50px; height: 100%;
}
.bd-film-left  { left: 0; }
.bd-film-right { right: 0; transform: scaleX(-1); }
.bd-mstar {
  position: absolute; color: var(--kb-gold-300);
  opacity: 0; line-height: 1;
  animation: bd-twinkle 4.4s ease-in-out infinite;
}
.bd-popcorn {
  position: absolute; top: -40px; line-height: 1; opacity: 0;
  animation: popcorn-fall linear infinite;
}
@keyframes popcorn-fall {
  0%   { transform: translateY(0) rotate(0); opacity: 0; }
  10%  { opacity: 0.9; }
  100% { transform: translateY(110vh) rotate(720deg); opacity: 0; }
}

/* ---------- NEON ---------- */
.bd-neon .bd-bg {
  background:
    radial-gradient(60% 60% at 50% 30%, #1F1538 0%, transparent 70%),
    linear-gradient(180deg, #0E0E14 0%, #07070D 100%);
}
.bd-grid {
  position: absolute; left: -10%; right: -10%; bottom: 0; height: 65%;
  background-image:
    linear-gradient(90deg, rgba(255,61,171,0.45) 1px, transparent 1px),
    linear-gradient(0deg, rgba(43,224,240,0.45) 1px, transparent 1px);
  background-size: 60px 60px;
  transform: perspective(500px) rotateX(62deg);
  transform-origin: bottom;
  mask-image: linear-gradient(to top, black 30%, transparent 100%);
  -webkit-mask-image: linear-gradient(to top, black 30%, transparent 100%);
  opacity: 0.55;
  animation: grid-pulse 4s ease-in-out infinite;
}
@keyframes grid-pulse {
  0%, 100% { opacity: 0.4; }
  50%      { opacity: 0.7; }
}
.bd-glow {
  position: absolute; width: 380px; height: 380px; border-radius: 999px;
  filter: blur(80px); opacity: 0.55;
  animation: glow-float 14s ease-in-out infinite;
}
.bd-glow-pink   { background: #FF3DAB; top: 5%;    left: 5%;  }
.bd-glow-cyan   { background: #2BE0F0; top: 12%;   right: 8%; animation-delay: -3s; }
.bd-glow-green  { background: #B8FF3D; bottom: 4%; left: 35%; animation-delay: -6s; opacity: 0.35; }
.bd-glow-purple { background: #A06BFF; top: 35%;   left: 40%; animation-delay: -9s; opacity: 0.45; }
@keyframes glow-float {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50%      { transform: translate(60px, -40px) scale(1.1); }
}
.bd-spark {
  position: absolute; opacity: 0; line-height: 1;
  animation: bd-twinkle 3.2s ease-in-out infinite;
}

/* Hero text contrasts for jungle theme */
[data-theme="jungle"] .hero h1 { color: #1E3A28; }
[data-theme="jungle"] .hero h1 em { color: #C99A2A; }
[data-theme="jungle"] .hero-sub { color: rgba(30,58,40,0.78); }
[data-theme="jungle"] .hero-script { color: #C99A2A; }
[data-theme="jungle"] .hero-eyebrow { color: #1E3A28; }

/* hide existing CSS gradient on .hero — backdrop handles it now */
.hero { background: var(--bg-page); }
[data-theme="movie"] .hero,
[data-theme="neon"]  .hero { background: var(--bg-page); }

/* keep hero content above the backdrop */
.hero-inner { position: relative; z-index: 2; }

/* the stars/garland from before are no longer rendered; remove unused rules-of-existence */
.hero .stars, .hero .garland { display: none; }

@media (max-width: 700px) {
  .bd-pampas { width: 180px; height: 220px; }
  .bd-leaf { transform-origin: center !important; }
  .bd-leaf-tl, .bd-leaf-tr, .bd-leaf-bl, .bd-leaf-br { width: 200px; }
  .bd-monkey { font-size: 42px; top: 32%; right: 4%; }
  .bd-film { width: 30px; }
}


/* ========================================================
   #4 — WHATSAPP BUBBLE
   ======================================================== */
.wa-fab {
  position: fixed;
  right: max(22px, env(safe-area-inset-right));
  bottom: calc(88px + env(safe-area-inset-bottom, 0px));
  z-index: 95;
  width: 58px; height: 58px; border-radius: 999px;
  background: #25D366;
  display: grid; place-items: center;
  border: none; padding: 0;
  box-shadow: 0 10px 26px rgba(37,211,102,0.45), var(--shadow-md);
  cursor: pointer;
  transition: transform var(--dur-base) var(--ease-bounce),
              background var(--dur-base) var(--ease-out),
              box-shadow var(--dur-base);
  animation: wa-pulse 2.8s ease-in-out infinite;
}
.wa-fab:hover { transform: scale(1.08); }
.wa-fab:active { transform: scale(0.95); }
.wa-fab.open {
  animation: none;
  background: var(--kb-night-500);
  box-shadow: var(--shadow-md);
}
.wa-x { color: #fff; font-size: 20px; font-weight: 700; line-height: 1; }
@keyframes wa-pulse {
  0%, 100% { box-shadow: 0 10px 26px rgba(37,211,102,0.45), 0 0 0 0 rgba(37,211,102,0.55); }
  60%      { box-shadow: 0 10px 26px rgba(37,211,102,0.45), 0 0 0 20px rgba(37,211,102,0); }
}

.wa-panel {
  position: fixed;
  right: max(22px, env(safe-area-inset-right));
  bottom: calc(158px + env(safe-area-inset-bottom, 0px));
  width: 320px;
  max-width: calc(100vw - 28px);
  max-height: calc(100vh - 200px - env(safe-area-inset-bottom, 0px));
  display: flex; flex-direction: column;
  background: var(--bg-page);
  border-radius: 22px;
  box-shadow: 0 24px 60px rgba(33,21,56,0.25), var(--shadow-lg);
  overflow: hidden;
  z-index: 96;
  animation: wa-pop 280ms var(--ease-bounce);
  border: 1px solid var(--border-soft);
  transform-origin: bottom right;
}
@keyframes wa-pop {
  from { opacity: 0; transform: scale(0.85) translateY(8px); }
  to   { opacity: 1; transform: scale(1)    translateY(0); }
}
.wa-head {
  background: #075E54;
  padding: 14px 16px;
  display: flex; gap: 12px; align-items: center;
  color: #fff;
}
.wa-avatar {
  width: 42px; height: 42px; border-radius: 999px;
  background: linear-gradient(135deg, var(--kb-rose-400), var(--kb-rose-500));
  display: grid; place-items: center;
  color: #fff; font-size: 18px;
  box-shadow: inset 0 0 0 2px rgba(255,255,255,0.2);
}
.wa-name {
  font-family: var(--font-display); font-weight: 700;
  font-size: 15px; color: #fff;
}
.wa-status {
  font-family: var(--font-body); font-size: 11px;
  color: rgba(255,255,255,0.85);
  display: inline-flex; align-items: center; gap: 5px;
}
.wa-dot {
  width: 7px; height: 7px; border-radius: 999px;
  background: #4ADE80;
  box-shadow: 0 0 6px #4ADE80;
}
.wa-body {
  padding: 18px 16px 14px;
  background:
    radial-gradient(circle at 20% 20%, rgba(228,139,160,0.10), transparent 40%),
    #ECE5DD;
  min-height: 92px;
  position: relative;
  flex: 1 1 auto;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.wa-cta { flex: 0 0 auto; }
.wa-bubble {
  background: #fff;
  border-radius: 4px 12px 12px 12px;
  padding: 10px 14px 20px;
  font-family: var(--font-body); font-size: 13.5px; line-height: 1.55;
  color: var(--kb-night-500);
  box-shadow: 0 1px 1px rgba(0,0,0,0.08);
  max-width: 92%;
  position: relative;
  animation: wa-msg 360ms var(--ease-out) both;
}
@keyframes wa-msg {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.wa-time {
  position: absolute; right: 10px; bottom: 5px;
  font-size: 10px; color: rgba(0,0,0,0.42);
  font-family: var(--font-body);
}
.wa-typing {
  display: inline-flex; gap: 4px;
  background: #fff; border-radius: 12px;
  padding: 10px 14px;
  margin-top: 8px;
  box-shadow: 0 1px 1px rgba(0,0,0,0.08);
  animation: wa-msg 360ms 280ms var(--ease-out) both;
}
.wa-typing span {
  width: 6px; height: 6px; border-radius: 999px;
  background: rgba(0,0,0,0.35);
  animation: wa-bounce 1.2s ease-in-out infinite;
}
.wa-typing span:nth-child(2) { animation-delay: 0.15s; }
.wa-typing span:nth-child(3) { animation-delay: 0.30s; }
@keyframes wa-bounce {
  0%, 60%, 100% { transform: translateY(0); opacity: 0.4; }
  30%           { transform: translateY(-4px); opacity: 1; }
}
.wa-cta {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  background: #25D366;
  color: #fff !important;
  font-family: var(--font-display); font-weight: 700; font-size: 14px;
  padding: 14px;
  text-decoration: none;
  transition: background var(--dur-fast);
}
.wa-cta:hover { background: #1FB855; }

[data-night] .wa-panel {
  background: var(--bg-surface);
  border-color: rgba(255,255,255,0.08);
}

@media (max-width: 600px) {
  .wa-fab   {
    right: max(14px, env(safe-area-inset-right));
    bottom: calc(78px + env(safe-area-inset-bottom, 0px));
    width: 52px; height: 52px;
  }
  .wa-panel {
    right: max(14px, env(safe-area-inset-right));
    bottom: calc(140px + env(safe-area-inset-bottom, 0px));
  }
}
/* Landscape iPhones: anchor panel near top of fab instead, allow scroll */
@media (max-height: 520px) {
  .wa-panel {
    max-height: calc(100vh - 100px);
    bottom: calc(env(safe-area-inset-bottom, 0px) + 8px);
  }
  .wa-body { min-height: 0; }
}

/* ========================================================
   #5 — THEME TRANSITION BURST
   ======================================================== */
.theme-burst {
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 80;
  overflow: hidden;
}
.theme-burst-wipe {
  position: absolute; left: 50%; top: 42%;
  width: 140vmax; height: 140vmax;
  transform: translate(-50%, -50%) scale(0);
  background: radial-gradient(closest-side, var(--burst-color, #E48BA0) 0%, transparent 65%);
  opacity: 0;
  mix-blend-mode: screen;
  animation: tb-wipe 760ms cubic-bezier(0.22, 0.61, 0.36, 1) forwards;
}
@keyframes tb-wipe {
  0%   { opacity: 0;   transform: translate(-50%,-50%) scale(0.08); }
  35%  { opacity: 0.55; }
  100% { opacity: 0;   transform: translate(-50%,-50%) scale(1.2); }
}
.theme-burst-ring {
  position: absolute; left: 50%; top: 42%;
  width: 12px; height: 12px; border-radius: 999px;
  border: 2.5px solid var(--burst-color, #E48BA0);
  transform: translate(-50%, -50%) scale(0);
  opacity: 0.85;
  animation: tb-ring 900ms cubic-bezier(0.22, 0.61, 0.36, 1) forwards;
}
.theme-burst-ring--2 {
  border-width: 1.5px;
  animation: tb-ring 1100ms 120ms cubic-bezier(0.22, 0.61, 0.36, 1) forwards;
  opacity: 0.55;
}
@keyframes tb-ring {
  0%   { transform: translate(-50%,-50%) scale(0);   opacity: 0.85; }
  100% { transform: translate(-50%,-50%) scale(280); opacity: 0; }
}
.theme-burst-spark {
  position: absolute;
  display: inline-block;
  opacity: 0;
  transform: translate(-50%, -50%) scale(0);
  animation: tb-spark 950ms cubic-bezier(0.22, 0.61, 0.36, 1) forwards;
  text-shadow: 0 0 14px currentColor;
  will-change: transform, opacity;
  font-family: var(--font-display);
}
@keyframes tb-spark {
  0%   { opacity: 0; transform: translate(-50%,-50%) scale(0) rotate(0); }
  30%  { opacity: 1;
         transform: translate(calc(-50% + var(--tx, 0vmin) * 0.35),
                              calc(-50% + var(--ty, 0vmin) * 0.35))
                    scale(1.25) rotate(calc(var(--rot, 0deg) * 0.45)); }
  100% { opacity: 0;
         transform: translate(calc(-50% + var(--tx, 0vmin)),
                              calc(-50% + var(--ty, 0vmin)))
                    scale(0.35) rotate(var(--rot, 0deg)); }
}

@media (prefers-reduced-motion: reduce) {
  .theme-burst { display: none; }
}

/* ========================================================
   #6 — NIGHT-MODE CURSOR SPARKLES
   ======================================================== */
.night-spark-layer {
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 70;
}
.night-spark {
  position: fixed;
  transform: translate(-50%, -50%);
  pointer-events: none;
  animation: ns-rise 1150ms cubic-bezier(0.22, 0.61, 0.36, 1) forwards;
  text-shadow: 0 0 12px currentColor, 0 0 2px currentColor;
  will-change: transform, opacity;
  font-family: var(--font-display);
  line-height: 1;
}
@keyframes ns-rise {
  0%   { opacity: 0; transform: translate(-50%, -50%) scale(0.2) rotate(0deg); }
  20%  { opacity: 1; }
  60%  { opacity: 0.85;
         transform: translate(calc(-50% + var(--dx, 0px) * 0.55),
                              calc(-50% + var(--dy, 0px) * 0.55))
                    scale(1.1) rotate(18deg); }
  100% { opacity: 0;
         transform: translate(calc(-50% + var(--dx, 0px)),
                              calc(-50% + var(--dy, 0px)))
                    scale(0.4) rotate(42deg); }
}


/* ========================================================
   CONFIGURATOR — inline theme picker
   ======================================================== */
.cfg-theme-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
  margin-top: 4px;
}
.cfg-theme-tile {
  position: relative;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 12px 6px 10px;
  background: var(--bg-page);
  border: 1.5px solid var(--border-soft);
  border-radius: 14px;
  cursor: pointer;
  transition: transform var(--dur-fast) var(--ease-out),
              border-color var(--dur-fast),
              box-shadow var(--dur-fast),
              background var(--dur-fast);
  font-family: inherit;
}
.cfg-theme-tile:hover {
  transform: translateY(-2px);
  border-color: var(--tile-color, var(--kb-rose-400));
  box-shadow: var(--shadow-sm);
}
.cfg-theme-tile.active {
  border-color: var(--tile-color, var(--kb-rose-400));
  background: color-mix(in oklab, var(--tile-color) 8%, var(--bg-page));
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--tile-color) 22%, transparent);
}
.cfg-theme-tile.active::after {
  content: '✓';
  position: absolute; top: 6px; right: 8px;
  width: 18px; height: 18px;
  background: var(--tile-color, var(--kb-rose-400));
  color: #fff;
  border-radius: 999px;
  display: grid; place-items: center;
  font-size: 11px; font-weight: 700;
}
.cfg-theme-swatch {
  width: 38px; height: 38px;
  border-radius: 999px;
  background: var(--tile-color, var(--kb-rose-400));
  box-shadow: inset 0 0 0 2px rgba(255,255,255,0.5),
              0 4px 10px color-mix(in oklab, var(--tile-color) 35%, transparent);
}
.cfg-theme-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 12px;
  color: var(--fg-2);
  letter-spacing: 0.02em;
}
.cfg-theme-tile.active .cfg-theme-name {
  color: var(--kb-night-500);
}

@media (max-width: 600px) {
  .cfg-theme-grid {
    grid-template-columns: repeat(5, 1fr);
    gap: 6px;
  }
  .cfg-theme-tile { padding: 10px 4px 8px; }
  .cfg-theme-swatch { width: 30px; height: 30px; }
  .cfg-theme-name { font-size: 10.5px; }
}


/* ========================================================
   BEHEER (admin) modus indicator
   ======================================================== */
.admin-badge {
  position: fixed;
  top: calc(14px + env(safe-area-inset-top, 0px));
  left: max(14px, env(safe-area-inset-left));
  z-index: 110;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 10px 8px 14px;
  background: var(--kb-night-500);
  color: var(--kb-cream-50);
  border-radius: 999px;
  font-family: var(--font-display);
  font-weight: 600; font-size: 12px;
  letter-spacing: 0.04em;
  box-shadow: 0 10px 24px rgba(33,21,56,0.28);
  animation: admin-in 360ms var(--ease-bounce) both;
}
@keyframes admin-in {
  from { opacity: 0; transform: translateY(-8px) scale(0.92); }
  to   { opacity: 1; transform: translateY(0)    scale(1); }
}
.admin-dot {
  width: 8px; height: 8px; border-radius: 999px;
  background: var(--kb-gold-400);
  box-shadow: 0 0 0 0 var(--kb-gold-400);
  animation: admin-pulse 1.8s ease-in-out infinite;
}
@keyframes admin-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(230, 187, 76, 0.6); }
  50%      { box-shadow: 0 0 0 8px rgba(230, 187, 76, 0); }
}
.admin-exit {
  background: rgba(255,255,255,0.14);
  color: inherit;
  border: none;
  width: 22px; height: 22px;
  border-radius: 999px;
  font-size: 11px;
  display: grid; place-items: center;
  margin-left: 2px;
  transition: background var(--dur-fast);
}
.admin-exit:hover { background: rgba(255,255,255,0.28); }


/* ========================================================
   Admin-controlled banner (top of site)
   ======================================================== */
.admin-banner {
  position: relative; z-index: 60;
  color: #fff;
  text-align: center;
  font-family: var(--font-display); font-weight: 600;
  font-size: 14px;
  padding: 10px 16px;
  letter-spacing: 0.02em;
}


/* ========================================================
   #2 — Postcode bezorgchecker
   ======================================================== */
.pc-check { margin-top: 28px; max-width: 460px; }
.pc-row {
  display: flex; gap: 8px;
  background: var(--bg-page);
  border-radius: 999px;
  padding: 5px 5px 5px 18px;
  box-shadow: var(--shadow-sm);
  border: 1.5px solid var(--border-soft);
}
.pc-input {
  flex: 1;
  border: none; background: transparent;
  font-family: var(--font-body); font-size: 15px;
  outline: none; padding: 8px 4px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--fg-1);
}
.pc-input::placeholder { color: var(--fg-3); text-transform: none; letter-spacing: 0; }
.pc-btn {
  background: var(--t-accent, var(--kb-rose-500));
  color: #fff;
  border: none;
  padding: 10px 22px;
  border-radius: 999px;
  font-family: var(--font-display); font-weight: 700;
  font-size: 14px;
  transition: transform var(--dur-fast), background var(--dur-fast);
}
.pc-btn:hover { transform: translateY(-1px); }
.pc-result {
  margin-top: 10px;
  padding: 10px 14px 10px 12px;
  border-radius: 14px;
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-body); font-size: 14px;
  animation: pc-pop 280ms var(--ease-bounce) both;
}
.pc-result.ok    { background: rgba(122,179,108,0.18); color: #2D6B2D; }
.pc-result.maybe { background: rgba(230,187,76,0.22);  color: #7A5818; }
.pc-result.no    { background: rgba(228,139,160,0.22); color: #8B3A52; }
.pc-result-icon {
  width: 22px; height: 22px; border-radius: 999px;
  background: currentColor; color: #fff;
  display: grid; place-items: center;
  font-weight: 700; font-size: 12px;
}
.pc-result.ok    .pc-result-icon { background: #5BAA76; color: #fff; }
.pc-result.maybe .pc-result-icon { background: #E6BB4C; color: #fff; }
.pc-result.no    .pc-result-icon { background: #D9534F; color: #fff; }
@keyframes pc-pop {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

[data-night] .pc-row { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.1); }
[data-night] .pc-input { color: var(--fg-1); }

/* ========================================================
   #3 — Hero prijs-slider card
   ======================================================== */
.hero-slider {
  margin-top: 32px;
  background: var(--bg-page);
  border: 1.5px solid var(--border-soft);
  border-radius: 22px;
  padding: 20px 22px;
  box-shadow: var(--shadow-md);
  max-width: 460px;
}
.hero-slider-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  margin-bottom: 14px;
}
.hero-slider-eyebrow {
  font-family: var(--font-display); font-weight: 600;
  font-size: 10.5px; letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.hero-slider-total {
  font-family: var(--font-display); font-weight: 700;
  font-size: 38px; line-height: 1; letter-spacing: -0.02em;
  color: var(--fg-1);
}
.hero-slider-currency { font-size: 22px; vertical-align: top; margin-right: 2px; }
.hero-slider-row {
  display: flex; gap: 16px; align-items: center;
  margin-bottom: 14px;
}
.hero-slider-label {
  font-family: var(--font-display); font-weight: 600;
  font-size: 13px; color: var(--fg-2);
  min-width: 84px;
}
.hero-slider-label span {
  color: var(--t-accent, var(--kb-rose-500));
  font-size: 22px; font-weight: 700;
  margin-right: 4px;
}
.hero-slider-input {
  flex: 1;
  -webkit-appearance: none; appearance: none;
  height: 6px; border-radius: 999px;
  background: linear-gradient(90deg, var(--t-accent, var(--kb-rose-400)) 0%, var(--t-accent, var(--kb-rose-400)) var(--p, 50%), var(--border-soft) var(--p, 50%));
  outline: none;
  cursor: pointer;
}
.hero-slider-input::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 22px; height: 22px; border-radius: 999px;
  background: #fff;
  border: 3px solid var(--t-accent, var(--kb-rose-500));
  box-shadow: var(--shadow-sm);
  cursor: grab;
  transition: transform var(--dur-fast);
}
.hero-slider-input::-webkit-slider-thumb:active { cursor: grabbing; transform: scale(1.15); }
.hero-slider-input::-moz-range-thumb {
  width: 22px; height: 22px; border-radius: 999px;
  background: #fff;
  border: 3px solid var(--t-accent, var(--kb-rose-500));
}
.hero-slider-segmented {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
  margin-bottom: 14px;
}
.hero-seg {
  background: transparent;
  border: 1.5px solid var(--border-soft);
  border-radius: 12px;
  padding: 10px;
  font-family: var(--font-display); font-weight: 700; font-size: 14px;
  color: var(--fg-2);
  display: flex; flex-direction: column; gap: 2px;
  transition: all var(--dur-fast);
  cursor: pointer;
}
.hero-seg:hover { border-color: var(--fg-1); }
.hero-seg.active {
  background: var(--t-accent, var(--kb-rose-500));
  border-color: var(--t-accent, var(--kb-rose-500));
  color: #fff;
}
.hero-seg-sub {
  font-family: var(--font-body); font-weight: 400;
  font-size: 11.5px; opacity: 0.85; letter-spacing: 0;
}
.hero-slider-cta {
  width: 100%;
  background: var(--fg-1);
  color: var(--bg-page);
  border: none;
  padding: 12px 18px;
  border-radius: 12px;
  font-family: var(--font-display); font-weight: 700; font-size: 14.5px;
  cursor: pointer;
  transition: transform var(--dur-fast), background var(--dur-fast);
}
.hero-slider-cta:hover { background: var(--t-accent, var(--kb-rose-500)); transform: translateY(-1px); }

[data-night] .hero-slider {
  background: rgba(255,255,255,0.04);
  border-color: rgba(255,255,255,0.10);
}

@media (max-width: 600px) {
  .hero-slider { padding: 16px 16px; }
  .hero-slider-total { font-size: 30px; }
}

/* ========================================================
   #14 — Scroll-reveal tipi section
   ======================================================== */
.scroll-tipi {
  padding: 96px 22px;
  background: linear-gradient(180deg, var(--bg-page), var(--bg-surface));
  position: relative;
  overflow: hidden;
}
.scroll-tipi-inner {
  max-width: 1100px; margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}
.scroll-tipi-eyebrow {
  font-family: var(--font-display); font-weight: 600;
  font-size: 11px; letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--t-accent, var(--kb-rose-500));
}
.scroll-tipi-copy h2 {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(28px, 4.4vw, 52px);
  line-height: 1.05; letter-spacing: -0.02em;
  margin: 10px 0 14px;
}
.scroll-tipi-copy h2 em {
  font-style: italic;
  color: var(--t-accent, var(--kb-rose-500));
  font-family: var(--font-script, var(--font-display));
}
.scroll-tipi-copy p {
  font-size: 16px; line-height: 1.65;
  color: var(--fg-2);
  max-width: 420px;
}
.scroll-tipi-stage {
  position: relative;
  aspect-ratio: 1 / 1;
  display: grid; place-items: center;
}
.scroll-tipi-svg { width: 100%; max-width: 380px; }
.scroll-tipi-hint {
  position: absolute; bottom: -8px; left: 50%; transform: translateX(-50%);
  font-family: var(--font-display); font-size: 12px;
  color: var(--fg-3);
  transition: opacity 400ms;
  animation: scroll-hint 2.4s ease-in-out infinite;
}
@keyframes scroll-hint {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%      { transform: translateX(-50%) translateY(4px); }
}
@media (max-width: 760px) {
  .scroll-tipi-inner { grid-template-columns: 1fr; gap: 28px; }
  .scroll-tipi { padding: 60px 18px; }
}

/* ========================================================
   #17 — Confetti
   ======================================================== */
.kb-confetti-layer {
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 200;
  overflow: hidden;
}
.kb-confetti-piece {
  position: fixed;
  display: inline-block;
  text-shadow: 0 0 8px currentColor;
  will-change: transform, opacity;
  animation: kb-confetti 1.5s cubic-bezier(0.22, 0.61, 0.36, 1) forwards;
}
@keyframes kb-confetti {
  0%   { opacity: 0; transform: translate(-50%, -50%) scale(0.2) rotate(0deg); }
  15%  { opacity: 1; }
  100% { opacity: 0;
         transform: translate(calc(-50% + var(--dx, 0)),
                              calc(-50% + var(--dy, 0) + 300px))
                    scale(0.7) rotate(var(--rot, 360deg)); }
}

/* ========================================================
   #21 — Share button
   ======================================================== */
.share-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px;
  background: var(--bg-page);
  border: 1.5px solid var(--border-soft);
  border-radius: 999px;
  font-family: var(--font-display); font-weight: 600;
  font-size: 13px;
  color: var(--fg-1);
  cursor: pointer;
  transition: all var(--dur-fast);
}
.share-btn:hover {
  border-color: var(--t-accent, var(--fg-1));
  transform: translateY(-1px);
}
.share-btn-icon { font-size: 14px; }

/* ========================================================
   #26 — Instagram strip
   ======================================================== */
.insta {
  padding: 80px 22px 70px;
  max-width: 1240px; margin: 0 auto;
}
.insta-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 16px; flex-wrap: wrap;
  margin-bottom: 28px;
}
.insta-eyebrow {
  display: block;
  font-family: var(--font-display); font-weight: 600;
  font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.insta-head h2 {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(28px, 4vw, 44px);
  letter-spacing: -0.02em;
  margin: 6px 0 0;
}
.insta-head h2 em {
  background: linear-gradient(135deg, #DD2A7B, #8134AF, #515BD4);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  font-style: italic;
  font-family: var(--font-script, var(--font-display));
}
.insta-follow {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 10px 18px;
  background: linear-gradient(135deg, #DD2A7B, #8134AF, #515BD4);
  color: #fff !important;
  font-family: var(--font-display); font-weight: 700;
  font-size: 14px;
  text-decoration: none;
  border-radius: 999px;
  transition: transform var(--dur-fast);
}
.insta-follow:hover { transform: translateY(-1px); }
.insta-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 8px;
}
.insta-tile {
  aspect-ratio: 1 / 1;
  background-size: cover; background-position: center;
  border-radius: 12px;
  position: relative;
  overflow: hidden;
  display: block;
}
.insta-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(33,21,56,0.7));
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 10px 12px;
  color: #fff;
  opacity: 0;
  transition: opacity var(--dur-base);
}
.insta-tile:hover .insta-overlay { opacity: 1; }
.insta-heart {
  position: absolute; top: 10px; right: 12px;
  font-size: 16px;
  text-shadow: 0 1px 4px rgba(0,0,0,0.4);
}
.insta-cap {
  font-family: var(--font-display); font-weight: 600;
  font-size: 12px;
}
@media (max-width: 820px) {
  .insta-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 460px) {
  .insta-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ========================================================
   #37 — Seasonal overlay (snow / sun)
   ======================================================== */
.seasonal-snow, .seasonal-sun {
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 55;
  overflow: hidden;
}
.snowflake {
  position: absolute; top: -20px;
  color: rgba(255,255,255,0.85);
  text-shadow: 0 0 6px rgba(255,255,255,0.6);
  animation: snowfall linear infinite;
  will-change: transform;
}
@keyframes snowfall {
  0%   { transform: translateY(-10vh) translateX(0)            rotate(0deg);   opacity: 0; }
  10%  { opacity: 1; }
  100% { transform: translateY(110vh) translateX(var(--drift, 0)) rotate(360deg); opacity: 0.7; }
}
.sunfleck {
  position: absolute; bottom: -20px;
  color: rgba(255, 215, 100, 0.65);
  text-shadow: 0 0 10px rgba(255, 220, 130, 0.8);
  animation: sun-rise linear infinite;
}
@keyframes sun-rise {
  0%   { transform: translateY(0)     scale(0.6); opacity: 0; }
  30%  { opacity: 1; }
  100% { transform: translateY(-120vh) scale(1.2); opacity: 0; }
}

/* ========================================================
   #39 — 3D tipi section
   ======================================================== */
.hero3d {
  padding: 90px 22px;
  background: linear-gradient(180deg, var(--bg-surface), var(--bg-page));
  position: relative;
}
.hero3d-inner {
  max-width: 1100px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 56px; align-items: center;
}
.hero3d-copy h2 {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(28px, 4.4vw, 52px);
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin: 10px 0 14px;
}
.hero3d-copy h2 em {
  font-style: italic;
  color: var(--t-accent, var(--kb-rose-500));
  font-family: var(--font-script, var(--font-display));
}
.hero3d-copy p {
  font-size: 16px; line-height: 1.65;
  color: var(--fg-2);
  max-width: 420px;
}
.hero3d-eyebrow {
  font-family: var(--font-display); font-weight: 600;
  font-size: 11px; letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--t-accent, var(--kb-rose-500));
}
.hero3d-hint {
  font-size: 13px !important;
  color: var(--fg-3) !important;
  margin-top: 16px;
}
.hero3d-canvas {
  width: 100%; aspect-ratio: 1 / 1;
  max-height: 460px;
  border-radius: 22px;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 30%, rgba(228,139,160,0.18), transparent 60%),
    var(--bg-page);
  border: 1.5px solid var(--border-soft);
  cursor: grab;
  position: relative;
  touch-action: pan-y;
}
.hero3d-canvas:active { cursor: grabbing; }
.hero3d-canvas canvas { display: block; }
.hero3d-loading {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 12px;
  color: var(--fg-3);
  font-family: var(--font-display); font-size: 13px;
}
.hero3d-loading-spinner {
  width: 28px; height: 28px;
  border-radius: 999px;
  border: 3px solid var(--border-soft);
  border-top-color: var(--t-accent, var(--kb-rose-500));
  animation: spin 720ms linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
@media (max-width: 760px) {
  .hero3d-inner { grid-template-columns: 1fr; gap: 28px; }
  .hero3d { padding: 60px 18px; }
}

/* ========================================================
   #20 — Bottom-sheet booking modal (mobile)
   ======================================================== */
@media (max-width: 720px) {
  .modal-mask { align-items: flex-end; padding: 0; }
  .modal {
    width: 100%; max-width: 100%;
    border-radius: 22px 22px 0 0;
    max-height: 92vh;
    margin-bottom: 0;
    transform: translateY(100%);
    animation: sheet-up 320ms cubic-bezier(0.22, 0.61, 0.36, 1) forwards;
  }
  .modal::before {
    content: '';
    position: absolute; top: 8px; left: 50%; transform: translateX(-50%);
    width: 40px; height: 4px;
    background: rgba(33,21,56,0.18);
    border-radius: 999px;
  }
}
@keyframes sheet-up {
  to { transform: translateY(0); }
}

.hero3d-fallback {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 8px;
  text-align: center;
  padding: 24px;
  color: var(--fg-2);
  font-family: var(--font-display);
  font-size: 14px;
}
.hero3d-fallback strong { font-size: 15px; color: var(--fg-1); }
.hero3d-fallback .muted { font-family: var(--font-body); font-size: 12.5px; color: var(--fg-3); }


/* ========================================================
   #24 — Lisa AI chatbot (bottom-LEFT to avoid WA bubble)
   ======================================================== */
.lisa-fab {
  position: fixed;
  left: max(22px, env(safe-area-inset-left));
  bottom: calc(22px + env(safe-area-inset-bottom, 0px));
  z-index: 95;
  width: 58px; height: 58px; border-radius: 999px;
  background: linear-gradient(135deg, var(--kb-rose-500), var(--kb-gold-400));
  border: none; padding: 0;
  display: grid; place-items: center;
  cursor: pointer;
  box-shadow: 0 10px 26px rgba(228,139,160,0.45), var(--shadow-md);
  transition: transform var(--dur-base) var(--ease-bounce), background var(--dur-base);
  color: #fff;
  font-size: 22px;
}
.lisa-fab:hover { transform: scale(1.06); }
.lisa-fab:active { transform: scale(0.95); }
.lisa-fab.open {
  background: var(--kb-night-500);
  font-size: 18px; font-weight: 700;
}
.lisa-fab-icon { font-size: 26px; line-height: 1; }
.lisa-fab-pulse {
  position: absolute; inset: 0; border-radius: 999px;
  box-shadow: 0 0 0 0 rgba(228,139,160,0.6);
  animation: lisa-pulse 2.4s ease-in-out infinite;
  pointer-events: none;
}
@keyframes lisa-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(228,139,160,0.55); }
  60%      { box-shadow: 0 0 0 18px rgba(228,139,160,0); }
}

.lisa-panel {
  position: fixed;
  left: max(22px, env(safe-area-inset-left));
  bottom: calc(92px + env(safe-area-inset-bottom, 0px));
  width: 340px; max-width: calc(100vw - 28px);
  height: 480px; max-height: calc(100vh - 140px);
  background: var(--bg-page);
  border-radius: 22px;
  box-shadow: 0 24px 60px rgba(33,21,56,0.25), var(--shadow-lg);
  overflow: hidden;
  z-index: 96;
  display: flex; flex-direction: column;
  animation: lisa-pop 280ms var(--ease-bounce);
  border: 1px solid var(--border-soft);
  transform-origin: bottom left;
}
@keyframes lisa-pop {
  from { opacity: 0; transform: scale(0.85) translateY(8px); }
  to   { opacity: 1; transform: scale(1)    translateY(0); }
}
.lisa-head {
  background: linear-gradient(135deg, var(--kb-rose-500), var(--kb-gold-400));
  padding: 14px 16px;
  display: flex; gap: 12px; align-items: center;
  color: #fff;
  flex: 0 0 auto;
}
.lisa-avatar {
  width: 42px; height: 42px; border-radius: 999px;
  background: #fff;
  color: var(--kb-rose-500);
  font-family: var(--font-display); font-weight: 700;
  font-size: 18px;
  display: grid; place-items: center;
  position: relative;
  box-shadow: inset 0 0 0 2px rgba(255,255,255,0.6);
}
.lisa-status-dot {
  position: absolute; bottom: 2px; right: 2px;
  width: 10px; height: 10px; border-radius: 999px;
  background: #4ADE80;
  border: 2px solid #fff;
}
.lisa-name {
  font-family: var(--font-display); font-weight: 700;
  font-size: 15px; color: #fff;
  display: flex; align-items: center; gap: 6px;
}
.lisa-ai-badge {
  background: rgba(255,255,255,0.22);
  font-size: 9px;
  padding: 2px 6px;
  border-radius: 999px;
  letter-spacing: 0.06em;
}
.lisa-status { font-family: var(--font-body); font-size: 11px; color: rgba(255,255,255,0.9); }
.lisa-body {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 16px;
  background:
    radial-gradient(circle at 80% 10%, rgba(228,139,160,0.06), transparent 50%),
    var(--bg-page);
  display: flex; flex-direction: column; gap: 8px;
}
.lisa-msg {
  max-width: 80%;
  padding: 10px 14px;
  border-radius: 14px;
  font-family: var(--font-body); font-size: 14px; line-height: 1.55;
  animation: lisa-msg-in 240ms var(--ease-out) both;
}
@keyframes lisa-msg-in {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.lisa-msg.theirs {
  background: var(--bg-surface);
  color: var(--fg-1);
  border-bottom-left-radius: 4px;
  align-self: flex-start;
}
.lisa-msg.mine {
  background: var(--kb-rose-500);
  color: #fff;
  border-bottom-right-radius: 4px;
  align-self: flex-end;
}
.lisa-typing {
  display: inline-flex; gap: 4px;
  padding: 12px 14px;
}
.lisa-typing span {
  width: 6px; height: 6px; border-radius: 999px;
  background: var(--fg-3);
  animation: lisa-bounce 1.2s ease-in-out infinite;
}
.lisa-typing span:nth-child(2) { animation-delay: 0.15s; }
.lisa-typing span:nth-child(3) { animation-delay: 0.30s; }
@keyframes lisa-bounce {
  0%, 60%, 100% { transform: translateY(0); opacity: 0.4; }
  30%           { transform: translateY(-4px); opacity: 1; }
}
.lisa-input {
  display: flex; gap: 6px;
  padding: 12px;
  border-top: 1px solid var(--border-soft);
  background: var(--bg-page);
  flex: 0 0 auto;
}
.lisa-input input {
  flex: 1;
  background: var(--bg-surface);
  border: 1.5px solid var(--border-soft);
  border-radius: 999px;
  padding: 10px 14px;
  font-family: var(--font-body); font-size: 14px;
  color: var(--fg-1);
  outline: none;
}
.lisa-input input:focus { border-color: var(--kb-rose-500); }
.lisa-input button {
  width: 38px; height: 38px;
  border-radius: 999px;
  border: none;
  background: var(--kb-rose-500);
  color: #fff;
  font-size: 18px; font-weight: 700;
  cursor: pointer;
  transition: transform var(--dur-fast);
}
.lisa-input button:hover:not(:disabled) { transform: scale(1.08); }
.lisa-input button:disabled { opacity: 0.4; cursor: not-allowed; }
.lisa-foot {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 14px 10px;
  font-size: 10.5px;
  color: var(--fg-3);
  border-top: 1px solid var(--border-soft);
}
.lisa-foot a { color: var(--kb-rose-500); text-decoration: none; font-weight: 600; }

[data-night] .lisa-panel { background: var(--bg-surface); border-color: rgba(255,255,255,0.08); }
[data-night] .lisa-msg.theirs { background: rgba(255,255,255,0.06); color: var(--fg-1); }
[data-night] .lisa-input { background: var(--bg-surface); border-color: rgba(255,255,255,0.08); }
[data-night] .lisa-input input { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.1); }

@media (max-width: 600px) {
  .lisa-fab { left: 14px; bottom: calc(14px + env(safe-area-inset-bottom, 0px)); width: 52px; height: 52px; }
  .lisa-panel { left: 14px; bottom: calc(80px + env(safe-area-inset-bottom, 0px)); width: calc(100vw - 28px); }
}

/* ========================================================
   #38 — Real Instagram embeds layout
   ======================================================== */
.insta-embeds {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  align-items: start;
}
.insta-embed {
  min-width: 0;
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.insta-embed blockquote {
  margin: 0 !important;
}
@media (max-width: 820px) {
  .insta-embeds { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px) {
  .insta-embeds { grid-template-columns: 1fr; }
}


/* ========================================================
   CONTRAST-PASS — overrides voor nieuwe secties
   Zorgt voor leesbare tekst in alle modes (light/dark/themes)
   ======================================================== */

/* ── Scroll-tipi section ── */
[data-night] .scroll-tipi {
  background: linear-gradient(180deg, var(--bg-page), var(--bg-surface));
}
[data-night] .scroll-tipi-copy h2 { color: var(--kb-cream-50); }
[data-night] .scroll-tipi-copy p  { color: rgba(251,247,241,0.78); }
[data-night] .scroll-tipi-eyebrow { color: var(--kb-gold-300); }
[data-night] .scroll-tipi-hint    { color: rgba(251,247,241,0.55); }

/* ── 3D tipi section ── */
[data-night] .hero3d {
  background: linear-gradient(180deg, var(--bg-surface), var(--bg-page));
}
[data-night] .hero3d-copy h2 { color: var(--kb-cream-50); }
[data-night] .hero3d-copy p  { color: rgba(251,247,241,0.78); }
[data-night] .hero3d-eyebrow { color: var(--kb-gold-300); }
[data-night] .hero3d-hint    { color: rgba(251,247,241,0.55) !important; }
[data-night] .hero3d-canvas {
  background:
    radial-gradient(circle at 50% 30%, rgba(228,139,160,0.25), transparent 60%),
    rgba(255,255,255,0.03);
  border-color: rgba(255,255,255,0.10);
}
[data-night] .hero3d-fallback strong { color: var(--kb-cream-50); }
[data-night] .hero3d-fallback .muted { color: rgba(251,247,241,0.55); }
[data-night] .hero3d-loading { color: rgba(251,247,241,0.55); }

/* ── Instagram strip ── */
[data-night] .insta-head h2 { color: var(--kb-cream-50); }
[data-night] .insta-eyebrow { color: rgba(251,247,241,0.55); }
[data-night] .insta-embed { background: var(--bg-surface); }

/* ── Postcode checker text contrast for movie/neon themes ── */
[data-theme="movie"] .pc-input,
[data-theme="neon"]  .pc-input { color: var(--kb-cream-50); }
[data-theme="movie"] .pc-row,
[data-theme="neon"]  .pc-row {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.15);
}
[data-theme="movie"] .pc-input::placeholder,
[data-theme="neon"]  .pc-input::placeholder { color: rgba(255,255,255,0.4); }

/* ── Hero price slider for dark themes ── */
[data-theme="movie"] .hero-slider,
[data-theme="neon"]  .hero-slider,
[data-night]         .hero-slider {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.12);
}
[data-theme="movie"] .hero-slider-eyebrow,
[data-theme="neon"]  .hero-slider-eyebrow,
[data-night]         .hero-slider-eyebrow { color: rgba(251,247,241,0.6); }
[data-theme="movie"] .hero-slider-total,
[data-theme="neon"]  .hero-slider-total,
[data-night]         .hero-slider-total { color: var(--kb-cream-50); }
[data-theme="movie"] .hero-slider-label,
[data-theme="neon"]  .hero-slider-label,
[data-night]         .hero-slider-label { color: rgba(251,247,241,0.78); }
[data-theme="movie"] .hero-seg,
[data-theme="neon"]  .hero-seg,
[data-night]         .hero-seg {
  color: rgba(251,247,241,0.78);
  border-color: rgba(255,255,255,0.18);
}
[data-theme="movie"] .hero-slider-cta,
[data-theme="neon"]  .hero-slider-cta {
  background: var(--kb-gold-400); color: var(--kb-night-500);
}
[data-night] .hero-slider-cta { background: var(--kb-gold-400); color: var(--kb-night-500); }

/* ── Theme tile labels on light themes ── */
.tipi-label { color: var(--kb-night-500); }
[data-theme="beauty"] .tipi-label,
[data-theme="pink"]   .tipi-label,
[data-theme="jungle"] .tipi-label { color: var(--kb-night-500); }

/* ── Share button on dark themes (was invisible) ── */
[data-theme="movie"] .share-btn,
[data-theme="neon"]  .share-btn,
[data-night]         .share-btn {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.18);
  color: var(--kb-cream-50);
}
[data-theme="movie"] .share-btn:hover,
[data-theme="neon"]  .share-btn:hover { border-color: var(--kb-gold-400); }

/* ── Configurator theme tile names in night mode ── */
[data-night] .cfg-theme-tile {
  background: rgba(255,255,255,0.04);
  border-color: rgba(255,255,255,0.10);
}
[data-night] .cfg-theme-tile:hover { border-color: var(--tile-color); }
[data-night] .cfg-theme-tile.active .cfg-theme-name { color: var(--kb-cream-50); }
[data-night] .cfg-theme-name { color: rgba(251,247,241,0.75); }

/* ── Footer link to beheer — clearer ── */
.ftr-admin-link {
  opacity: 0.7;
  transition: opacity 200ms;
}
.ftr-admin-link:hover { opacity: 1; }

/* ── Admin banner text shadow for any color ── */
.admin-banner { text-shadow: 0 1px 2px rgba(0,0,0,0.25); }

/* ── Modal text-vis when in light hero theme ── */
.modal h3, .modal h2 { color: var(--kb-night-500); }
[data-night] .modal { background: var(--bg-surface); }
[data-night] .modal h3, [data-night] .modal h2 { color: var(--kb-cream-50); }
[data-night] .modal label { color: rgba(251,247,241,0.8); }
[data-night] .modal input,
[data-night] .modal select,
[data-night] .modal textarea {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.12);
  color: var(--kb-cream-50);
}
[data-night] .modal input::placeholder,
[data-night] .modal textarea::placeholder { color: rgba(251,247,241,0.4); }
