/* Thuisscan — rustige typografie, één accentkleur (#2a6b5e = dutch-green). */
:root {
  --ink: #1a1a1a;
  --muted: #6b6b6b;
  --line: #e4e4e4;
  --bg: #fafaf7;
  --card: #ffffff;
  --accent: #2a6b5e;
  --accent-soft: #e8f1ef;
  --strong: #1d7a56;   /* sterker dan gemiddelde */
  --weak: #a14a3a;     /* aandachtspunt */
  --neutral: #8a8a8a;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Inter", "Helvetica Neue", sans-serif;
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  line-height: 1.5;
}
/* Respecteer iPhone notch / dynamic island.
   NIET overflow-x: hidden op html/body zetten — dat maakt overflow-y
   impliciet 'auto' en knipt absolute-positioned dropdowns (zoals de
   suggesties-lijst onder de zoekbalk) visueel af. Horizontale overflow
   voorkomen we op de specifieke containers die breed kunnen worden
   (iframes in .map-pane hebben al width:100%, en alle .card's zijn
   max-width begrensd). */
body {
  padding-left: env(safe-area-inset-left);
  padding-right: env(safe-area-inset-right);
}

/* Hero */
.hero {
  max-width: 720px;
  margin: 0 auto;
  padding: 4rem 1.5rem 2rem;
  text-align: center;
}

.hero h1 {
  font-size: 2.5rem;
  margin: 0 0 0.25rem;
  letter-spacing: -0.02em;
  font-weight: 700;
}

.subtitle {
  color: var(--muted);
  font-size: 1.1rem;
  margin: 0 0 2rem;
}

/* Search */
.search {
  position: relative;
  max-width: 520px;
  margin: 0 auto;
}

.search input {
  width: 100%;
  padding: 0.9rem 1.1rem;
  font-size: 1.05rem;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  outline: none;
  transition: border-color 0.15s;
}

.search input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

#suggestions {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 10px;
  margin-top: 4px;
  list-style: none;
  padding: 4px 0;
  max-height: 260px;
  overflow-y: auto;
  z-index: 10;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
}

#suggestions li {
  padding: 0.6rem 1rem;
  cursor: pointer;
  font-size: 0.95rem;
}

#suggestions li:hover,
#suggestions li[aria-selected="true"] {
  background: var(--accent-soft);
}

/* Main result */
main {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 1.5rem 6rem;
}

.section-address {
  margin: 2rem 0 1.5rem;
}

.section-address h2 {
  font-size: 1.6rem;
  margin: 0;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.section-address .muted {
  margin: 0.25rem 0 0;
  font-size: 0.9rem;
}

/* Cards */
.card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 1.4rem 1.5rem;
  margin: 0 0 1rem;
}

.card h3 {
  font-size: 1.05rem;
  font-weight: 600;
  margin: 0 0 1rem;
  color: var(--ink);
  letter-spacing: 0.02em;
}

.pending-card h3 { color: var(--muted); }
.pending-card p { color: var(--muted); margin: 0; font-size: 0.9rem; }

.grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem 1.5rem;
}

.grid-2 .label {
  display: block;
  font-size: 0.8rem;
  color: var(--muted);
  margin-bottom: 0.1rem;
}

