/* Surfse v13 — kleurupdate: waterblauwe basis, turquoise primary, goud voor epic */
:root{
  --deep:#071f2a;--deep-2:#0b2a35;--ink:#eaf7fb;--muted:#8fb0bc;--ocean:#0e6f86;--surfse:#1fb6c9;--water:#56d6e6;--foam:#e8fbff;--sand:#fff8ed;--card:rgba(255,255,255,.94);--line:rgba(130,190,205,.24);--good:#27b878;--warn:#f0a83a;--bad:#ef5350;--epic:#f5b942;--shadow:0 18px 50px rgba(0,0,0,.22);--radius:24px;
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;background:
  radial-gradient(circle at 20% -10%, rgba(31,182,201,.20), transparent 34%),
  radial-gradient(circle at 85% 10%, rgba(245,185,66,.10), transparent 26%),
  linear-gradient(180deg,#071f2a 0%,#0b2a35 56%,#102f37 100%);
color:var(--ink);min-height:100vh;-webkit-font-smoothing:antialiased}button,input,textarea{font:inherit}button{cursor:pointer}.topbar{position:sticky;top:0;z-index:20;display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:rgba(7,31,42,.82);backdrop-filter:blur(18px);border-bottom:1px solid rgba(143,224,238,.15)}.brand{display:flex;align-items:center;gap:10px}.brand-logo{width:44px;height:44px;object-fit:contain;border-radius:12px}.brand strong{display:block;font-size:16px}.brand span{display:block;font-size:12px;color:#a8cbd5;margin-top:1px}.source-link{font-size:12px;font-weight:800;color:#dffbff;text-decoration:none;background:rgba(31,182,201,.12);border:1px solid rgba(143,224,238,.22);border-radius:999px;padding:8px 10px}main{width:min(920px,100%);margin:0 auto;padding:14px 14px 28px}.card,.mini-card{background:rgba(255,255,255,.96);border:1px solid rgba(143,224,238,.22);border-radius:var(--radius);box-shadow:var(--shadow);color:#12202a}.hero{position:relative;overflow:hidden;padding:22px;margin-bottom:14px;background:linear-gradient(135deg,#061923 0%,#0e6f86 58%,#1fb6c9 100%);color:#fff}.surf-decision{position:relative;z-index:2;display:grid;gap:5px;margin-bottom:18px;padding:14px;border:1px solid rgba(255,255,255,.22);border-radius:20px;background:rgba(255,255,255,.12);backdrop-filter:blur(12px)}.surf-decision strong{font-size:22px;letter-spacing:-.04em}.surf-decision span:last-child{font-size:13px;line-height:1.35;color:#dff7ff}.surf-badge{width:max-content;border-radius:999px;padding:6px 10px;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.07em}.surf-badge.good{background:rgba(23,138,85,.22);color:#d8ffe9}.surf-badge.warn{background:rgba(183,121,31,.25);color:#fff2cc}.surf-badge.bad{background:rgba(185,28,28,.24);color:#ffe1e1}.surf-badge.unknown{background:rgba(255,255,255,.18);color:#fff}.hero-social{position:relative;z-index:2;margin-top:16px;border-radius:16px;padding:11px 13px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.2);font-weight:900;color:#fff}.hero:after{content:"";position:absolute;right:-70px;bottom:-80px;width:220px;height:220px;border:26px solid rgba(255,255,255,.16);border-radius:50%}.eyebrow{margin:0 0 8px;color:#c7f0ff;font-weight:900;text-transform:uppercase;font-size:11px;letter-spacing:.09em}.hero h1{margin:0;font-size:clamp(29px,8vw,54px);line-height:.96;letter-spacing:-.06em;max-width:720px}.sub{font-size:15px;line-height:1.6;color:#dff7ff;max-width:620px;margin:14px 0 0}.hero-actions{display:grid;gap:10px;margin-top:20px;position:relative;z-index:2}.primary,.ghost{border:0;border-radius:18px;padding:16px 18px;font-weight:900}.primary{background:linear-gradient(135deg,#1fb6c9,#0e8ea4);color:#fff;box-shadow:0 12px 28px rgba(31,182,201,.28)}.ghost{background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.28)}.full{width:100%}.status-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:14px}.mini-card{padding:16px;min-height:148px}.mini-card .icon{width:44px;height:44px;border-radius:16px;background:var(--foam);display:grid;place-items:center;font-size:25px;margin-bottom:14px}.mini-card small{display:block;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:900}.mini-card strong{display:block;font-size:30px;line-height:1.05;margin:8px 0 2px;letter-spacing:-.04em}.mini-card span:last-child{display:block;color:var(--muted);font-size:13px;line-height:1.35}.mini-card.good{border-color:rgba(39,184,120,.26);background:#f0fff7}.mini-card.warn{border-color:rgba(240,168,58,.30);background:#fff9ec}.mini-card.bad{border-color:rgba(239,83,80,.26);background:#fff4f4}.mini-card.good strong{color:var(--good)}.mini-card.warn strong{color:var(--warn)}.mini-card.bad strong{color:var(--bad)}.signup,.crew-card,.safety-card{padding:18px;margin-bottom:14px}.section-title{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px}.section-title h2{font-size:22px;letter-spacing:-.04em;margin:0}.section-title p{margin:5px 0 0;color:var(--muted);font-size:14px}.icon-btn{width:36px;height:36px;border-radius:12px;border:1px solid var(--line);background:#fff;color:var(--muted);font-size:24px;line-height:0}.signup label{display:block;font-size:13px;font-weight:900;color:var(--ink);margin-bottom:14px}.signup input,.signup textarea{width:100%;margin-top:8px;border:1.5px solid var(--line);background:#fbfdff;border-radius:16px;padding:14px;color:var(--ink);outline:0}.signup textarea{resize:vertical;min-height:82px}.signup input:focus,.signup textarea:focus{border-color:var(--water);box-shadow:0 0 0 4px rgba(58,167,216,.14)}fieldset{border:0;margin:0 0 14px;padding:0}legend{font-size:13px;font-weight:900;margin-bottom:8px}.segmented{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.segmented.grid{grid-template-columns:repeat(2,1fr)}.segmented button{border:1.5px solid var(--line);background:#fbfdff;border-radius:15px;padding:13px 8px;font-weight:900;color:var(--muted)}.segmented button.active{border-color:var(--surfse);background:#e8fbff;color:#0e6f86;box-shadow:0 0 0 4px rgba(31,182,201,.10)}.privacy-note{font-size:12px;color:var(--muted);text-align:center;line-height:1.5;margin:12px 0 0}.counts{display:flex;gap:8px}.counts div{min-width:72px;text-align:center;background:var(--foam);border:1px solid var(--line);border-radius:16px;padding:9px}.counts strong{display:block;font-size:25px;color:#0e6f86;line-height:1}.counts span{display:block;font-size:10px;text-transform:uppercase;font-weight:900;color:var(--muted);margin-top:3px}.session-list{display:grid;gap:10px}.empty{padding:24px;text-align:center;color:var(--muted);background:#fbfdff;border:1px dashed var(--line);border-radius:18px}.session{display:grid;grid-template-columns:52px 1fr auto;gap:12px;align-items:center;padding:13px;border:1px solid var(--line);border-radius:20px;background:#fbfdff}.avatar{width:52px;height:52px;border-radius:18px;display:grid;place-items:center;background:linear-gradient(135deg,#0e6f86,#1fb6c9);color:#fff;font-weight:900;font-size:20px}.session h3{margin:0;font-size:16px}.session .note{margin:4px 0 0;color:var(--muted);font-size:13px;line-height:1.35}.chips{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}.chip{font-size:11px;font-weight:900;border-radius:999px;padding:4px 8px;background:#e8fbff;color:#0e6f86}.chip.day{background:#e9f9ee;color:#178a55}.delete-btn{border:0;background:transparent;color:#b7c2d0;font-size:20px;padding:8px}.check-list p{margin:9px 0;color:#31445b;line-height:1.55}.map-link{display:block;margin-top:14px;padding:14px;border-radius:16px;background:#e8fbff;border:1px solid rgba(31,182,201,.22);color:#0e6f86;font-weight:900;text-decoration:none;text-align:center}footer{text-align:center;color:#a8cbd5;font-size:12px;padding:12px 20px 28px}.toast{position:fixed;left:14px;right:14px;bottom:18px;z-index:50;transform:translateY(120px);opacity:0;transition:.24s ease;background:#071827;color:#fff;border-radius:18px;padding:14px 16px;text-align:center;font-weight:800;box-shadow:0 18px 44px rgba(7,24,39,.24)}.toast.show{transform:translateY(0);opacity:1}@media(min-width:760px){main{padding-top:24px}.hero{padding:34px}.surf-decision{max-width:520px}.hero-actions{grid-template-columns:auto auto;justify-content:start}.status-grid{grid-template-columns:repeat(3,1fr)}.mini-card{padding:20px}.signup,.crew-card,.safety-card{padding:24px}.segmented.grid{grid-template-columns:repeat(4,1fr)}}@media(max-width:640px){.status-grid{grid-template-columns:1fr 1fr}.status-grid .mini-card:last-child{grid-column:1/-1}}@media(max-width:370px){.status-grid{grid-template-columns:1fr}.status-grid .mini-card:last-child{grid-column:auto}.session{grid-template-columns:44px 1fr}.delete-btn{display:none}}

/* v11 — Spotinfo + epic condities */
.spot-info-card{
  margin:0 0 14px;
  padding:22px;
  overflow:hidden;
  color:#f7fbff;
  background:
    radial-gradient(circle at 82% 8%, rgba(245,185,66,.20), transparent 32%),
    radial-gradient(circle at 12% 0%, rgba(31,182,201,.18), transparent 32%),
    linear-gradient(135deg,#061923 0%,#0b2632 56%,#123642 100%);
  border-color:rgba(255,255,255,.08);
  box-shadow:0 22px 54px rgba(7,24,39,.22);
}
.spot-info-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:18px}
.eyebrow.dark{color:#8fe4ff;margin-bottom:6px}
.spot-info-card h2{margin:0;font-size:clamp(30px,6vw,46px);line-height:1;letter-spacing:-.06em;color:#fff}
.spot-pill{flex:0 0 auto;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.08);border-radius:999px;padding:9px 11px;font-size:12px;font-weight:900;color:#d7e8f5}
.epic-summary{display:grid;gap:6px;border-top:1px solid rgba(255,255,255,.13);border-bottom:1px solid rgba(255,255,255,.13);padding:18px 0;margin-bottom:18px}
.epic-kicker{width:max-content;text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:950;color:var(--epic)}
.epic-summary strong{font-size:clamp(34px,8vw,62px);letter-spacing:-.07em;line-height:.95;color:#fff}
.epic-summary p{margin:0;max-width:680px;color:#cbd6e2;line-height:1.45;font-size:15px}
.epic-bars{display:grid;gap:18px;margin:16px 0 20px}
.epic-row-label{display:flex;align-items:end;justify-content:space-between;gap:12px;margin-bottom:8px;color:#cbd6e2;font-weight:950;text-transform:uppercase;letter-spacing:.06em;font-size:12px}
.epic-row-hint{font-size:12px;text-transform:none;letter-spacing:0;color:#8795a8;font-weight:800}
.epic-ticks{display:grid;gap:6px}
.epic-tick-labels,.epic-tick-boxes{display:grid;gap:6px;grid-template-columns:repeat(var(--epic-count),minmax(0,1fr))}
.epic-tick-labels span{text-align:center;color:#eef6ff;font-size:13px;font-weight:900}
.epic-box{height:22px;border-radius:7px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.08);box-shadow:inset 0 1px 0 rgba(255,255,255,.07)}
.epic-box.near{background:rgba(245,185,66,.28);border-color:rgba(245,185,66,.25)}
.epic-box.ideal{background:linear-gradient(180deg,#ffd978,#f5b942);border-color:rgba(245,185,66,.62);box-shadow:0 0 24px rgba(245,185,66,.22),inset 0 1px 0 rgba(255,255,255,.26)}
.spot-copy{display:grid;gap:8px;color:#d7e0ea;font-size:15px;line-height:1.45}
.spot-copy p{margin:0}.spot-copy strong{color:#fff}
@media(min-width:760px){.spot-info-card{padding:30px}.epic-bars{max-width:720px}.epic-box{height:26px}}
@media(max-width:520px){.spot-info-head{display:grid}.spot-pill{width:max-content}.epic-tick-labels span{font-size:12px}.epic-box{height:20px}.spot-info-card{padding:20px}}


/* v14 — windrichting + beste moment */
.surf-insights{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:1fr;
  gap:8px;
  margin:-6px 0 18px;
}
.surf-insights span{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.20);
  background:rgba(255,255,255,.10);
  color:#effcff;
  font-weight:900;
  font-size:13px;
  letter-spacing:-.01em;
}
@media(min-width:620px){
  .surf-insights{grid-template-columns:auto auto;justify-content:start}
  .surf-insights span{padding:0 14px;justify-content:flex-start}
}

/* v17 — use cases voor spotcontext/community */
.usecase-panel{margin-top:18px;padding:16px;border-radius:20px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.13);color:#eef8ff}
.usecase-kicker{display:block;text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:950;color:var(--water);margin-bottom:6px}
.usecase-panel strong{display:block;font-size:22px;line-height:1.08;letter-spacing:-.04em;color:#fff;margin-bottom:10px}
.usecase-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.usecase-tags span{border-radius:999px;background:rgba(31,182,201,.16);border:1px solid rgba(86,214,230,.24);color:#dffbff;font-size:12px;font-weight:900;padding:7px 9px}
.usecase-notes{margin:0;padding-left:18px;color:#cbd6e2;line-height:1.45;font-size:14px}
.usecase-notes li+li{margin-top:4px}

/* v18 — homepage + multi-spot routing fix */
[hidden]{display:none!important}
.home-app{padding-top:18px}.home-hero{padding:34px}.home-hero h1{max-width:780px}.home-intro,.home-spots-card{padding:22px;margin-bottom:14px}.home-intro h2{margin:0 0 12px;font-size:clamp(28px,6vw,44px);line-height:1;letter-spacing:-.06em;color:#12202a}.home-points{display:grid;gap:10px}.home-points p{margin:0;color:#31445b;line-height:1.5}.home-points strong{color:#0e6f86}.home-spot-list{display:grid;gap:12px}.home-spot-card{display:grid;gap:14px;padding:18px;border:1px solid var(--line);border-radius:22px;background:#fbfdff;color:#12202a;text-decoration:none;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.home-spot-card:hover{transform:translateY(-1px);border-color:rgba(31,182,201,.45);box-shadow:0 16px 34px rgba(7,31,42,.12)}.home-spot-type{display:inline-block;margin-bottom:8px;border-radius:999px;padding:6px 9px;background:#e8fbff;color:#0e6f86;font-size:11px;font-weight:950;text-transform:uppercase;letter-spacing:.08em}.home-spot-card h3{margin:0;font-size:24px;letter-spacing:-.04em}.home-spot-card p{margin:6px 0 0;color:#55707c;line-height:1.45}.home-spot-meta{display:grid;gap:4px;align-content:start}.home-spot-meta strong{font-size:20px;color:#0e6f86;letter-spacing:-.03em}.home-spot-meta>span{color:#8fb0bc;font-size:13px}.home-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.home-tags span{border-radius:999px;background:#e8fbff;color:#0e6f86;font-size:11px;font-weight:900;padding:5px 8px}@media(min-width:760px){.home-intro,.home-spots-card{padding:28px}.home-spot-card{grid-template-columns:1fr 220px;align-items:start}.home-points{grid-template-columns:repeat(3,1fr)}}

/* v21 — spot terugknop + topbar acties */
.top-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.home-link{font-size:12px;font-weight:900;color:#dffbff;text-decoration:none;background:rgba(255,255,255,.08);border:1px solid rgba(143,224,238,.20);border-radius:999px;padding:8px 10px}
.home-link:hover,.source-link:hover{border-color:rgba(143,224,238,.44);background:rgba(31,182,201,.18)}
@media(max-width:420px){.topbar{gap:10px}.brand-logo{width:38px;height:38px}.top-actions{gap:6px}.home-link,.source-link{font-size:11px;padding:7px 8px}}

/* v22 materiaaladvies */
.material-icon{font-size:18px!important;font-weight:950;color:#0e6f86}
@media(min-width:760px){.status-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:640px){.status-grid{grid-template-columns:1fr 1fr}.status-grid .mini-card:last-child{grid-column:auto}}
@media(max-width:370px){.status-grid{grid-template-columns:1fr}.status-grid .mini-card:last-child{grid-column:auto}}

/* v24 — beste spot vandaag */
.home-best-card{padding:22px;margin-bottom:14px}
.home-best-spot{display:grid;gap:12px}
.home-best-main{display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center;padding:20px;border:1px solid rgba(31,182,201,.28);border-radius:24px;background:linear-gradient(135deg,#e8fbff 0%,#fbfdff 58%,#fff6dc 100%);color:#12202a;text-decoration:none;box-shadow:0 18px 40px rgba(7,31,42,.10)}
.home-best-main h3{margin:8px 0 4px;font-size:clamp(30px,7vw,50px);line-height:.95;letter-spacing:-.07em;color:#071f2a}
.home-best-main p{margin:0;color:#365363;font-weight:800;line-height:1.35}
.home-best-score{display:grid;place-items:center;min-width:78px;min-height:78px;border-radius:22px;background:#071f2a;color:#dffbff;border:1px solid rgba(143,224,238,.26)}
.home-best-score strong{font-size:34px;line-height:1;letter-spacing:-.06em;color:#f5b942}
.home-best-score span{font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:950;color:#8fe0ee}
.home-spot-type.good{background:#dcfce7;color:#166534}.home-spot-type.warn{background:#fff7d6;color:#8a5a00}.home-spot-type.info{background:#e8fbff;color:#0e6f86}.home-spot-type.bad{background:#fee2e2;color:#991b1b}
.home-rank-list{display:grid;gap:8px}.home-rank-row{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;padding:12px 14px;border-radius:16px;border:1px solid var(--line);background:#fbfdff;color:#12202a;text-decoration:none}.home-rank-row span{font-weight:900}.home-rank-row strong{font-size:12px;color:#0e6f86}.home-rank-row small{color:#55707c;font-weight:800}.home-match-line{margin-top:8px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}.home-match-line strong{font-size:12px;color:#0e6f86}.home-match-line span{font-size:12px;color:#55707c;font-weight:900}
@media(max-width:620px){.home-best-main{grid-template-columns:1fr}.home-best-score{width:78px}.home-rank-row{grid-template-columns:1fr}.home-rank-row strong,.home-rank-row small{justify-self:start}}

/* v25 — realistische ranking + community count */
.home-community{display:inline-flex;width:max-content;margin-top:10px;border-radius:999px;padding:7px 10px;background:rgba(31,182,201,.12);border:1px solid rgba(31,182,201,.24);color:#0e6f86;font-size:12px;font-weight:950}
.home-rank-row small{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.home-match-line span+span{color:#0e6f86;background:#e8fbff;border-radius:999px;padding:3px 7px}
@media(max-width:620px){.home-rank-row small{justify-content:flex-start}}


/* v30 — homepage community visibility */
.home-community-card{padding:22px;margin-bottom:14px}
.home-community-list{display:grid;gap:10px}
.home-community-row{display:grid;grid-template-columns:1fr auto;gap:14px;align-items:center;padding:14px 16px;border:1px solid rgba(31,182,201,.24);border-radius:18px;background:#fbfdff;color:#12202a;text-decoration:none;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}
.home-community-row:hover{transform:translateY(-1px);border-color:rgba(31,182,201,.45);box-shadow:0 14px 30px rgba(7,31,42,.10)}
.home-community-row strong{display:block;font-size:18px;letter-spacing:-.03em;color:#071f2a}
.home-community-row span{display:block;margin-top:3px;color:#55707c;font-size:13px;font-weight:800}
.home-community-row em{font-style:normal;border-radius:999px;background:#e8fbff;color:#0e6f86;font-size:12px;font-weight:950;padding:7px 10px;white-space:nowrap}
@media(max-width:620px){.home-community-row{grid-template-columns:1fr}.home-community-row em{width:max-content}}

.home-list-subtitle { margin: 10px 2px 6px; color: rgba(230,246,250,.72); font-weight: 800; font-size: 13px; text-transform: uppercase; letter-spacing: .08em; }

/* v34 — contrastfix sessieformulier */
.signup{
  color:#071f2a;
}
.signup .section-title h2,
.signup label,
.signup legend{
  color:#071f2a;
}
.signup .section-title p,
.signup .privacy-note{
  color:#55707c;
}
.signup input,
.signup textarea{
  color:#071f2a;
  background:#fbfdff;
}
.signup input::placeholder,
.signup textarea::placeholder{
  color:#6f8190;
  opacity:1;
}
.signup input:focus,
.signup textarea:focus{
  color:#071f2a;
}
.signup .segmented button{
  color:#55707c;
  background:#fbfdff;
}
.signup .segmented button.active{
  color:#075f70;
  background:#e8fbff;
}
.signup .icon-btn{
  color:#55707c;
}


/* v47 — waterplanten en foilen */
.weed-panel{margin-top:18px;padding:16px;border-radius:20px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.13);color:#eef8ff}
.weed-kicker{display:block;text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:950;color:#8fe0ee;margin-bottom:6px}
.weed-panel strong{display:block;font-size:22px;line-height:1.08;letter-spacing:-.04em;color:#fff;margin-bottom:8px}
.weed-panel p{margin:6px 0 0;color:#cbd6e2;line-height:1.45;font-size:14px}
.weed-panel.low{border-color:rgba(39,184,120,.35);background:rgba(39,184,120,.10)}
.weed-panel.moderate{border-color:rgba(240,168,58,.42);background:rgba(240,168,58,.12)}
.weed-panel.high{border-color:rgba(239,83,80,.42);background:rgba(239,83,80,.12)}
.weed-panel.low .weed-kicker{color:#9ff2c7}.weed-panel.moderate .weed-kicker{color:#ffd28a}.weed-panel.high .weed-kicker{color:#ffb3b3}

/* v35 — admin spots */
.admin-shell{width:min(1180px,100%);margin:0 auto;padding:18px 14px 42px}.admin-grid{display:grid;gap:14px}.admin-panel{background:rgba(255,255,255,.96);color:#12202a;border:1px solid rgba(143,224,238,.22);border-radius:24px;box-shadow:var(--shadow);padding:18px}.admin-list{display:grid;gap:8px}.admin-list button{width:100%;text-align:left;border:1px solid var(--line);background:#fbfdff;border-radius:16px;padding:12px;color:#12202a;font-weight:900}.admin-list button.active{border-color:var(--surfse);background:#e8fbff;color:#0e6f86}.admin-form{display:grid;gap:16px}.admin-field{display:grid;gap:7px}.admin-field label,.admin-label{font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.06em;color:#55707c}.admin-field input,.admin-field textarea,.admin-field select{width:100%;border:1.5px solid var(--line);border-radius:14px;padding:12px;background:#fbfdff;color:#12202a;outline:0}.admin-field textarea{min-height:76px;resize:vertical}.admin-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.admin-checks{display:flex;flex-wrap:wrap;gap:8px}.admin-checks label{display:flex;align-items:center;gap:6px;border:1px solid var(--line);background:#fbfdff;border-radius:999px;padding:8px 10px;font-weight:900;color:#31445b}.admin-actions{display:flex;gap:10px;flex-wrap:wrap}.admin-message{border-radius:16px;padding:12px;background:#eef9fc;color:#0e6f86;font-weight:800}.admin-message.bad{background:#fff4f4;color:#b91c1c}.admin-help{color:#55707c;line-height:1.45;font-size:14px}.admin-token{display:grid;gap:10px}.admin-muted{color:#8ba1ad;font-size:13px}.admin-section-title{font-size:20px;margin:0 0 8px;letter-spacing:-.04em}@media(min-width:900px){.admin-grid{grid-template-columns:280px 1fr}.admin-panel{padding:22px}.admin-form .admin-two{display:grid;grid-template-columns:1fr 1fr;gap:12px}}

/* v38 — lokale wijzigingsvoorstellen */
.home-suggestions-card,.public-suggestions-card,.local-edit-card,.suggestion-form-card{padding:22px;margin-bottom:14px}
.suggestion-link{align-self:start;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#e8fbff;color:#0e6f86;border:1px solid rgba(31,182,201,.24);padding:10px 13px;font-size:12px;font-weight:950;text-decoration:none;white-space:nowrap}
.suggestion-link.light{background:rgba(255,255,255,.12);color:#dffbff;border-color:rgba(143,224,238,.22)}
.home-suggestions-list{display:grid;gap:8px}.suggestion-mini-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:12px 14px;border-radius:16px;border:1px solid var(--line);background:#fbfdff;color:#12202a;text-decoration:none}.suggestion-mini-row span{font-weight:900}.suggestion-mini-row strong{font-size:12px;border-radius:999px;background:#fff7d6;color:#8a5a00;padding:5px 8px}.spot-suggestion-badge{display:inline-flex;width:max-content;margin-top:8px;border-radius:999px;background:#fff7d6;color:#8a5a00;border:1px solid rgba(240,168,58,.24);font-size:12px;font-weight:950;padding:5px 8px}
.local-edit-card{background:linear-gradient(135deg,#071f2a 0%,#0e6f86 100%);color:#fff;border-color:rgba(255,255,255,.12)}.local-edit-card h2{color:#fff}.local-edit-card .section-title p{color:#dff7ff}.local-edit-actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}.local-edit-card .empty{background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.16);color:#dff7ff}
.public-suggestions-list{display:grid;gap:10px}.public-suggestions-list.compact{margin-top:6px}.suggestion-card{display:grid;gap:9px;padding:14px;border-radius:18px;border:1px solid var(--line);background:#fbfdff;color:#12202a}.local-edit-card .suggestion-card{background:rgba(255,255,255,.96)}.suggestion-card-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.suggestion-card-head strong{display:block;font-size:17px;color:#071f2a}.suggestion-card-head span{display:block;margin-top:3px;font-size:12px;font-weight:900;color:#0e6f86}.suggestion-card-head em{font-style:normal;border-radius:999px;background:#fff7d6;color:#8a5a00;font-size:11px;font-weight:950;padding:6px 8px;white-space:nowrap}.suggestion-card p{margin:0;color:#31445b;line-height:1.45;font-weight:700}.suggestion-card small{color:#55707c;line-height:1.4}.suggestion-card footer{padding:0;text-align:left;color:#8ba1ad;font-size:12px;font-weight:900}.suggestions-page{padding-top:18px}.suggestions-hero{margin-bottom:14px}
.suggestion-form{display:grid;gap:14px}.suggestion-form label{display:block;font-size:13px;font-weight:900;color:#071f2a}.suggestion-form input,.suggestion-form textarea,.suggestion-form select{width:100%;margin-top:8px;border:1.5px solid var(--line);background:#fbfdff;border-radius:16px;padding:14px;color:#071f2a;outline:0}.suggestion-form textarea{resize:vertical;min-height:94px}.suggestion-form select:focus,.suggestion-form input:focus,.suggestion-form textarea:focus{border-color:var(--water);box-shadow:0 0 0 4px rgba(58,167,216,.14)}.label-muted{font-weight:800;color:#8ba1ad}.honeypot{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;opacity:0!important;pointer-events:none!important}
@media(max-width:620px){.suggestion-card-head{display:grid}.suggestion-card-head em{width:max-content}.local-edit-actions{display:grid}.suggestion-link{width:max-content}}
.admin-suggestion-list{display:grid;gap:12px}.admin-suggestion-card{display:grid;gap:12px;padding:16px;border:1px solid var(--line);border-radius:20px;background:#fbfdff;color:#12202a}.admin-suggestion-card p{margin:0;color:#31445b;line-height:1.45;font-weight:750}.admin-suggestion-card small{color:#55707c;line-height:1.4}.admin-suggestion-card footer{padding:0;text-align:left;color:#8ba1ad;font-size:12px;font-weight:900}.admin-suggestion-card footer a{color:#0e6f86;text-decoration:none;font-weight:950}

/* v42 — eenvoudiger layout en surfer-vriendelijke local input */
.home-hero{padding:28px;margin-bottom:12px}
.home-hero h1{font-size:clamp(34px,9vw,62px)}
.home-hero .sub{max-width:560px;font-size:15px;line-height:1.5}
.home-best-card,.home-community-card,.home-suggestions-card,.home-spots-card{padding:18px;margin-bottom:12px}
.home-best-main{padding:18px;border-radius:22px}
.home-best-main h3{font-size:clamp(30px,8vw,48px)}
.home-best-score{min-width:70px;min-height:70px;border-radius:20px}
.home-rank-list{margin-top:6px}
.home-community-row{padding:12px 14px;border-radius:16px}
.home-spot-list{gap:10px}
.home-spot-card{padding:15px;border-radius:19px;box-shadow:none}
.home-spot-card h3{font-size:21px}
.home-spot-card p{font-size:13px;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.home-spot-meta strong{font-size:16px}
.home-tags{display:none}
.home-list-subtitle{color:#9bd8e2;margin-top:12px}
.spot-info-card{padding:18px;border-radius:22px;background:linear-gradient(135deg,#061923 0%,#0b2632 100%)}
.spot-info-head{margin-bottom:12px}
.spot-info-card h2{font-size:clamp(28px,7vw,42px)}
.epic-summary{padding:14px 0;margin-bottom:14px}
.epic-summary strong{font-size:clamp(30px,8vw,48px)}
.epic-summary p{font-size:14px;line-height:1.4}
.spot-copy{gap:8px}
.weed-panel,.usecase-panel{margin-top:12px;padding:13px;border-radius:18px}
.local-edit-card{background:#fbfdff;color:#12202a;border-color:var(--line);box-shadow:0 14px 36px rgba(7,31,42,.12)}
.local-edit-card h2{color:#071f2a}.local-edit-card .section-title p{color:#55707c}.local-edit-card .eyebrow.dark{color:#0e6f86}
.local-edit-card .empty{background:#fff;border-color:var(--line);color:#8ba1ad;padding:16px}
.local-edit-card .suggestion-card{background:#fff}
.suggestion-link.light{background:#e8fbff;color:#0e6f86;border-color:rgba(31,182,201,.24)}
.local-edit-actions{margin-bottom:10px}
.suggestion-form-card{padding:18px}
.choice-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:8px}
.choice-grid button{border:1.5px solid var(--line);background:#fbfdff;border-radius:15px;padding:12px 8px;font-weight:950;color:#55707c}
.choice-grid button.active{border-color:var(--surfse);background:#e8fbff;color:#075f70;box-shadow:0 0 0 4px rgba(31,182,201,.10)}
.bft-grid{grid-template-columns:repeat(5,1fr)}
.form-hint{margin:2px 0 0;color:#55707c;font-size:12px;line-height:1.45;font-weight:800}
.suggestion-form fieldset{margin:0}.suggestion-form legend{color:#071f2a}
@media(max-width:620px){.home-best-card,.home-community-card,.home-suggestions-card,.home-spots-card{padding:16px}.choice-grid{grid-template-columns:repeat(4,1fr)}.bft-grid{grid-template-columns:repeat(5,1fr)}.spot-info-card{padding:16px}}

/* v43 — compacter mobiel, afstand en waterplanten */
.home-hero{padding:20px 18px;margin-bottom:10px}
.home-hero h1{font-size:clamp(30px,8vw,50px)}
.home-hero .sub{margin-top:10px;font-size:14px;line-height:1.45}
.home-location-bar{display:flex;gap:10px;align-items:center;justify-content:space-between;margin-top:12px;padding:11px 12px;border-radius:16px;background:#fbfdff;border:1px solid var(--line);color:#55707c;font-size:12px;font-weight:850}
.location-btn{border:0;border-radius:999px;background:#e8fbff;color:#0e6f86;font-weight:950;padding:9px 11px;white-space:nowrap}
.home-sort-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px}
.home-sort-tabs button{border:1px solid var(--line);background:#fbfdff;color:#55707c;border-radius:999px;padding:10px 8px;font-weight:950}
.home-sort-tabs button.active{background:#071f2a;color:#fff;border-color:#071f2a}
.home-alert,.waterplants-badge{display:inline-flex;width:max-content;border-radius:999px;padding:6px 9px;background:#fff4e2;color:#8a5a00;border:1px solid rgba(240,168,58,.24);font-size:12px;font-weight:950;margin-top:8px}
.waterplants-badge.warn{background:#fff4f4;color:#b91c1c;border-color:rgba(239,83,80,.22)}
.home-spot-card.compact{display:grid;grid-template-columns:1fr;gap:10px;padding:14px}
.home-spot-card.compact h3{font-size:20px;margin-bottom:4px}
.home-spot-card.compact p{-webkit-line-clamp:1;font-size:12px;margin-bottom:0}
.home-spot-card.compact .home-spot-meta{gap:5px}
.waterplants-panel .waterplants-report-text{font-weight:850;color:#dff7ff}
.waterplants-actions{display:flex;flex-wrap:wrap;gap:9px;margin-top:12px}
.report-waterplants-btn{background:rgba(255,255,255,.12);padding:10px 12px;border-radius:999px;font-size:12px;color:#fff}
.local-edit-card{padding:16px}
.safety-card{margin-bottom:82px}
.mobile-sticky-actions{display:none}
@media(max-width:680px){
  main{padding:10px 10px 24px}
  .topbar{padding:9px 10px}.brand-logo{width:38px;height:38px}.source-link{display:none}
  .hero{padding:16px;margin-bottom:10px;border-radius:20px}
  .surf-decision{margin-bottom:10px;padding:12px;border-radius:16px}.surf-decision strong{font-size:20px}
  .surf-insights{gap:6px;flex-wrap:wrap}.hero-social{margin-top:10px;padding:9px 10px;font-size:13px}
  .hero-actions{grid-template-columns:1fr 1fr;margin-top:12px}.hero-actions .primary,.hero-actions .ghost{padding:12px 10px;border-radius:14px}
  .status-grid{grid-template-columns:1fr 1fr;gap:8px}.mini-card{min-height:116px;padding:12px;border-radius:18px}.mini-card .icon{width:34px;height:34px;border-radius:12px;font-size:19px;margin-bottom:8px}.mini-card strong{font-size:21px}.mini-card span:last-child{font-size:12px}
  .home-best-card,.home-community-card,.home-suggestions-card,.home-spots-card,.crew-card,.signup,.safety-card,.spot-info-card,.suggestion-form-card{border-radius:20px;padding:14px;margin-bottom:10px}
  .home-best-main{padding:14px;border-radius:18px;grid-template-columns:1fr}.home-best-main h3{font-size:31px}.home-best-score{display:none}
  .home-rank-row{grid-template-columns:1fr}.home-rank-row strong,.home-rank-row small{justify-self:start}
  .home-location-bar{display:grid;grid-template-columns:1fr;gap:8px}.location-btn{width:max-content}
  .section-title{margin-bottom:10px}.section-title h2{font-size:20px}.section-title p{font-size:12px}
  .home-community-row{padding:11px 12px}.home-community-row strong{font-size:16px}
  .spot-info-card h2{font-size:26px}.epic-summary strong{font-size:30px}.epic-bars{display:none}.spot-copy p{font-size:13px}
  .waterplants-actions{display:grid}.waterplants-actions .suggestion-link,.report-waterplants-btn{width:100%;justify-content:center;text-align:center}
  .local-edit-actions{display:grid;grid-template-columns:1fr 1fr}.local-edit-actions .primary,.local-edit-actions .suggestion-link{width:100%;justify-content:center}
  .mobile-sticky-actions{position:fixed;left:10px;right:10px;bottom:10px;z-index:35;display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:8px;border-radius:20px;background:rgba(7,31,42,.88);backdrop-filter:blur(14px);border:1px solid rgba(143,224,238,.18);box-shadow:0 18px 50px rgba(0,0,0,.28)}
  .mobile-sticky-actions .primary,.mobile-sticky-actions .ghost{padding:12px;border-radius:14px}.mobile-sticky-actions .ghost{background:rgba(255,255,255,.12);color:#fff}
}


/* v44 — compacte layout: minder groot, rustiger en meer dashboard */
:root{
  --shadow:0 8px 22px rgba(7,31,42,.12);
  --radius:18px;
}
body{
  background:
    radial-gradient(circle at 15% -5%, rgba(31,182,201,.12), transparent 28%),
    linear-gradient(180deg,#071f2a 0%,#0b2a35 100%);
}
.topbar{padding:8px 12px;min-height:54px}
.brand{gap:8px}.brand-logo{width:34px;height:34px;border-radius:10px}.brand strong{font-size:15px}.brand span{font-size:11px}.source-link{padding:6px 9px;font-size:11px}
main{width:min(860px,100%);padding:10px 12px 22px}.card,.mini-card{border-radius:18px;box-shadow:var(--shadow)}
.hero{padding:15px 16px;margin-bottom:10px;border-radius:18px;background:linear-gradient(135deg,#071f2a 0%,#0b5060 100%)}.hero:after{display:none}.eyebrow{font-size:10px;margin-bottom:5px;letter-spacing:.08em}.hero h1,.home-hero h1{font-size:clamp(24px,6vw,36px);line-height:1.05;letter-spacing:-.04em}.sub,.home-hero .sub{font-size:13px;line-height:1.4;margin-top:7px}.hero-actions{margin-top:12px;gap:8px}.primary,.ghost{padding:11px 13px;border-radius:13px;font-size:14px}.surf-decision{padding:11px 12px;margin-bottom:10px;border-radius:14px;gap:4px}.surf-badge{padding:4px 8px;font-size:10px}.surf-decision strong{font-size:18px;letter-spacing:-.02em}.surf-decision span:last-child{font-size:12px;line-height:1.3}.surf-insights span{min-height:28px;padding:0 10px;font-size:11px}.hero-social{padding:8px 10px;margin-top:9px;border-radius:13px;font-size:13px}
.home-hero{padding:14px 16px}.home-best-card,.home-community-card,.home-suggestions-card,.home-spots-card,.crew-card,.signup,.safety-card,.public-suggestions-card,.suggestion-form-card,.local-edit-card{padding:13px;margin-bottom:9px;border-radius:18px}.section-title{margin-bottom:9px;gap:8px}.section-title h2{font-size:18px;letter-spacing:-.025em}.section-title p{font-size:12px;margin-top:3px;line-height:1.35}.home-best-main{padding:12px 13px;border-radius:16px;gap:10px;background:#fbfdff}.home-best-main h3{font-size:24px;line-height:1.05;letter-spacing:-.035em;margin:5px 0 2px}.home-best-main p{font-size:12px;line-height:1.32;font-weight:750}.home-best-score{display:none}.home-spot-type{padding:4px 7px;font-size:10px;letter-spacing:.05em;margin-bottom:4px}.home-rank-list{gap:6px;margin-top:7px}.home-rank-row{padding:9px 10px;border-radius:13px;gap:6px;grid-template-columns:1fr auto}.home-rank-row span{font-size:13px}.home-rank-row strong{font-size:11px}.home-rank-row small{grid-column:1/-1;font-size:11px;justify-content:flex-start}.home-location-bar{margin-top:9px;padding:8px 9px;border-radius:13px;font-size:11px}.location-btn{padding:7px 9px;font-size:12px}.home-sort-tabs{gap:6px;margin-top:8px}.home-sort-tabs button{padding:8px 6px;font-size:12px}.home-community-list,.home-spot-list,.home-suggestions-list,.public-suggestions-list{gap:7px}.home-community-row{padding:9px 10px;border-radius:13px;gap:8px}.home-community-row strong{font-size:14px}.home-community-row span{font-size:11px}.home-community-row em{font-size:11px;padding:5px 7px}.home-spot-card,.home-spot-card.compact{padding:10px 11px;border-radius:14px;gap:6px}.home-spot-card.compact h3,.home-spot-card h3{font-size:16px;line-height:1.15;margin:0}.home-spot-card.compact p,.home-spot-card p{font-size:11px;line-height:1.28;-webkit-line-clamp:1}.home-spot-meta{gap:3px}.home-spot-meta strong{font-size:13px}.home-spot-meta>span{font-size:11px}.spot-suggestion-badge,.home-alert,.waterplants-badge{font-size:10px;padding:4px 7px;margin-top:4px}
.status-grid{gap:8px;margin-bottom:9px}.mini-card{min-height:0;padding:10px}.mini-card .icon{width:30px;height:30px;border-radius:10px;font-size:17px;margin-bottom:6px}.mini-card small{font-size:9.5px;letter-spacing:.06em}.mini-card strong{font-size:19px;margin:4px 0 1px;letter-spacing:-.02em}.mini-card span:last-child{font-size:11px;line-height:1.25}.counts{gap:6px}.counts div{min-width:56px;padding:7px;border-radius:13px}.counts strong{font-size:19px}.counts span{font-size:9px}.session-list{gap:7px}.session{grid-template-columns:40px 1fr auto;padding:9px;border-radius:14px;gap:9px}.avatar{width:40px;height:40px;border-radius:13px;font-size:16px}.session h3{font-size:14px}.session .note{font-size:11px}.chips{margin-top:5px;gap:4px}.chip{font-size:10px;padding:3px 6px}.empty{padding:15px;border-radius:14px;font-size:12px}
.spot-info-card{padding:13px;border-radius:18px;background:linear-gradient(135deg,#061923 0%,#0b2632 100%);box-shadow:var(--shadow)}.spot-info-head{margin-bottom:9px}.spot-info-card h2{font-size:22px;line-height:1.05}.spot-pill{padding:6px 8px;font-size:10px}.epic-summary{padding:10px 0;margin-bottom:10px;gap:4px}.epic-kicker,.weed-kicker,.usecase-kicker{font-size:10px;letter-spacing:.06em}.epic-summary strong{font-size:24px;line-height:1.05;letter-spacing:-.035em}.epic-summary p{font-size:12px;line-height:1.35}.epic-bars{display:none}.spot-copy{gap:6px}.spot-copy p{font-size:12px;line-height:1.35}.weed-panel,.usecase-panel{margin-top:9px;padding:10px;border-radius:14px}.weed-panel strong,.usecase-panel strong{font-size:17px;margin-bottom:4px}.weed-panel p{font-size:12px;line-height:1.35}.usecase-notes{margin:7px 0 0;padding-left:17px}.usecase-tags span{font-size:10px;padding:4px 6px}.waterplants-actions{gap:7px;margin-top:9px}.suggestion-link,.report-waterplants-btn{padding:8px 10px;font-size:11px}.local-edit-actions{gap:7px;margin-bottom:7px}.suggestion-card{padding:10px;border-radius:14px;gap:6px}.suggestion-card-head strong{font-size:14px}.suggestion-card p{font-size:12px;line-height:1.35}.suggestion-card small,.suggestion-card footer{font-size:11px}.suggestion-card-head em{font-size:10px;padding:4px 6px}.suggestion-form{gap:10px}.suggestion-form label{font-size:12px}.suggestion-form input,.suggestion-form textarea,.suggestion-form select,.signup input,.signup textarea{margin-top:5px;border-radius:12px;padding:10px;font-size:13px}.suggestion-form textarea{min-height:74px}.choice-grid{gap:6px}.choice-grid button,.segmented button{border-radius:12px;padding:9px 6px;font-size:12px}.privacy-note{font-size:11px;margin-top:8px}.check-list p{font-size:12px;line-height:1.35;margin:6px 0}.map-link{padding:10px;border-radius:13px;font-size:13px}.toast{border-radius:14px;padding:11px 13px;font-size:13px}
@media(min-width:760px){main{padding-top:14px}.hero{padding:20px}.home-hero{padding:18px 20px}.home-best-card,.home-community-card,.home-suggestions-card,.home-spots-card,.crew-card,.signup,.safety-card,.public-suggestions-card,.suggestion-form-card,.local-edit-card{padding:16px}.home-spot-card{grid-template-columns:1fr 185px}.status-grid{grid-template-columns:repeat(4,1fr)}.home-best-main h3{font-size:28px}.spot-info-card{padding:16px}.spot-info-card h2{font-size:26px}.epic-summary strong{font-size:28px}}
@media(max-width:680px){main{padding:8px 8px 22px}.topbar{padding:7px 8px}.brand-logo{width:32px;height:32px}.hero,.home-hero{padding:13px;border-radius:16px}.hero h1,.home-hero h1{font-size:25px}.sub,.home-hero .sub{font-size:12px}.hero-actions{grid-template-columns:1fr 1fr}.hero-actions .primary,.hero-actions .ghost{padding:10px 8px}.home-best-card,.home-community-card,.home-suggestions-card,.home-spots-card,.crew-card,.signup,.safety-card,.spot-info-card,.suggestion-form-card,.local-edit-card,.public-suggestions-card{padding:11px;border-radius:16px;margin-bottom:8px}.section-title h2{font-size:17px}.home-best-main{padding:10px;border-radius:14px}.home-best-main h3{font-size:22px}.status-grid{grid-template-columns:repeat(4,1fr);gap:6px}.mini-card{padding:8px;border-radius:14px;text-align:left}.mini-card .icon{display:none}.mini-card strong{font-size:16px}.mini-card small{font-size:8.5px}.mini-card span:last-child{font-size:10px}.spot-info-card h2{font-size:21px}.epic-summary strong{font-size:22px}.local-edit-actions{grid-template-columns:1fr 1fr}.mobile-sticky-actions{left:8px;right:8px;bottom:8px;padding:7px;border-radius:16px}.mobile-sticky-actions .primary,.mobile-sticky-actions .ghost{padding:10px;border-radius:12px;font-size:13px}.safety-card{margin-bottom:70px}.counts div{min-width:50px}}
@media(max-width:430px){.status-grid{grid-template-columns:repeat(2,1fr)}.mini-card{min-height:66px}.home-rank-row{grid-template-columns:1fr}.home-community-row{grid-template-columns:1fr}.home-community-row em{width:max-content}.spot-info-head{display:grid}.spot-pill{width:max-content}.local-edit-actions{grid-template-columns:1fr}.waterplants-actions{display:grid}.waterplants-actions .suggestion-link,.report-waterplants-btn{width:100%;justify-content:center}.choice-grid{grid-template-columns:repeat(4,1fr)}.bft-grid{grid-template-columns:repeat(5,1fr)}}

/* v47 — compacte homepage en database-first basis */
.home-personal-card{padding:13px;margin-bottom:9px;border-radius:18px;background:#fff;box-shadow:var(--shadow);border:1px solid rgba(200,218,226,.72)}
.origin-form{display:grid;gap:6px;margin:2px 0 8px}
.origin-form label{font-size:12px;font-weight:900;color:#29434f}
.origin-row{display:grid;grid-template-columns:1fr auto;gap:7px;align-items:center}
.origin-row input{width:100%;border:1.5px solid var(--line);border-radius:13px;padding:9px 10px;font:inherit;font-size:13px;font-weight:750;color:#071f2a;background:#fbfdff;outline:none}
.origin-row input:focus{border-color:var(--surfse);box-shadow:0 0 0 4px rgba(31,182,201,.10);background:#fff}
.location-btn.secondary{background:#f5f8fa;color:#55707c;border:1px solid var(--line)}
.geo-note{margin:8px 2px 0;color:#6f8793;font-size:10.5px;line-height:1.35;font-weight:750}
.personal-reason{display:inline-flex;width:max-content;max-width:100%;margin-top:6px;padding:4px 7px;border-radius:999px;background:#eef8f1;color:#2f7a45;font-size:10px;font-weight:950}
.compact-list{margin-top:6px}
@media(max-width:680px){.home-personal-card{padding:11px;border-radius:16px;margin-bottom:8px}.origin-row{grid-template-columns:1fr auto;gap:6px}.origin-row input{padding:8px 9px;font-size:12px}.geo-note{font-size:10px}.personal-reason{font-size:9.5px}}
@media(max-width:430px){.origin-row{grid-template-columns:1fr}.origin-row .location-btn{width:100%}.home-location-bar .location-btn.secondary{width:max-content}}


/* v49 - AI-verwachting compact */
.ai-insight-card{padding:13px 15px;margin-bottom:10px;border-radius:18px;background:#f7fcff;border-color:rgba(31,182,201,.22)}
.ai-insight-card .section-title{margin-bottom:6px}
.ai-insight-card h2{font-size:17px;margin:0;letter-spacing:-.02em}
.ai-insight-card p{font-size:12px;line-height:1.4;margin:3px 0 0;color:var(--muted)}
.ai-insight-meta{font-size:10.5px!important;color:#6d8192!important;margin-top:7px!important}
@media(max-width:680px){.ai-insight-card{padding:10px 11px;margin-bottom:8px;border-radius:15px}.ai-insight-card h2{font-size:15px}.ai-insight-card p{font-size:11.5px}}


/* v50 — eenvoudige spotkaart zonder externe kaartdienst (overschreven in v51) */
.home-map-card{padding:18px;margin-bottom:12px}
.surfse-map{position:relative;height:280px;border-radius:20px;overflow:hidden;background:
  radial-gradient(circle at 60% 44%, rgba(86,214,230,.42), transparent 0 19%, transparent 20%),
  linear-gradient(135deg,#dff7ff 0%,#f8fdff 50%,#edf7f1 100%);border:1px solid var(--line)}
.map-water-shape{position:absolute;inset:10%;border-radius:45% 55% 50% 40%;background:linear-gradient(135deg,rgba(86,214,230,.34),rgba(31,182,201,.18));filter:blur(.2px)}
.map-pin{position:absolute;transform:translate(-50%,-50%);width:28px;height:28px;border:2px solid #fff;border-radius:999px;display:grid;place-items:center;box-shadow:0 7px 18px rgba(7,31,42,.24);z-index:2;background:#8fb0bc}
.map-pin span{width:10px;height:10px;border-radius:999px;background:#fff;display:block}
.map-pin.good{background:var(--good)}.map-pin.warn{background:var(--warn)}.map-pin.bad{background:var(--bad)}
.map-legend{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;color:#55707c;font-size:12px;font-weight:800}.map-legend span{display:flex;align-items:center;gap:5px}.map-dot{width:10px;height:10px;border-radius:999px;display:inline-block}.map-dot.good{background:var(--good)}.map-dot.warn{background:var(--warn)}.map-dot.bad{background:var(--bad)}
.map-selected{margin-top:10px;border:1px solid var(--line);background:#fbfdff;border-radius:16px;padding:11px;color:#55707c;font-size:13px}.map-selected a{display:grid;gap:3px;color:#12202a;text-decoration:none}.map-selected strong{font-size:16px}.map-selected span{color:#0e6f86;font-weight:900}.map-selected small{color:#55707c;line-height:1.3}.report-waterplants-btn.good{background:#e9f9ee;color:#178a55;border-color:rgba(39,184,120,.26)}
@media(max-width:680px){.home-map-card{padding:11px;border-radius:16px;margin-bottom:8px}.surfse-map{height:220px;border-radius:16px}.map-pin{width:24px;height:24px}.map-legend{font-size:10.5px;gap:6px}.map-selected{font-size:12px;padding:9px}}


/* v51 — echte MapLibre spotkaart */
.home-map-card{padding:18px;margin-bottom:12px}
.surfse-map.maplibre-surfse-map{
  position:relative;
  height:360px;
  border-radius:20px;
  overflow:hidden;
  background:#dff7ff;
  border:1px solid var(--line);
}
.map-loading{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  color:#55707c;
  font-size:13px;
  font-weight:850;
  background:linear-gradient(135deg,#dff7ff 0%,#f8fdff 50%,#edf7f1 100%);
}
.maplibregl-ctrl-bottom-left,.maplibregl-ctrl-bottom-right{font-size:10px}
.maplibregl-ctrl-attrib{border-radius:10px 0 0 0;opacity:.86}
.maplibregl-ctrl-group{border-radius:14px!important;overflow:hidden;box-shadow:0 8px 18px rgba(7,31,42,.12)!important}
.maplibre-spot-pin{
  width:28px;
  height:28px;
  border:3px solid #fff;
  border-radius:999px;
  display:grid;
  place-items:center;
  box-shadow:0 8px 20px rgba(7,31,42,.24);
  cursor:pointer;
  transition:transform .12s ease, box-shadow .12s ease;
  background:#8fb0bc;
  padding:0;
}
.maplibre-spot-pin span{width:10px;height:10px;border-radius:999px;background:#fff;display:block}
.maplibre-spot-pin.good{background:var(--good)}
.maplibre-spot-pin.warn{background:var(--warn)}
.maplibre-spot-pin.bad{background:var(--bad)}
.maplibre-spot-pin.unknown{background:#8fb0bc}
.maplibre-spot-pin:hover,.maplibre-spot-pin.active{transform:scale(1.12);box-shadow:0 12px 26px rgba(7,31,42,.30)}
.map-legend{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;color:#55707c;font-size:12px;font-weight:800}
.map-legend span{display:flex;align-items:center;gap:5px}.map-dot{width:10px;height:10px;border-radius:999px;display:inline-block}.map-dot.good{background:var(--good)}.map-dot.warn{background:var(--warn)}.map-dot.bad{background:var(--bad)}
.map-selected{margin-top:10px;border:1px solid var(--line);background:#fbfdff;border-radius:16px;padding:11px;color:#55707c;font-size:13px}
.map-selected a{display:grid;gap:3px;color:#12202a;text-decoration:none}.map-selected strong{font-size:16px}.map-selected span{color:#0e6f86;font-weight:900}.map-selected small{color:#55707c;line-height:1.3}
@media(max-width:680px){.home-map-card{padding:11px;border-radius:16px;margin-bottom:8px}.surfse-map.maplibre-surfse-map{height:320px;border-radius:16px}.maplibre-spot-pin{width:24px;height:24px}.map-legend{font-size:10.5px;gap:6px}.map-selected{font-size:12px;padding:9px}}


/* v52 map-first + cache */
#homeBestCard,
#homePersonalCard {
  display: none !important;
}

#homeMapCard {
  margin-bottom: 12px;
}

#homeSpotMap,
.surfse-map.maplibre-surfse-map {
  height: 500px !important;
  min-height: 460px !important;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(143,224,238,.40);
  background: #dff1f6;
}

.map-cache-note {
  margin: -4px 0 10px;
  font-size: 12px;
  color: #6b8995;
  font-weight: 700;
}

.map-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
  align-items: center;
  margin: 8px 0 12px;
  font-size: 13px;
  color: #335766;
  font-weight: 800;
}

.map-legend span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.map-dot.unknown { background: #8395a7; }

.home-map-top-options {
  margin-top: 14px;
}

.map-options-head {
  display: flex;
  flex-direction: column;
  gap: 3px;
  margin-bottom: 8px;
}

.map-options-head strong {
  font-size: 16px;
}

.map-options-head span {
  font-size: 13px;
  color: #6b8995;
}

.map-options-list {
  display: grid;
  gap: 8px;
}

.map-option-row {
  display: grid;
  grid-template-columns: 30px 1fr;
  gap: 10px;
  align-items: center;
  padding: 10px 11px;
  border-radius: 14px;
  border: 1px solid #d6e8ed;
  background: #f8fcfd;
  color: inherit;
  text-decoration: none;
}

.map-option-row em {
  width: 26px;
  height: 26px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: #e8fbff;
  color: #0b6e84;
  font-style: normal;
  font-weight: 900;
}

.map-option-row strong {
  display: block;
  font-size: 14px;
}

.map-option-row span {
  display: block;
  margin-top: 2px;
  font-size: 12px;
  color: #55727d;
}

@media (max-width: 680px) {
  #homeSpotMap,
  .surfse-map.maplibre-surfse-map {
    height: 420px !important;
    min-height: 400px !important;
  }

  .map-legend {
    font-size: 12px;
    gap: 7px 10px;
  }
}

/* v58.2 — rustige homepage-intro zonder dubbele CTA bovenaan */
.home-hero-note{position:relative;z-index:2;margin:14px 0 0;max-width:640px;color:#dff7ff;font-size:14px;line-height:1.55;font-weight:800}
@media(max-width:680px){.home-hero-note{font-size:12px;line-height:1.4;margin-top:9px}}

/* v58.1 — alle-spots-pagina en compacte homepage */
.topbar .brand{color:inherit;text-decoration:none}
.home-all-spots-link{
  display:flex;align-items:center;justify-content:center;
  border:1px dashed rgba(31,182,201,.45);border-radius:18px;
  padding:14px 16px;background:#f7fcff;color:#0e6f86;
  text-decoration:none;font-weight:950
}
.home-all-spots-link:hover{background:#e8fbff;border-color:rgba(31,182,201,.72)}
.all-spots-page{width:min(1060px,100%);max-width:none;margin:0 auto;padding:16px 12px 34px}
.all-spots-hero{
  display:grid;gap:18px;align-items:end;
  border-color:rgba(143,224,238,.20);
  background:
    radial-gradient(circle at 88% 8%, rgba(245,185,66,.18), transparent 30%),
    linear-gradient(135deg,#061923 0%,#0b5060 58%,#159fb3 100%);
}
.all-spots-hero .hero-text{position:relative;z-index:2}
.all-spots-search{position:relative;z-index:2;display:grid;gap:7px;align-self:end}
.all-spots-search label{font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.08em;color:#c7f0ff}
.all-spots-search input{
  width:100%;border:1px solid rgba(255,255,255,.30);border-radius:16px;
  padding:13px 14px;background:rgba(255,255,255,.95);color:#071f2a;
  font:inherit;font-weight:850;outline:none;box-shadow:0 12px 28px rgba(7,31,42,.12)
}
.all-spots-search input::placeholder{color:#6b8995}
.all-spots-search input:focus{border-color:#8fe0ee;box-shadow:0 0 0 4px rgba(31,182,201,.18),0 12px 28px rgba(7,31,42,.12)}
.all-spots-intro{
  display:flex;justify-content:space-between;align-items:flex-start;gap:14px;
  padding:18px;margin:12px 0;color:#12202a
}
.all-spots-intro h2{margin:0 0 5px;font-size:24px;letter-spacing:-.04em;color:#071f2a}
.all-spots-intro p{margin:0;color:#55707c;line-height:1.45;font-weight:750}
.all-spots-group{
  margin:14px 0;padding:18px;border:1px solid rgba(143,224,238,.24);
  border-radius:24px;background:rgba(255,255,255,.96);box-shadow:0 18px 44px rgba(7,31,42,.13);color:#12202a
}
.all-spots-group-head{display:flex;align-items:end;justify-content:space-between;gap:12px;margin:0 0 12px}
.all-spots-group-head h2{margin:0;font-size:24px;letter-spacing:-.045em;color:#071f2a}
.all-spots-group-head span{flex:0 0 auto;border-radius:999px;background:#e8fbff;color:#0e6f86;padding:6px 10px;font-size:12px;font-weight:950}
.all-spots-list{display:grid;gap:10px}
.all-spot-card{
  display:grid;gap:9px;padding:15px 16px;border:1px solid #d6e8ed;border-radius:20px;
  background:linear-gradient(180deg,#ffffff 0%,#f8fcfd 100%);color:#12202a;text-decoration:none;
  box-shadow:0 10px 22px rgba(7,31,42,.05);transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease
}
.all-spot-card:hover{transform:translateY(-1px);border-color:rgba(31,182,201,.55);box-shadow:0 16px 34px rgba(7,31,42,.12)}
.all-spot-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.all-spot-card strong{display:block;font-size:20px;line-height:1.05;letter-spacing:-.04em;color:#071f2a}
.all-spot-type{flex:0 0 auto;border-radius:999px;background:#eef8fb;color:#0e6f86;padding:5px 8px;font-size:10.5px;font-weight:950;text-transform:uppercase;letter-spacing:.055em;white-space:nowrap}
.all-spot-card p{margin:0;color:#486876;line-height:1.42;font-weight:700;font-size:13.5px}
.all-spot-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:1px}
.all-spot-meta span{color:#0e6f86;background:#e8fbff;border-radius:999px;padding:5px 8px;font-size:11.5px;font-weight:900;max-width:100%}
@media(min-width:760px){
  .all-spots-hero{grid-template-columns:1fr minmax(280px,360px)}
  .all-spots-list{grid-template-columns:repeat(2,minmax(0,1fr))}
  .all-spot-card{min-height:178px;align-content:start}
}
@media(max-width:680px){
  .all-spots-page{padding:8px 8px 24px}
  .all-spots-hero{gap:12px}
  .all-spots-intro{display:block;padding:13px;border-radius:16px;margin:8px 0}
  .all-spots-intro h2{font-size:20px}
  .all-spots-intro p{font-size:12.5px}
  .all-spots-group{padding:12px;border-radius:18px;margin:9px 0}
  .all-spots-group-head h2{font-size:20px}
  .all-spots-list{gap:7px}
  .all-spot-card{padding:11px 12px;border-radius:15px;gap:7px}
  .all-spot-title-row{display:grid;gap:6px}
  .all-spot-card strong{font-size:17px}
  .all-spot-card p{font-size:12px;line-height:1.34}
  .all-spot-meta span{font-size:10.5px;padding:4px 7px}
}


/* v58.4 — duidelijkere kaartselectie met CTA */
.map-selected{
  background:#f8fcfd;
  border:1px solid #d6e8ed;
  color:#506a76;
}
.map-selected-card{
  display:grid;
  grid-template-columns:1fr auto;
  gap:12px;
  align-items:center;
}
.map-selected-main{
  display:grid;
  gap:3px;
  color:#12202a;
  text-decoration:none;
  min-width:0;
}
.map-selected-main strong{font-size:16px;line-height:1.15}
.map-selected-main span{color:#0e6f86;font-weight:900}
.map-selected-main small{color:#55707c;line-height:1.35}
.map-selected-button,
.map-popup-card a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:36px;
  padding:8px 14px;
  border-radius:999px;
  border:1px solid rgba(14,111,134,.18);
  background:linear-gradient(135deg,#0e6f86,#1fb6c9);
  color:#ffffff!important;
  text-decoration:none!important;
  font-weight:950;
  box-shadow:0 10px 22px rgba(14,111,134,.24);
  white-space:nowrap;
  opacity:1;
}
.map-selected-button:visited,
.map-popup-card a:visited{color:#ffffff!important}
.map-selected-button:hover,
.map-popup-card a:hover{
  transform:translateY(-1px);
  background:linear-gradient(135deg,#0b5f73,#159fb1);
  color:#ffffff!important;
}
.map-popup-card{display:grid;gap:5px;min-width:170px;color:#12202a}
.map-popup-card strong{font-size:15px;line-height:1.15}
.map-popup-card span{font-size:12px;color:#55707c;font-weight:800;line-height:1.25}
.map-popup-card a{margin-top:4px;min-height:32px;padding:7px 10px;font-size:12px}
.maplibregl-popup-content{border-radius:16px!important;padding:12px!important;box-shadow:0 16px 34px rgba(7,31,42,.22)!important;border:1px solid rgba(214,232,237,.8)}
.maplibregl-popup-close-button{font-size:18px;color:#55707c;padding:2px 7px}
.maplibre-spot-pin::after{
  content:'';
  position:absolute;
  inset:-8px;
  border-radius:999px;
}
@media(max-width:680px){
  .map-selected-card{grid-template-columns:1fr;gap:9px}
  .map-selected-button{width:100%;min-height:40px}
}


/* v59.2 — server-rendered spotdetail fallback voor SEO en no-JS */
.js .spot-static-page { display: none; }
.spot-static-page { width: min(1120px, calc(100% - 24px)); margin: 18px auto 28px; }
.spot-static-hero { padding: 24px; }
.spot-static-nav { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:14px; }
.spot-static-nav a,
.spot-static-links a { display:inline-flex; align-items:center; gap:6px; text-decoration:none; font-weight:800; color:#075985; background:#e0f2fe; border:1px solid rgba(14,116,144,.18); border-radius:999px; padding:9px 12px; }
.spot-static-hero h1 { margin: 6px 0 10px; color:#073b4c; font-size: clamp(2rem, 6vw, 4rem); line-height:.95; letter-spacing:-.06em; }
.spot-static-hero .sub { color:#285262; max-width:820px; }
.spot-static-chips { display:flex; flex-wrap:wrap; gap:8px; margin-top:16px; }
.spot-static-chips span { background:#f0f9ff; border:1px solid rgba(14,116,144,.15); color:#075985; border-radius:999px; padding:8px 10px; font-weight:800; font-size:.85rem; }
.spot-static-grid { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap:14px; margin:14px 0; }
.spot-static-card { padding:20px; color:#17384a; }
.spot-static-card h2 { margin:0 0 10px; color:#073b4c; }
.spot-static-card p { color:#31596a; line-height:1.6; }
.spot-static-card dl { display:grid; gap:10px; margin:0; }
.spot-static-card dl div { display:flex; justify-content:space-between; gap:14px; border-bottom:1px solid rgba(15,76,129,.1); padding-bottom:8px; }
.spot-static-card dt { font-weight:800; color:#456b78; }
.spot-static-card dd { margin:0; color:#073b4c; font-weight:800; text-align:right; }
.spot-static-card ul { margin:10px 0 0 18px; color:#31596a; line-height:1.6; }
.spot-static-links { display:flex; flex-wrap:wrap; gap:10px; }
.spot-static-js-note { margin-top:14px; }
@media (max-width: 760px) {
  .spot-static-page { width: min(100% - 16px, 1120px); margin-top:10px; }
  .spot-static-grid { grid-template-columns: 1fr; }
  .spot-static-card dl div { display:block; }
  .spot-static-card dd { text-align:left; margin-top:3px; }
}
