:root {
  --zee: #0e5a63;
  --zee-donker: #093a41;
  --lagoon: #12b3c4;
  --lagoon-licht: #6fe0e8;
  --goud: #c9a24b;
  --goud-licht: #e8d9ae;
  --koraal: #e8734a;
  --groen: #1a9d6c;
  --amber: #c17c1f;
  --grijs: #6b7280;
  --bg: #faf7f1;
  --kaart: #ffffff;
  --rand: #ece5d6;
  --schaduw: 0 10px 30px -12px rgba(9, 58, 65, .25);
  --schaduw-groot: 0 24px 48px -16px rgba(9, 58, 65, .35);
  --tekst: #1c2a2e;
  --tekst-kop: var(--zee-donker);
  --veld-bg: #ffffff;
}

html[data-theme="dark"] {
  --bg: #0f1a1c;
  --kaart: #16262a;
  --rand: #24373b;
  --grijs: #93a3a5;
  --tekst: #e8ecec;
  --tekst-kop: #f2ede0;
  --veld-bg: #1c2f33;
  --schaduw: 0 10px 30px -12px rgba(0, 0, 0, .5);
  --schaduw-groot: 0 24px 48px -16px rgba(0, 0, 0, .6);
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: "Inter", "Segoe UI", Arial, sans-serif;
  background:
    radial-gradient(1200px 400px at 10% -10%, #fdf6e6 0%, transparent 60%),
    radial-gradient(900px 500px at 100% 0%, #eaf3f1 0%, transparent 55%),
    var(--bg);
  color: var(--tekst);
  transition: background .2s ease, color .2s ease;
}
html[data-theme="dark"] body {
  background: var(--bg);
}
html[data-theme="dark"] header { background: rgba(15, 26, 28, .75); }
html[data-theme="dark"] .zoekbalk { background: rgba(28, 47, 51, .85); }
html[data-theme="dark"] .wizard-paneel { background: linear-gradient(180deg, #1c2f33, #16262a); border-color: var(--rand); }
html[data-theme="dark"] .extra-dienst { background: #2a2110; }
html[data-theme="dark"] .foto-drop { background: #182428; }
html[data-theme="dark"] .foto-drop:hover, html[data-theme="dark"] .foto-drop.actief { background: #2a2110; color: var(--tekst-kop); }
html[data-theme="dark"] .premium-knop:hover { background: #2a2110; }
html[data-theme="dark"] .vergelijk-kolom { background: #182428; }
html[data-theme="dark"] .vergelijk-kolom.premium { background: linear-gradient(180deg, #2a2110, #182428); }

h1, h2, .logo, .prijs { font-family: "Cormorant Garamond", "Segoe UI", serif; }

header {
  background: linear-gradient(120deg, rgba(18, 179, 196, .10), rgba(255, 255, 255, .78) 55%);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--rand);
  padding: 16px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: sticky;
  top: 0;
  z-index: 10;
}

header .logo {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  cursor: pointer;
}
.logo-mark { flex-shrink: 0; }
.logo-tekst {
  font-size: 26px;
  font-weight: 700;
  color: var(--tekst-kop);
  letter-spacing: .02em;
  border-bottom: 2px solid var(--goud);
  padding-bottom: 2px;
}
.logo-tekst span {
  color: var(--grijs);
  font-weight: 400;
  font-size: 12px;
  display: block;
  font-family: "Inter", sans-serif;
  letter-spacing: .04em;
  text-transform: uppercase;
  border: none;
}
header nav a {
  margin-left: 24px;
  text-decoration: none;
  color: #334155;
  font-size: 14px;
  transition: color .2s ease;
}
header nav a:hover { color: var(--goud); }

header nav { display: flex; align-items: center; gap: 28px; }

/* Smalle utility-balk boven de hoofdheader: taal + account-links, weg bij de hoofdnavigatie */
.topbar {
  background: linear-gradient(90deg, var(--zee-donker), var(--zee) 70%, var(--lagoon));
  padding: 7px 0;
}
.topbar-inner {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.topbar-links { display: flex; gap: 18px; }
.topbar-links a {
  color: rgba(255,255,255,.82);
  text-decoration: none;
  font-size: 12px;
  font-family: "Inter", sans-serif;
  letter-spacing: .02em;
  transition: color .15s ease;
}
.topbar-links a:hover { color: var(--goud-licht); }

.taal-switcher {
  display: inline-flex;
  border: 1px solid rgba(255,255,255,.25);
  border-radius: 999px;
  padding: 2px;
}
.taal-knop {
  border: none;
  background: transparent;
  padding: 3px 9px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .03em;
  color: rgba(255,255,255,.7);
  cursor: pointer;
  font-family: "Inter", sans-serif;
  transition: all .15s ease;
}
.taal-knop:hover { color: #fff; }
.taal-knop.actief {
  background: var(--goud);
  color: var(--zee-donker);
}

.thema-switcher { display: inline-flex; gap: 8px; margin-top: 10px; }
.thema-knop {
  border: 1px solid var(--rand);
  background: var(--veld-bg);
  color: var(--tekst);
  padding: 10px 18px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  font-family: "Inter", sans-serif;
  transition: all .15s ease;
}
.thema-knop.actief {
  background: linear-gradient(135deg, var(--zee), var(--zee-donker));
  color: #fff;
  border-color: transparent;
}

.stats-rij { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-top: 6px; }
.stat-kaart {
  background: var(--veld-bg);
  border: 1px solid var(--rand);
  border-radius: 14px;
  padding: 16px;
  text-align: center;
  width: 100%;
  cursor: pointer;
  font-family: "Inter", sans-serif;
  transition: transform .15s ease, box-shadow .15s ease;
}
.stat-kaart:hover { transform: translateY(-2px); box-shadow: var(--schaduw); border-color: var(--goud); }
.stat-getal { display: block; font-size: 28px; font-weight: 700; color: var(--goud); font-family: "Cormorant Garamond", serif; }
.stat-kaart span:last-child { font-size: 12px; color: var(--grijs); font-family: "Inter", sans-serif; }
.stats-sub { font-size: 15px; color: var(--tekst-kop); margin: 20px 0 4px; font-family: "Inter", sans-serif; }

.koop-huur-toggle {
  display: inline-flex;
  gap: 4px;
  background: #f1efe8;
  padding: 3px;
  border-radius: 10px;
}
.koop-huur-toggle .chip {
  border: none;
  padding: 8px 16px;
  border-radius: 8px;
  margin: 0;
}
.koop-huur-toggle .chip.actief {
  background: linear-gradient(135deg, var(--zee), var(--zee-donker));
  color: #fff;
  border-color: transparent;
  box-shadow: none;
}

.gebied-kaart {
  height: 200px;
  border-radius: 14px;
  margin-top: 10px;
  overflow: hidden;
  box-shadow: var(--schaduw);
  border: 1px solid var(--rand);
}

.hero {
  padding: 44px 32px 12px;
  max-width: 1140px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 40px;
  align-items: center;
}
.hero h1 { font-size: 40px; font-weight: 700; margin-bottom: 6px; color: var(--tekst-kop); }
.hero p { color: var(--grijs); margin-top: 0; font-size: 15px; }

.hero-scene {
  position: relative;
  height: 360px;
  border-radius: 28px;
  overflow: hidden;
  background: linear-gradient(180deg, #ffe9b8 0%, #ffd08a 20%, var(--lagoon) 46%, var(--zee-donker) 100%);
  box-shadow: var(--schaduw-groot);
}
.hero-zon {
  position: absolute;
  top: 30px;
  right: 50px;
  width: 70px;
  height: 70px;
  border-radius: 50%;
  background: radial-gradient(circle, #fff6dd 0%, #ffd35c 55%, rgba(255, 211, 92, 0) 75%);
  box-shadow: 0 0 60px 22px rgba(255, 211, 92, .5);
}
.hero-palm {
  position: absolute;
  bottom: 6px;
  left: 24px;
  width: 90px;
  height: 160px;
  opacity: .92;
}
.hero-golven {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 100px;
  background: repeating-linear-gradient(115deg, rgba(255, 255, 255, .18) 0 6px, transparent 6px 26px);
}
.hero-scene-label {
  position: absolute;
  bottom: 16px;
  right: 20px;
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  font-family: "Inter", sans-serif;
  background: rgba(9, 58, 65, .35);
  padding: 4px 12px;
  border-radius: 999px;
  backdrop-filter: blur(3px);
}
.personaliseer-link {
  display: inline-block;
  margin-top: 10px;
  color: var(--goud);
  font-weight: 600;
  font-size: 14px;
  text-decoration: none;
  font-family: "Inter", sans-serif;
}
.personaliseer-link:hover { text-decoration: underline; }

.zoekbalk {
  display: flex;
  gap: 10px;
  background: rgba(255, 255, 255, .85);
  backdrop-filter: blur(6px);
  border: 1px solid var(--rand);
  padding: 12px;
  border-radius: 16px;
  margin-top: 20px;
  box-shadow: var(--schaduw);
}
.zoekbalk input, .zoekbalk select {
  flex: 1;
  padding: 10px 12px;
  border: 1px solid var(--rand);
  border-radius: 10px;
  font-size: 14px;
  background: var(--veld-bg);
}
.zoekbalk button {
  background: linear-gradient(135deg, var(--zee), var(--zee-donker));
  color: white;
  border: none;
  padding: 10px 24px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: .02em;
  cursor: pointer;
  box-shadow: 0 8px 20px -6px rgba(9, 58, 65, .55);
  transition: transform .15s ease, box-shadow .15s ease;
}
.zoekbalk button:hover { transform: translateY(-2px); box-shadow: 0 12px 26px -6px rgba(9, 58, 65, .6); }

.grid {
  max-width: 1140px;
  margin: 28px auto;
  padding: 0 32px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 24px;
  perspective: 1000px;
}

.kaart {
  background: var(--kaart);
  border: 1px solid var(--rand);
  border-radius: 18px;
  overflow: hidden;
  display: block;
  text-decoration: none;
  color: inherit;
  box-shadow: var(--schaduw);
  transition: transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s ease;
  transform-style: preserve-3d;
}
.kaart:hover {
  transform: translateY(-8px) rotateX(2deg) rotateY(-2deg) scale(1.015);
  box-shadow: var(--schaduw-groot);
}

.kaart .foto {
  height: 180px;
  position: relative;
  background:
    linear-gradient(135deg, rgba(255,255,255,.35) 0%, rgba(255,255,255,0) 40%),
    linear-gradient(135deg, var(--zee-donker) 0%, var(--lagoon) 55%, var(--goud-licht) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,.9);
  font-size: 13px;
  overflow: hidden;
}
.kaart .foto::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(115deg, transparent 40%, rgba(255,255,255,.25) 50%, transparent 60%);
}

.hart-knop {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: none;
  background: rgba(255,255,255,.9);
  font-size: 17px;
  line-height: 1;
  color: var(--koraal);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 3;
  transition: transform .15s ease;
}
.hart-knop:hover { transform: scale(1.12); }
.hart-knop.actief { background: #fff; }
.detail-hero .hart-knop { top: 16px; right: 16px; width: 40px; height: 40px; font-size: 20px; }

.kaart .inhoud { padding: 18px; }
.kaart .prijs { font-size: 24px; font-weight: 700; color: var(--tekst-kop); }
.kaart .adres { color: var(--grijs); font-size: 13px; margin-bottom: 10px; font-family: "Inter", sans-serif; }

.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 999px;
  margin-right: 6px;
  margin-bottom: 6px;
  border: 1px solid transparent;
  font-family: "Inter", sans-serif;
}
.badge.groen { background: #e4f6ee; color: #0f7a51; border-color: #cdeddd; }
.badge.amber { background: #fbf1e0; color: var(--amber); border-color: #f3e2bd; }
.badge.blauw { background: #e7f1f2; color: var(--zee); border-color: #d3e7e9; }
.badge.goud {
  background: linear-gradient(135deg, #fff7e6, #f7e6b8);
  color: #8a6d1c;
  border-color: var(--goud);
}

.meta-rij {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  color: var(--grijs);
  margin-top: 12px;
  border-top: 1px dashed var(--rand);
  padding-top: 10px;
  font-family: "Inter", sans-serif;
}

.disclaimer {
  max-width: 1140px;
  margin: 30px auto;
  padding: 14px 32px;
  color: var(--grijs);
  font-size: 12px;
}

/* Detailpagina */
.detail-wrap {
  max-width: 940px;
  margin: 32px auto;
  padding: 0 32px;
}
.detail-hero {
  height: 320px;
  border-radius: 20px;
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(255,255,255,.3) 0%, rgba(255,255,255,0) 40%),
    linear-gradient(135deg, var(--zee-donker) 0%, var(--lagoon) 55%, var(--goud-licht) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,.92);
  margin-bottom: 24px;
  box-shadow: var(--schaduw-groot);
}
.detail-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(115deg, transparent 40%, rgba(255,255,255,.25) 50%, transparent 60%);
}

.detail-titel { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; gap: 12px; }
.detail-titel h1 { margin: 0 0 6px; font-size: 30px; color: var(--tekst-kop); }
.detail-titel .prijs {
  font-size: 30px;
  font-weight: 700;
  color: var(--tekst-kop);
  border-bottom: 3px solid var(--goud);
  padding-bottom: 2px;
}

.paneel {
  background: var(--kaart);
  border: 1px solid var(--rand);
  border-radius: 18px;
  padding: 22px 24px;
  margin-top: 20px;
  box-shadow: var(--schaduw);
  transition: box-shadow .2s ease, transform .2s ease;
}
.paneel:hover { box-shadow: var(--schaduw-groot); transform: translateY(-2px); }
.paneel h2 {
  font-size: 13px;
  margin: 0 0 14px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--goud);
  font-family: "Inter", sans-serif;
  font-weight: 700;
}

.check-rij {
  display: flex;
  justify-content: space-between;
  padding: 10px 0;
  border-bottom: 1px dashed var(--rand);
  font-size: 14px;
  font-family: "Inter", sans-serif;
}
.check-rij:last-child { border-bottom: none; }
.check-rij .status-ok { color: var(--groen); font-weight: 600; }
.check-rij .status-let-op { color: var(--amber); font-weight: 600; }

.prijs-vergelijk {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 10px;
}
.prijs-balk {
  flex: 1;
  height: 12px;
  background: linear-gradient(90deg, #e4f6ee, var(--goud-licht), #fde3d3);
  border-radius: 8px;
  position: relative;
  box-shadow: inset 0 1px 3px rgba(0,0,0,.08);
}
.prijs-balk .marker {
  position: absolute;
  top: -5px;
  width: 5px;
  height: 22px;
  background: var(--zee-donker);
  border-radius: 3px;
  box-shadow: 0 0 0 4px rgba(9,58,65,.15), 0 2px 6px rgba(9,58,65,.4);
}

.footnote { color: var(--grijs); font-size: 12px; margin-top: 6px; font-family: "Inter", sans-serif; }

/* Actieknoppen op detailpagina: gratis reageren + premium rapport */
.actie-rij { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 18px; }
.actie-rij .wizard-cta { background: linear-gradient(135deg, var(--zee), var(--zee-donker)); box-shadow: 0 10px 24px -8px rgba(9,58,65,.5); }
.premium-knop {
  background: var(--veld-bg);
  border: 1.5px dashed var(--goud);
  color: #8a6d1c;
  padding: 12px 22px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  font-family: "Inter", sans-serif;
}
.premium-knop:hover { background: #fff7e6; }

/* Login-pagina's (klant + makelaar) */
.login-wrap {
  max-width: 980px;
  margin: 40px auto;
  padding: 0 32px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  align-items: start;
}
.login-kaart, .vergelijk-kaart {
  background: var(--kaart);
  border: 1px solid var(--rand);
  border-radius: 18px;
  padding: 28px 30px;
  box-shadow: var(--schaduw);
}
.login-kaart h1 { font-size: 28px; margin: 6px 0 4px; color: var(--tekst-kop); }
.login-kaart form { margin-top: 18px; }
.login-kaart .veld { margin-bottom: 14px; }
.login-kaart input {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--rand);
  border-radius: 10px;
  font-size: 14px;
}
.login-knop { width: 100%; margin-top: 6px; }
.mp-cta {
  display: block;
  text-align: center;
  text-decoration: none;
  background: linear-gradient(135deg, var(--goud), #a9822f);
  box-shadow: 0 10px 24px -8px rgba(169, 130, 47, .6);
}
.login-nieuw { margin-top: 16px; text-align: center; }
.login-nieuw a { color: var(--goud); font-weight: 600; text-decoration: none; margin-left: 4px; }

.login-secundair {
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px dashed var(--rand);
  display: flex;
  justify-content: center;
  gap: 20px;
}
.login-secundair a { color: var(--grijs); font-size: 13px; text-decoration: none; font-family: "Inter", sans-serif; }
.login-secundair a:hover { color: var(--goud); }

.vergelijk-kaart h2 { font-size: 22px; color: var(--tekst-kop); margin: 0 0 16px; }
.vergelijk-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.vergelijk-kolom { padding: 16px; border-radius: 14px; background: #f8faf9; border: 1px solid var(--rand); }
.vergelijk-kolom.premium { background: linear-gradient(180deg, #fff9ec, #fff); border-color: var(--goud); }
.vergelijk-kop { font-weight: 700; font-size: 13px; text-transform: uppercase; letter-spacing: .05em; margin-bottom: 10px; font-family: "Inter", sans-serif; }
.vergelijk-kop.gratis { color: var(--groen); }
.vergelijk-kop.premium { color: var(--goud); }
.vergelijk-kolom ul { list-style: none; padding: 0; margin: 0; font-size: 13px; font-family: "Inter", sans-serif; }
.vergelijk-kolom li { padding: 6px 0; }

.extra-dienst {
  margin-top: 18px;
  padding: 14px 16px;
  border: 1px dashed var(--goud);
  border-radius: 12px;
  background: #fffdf5;
}
.extra-dienst p { margin: 8px 0 0; font-size: 14px; font-family: "Inter", sans-serif; color: #1c2a2e; font-weight: 600; }
.extra-dienst .footnote { font-weight: 400; }

/* Snel-plaatsen flow (verhuurders/eigenaren) */
.snel-wrap { max-width: 640px; margin: 40px auto; padding: 0 32px; }
.snel-wrap h1 { font-size: 30px; color: var(--tekst-kop); margin: 6px 0 4px; }
.snel-wrap.infopagina { max-width: 760px; }
.snel-wrap.infopagina > p { color: var(--grijs); font-size: 15px; margin-top: 10px; }

.info-lijst { list-style: none; padding: 0; margin: 0; }
.info-lijst li {
  padding: 10px 0;
  border-bottom: 1px dashed var(--rand);
  font-size: 14px;
  font-family: "Inter", sans-serif;
  line-height: 1.5;
}
.info-lijst li:last-child { border-bottom: none; }

.stappen-lijst { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.snel-stap-mini { display: flex; align-items: flex-start; gap: 12px; }
.snel-stap-mini .snel-nummer { position: static; flex-shrink: 0; }
.snel-stap-mini p { margin: 0; font-size: 14px; font-family: "Inter", sans-serif; padding-top: 3px; }

.pijler-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 8px; }
.pijler { background: var(--veld-bg); border: 1px solid var(--rand); border-radius: 14px; padding: 18px; }
.pijler-icoon { font-size: 26px; }
.pijler h3 { font-size: 16px; color: var(--tekst-kop); margin: 8px 0 6px; font-family: "Inter", sans-serif; }
.pijler p { font-size: 13px; color: var(--grijs); margin: 0; font-family: "Inter", sans-serif; }
.pijler-link { text-decoration: none; display: block; transition: transform .15s ease, box-shadow .15s ease; }
.pijler-link:hover { transform: translateY(-3px); box-shadow: var(--schaduw); border-color: var(--goud); }

.hero-eyebrow {
  display: inline-block;
  background: linear-gradient(135deg, #fff7e6, #f7e6b8);
  color: #8a6d1c;
  border: 1px solid var(--goud);
  padding: 5px 14px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .02em;
  font-family: "Inter", sans-serif;
  margin-bottom: 10px;
}

.highlights-grid {
  grid-template-columns: repeat(4, 1fr);
  max-width: 1140px;
  margin: 24px auto 0;
  padding: 0 32px;
}

.cta-sectie {
  max-width: 1140px;
  margin: 40px auto;
  padding: 40px 32px;
  text-align: center;
  background: linear-gradient(135deg, var(--zee), var(--zee-donker));
  border-radius: 24px;
  color: #fff;
}
.cta-sectie h2 { font-size: 30px; margin: 0 0 8px; color: #fff; }
.cta-sectie p { font-size: 15px; color: rgba(255,255,255,.85); margin: 0 0 20px; }
.cta-knop {
  display: inline-block;
  width: auto;
  background: linear-gradient(135deg, var(--goud), #a9822f);
  box-shadow: 0 10px 24px -8px rgba(0,0,0,.4);
}
.snel-stap, .snel-resultaat {
  position: relative;
  padding-left: 54px;
  margin-top: 22px;
}
.snel-nummer {
  position: absolute;
  left: 20px;
  top: 22px;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--zee), var(--zee-donker));
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 14px;
}
.snel-nummer.status-ok { background: linear-gradient(135deg, var(--groen), #0f7a51); }
.foto-drop {
  border: 2px dashed var(--rand);
  border-radius: 12px;
  padding: 26px 16px;
  text-align: center;
  color: var(--grijs);
  font-size: 13px;
  font-family: "Inter", sans-serif;
  cursor: pointer;
  transition: all .15s ease;
  background: #fbfaf7;
}
.foto-drop:hover, .foto-drop.actief { border-color: var(--goud); background: #fff9ec; color: var(--zee-donker); }

.snel-knop { margin-top: 8px; width: 100%; }
.snel-resultaat h2 { font-size: 20px; color: var(--groen); margin: 0 0 6px; }
.snel-resultaat.verborgen, .snel-stap.verborgen { display: none; }

/* Wensen-wizard (intake nieuwe bezoekers) */
.overlay {
  position: fixed;
  inset: 0;
  background: rgba(9, 58, 65, .45);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  z-index: 100;
}
.overlay.verborgen { display: none; }

.wizard-paneel {
  position: relative;
  background: linear-gradient(180deg, #fffdf8, #ffffff);
  border-radius: 22px;
  padding: 32px 36px;
  max-width: 620px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: var(--schaduw-groot);
  border: 1px solid var(--goud-licht);
}

.wizard-sluit {
  position: absolute;
  top: 16px;
  right: 18px;
  border: none;
  background: transparent;
  font-size: 22px;
  line-height: 1;
  color: var(--grijs);
  cursor: pointer;
}
.wizard-sluit:hover { color: var(--tekst-kop); }

.wizard-eyebrow {
  text-transform: uppercase;
  letter-spacing: .1em;
  font-size: 11px;
  color: var(--goud);
  font-weight: 700;
  font-family: "Inter", sans-serif;
}
.wizard-kop h2 { margin: 6px 0 4px; font-size: 28px; color: var(--tekst-kop); }

.wizard-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-top: 20px;
}
.veld-breed { grid-column: 1 / -1; }
.veld label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: #334155;
  margin-bottom: 6px;
  font-family: "Inter", sans-serif;
}
.veld select, .veld input, .veld textarea {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--rand);
  border-radius: 10px;
  font-size: 14px;
  background: var(--veld-bg);
  color: var(--tekst);
  font-family: "Inter", sans-serif;
}
.veld textarea { resize: vertical; }

.chip-groep { display: flex; flex-wrap: wrap; gap: 8px; }
.chip {
  border: 1px solid var(--rand);
  background: var(--veld-bg);
  color: var(--tekst);
  padding: 7px 14px;
  border-radius: 999px;
  font-size: 13px;
  font-family: "Inter", sans-serif;
  cursor: pointer;
  transition: all .15s ease;
}
.chip:hover { border-color: var(--goud); }
.chip.actief {
  background: linear-gradient(135deg, var(--zee), var(--zee-donker));
  border-color: var(--zee-donker);
  color: #fff;
  box-shadow: 0 6px 16px -6px rgba(9,58,65,.5);
}

.wizard-acties {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 26px;
  gap: 12px;
  flex-wrap: wrap;
}
.wizard-overslaan {
  color: var(--grijs);
  font-size: 13px;
  text-decoration: underline;
}
.wizard-cta {
  background: linear-gradient(135deg, var(--goud), #a9822f);
  color: #fff;
  border: none;
  padding: 12px 26px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 10px 24px -8px rgba(169, 130, 47, .6);
  transition: transform .15s ease;
}
.wizard-cta:hover { transform: translateY(-2px); }

@media (max-width: 640px) {
  .wizard-grid { grid-template-columns: 1fr; }
  .wizard-paneel { padding: 24px 20px; }
  .stappen-lijst { grid-template-columns: 1fr; }
  .pijler-grid { grid-template-columns: 1fr; }
  .highlights-grid { padding: 0 16px; }
  .cta-sectie { padding: 32px 20px; margin: 32px 16px; }
  .cta-sectie h2 { font-size: 24px; }
  .snel-wrap { padding: 0 20px; }
  header { flex-direction: column; align-items: flex-start; gap: 8px; padding: 14px 20px; }
  header nav { display: flex; flex-wrap: wrap; }
  header nav a { margin-left: 0; margin-right: 16px; }
  .hero { grid-template-columns: 1fr; gap: 20px; }
  .hero-scene { height: 200px; order: -1; }
  .hero h1 { font-size: 28px; }
  .zoekbalk { flex-direction: column; }
  .zoekbalk button { width: 100%; }
  .grid { grid-template-columns: 1fr; padding: 0 16px; }
  .hero { padding: 24px 16px 8px; }
  .detail-wrap { padding: 0 16px; }
  .detail-titel { flex-direction: column; }
  .detail-titel .prijs { font-size: 24px; }
  .detail-hero { height: 200px; }
  .kaart:hover { transform: translateY(-4px) scale(1.01); }
  .taal-switcher { margin-left: 0; margin-top: 4px; }
  .gebied-kaart { height: 160px; }
  .stats-rij { grid-template-columns: 1fr; }
  .topbar-inner { flex-direction: column; align-items: flex-start; gap: 6px; padding: 0 20px; }
  .login-wrap { grid-template-columns: 1fr; padding: 0 20px; }
  .vergelijk-grid { grid-template-columns: 1fr; }
}