.grid-2 strong {
  font-size: 1.4rem;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.pending { color: var(--muted); font-weight: 400; font-size: 1rem; }
.small-strong { font-size: 0.95rem !important; font-weight: 500 !important; color: var(--muted); }

/* Energielabel-badge — groen A..G rood */
.label-badge {
  display: inline-block;
  padding: 0.2rem 0.8rem;
  border-radius: 6px;
  color: #fff;
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.03em;
}
.label-Appppp, .label-Apppp, .label-Appp { background: #0a8a3f; }
.label-App { background: #2ba657; }
.label-Ap  { background: #5cc273; }
.label-A   { background: #88c947; }
.label-B   { background: #c3d82e; }
.label-C   { background: #ffcc00; }
.label-D   { background: #ff9500; }
.label-E   { background: #f06e1e; }
.label-F   { background: #d93a2a; }
.label-G   { background: #a22020; }

/* Chips (↑ sterk / → gemiddeld / ↓ aandachtspunt) */
.chip {
  display: inline-block;
  margin: 0.4rem 0 0;
  padding: 0.15rem 0.6rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 500;
}
.chip-good    { background: #e4f4eb; color: var(--strong); }
.chip-neutral { background: #f3f3f0; color: var(--neutral); }
.chip-warn    { background: #fbe8e1; color: var(--weak); }

/* WOZ-trend mini */
.trend {
  margin: 0.3rem 0 0;
  font-size: 0.8rem;
  color: var(--muted);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
}
.trend-chip {
  display: inline-block;
  padding: 0.1rem 0.5rem;
  border-radius: 999px;
  font-weight: 500;
  font-size: 0.75rem;
}
.trend-good    { background: #e4f4eb; color: var(--strong); }
.trend-neutral { background: #f3f3f0; color: var(--neutral); }
.trend-warn    { background: #fbe8e1; color: var(--weak); }
.spark { font-variant-numeric: tabular-nums; font-size: 0.72rem; }

/* Eigendomsverhouding — stacked bar (koop / sociale huur / particulier) */
.eigendom .eig-bar {
  display: flex;
  width: 100%;
  height: 16px;
  border-radius: 8px;
  overflow: hidden;
  margin: 0.6rem 0 0.5rem;
  background: var(--line);
}
.eig-seg {
  display: block;
  height: 100%;
  transition: flex 0.4s ease;
}
.eig-koop { background: var(--strong); }          /* groen: stabiel eigendom */
.eig-soc  { background: #4a7fb5; }                /* blauw: corporatie */
.eig-par  { background: #d9a441; }                /* oker: particulier */

.eig-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem 1.2rem;
  font-size: 0.82rem;
  color: var(--muted);
  margin-bottom: 0.4rem;
}
.eig-leg {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}
.eig-leg strong {
  font-weight: 600;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  font-size: 0.85rem;
}
.eig-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  display: inline-block;
}
.eig-dot.eig-koop { background: var(--strong); }
.eig-dot.eig-soc  { background: #4a7fb5; }
.eig-dot.eig-par  { background: #d9a441; }

/* Leeftijdsprofiel — hergebruikt eig-bar/eig-seg/eig-dot, alleen kleuren per klasse.
   Warm oranje voor kinderen, groen voor werkzame leeftijd, paarsblauw voor 65+. */
.eig-seg.leef-jong   { background: #e8935c; }
.eig-seg.leef-midden { background: var(--strong); }
.eig-seg.leef-oud    { background: #7b6aa8; }
.eig-dot.leef-jong   { background: #e8935c; }
.eig-dot.leef-midden { background: var(--strong); }
.eig-dot.leef-oud    { background: #7b6aa8; }

@media (max-width: 560px) {
  .eig-legend { gap: 0.5rem 0.9rem; font-size: 0.78rem; }
}

/* Verkiezing TK2023 */
.field-fullwidth { grid-column: 1 / -1; }
.verkiezing-list {
  list-style: none;
  padding: 0;
  margin: 0.3rem 0 0;
}
.verkiezing-list li {
  padding: 0.35rem 0;
  border-top: 1px solid var(--line);
  display: flex;
  gap: 0.6rem;
  align-items: center;
  font-size: 0.95rem;
}
.verkiezing-list li:first-child { border-top: none; }
.verkiezing-list .gem { font-variant-numeric: tabular-nums; color: var(--ink); }
.verkiezing-list .nl { color: var(--muted); font-size: 0.8rem; }

.prov {
  margin: 1rem 0 0;
  padding-top: 0.8rem;
  border-top: 1px solid var(--line);
  font-size: 0.78rem;
  color: var(--muted);
}

.muted { color: var(--muted); }
.small { font-size: 0.85rem; }

/* Kaart (MapLibre) + tabs voor Street View / Satelliet / 3D */
.mapcard {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
  margin: 0 0 1rem;
}
.map-tabs {
  display: flex;
  border-bottom: 1px solid var(--line);
  background: var(--bg);
}
.map-tab {
  flex: 1;
  padding: 0.7rem 0.6rem;
  background: transparent;
  color: var(--muted);
  border: none;
  border-right: 1px solid var(--line);
  font-size: 0.85rem;
  cursor: pointer;
  transition: all 0.15s;
  text-decoration: none;
  text-align: center;
  font-family: inherit;
}
.map-tab:last-child { border-right: none; }
.map-tab:hover { background: var(--accent-soft); color: var(--ink); }
.map-tab.active {
  background: var(--card);
  color: var(--ink);
  font-weight: 600;
  border-bottom: 2px solid var(--accent);
  margin-bottom: -1px;
}
.map-tab-ext { color: var(--muted); font-size: 0.78rem; }

.map-viewport {
  position: relative;
  height: 340px;
  background: #e9e6dc;
}
.map-pane {
  position: absolute; inset: 0;
  display: none;
  width: 100%;
  height: 100%;
}
.map-pane.active { display: block; }
.map-pane iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}
#map { width: 100%; height: 100%; }

.map-fallback {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  padding: 2rem;
  text-align: center;
  color: var(--muted);
  font-size: 0.9rem;
}
.map-btn {
  padding: 0.55rem 1.1rem;
  background: var(--card);
  color: var(--ink);
  border: 1px solid var(--line);
  border-radius: 8px;
  font-size: 0.85rem;
  text-decoration: none;
  transition: background 0.15s;
}
.map-btn:hover { background: var(--accent-soft); border-color: var(--accent); }

/* Sociale betekenis-laag: 3 vragen-kaarten */
.vragen {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.8rem;
  margin: 0 0 1.5rem;
}
.vraag-card {
  background: var(--card);
  border: 1px solid var(--line);
  border-left: 4px solid var(--neutral);
  border-radius: 12px;
  padding: 1rem 1.2rem;
}
.vraag-good    { border-left-color: var(--strong); }
.vraag-neutral { border-left-color: var(--neutral); }
.vraag-warn    { border-left-color: var(--weak); }
.vraag-mixed   { border-left-color: #d9a441; }
.vraag-header {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-bottom: 0.3rem;
}
.vraag-icoon { font-size: 1.4rem; }
.vraag-title {
  flex: 1;
  margin: 0;
  font-size: 1rem;
  font-weight: 600;
}
.vraag-badge {
  font-size: 0.72rem;
  padding: 0.15rem 0.55rem;
  border-radius: 999px;
  background: var(--bg);
  color: var(--muted);
}
.vraag-good .vraag-badge    { background: #e4f4eb; color: var(--strong); }
.vraag-warn .vraag-badge    { background: #fbe8e1; color: var(--weak); }
.vraag-mixed .vraag-badge   { background: #fdf5e6; color: #a06b15; }

.vraag-sam {
  margin: 0 0 0.6rem;
  font-size: 0.9rem;
  line-height: 1.45;
  color: var(--ink);
  opacity: 0.85;
}
.vraag-cats {
  margin-top: 0.8rem;
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
}
/* Elke categorie = icoon + naam + label rechts, balk eronder, samenvatting daaronder */
.cat {
  background: transparent;
  border-radius: 6px;
  cursor: pointer;
}
.cat summary {
  list-style: none;
  display: block;
  padding: 0;
}
.cat summary::-webkit-details-marker { display: none; }

.cat-row {
  display: grid;
  grid-template-columns: 22px 1fr auto;
  gap: 0.6rem;
  align-items: baseline;
  margin-bottom: 0.3rem;
}
.cat-icon { font-size: 1rem; }
.cat-naam {
  font-weight: 600;
  color: var(--ink);
  font-size: 0.92rem;
}
.cat-label {
  font-size: 0.8rem;
  font-weight: 500;
  padding: 0.1rem 0.55rem;
  border-radius: 999px;
  background: var(--bg);
  color: var(--muted);
}
.cat-good    .cat-label { background: #e4f4eb; color: var(--strong); }
.cat-warn    .cat-label { background: #fbe8e1; color: var(--weak); }
.cat-neutral .cat-label { background: #f0f0ec; color: var(--neutral); }

.cat-bar-row {
  display: grid;
  grid-template-columns: 1fr 40px;
  gap: 0.6rem;
  align-items: center;
  margin: 0 0 0.35rem 1.6rem;
}
.cat-bar {
  position: relative;
  height: 8px;
  background: #f1f1ed;
  border-radius: 4px;
  overflow: hidden;
}
.cat-bar-fill {
  position: absolute; inset: 0 auto 0 0;
  border-radius: 4px;
  transition: width 0.4s ease;
}
.cat-score {
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  color: var(--ink);
  font-size: 0.85rem;
}
.cat-score-max { color: var(--muted); font-weight: 400; font-size: 0.75rem; }

.cat-sam {
  margin: 0 0 0 1.6rem;
  font-size: 0.82rem;
  color: var(--muted);
  line-height: 1.4;
}

.vraag-factoren {
  list-style: none;
  padding: 0.7rem 0.8rem 0.2rem 1.6rem;
  margin: 0.6rem 0 0;
  background: var(--bg);
  border-radius: 6px;
  border-top: 1px dashed var(--line);
}

/* Score-badge naast vraag-titel (0-10) */
.vraag-score10 {
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  line-height: 1;
  margin-right: 0.3rem;
}
.vraag-score10-max { font-size: 0.72rem; color: var(--muted); font-weight: 400; }

/* Advies-blok onderaan vraag-card */
.vraag-advies {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: 0.7rem;
  align-items: start;
  margin-top: 1rem;
  padding: 0.8rem 1rem;
  background: var(--bg);
  border-left: 3px solid var(--accent);
  border-radius: 6px;
  font-size: 0.88rem;
  line-height: 1.5;
}
.vraag-good  .vraag-advies { border-left-color: var(--strong); }
.vraag-warn  .vraag-advies { border-left-color: var(--weak); }
.vraag-advies-icoon { font-size: 1rem; }
.vraag-advies p { margin: 0; color: var(--ink); }

@media (max-width: 560px) {
  .cat-row { grid-template-columns: 20px 1fr auto; gap: 0.4rem; }
  .cat-bar-row { margin-left: 0; }
  .cat-sam { margin-left: 0; }
  .vraag-factoren { padding-left: 0.8rem; }
  /* Vraag-card padding compacter op mobile */
  .vraag-card { padding: 0.9rem 1rem; }
  /* Advies-blok: iets minder padding zodat tekst meer ruimte krijgt */
  .vraag-advies { padding: 0.7rem 0.85rem; font-size: 0.85rem; gap: 0.5rem; }
}
.vraag-factor {
  display: grid;
  grid-template-columns: 16px 1fr auto;
  gap: 0.7rem;
  padding: 0.3rem 0;
  font-size: 0.9rem;
  align-items: center;
}
/* Bolletje-indicator per factor — dominante visuele cue */
.vf-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--neutral);
  display: inline-block;
  justify-self: center;
  box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.03); /* subtiele contrast-ring */
}
.vf-good    .vf-dot { background: var(--strong); }
.vf-warn    .vf-dot { background: var(--weak); }
.vf-neutral .vf-dot { background: #b8b8b8; }
.vf-label { color: var(--ink); opacity: 0.85; }
.vf-value {
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  font-weight: 500;
}

/* Cover — Leefbaarometer-score bovenaan resultaten */
.cover {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 1.5rem;
  margin: 0 0 1.5rem;
  border-left: 6px solid var(--accent);
}
.cover-top {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 1.5rem;
  align-items: center;
}
.cover[data-level="good"]    { border-left-color: var(--strong); }
.cover[data-level="neutral"] { border-left-color: var(--accent); }
.cover[data-level="warn"]    { border-left-color: var(--weak); }

.cover-score {
  font-feature-settings: "tnum";
  text-align: center;
  line-height: 1;
}
.cover-score strong {
  display: block;
  font-size: 4.5rem;
  font-weight: 700;
  letter-spacing: -0.04em;
  color: var(--ink);
}
.cover-suffix { color: var(--muted); font-size: 1rem; }

.cover-body { min-width: 0; }
.cover-label {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 0.3rem;
}
.cover-meaning {
  font-size: 0.9rem;
  color: var(--ink);
  opacity: 0.8;
  margin: 0 0 0.8rem;
  line-height: 1.4;
}

/* Cover highlights — cijferrapport-chips onder de label */
.cover-highlights {
  list-style: none;
  padding: 0;
  margin: 0 0 0.8rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}
.hl {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.25rem 0.65rem;
  border-radius: 999px;
  font-size: 0.8rem;
  background: var(--bg);
  border: 1px solid var(--line);
}
.hl-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--neutral);
}
.hl-good    { background: #e4f4eb; border-color: #c2e4cd; }
.hl-good    .hl-dot { background: var(--strong); }
.hl-warn    { background: #fbe8e1; border-color: #f0cbbe; }
.hl-warn    .hl-dot { background: var(--weak); }
.hl-neutral .hl-dot { background: #b8b8b8; }
.hl-label {
  color: var(--ink);
  opacity: 0.85;
}
.hl-value {
  color: var(--ink);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}
.cover-bar {
  position: relative;
  height: 8px;
  background: #f1f1ed;
  border-radius: 4px;
  overflow: hidden;
}
.cover-bar-fill {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: var(--accent);
  border-radius: 4px;
  transition: width 0.5s;
}
.cover[data-level="good"]    .cover-bar-fill { background: var(--strong); }
.cover[data-level="warn"]    .cover-bar-fill { background: var(--weak); }
.cover-bar-scale {
  display: flex;
  justify-content: space-between;
  font-size: 0.7rem;
  color: var(--muted);
  margin-top: 0.25rem;
}
.cover-scope {
  font-size: 0.72rem;
  color: var(--muted);
  margin-top: 0.3rem;
  text-align: center;
}
.cover-compare {
  margin: 0.8rem 0 0;
  padding-top: 0.6rem;
  border-top: 1px dashed var(--line);
  font-size: 0.85rem;
  color: var(--ink);
  line-height: 1.45;
}

@media (max-width: 560px) {
  .cover-top { grid-template-columns: 80px 1fr; padding: 0; gap: 1rem; }
  .cover-score strong { font-size: 3rem; }
  .cover { padding: 1rem; }
}

/* Cover — 5 sub-dimensies (opbouw van de score) */
.cover-dims {
  margin-top: 1.5rem;
  padding-top: 1.2rem;
  border-top: 1px solid var(--line);
}
.cover-dims-header {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  margin-bottom: 0.6rem;
  font-weight: 500;
}
.cover-dims-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 0.75rem;
}
.dim-row {
  display: grid;
  grid-template-columns: 220px 1fr 52px;
  gap: 0.8rem;
  align-items: center;
  font-size: 0.9rem;
}
.dim-info {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  min-width: 0;
}
.dim-desc {
  font-size: 0.74rem;
  color: var(--muted);
  line-height: 1.35;
}

.cover-waarschuwing {
  margin-top: 1rem;
  padding: 0.8rem 1rem;
  background: #fdf5e6;
  border-left: 3px solid #d9a441;
  border-radius: 6px;
  font-size: 0.82rem;
  color: #5a4215;
  line-height: 1.5;
}
.dim-label { color: var(--ink); }
.dim-bar {
  position: relative;
  height: 6px;
  background: #f1f1ed;
  border-radius: 3px;
  overflow: hidden;
}
.dim-bar-fill {
  position: absolute; inset: 0 auto 0 0;
  border-radius: 3px;
  transition: width 0.4s;
}
.dim-good    { background: var(--strong); }
.dim-neutral { background: var(--accent); }
.dim-warn    { background: var(--weak); }
.dim-score {
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  color: var(--ink);
}
.dim-max { color: var(--muted); font-weight: 400; font-size: 0.8rem; }

@media (max-width: 640px) {
  /* Op mobile: 2-rijen layout — label+desc bovenaan, bar+score eronder.
     Voorkomt dat de beschrijving in een smalle kolom geperst wordt. */
  .dim-row {
    grid-template-columns: 1fr 52px;
    grid-template-areas:
      "info info"
      "bar  score";
    row-gap: 0.4rem;
    column-gap: 0.6rem;
    font-size: 0.88rem;
  }
  .dim-info  { grid-area: info; }
  .dim-bar   { grid-area: bar; }
  .dim-score { grid-area: score; }
  .dim-desc  { font-size: 0.78rem; }
}

/* Trend / ontwikkeling — compacte 2-kolommen grid (recent + lange termijn) */
.cover-ontwikkeling {
  margin-top: 1.5rem;
  padding-top: 1.2rem;
  border-top: 1px solid var(--line);
}
.trend-grid {
  /* Trend-blocks (2 jaar + 10 jaar) onder elkaar i.p.v. naast elkaar.
     Naast elkaar voelde onbalans: de 2-jaar is vaak kort ('stabiel'),
     10-jaar heeft meer inhoud (dimensie-veranderingen). Verticaal leest
     rustiger en geeft beide blokken de ruimte die ze nodig hebben. */
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.6rem;
  margin-top: 0.6rem;
}
.trend-block {
  border: 1px solid var(--line);
  border-left: 4px solid var(--line);
  border-radius: 8px;
  padding: 0.8rem 1rem;
  background: #fafaf8;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}
.trend-block.trend-good    { border-left-color: var(--strong); background: #f2faf5; }
.trend-block.trend-warn    { border-left-color: var(--weak);   background: #fcf5f3; }
.trend-block.trend-neutral { border-left-color: var(--accent); background: #fafaf8; }

.trend-head {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.85rem;
  flex-wrap: wrap;
}
.trend-arrow {
  font-size: 1.1rem;
  line-height: 1;
  font-weight: 700;
}
.trend-good .trend-arrow    { color: var(--strong); }
.trend-warn .trend-arrow    { color: var(--weak); }
.trend-neutral .trend-arrow { color: var(--muted); }

.trend-horizon {
  font-weight: 600;
  color: var(--ink);
}
.trend-chip {
  margin-left: auto;
  font-size: 0.72rem;
  padding: 0.15rem 0.5rem;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 600;
}
.trend-chip-good    { background: #dcefe0; color: #265a33; }
.trend-chip-warn    { background: #f7dcd6; color: #7a2d1c; }
.trend-chip-neutral { background: #ececea; color: #555; }

.trend-desc {
  font-size: 0.88rem;
  color: var(--ink);
  line-height: 1.4;
}
.trend-dim {
  display: flex;
  align-items: baseline;
  gap: 0.4rem;
  font-size: 0.8rem;
  padding: 0.15rem 0;
}
.trend-dim-arrow {
  font-weight: 700;
  line-height: 1;
}
.trend-dim-good .trend-dim-arrow { color: var(--strong); }
.trend-dim-warn .trend-dim-arrow { color: var(--weak); }
.trend-dim-label { color: var(--ink); font-weight: 500; }
.trend-dim-dir {
  color: var(--muted);
  font-size: 0.75rem;
}
.trend-dim-good .trend-dim-dir { color: var(--strong); }
.trend-dim-warn .trend-dim-dir { color: var(--weak); }
.trend-dim-klasse {
  margin-left: auto;
  font-size: 0.72rem;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
  padding: 0.05rem 0.45rem;
  background: var(--bg);
  border-radius: 999px;
  border: 1px solid var(--line);
}
.trend-dim-good .trend-dim-klasse { color: var(--strong); border-color: #c2e4cd; background: #f2faf5; }
.trend-dim-warn .trend-dim-klasse { color: var(--weak);   border-color: #f0cbbe; background: #fcf5f3; }
.trend-period {
  font-size: 0.72rem;
  color: var(--muted);
  margin-top: auto;
  font-variant-numeric: tabular-nums;
}

@media (max-width: 560px) {
  .trend-grid { grid-template-columns: 1fr; }
}

/* Filter-chips voor voorzieningen */
.voorz-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin: 0 0 0.8rem;
}
.voorz-filter {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.3rem 0.7rem;
  font-size: 0.8rem;
  background: var(--bg);
  color: var(--muted);
  border: 1px solid var(--line);
  border-radius: 999px;
  cursor: pointer;
  font-family: inherit;
  transition: all 0.15s;
}
.voorz-filter:hover {
  background: var(--accent-soft);
  color: var(--ink);
  border-color: var(--accent);
}
.voorz-filter.active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
  font-weight: 500;
}
.voorz-filter .vf-icon { font-size: 0.9rem; }

/* Voorzieningen-lijst (vervangt de ringen) */
.voorz-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.voorz-item {
  display: grid;
  grid-template-columns: 28px 1fr 100px 72px;
  gap: 0.8rem;
  align-items: center;
  padding: 0.6rem 0;
  border-top: 1px solid var(--line);
  font-size: 0.95rem;
}
.voorz-item:first-child { border-top: none; }
.voorz-emoji { font-size: 1.05rem; text-align: center; }
.voorz-main { display: flex; flex-direction: column; min-width: 0; }
.voorz-label { color: var(--ink); }
.voorz-naam {
  font-size: 0.78rem;
  color: var(--muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-top: 0.1rem;
}
.voorz-naam.voorz-approx {
  font-style: italic;
  color: #a87b1a;
}

/* Skeleton loader — getoond terwijl /voorzieningen laadt (3-6s cold start
   op Overpass). Pulse-animatie geeft feedback dat er iets gebeurt. */
.voorz-loading-note {
  font-size: 0.82rem;
  color: var(--muted);
  padding: 0.3rem 0 0.2rem;
  font-style: italic;
}
.voorz-skeleton { opacity: 0.6; }
.voorz-skeleton .voorz-emoji { color: var(--line); }
.skel-bar {
  display: block;
  height: 10px;
  background: linear-gradient(90deg, #eee 0%, #f6f6f6 50%, #eee 100%);
  background-size: 200% 100%;
  border-radius: 5px;
  animation: skel-shimmer 1.4s infinite linear;
}
.skel-label { width: 55%; }
.skel-sub { width: 35%; height: 8px; margin-top: 5px; }
.skel-dist { width: 48px; height: 10px; margin-left: auto; }

@keyframes skel-shimmer {
  0%   { background-position: 100% 0; }
  100% { background-position: -100% 0; }
}
.voorz-bar {
  position: relative;
  height: 6px;
  background: #f1f1ed;
  border-radius: 3px;
  overflow: hidden;
}
.voorz-bar-fill {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: var(--accent);
  border-radius: 3px;
  transition: width 0.3s;
}
.v-near .voorz-bar-fill { background: var(--strong); }
.v-mid  .voorz-bar-fill { background: var(--accent); }
.v-far  .voorz-bar-fill { background: var(--neutral); }
.voorz-dist {
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-weight: 500;
  color: var(--muted);
  font-size: 0.9rem;
}

/* Referentie-blok onder elke waarde */
.field {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.field .label {
  display: block;
  font-size: 0.8rem;
  color: var(--muted);
  margin-bottom: 0.1rem;
}
.field strong {
  font-size: 1.4rem;
  font-weight: 600;
  letter-spacing: -0.01em;
}
.field .refline {
  margin: 0.3rem 0 0;
  font-size: 0.75rem;
  color: var(--muted);
}
.field .meaning {
  margin: 0.35rem 0 0;
  font-size: 0.85rem;
  line-height: 1.4;
  color: var(--ink);
  opacity: 0.78;
}
.field .hint {
  margin: 0.25rem 0 0;
  font-size: 0.78rem;
  color: var(--muted);
}
/* Subtiele niveau-indicator direct achter de value, bv. "€45.400 (wijk)" */
.scope-inline {
  font-size: 0.72rem;
  font-weight: 400;
  color: var(--muted);
  letter-spacing: normal;
  margin-left: 0.3rem;
  cursor: help;
}
.muted-strong { color: var(--muted); font-weight: 500; font-size: 1.1rem; }

@media (max-width: 560px) {
  .voorz-item { grid-template-columns: 24px 1fr 60px; gap: 0.5rem; }
  /* Op phones geen bar-kolom, wel emoji/label/afstand — duidelijker */
  .voorz-item .voorz-bar { display: none; }
  .voorz-naam { font-size: 0.74rem; }
}

/* States */
.error {
  max-width: 520px;
  margin: 1rem auto;
  padding: 0.8rem 1rem;
  background: #fde8e3;
  color: #7a2a1a;
  border-radius: 8px;
  font-size: 0.9rem;
  text-align: center;
}

.loading {
  text-align: center;
  color: var(--muted);
  padding: 2rem;
  font-size: 0.95rem;
}

/* ============================================================
   MOBILE — breedte-drempels:
     ≤720px: tablet + compact (reduceert padding, stackt grids)
     ≤560px: phone (al via losse queries bovenaan; deze bundelt overig)
     ≤380px: smalle iPhone SE / mini — nog tighter typografie
   ============================================================ */
@media (max-width: 720px) {
  /* Hero: veel minder top-ruimte — gebruikers willen direct zoeken */
  .hero { padding: 2rem 1rem 1.25rem; }
  .hero h1 { font-size: 2rem; }
  .subtitle { font-size: 1rem; margin-bottom: 1.25rem; }

  /* Search: input blijft ≥16px om iOS-zoom te voorkomen */
  .search input { padding: 0.8rem 1rem; font-size: 1rem; }

  /* Main content: minder zij-padding, meer ruimte voor content */
  main { padding: 0 1rem 4rem; }

  /* Cards: strakker aan de rand — geen 1.5rem meer */
  .card { padding: 1.1rem 1.1rem; }
  .cover { padding: 1.1rem; }

  /* Adres-kop: iets kleiner voor balans */
  .section-address h2 { font-size: 1.35rem; }

  /* Map: compacter, neemt niet halve scherm */
  .map-viewport { height: 280px; }

  /* Map-tabs: compacter padding zodat 4 labels passen zonder ellipsis */
  .map-tab {
    padding: 0.7rem 0.3rem;
    font-size: 0.78rem;
    /* Min tap-target 44px hoogte behouden */
    min-height: 44px;
  }
}

@media (max-width: 560px) {
  .rings-container { grid-template-columns: 1fr; }
  .grid-2 { grid-template-columns: 1fr; gap: 0.8rem; }

  /* Op phones: filter-pills compacter zodat meer per rij passen */
  .voorz-filter {
    padding: 0.35rem 0.6rem;
    font-size: 0.78rem;
    /* Tap-target minimaal 36px — pills mogen kleiner dan echte knoppen */
    min-height: 36px;
  }

  /* Map-tabs: alleen emoji + 1-woord label op smal scherm */
  .map-tab { font-size: 0.72rem; padding: 0.65rem 0.2rem; }

  /* Cover-compare tekst: wat meer lucht */
  .cover-compare { font-size: 0.82rem; }

  /* Trend-periode dichter tegen beschrijving — geen "stretch to bottom" */
  .trend-block { padding: 0.7rem 0.85rem; }

  /* Voorz-items: iets smaller min-target maar nog leesbaar */
  .voorz-item { padding: 0.55rem 0; font-size: 0.9rem; }

  /* Grid-2 fields: tijdelijk strongs iets kleiner op phone */
  .grid-2 strong, .field strong { font-size: 1.25rem; }

  /* Hero nog iets kleiner */
  .hero { padding-top: 1.5rem; }
  .hero h1 { font-size: 1.75rem; }
}

@media (max-width: 380px) {
  /* iPhone SE / mini */
  .hero h1 { font-size: 1.55rem; }
  .cover-score strong { font-size: 2.5rem; }
  .cover-top { grid-template-columns: 70px 1fr; gap: 0.8rem; }
  .map-tab { font-size: 0.68rem; padding: 0.6rem 0.15rem; }
  /* Map iets korter zodat content sneller in beeld komt */
  .map-viewport { height: 240px; }
}
