*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#0f1014;--s1:#16181e;--s2:#1e2028;--s3:#252830;
  --bdr:#2a2d38;--acc:#f07818;--acc2:#ff9a3c;
  --txt:#e8eaf0;--txt2:#a0a8bc;--mut:#9aa3b8;
  --grn:#22c55e;--red:#ef4444;--blue:#3b82f6;
  --font:'Barlow',sans-serif;--fontc:'Barlow Condensed',sans-serif;
  /* v3 design tokens — naast bestaande, geen overschrijvingen */
  --fh:'Syne',sans-serif;--fb:'DM Sans',sans-serif;
  --accent:#f97316;
  --bg2:#111111;--bg3:#161616;--bg4:#1e1e1e;
  --border:#1e1e1e;--border2:#2a2a2a;
  --text:#e8e8e8;--text2:#c8c8c8;--text3:#888;--text4:#555;--text5:#3a3a3a;
  --green:#10b981;
}
body.light-theme{
  --bg:#f0f2f5;--s1:#ffffff;--s2:#e8eaed;--s3:#dde0e6;
  --bdr:#d1d5db;--txt:#111827;--txt2:#4b5563;--mut:#9ca3af;
  color-scheme:light;
}
/* Wit tekst op elementen zonder expliciete achtergrond → donker maken */
body.light-theme [style*="color:#fff"]:not([style*="background"]),
body.light-theme [style*="color: #fff"]:not([style*="background"]),
body.light-theme [style*="color:white"]:not([style*="background"]){color:var(--txt)!important}
/* Feed-card border zichtbaar maken op lichte achtergrond */
body.light-theme .feed-card{border-color:rgba(0,0,0,.1)!important}
/* Select/option elementen (hardcoded donker) */
body.light-theme select,body.light-theme option{background-color:var(--s2)!important;color:var(--txt)!important}
/* Input en textarea placeholders */
body.light-theme input::placeholder,body.light-theme textarea::placeholder{color:var(--mut)!important}
/* Inputs met hardcoded donkere achtergrond via rgba */
body.light-theme input[style*="background:rgba(255,255,255,.06)"],
body.light-theme textarea[style*="background:rgba(255,255,255,.06)"]{background:var(--s2)!important;color:var(--txt)!important}
/* Kaart overlays leesbaar houden */
body.light-theme #znote,body.light-theme #ldr{background:rgba(255,255,255,.9)!important;color:var(--txt)!important}
html,body{height:100%;overflow:hidden;background:var(--bg,#0f1014);color:var(--txt,#e8eaf0);font-family:var(--font,'Barlow',sans-serif)}
body:not(.light-theme){color:#e8eaf0}
body.light-theme{color:#111827}
#topbar{position:fixed;top:0;left:0;right:0;height:54px;background:var(--s1);border-bottom:1px solid var(--bdr);display:flex;align-items:center;z-index:3000;padding:0 16px;gap:8px}
.logo-wrap{display:flex;align-items:center;gap:8px;padding-right:16px;border-right:1px solid var(--bdr);height:100%;flex-shrink:0}
.logo-ico{width:32px;height:32px;border-radius:7px;overflow:hidden;flex-shrink:0}
.logo-name{font-family:var(--fontc);font-size:19px;font-weight:800;color:var(--txt)}
.logo-name span{color:var(--acc)}
.logo-img{height:20px;width:auto;display:block;flex-shrink:0}
.nav-tabs{display:flex;height:100%;margin-left:8px}
.nav-tab{display:flex;align-items:center;gap:6px;padding:0 14px;color:var(--txt2);font-size:13px;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;background:none;border-top:none;border-left:none;border-right:none;font-family:var(--font)}
.nav-tab:hover{color:var(--txt)}
.nav-tab.active{color:var(--acc);border-bottom-color:var(--acc)}
#sinp-wrap{position:relative;flex:1;max-width:400px;margin:0 12px}
#sinp{width:100%;padding:8px 12px 8px 34px;background:var(--s2);border:1px solid var(--bdr);border-radius:7px;color:var(--txt);font-family:var(--font);font-size:13px;outline:none}
#sinp:focus{border-color:var(--acc)}
#sinp-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--mut);pointer-events:none}
#sugs{position:absolute;top:calc(100%+4px);background:var(--s1);border:1px solid var(--bdr);border-radius:8px;z-index:200;display:none;max-height:260px;overflow-y:auto}
#sugs.open{display:block}
.si{padding:9px 12px;cursor:pointer;border-bottom:1px solid var(--bdr);font-size:13px;display:flex;align-items:center;gap:8px}
.si:hover{background:var(--s2)}
.si-main{font-weight:600}.si-sub{font-size:11px;color:var(--mut);margin-top:1px}
#btn-vondst-snel{display:none;padding:7px 14px;border-radius:7px;border:none;background:linear-gradient(135deg,#f07818,#ff9a3c);color:#000;font-family:var(--font);font-size:12.5px;font-weight:700;cursor:pointer;align-items:center;gap:6px;flex-shrink:0;transition:opacity .15s}
#btn-vondst-snel:hover{opacity:.85}
#desktop-fab-vondst{display:none;position:fixed;bottom:32px;right:32px;width:56px;height:56px;border-radius:50%;background:var(--acc);color:#fff;font-size:28px;font-weight:800;border:none;cursor:pointer;align-items:center;justify-content:center;box-shadow:0 4px 18px rgba(240,120,24,.5);z-index:900;transition:transform .15s,box-shadow .15s;line-height:1;font-family:var(--font)}
#desktop-fab-vondst:hover{transform:scale(1.08);box-shadow:0 6px 24px rgba(240,120,24,.65)}
@media(min-width:1024px){#desktop-fab-vondst{display:flex}}
body:not(:has(#kaart-view.active)) #desktop-fab-vondst{display:none!important}
.top-btn{padding:7px 12px;border-radius:7px;border:1px solid var(--bdr);background:none;color:var(--txt2);font-family:var(--font);font-size:12.5px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .15s;flex-shrink:0}
.top-btn:hover{border-color:var(--acc);color:var(--acc)}
.top-btn.acc{background:linear-gradient(135deg,#f07818,#ff9a3c);border-color:transparent;color:#000;font-weight:700}
.top-btn.act{background:rgba(240,120,24,.18);border-color:var(--acc);color:var(--acc);font-weight:700}
.user-avatar{width:30px;height:30px;border-radius:50%;background:#161622;display:grid;place-items:center;font-size:13px;font-weight:800;color:rgba(255,255,255,.75);cursor:pointer;flex-shrink:0;border:2px solid rgba(255,140,0,0.55);box-shadow:0 0 12px rgba(255,140,0,0.35);overflow:hidden}
#app{position:fixed;top:54px;left:0;right:0;bottom:0;display:flex;flex-direction:row}
/* KAART */
#kaart-view{flex:1;display:flex;overflow:hidden}
#map{flex:1;position:relative}
#sidebar{width:340px;flex-shrink:0;background:var(--s1);border-left:1px solid var(--bdr);display:none;flex-direction:column;overflow:hidden}
#sidebar.open{display:flex}
#sbhead{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--bdr);flex-shrink:0}
.sb-tabs{display:flex;gap:4px}
.sb-tab{padding:5px 12px;border-radius:6px;border:none;background:none;color:var(--txt2);font-family:var(--font);font-size:12.5px;font-weight:600;cursor:pointer}
.sb-tab.active{background:rgba(240,120,24,.15);color:var(--acc)}
#sbody{flex:1;overflow-y:auto;padding:12px}
#rpanel{width:340px;flex-shrink:0;background:var(--s1);border-left:1px solid var(--bdr);display:none;flex-direction:column;overflow:hidden}
#rpanel.open{display:flex}
.rp-head{padding:14px 16px;border-bottom:1px solid var(--bdr);flex-shrink:0}
.rp-tag{font-size:10px;text-transform:uppercase;letter-spacing:1.2px;color:var(--acc);margin-bottom:5px}
.rp-title{font-family:var(--fontc);font-size:18px;font-weight:800;line-height:1.2}
.rp-sub{font-size:12px;color:var(--txt2);margin-top:3px}
.rp-body{flex:1;overflow-y:auto;padding:14px 16px}
.rp-close{background:none;border:none;color:var(--mut);font-size:18px;cursor:pointer;padding:4px}
/* KAART OVERLAYS */
#znote{position:absolute;top:10px;left:50%;transform:translateX(-50%);background:rgba(22,24,30,.9);border:1px solid var(--bdr);border-radius:8px;padding:7px 14px;font-size:12px;color:var(--txt2);z-index:500;pointer-events:none;white-space:nowrap}
#ldr{display:none;position:absolute;top:10px;left:10px;z-index:500;background:rgba(22,24,30,.9);border:1px solid var(--bdr);border-radius:8px;padding:7px 14px;font-size:12px;color:var(--txt2);align-items:center;gap:8px}
#ldr.on{display:flex}
.sp{width:14px;height:14px;border:2px solid var(--acc);border-top-color:transparent;border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
#zind{position:absolute;bottom:30px;right:10px;z-index:500;background:rgba(0,0,0,.6);border-radius:6px;padding:3px 8px;font-size:11px;color:var(--mut)}
#cbadge{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);z-index:500;background:rgba(240,120,24,.15);border:1px solid rgba(240,120,24,.4);border-radius:8px;padding:4px 12px;font-size:12px;color:var(--acc);pointer-events:none;display:none}
#cbadge.show{display:block}
.map-ctrl-btn{width:38px;height:38px;border-radius:9px;background:var(--s1);border:1px solid var(--bdr);color:var(--txt2);font-size:17px;cursor:pointer;display:grid;place-items:center;transition:all .15s;box-shadow:0 3px 10px rgba(0,0,0,.5)}
.map-ctrl-btn:hover{border-color:var(--acc);color:var(--acc)}
.map-ctrl-btn.act{background:rgba(240,120,24,.2);border-color:var(--acc);color:var(--acc)}
.ptip{background:var(--s1)!important;border:1px solid var(--acc)!important;color:var(--txt)!important;font-family:'Barlow Condensed',sans-serif!important;font-size:12px!important;font-weight:700!important;padding:2px 8px!important;border-radius:5px!important;box-shadow:0 3px 10px rgba(0,0,0,.5)!important;white-space:nowrap;pointer-events:none}
.verloren-popup .leaflet-popup-content-wrapper{background:var(--s1);border:1px solid var(--bdr);border-radius:10px;color:var(--txt);box-shadow:0 4px 16px rgba(0,0,0,.6)}
.verloren-popup .leaflet-popup-tip{background:var(--s1)}
.perceel-stack-popup .leaflet-popup-content-wrapper{background:var(--s1);border:1px solid var(--bdr);border-radius:10px;box-shadow:0 4px 20px rgba(0,0,0,.6);padding:10px 12px}
.perceel-stack-popup .leaflet-popup-tip{background:var(--s1)}
.perceel-stack-popup .leaflet-popup-content{margin:0}
.leaflet-control-attribution{display:none!important}
@keyframes dashMarch{to{stroke-dashoffset:-20}}
.perceel-selected{animation:dashMarch 0.6s linear infinite}
/* PANEL INPUTS */
.rp-lbl{font-size:10px;color:var(--txt2);font-weight:700;text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:3px}
.rp-inp{width:100%;padding:7px 10px;background:var(--s2);border:1px solid var(--bdr);border-radius:6px;color:var(--txt);font-family:var(--font);font-size:12.5px;outline:none}
.rp-inp:focus{border-color:var(--acc)}
.rp-prog{width:100%;accent-color:var(--acc);cursor:pointer;margin:6px 0 2px;height:4px}
/* VIEWS */
#dashboard-view,#vondsten-view,#locaties-view,#verloren-view,#profiel-view,#instellingen-view,#support-view,#advertenties-view,#ontdek-view,#gebruiker-view,#statistieken-view,#contacten-view,#zoekmomenten-view,#sessies-view,#abonnement-view{flex:1;overflow-y:auto;background:var(--bg);display:none}
#dashboard-view.active,#vondsten-view.active,#locaties-view.active,#verloren-view.active,#profiel-view.active,#instellingen-view.active,#support-view.active,#advertenties-view.active,#statistieken-view.active,#contacten-view.active,#zoekmomenten-view.active,#sessies-view.active,#abonnement-view.active{display:block}
#profiel-view,#gebruiker-view{position:relative;z-index:10;background:var(--bg);isolation:isolate}
/* DASHBOARD */
.dash-stat{background:var(--s1);border:1px solid var(--bdr);border-radius:10px;padding:16px;transition:border-color .2s}
.dash-stat:hover{border-color:rgba(240,120,24,.4)}
.dash-action{width:100%;padding:10px 12px;background:rgba(255,255,255,.03);border:1px solid var(--bdr);border-radius:8px;color:var(--txt);font-family:var(--font);cursor:pointer;display:flex;align-items:center;gap:12px;text-align:left;transition:all .15s}
.dash-action:hover{border-color:var(--acc);background:rgba(240,120,24,.07)}
.dash-vitem{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.04);cursor:pointer;transition:background .15s}
.dash-vitem:hover{background:rgba(255,255,255,.03)}
.dash-vitem:last-child{border:none}
.dash-vthumb{width:44px;height:44px;border-radius:8px;object-fit:cover;background:var(--s2);border:1px solid var(--bdr);display:grid;place-items:center;font-size:22px;flex-shrink:0}
.dash-sitem{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.04);cursor:pointer;transition:background .15s}
.dash-sitem:hover{background:rgba(255,255,255,.03)}
.notif-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--bdr);cursor:pointer;transition:background .15s}
.notif-item:hover{background:rgba(255,255,255,.04)}
.notif-item:last-child{border:none}
.notif-item.unread{background:rgba(240,120,24,.05)}
/* DM CHAT BUBBLES */
.dm-bubble{max-width:72%;padding:9px 13px;border-radius:14px;font-size:13px;line-height:1.45;word-break:break-word}
.dm-bubble.mijn{background:var(--acc);color:#000;border-bottom-right-radius:4px;align-self:flex-end}
.dm-bubble.ander{background:var(--s2);color:var(--txt);border-bottom-left-radius:4px;align-self:flex-start}
.dm-bubble-wrap{display:flex;flex-direction:column}
.dm-bubble-wrap.mijn{align-items:flex-end}
.dm-bubble-wrap.ander{align-items:flex-start}
.dm-tijd{font-size:10px;color:var(--mut);margin-top:2px}
/* PROFIEL DROPDOWN */
.pd-item{display:block;width:100%;padding:11px 16px;text-align:left;background:none;border:none;color:var(--txt);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}
.pd-item:hover{background:rgba(255,255,255,.06)}
/* MIJN SUB-TABS */
.mijn-subtabs{display:flex;gap:0;border-bottom:2px solid var(--bdr);background:var(--s1);overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;touch-action:pan-x;scrollbar-width:none}
.mijn-subtabs::-webkit-scrollbar{display:none}
.mijn-sub{padding:10px 20px;font-size:13px;font-weight:600;color:var(--txt2);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;font-family:var(--font);transition:all .15s;white-space:nowrap;flex-shrink:0}
.mijn-sub:hover{color:var(--txt)}
.mijn-sub.active{color:var(--acc);border-bottom-color:var(--acc)}
/* STATISTIEKEN KPI CARDS */
.stat-kpi-card{background:var(--s2);border:1px solid var(--bdr);border-radius:12px;padding:16px 18px;display:flex;flex-direction:column;gap:4px}
.skpi-val{font-family:var(--fontc);font-size:28px;font-weight:800;color:var(--acc);line-height:1}
.skpi-lbl{font-size:11px;color:var(--mut);font-weight:600;letter-spacing:.4px;text-transform:uppercase}
/* GEBRUIKER PROFIEL TABS */
.gp-tabs{display:flex;gap:0;border-bottom:2px solid rgba(255,255,255,0.08);margin-bottom:24px}
.gp-tab{padding:10px 20px;font-weight:700;color:rgba(255,255,255,0.4);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;font-family:var(--font);transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:4px}
.gp-tab .gp-tab-icon{font-size:20px;line-height:1}
.gp-tab .gp-tab-lbl{font-size:11px;font-weight:700;letter-spacing:.3px}
.gp-tab:hover{color:rgba(255,255,255,0.75)}
.gp-tab.actief{color:#fff;border-bottom-color:#f07818;text-shadow:0 0 14px rgba(255,140,0,0.45)}
/* AD SLIDESHOW */
.ad-slideshow{position:relative;overflow:hidden;border-radius:14px}
.ad-slide{display:none;animation:fadeSlide .4s ease;cursor:pointer}
.ad-slide.active{display:block}
@keyframes fadeSlide{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.ad-dots{display:flex;justify-content:center;gap:6px;padding:8px 0 4px}
.ad-dot{width:7px;height:7px;border-radius:50%;background:var(--bdr);cursor:pointer;transition:background .2s}
.ad-dot.act{background:var(--acc)}
.ad-arrows{position:absolute;top:40%;transform:translateY(-50%);width:100%;display:flex;justify-content:space-between;pointer-events:none;padding:0 8px;z-index:2}
.ad-arrow{pointer-events:all;width:28px;height:28px;background:rgba(0,0,0,.5);border-radius:50%;border:none;color:#fff;cursor:pointer;font-size:14px;display:grid;place-items:center;line-height:1}
/* PAGE */
.page-hd{margin-bottom:20px}
.page-title{font-family:var(--fontc);font-size:24px;font-weight:800}
.page-sub{font-size:13px;color:var(--txt2);margin-top:4px}
/* CARDS */
.vondst-card{background:var(--s2);border:1px solid var(--bdr);border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .15s,border-color .15s;display:flex;flex-direction:column;align-items:stretch}
.vondst-card:hover{transform:translateY(-2px);border-color:var(--acc)}
.vc-img{width:100%;aspect-ratio:1/1;max-height:160px;object-fit:cover;display:block;background:var(--s2);font-size:36px;text-align:center;line-height:1}
.vc-body{padding:10px;display:flex;flex-direction:column;gap:4px}
.vc-title{font-size:13px;font-weight:700;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vc-meta{font-size:11px;color:var(--mut);display:flex;flex-direction:column;gap:2px}
.vc-actions{display:flex;gap:4px;padding:8px 10px;border-top:1px solid var(--bdr)}
.vc-act{flex:1;padding:5px 4px;border-radius:6px;font-size:10px;font-weight:600;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;border:1px solid var(--bdr);background:transparent;color:var(--mut)}
.vc-act.edit{color:#3b82f6;border-color:rgba(59,130,246,.3)}
.vc-act.pub{color:#10b981;border-color:rgba(16,185,129,.3)}
.vc-act.del{color:#e5484d;border-color:rgba(229,72,77,.3)}
#vondsten-lijst{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;max-width:100%}
#vondsten-lijst.lijst-view{display:flex;flex-direction:column;gap:6px}
#vondsten-lijst.lijst-view .vondst-card{flex-direction:row;align-items:center}
#vondsten-lijst.lijst-view .vc-img{width:70px;height:70px;aspect-ratio:1;flex-shrink:0;border-radius:8px}
#vondsten-lijst.lijst-view .vc-actions{border-top:none;border-left:1px solid var(--bdr)}
#vondsten-lijst.lijst-view .vc-body{flex:1;min-width:0}
.badge{padding:2px 7px;border-radius:4px;font-size:10.5px;font-weight:600;background:rgba(240,120,24,.15);color:var(--acc)}
.ob-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.2);transition:all .25s;flex-shrink:0}
.ob-dot.act{width:24px;border-radius:4px;background:var(--acc)}
.ob-check-item{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:13px;cursor:pointer;border-bottom:1px solid var(--bdr);transition:color .15s}
.ob-check-item:last-child{border-bottom:none}
.ob-check-item:hover{color:var(--acc)}
.ob-check-item.done{color:var(--mut);text-decoration:line-through;pointer-events:none}
.ob-check-item.done .ob-check-ico{color:#22c55e}
/* IGROUP */
.ig{margin-bottom:14px}
.igt{font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:var(--acc);font-weight:700;margin-bottom:8px}
.ir{display:flex;align-items:baseline;justify-content:space-between;padding:5px 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:13px}
.ir:last-child{border:none}
.ik{color:var(--txt2);flex-shrink:0;margin-right:8px}
.iv{color:var(--txt);font-weight:600;text-align:right}
/* FORMS */
.form-group{margin-bottom:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-label{display:block;font-size:12px;font-weight:700;color:var(--txt2);margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}
.form-input,.form-select,.form-textarea{width:100%;padding:9px 12px;background:var(--s2);border:1px solid var(--bdr);border-radius:7px;color:var(--txt);font-family:var(--font);font-size:13.5px;outline:none;transition:border-color .2s}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--acc)}
.form-textarea{resize:vertical;min-height:80px}
.form-err{color:var(--red);font-size:12px;margin-top:4px}
#foto-preview{width:100%;height:100px;border:2px dashed var(--bdr);border-radius:8px;display:grid;place-items:center;color:var(--mut);font-size:13px;cursor:pointer;overflow:hidden;transition:border-color .2s}
#foto-preview:hover{border-color:var(--acc)}
/* BTN */
.btn{padding:8px 16px;border-radius:8px;border:1px solid var(--bdr);background:var(--s2);color:var(--txt);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:6px}
.btn:hover{border-color:var(--acc);color:var(--acc)}
.btn.primary{background:linear-gradient(135deg,#f07818,#ff9a3c);border-color:transparent;color:#000;font-weight:700}
.btn.primary:hover{opacity:.9}
.btn.danger{background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.3);color:var(--red)}
.btn.success{background:rgba(34,197,94,.15);border-color:rgba(34,197,94,.3);color:#22c55e}
/* MODAL */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:8000;display:none;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(3px)}
.modal-bg.open{display:grid}
.modal{background:var(--s1);border:1px solid var(--bdr);border-radius:14px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 30px 80px rgba(0,0,0,.8)}
#dm-modal .modal{width:780px!important;max-width:calc(100vw - 40px)!important;height:70vh;min-height:400px}
#dm-inbox-modal .modal{width:780px!important;max-width:calc(100vw - 40px)!important;height:70vh;min-height:400px}
#zoek-modal .modal{width:780px!important;max-width:calc(100vw - 40px)!important;height:70vh;min-height:400px}
#zm-uitnodig-modal .modal{width:780px!important;max-width:calc(100vw - 40px)!important;height:70vh;min-height:400px}
#volgers-modal .modal{width:780px!important;max-width:calc(100vw - 40px)!important;height:70vh;min-height:400px}
#volgend-modal .modal{width:780px!important;max-width:calc(100vw - 40px)!important;height:70vh;min-height:400px}
#vrienden-modal .modal{width:780px!important;max-width:calc(100vw - 40px)!important;height:70vh;min-height:400px}
#vdetail-modal{align-items:center!important;justify-content:center!important;padding:20px!important}
#vdetail-modal .modal{width:520px!important;max-width:calc(100vw - 32px)!important;max-height:88dvh!important;height:auto!important;border-radius:16px!important;overflow-y:auto!important}
#post-detail-modal .modal{width:90vw!important;max-width:680px!important;max-height:88vh!important}
@media(max-width:768px){#post-detail-modal{padding:0!important}#post-detail-modal .modal{width:100vw!important;height:100dvh!important;max-width:100vw!important;max-height:100dvh!important;border-radius:0!important}}
#post-aanmaken-modal > div{max-width:640px!important}
@media(max-width:768px){#post-aanmaken-modal{padding:0!important;align-items:flex-end!important}#post-aanmaken-modal > div{max-width:100vw!important;max-height:100dvh!important;border-radius:16px 16px 0 0!important;overflow-y:auto}}
#bewerk-post-modal .modal{max-width:680px!important}
@media(max-width:768px){#bewerk-post-modal{padding:0!important;align-items:flex-end!important}#bewerk-post-modal .modal{width:100vw!important;max-width:100vw!important;max-height:92dvh!important;border-radius:16px 16px 0 0!important}}
#event-popup-modal .modal{width:90vw!important;max-width:680px!important;max-height:88vh!important}
@media(max-width:768px){#event-popup-modal{padding:0!important}#event-popup-modal .modal{width:100vw!important;height:100dvh!important;max-width:100vw!important;max-height:100dvh!important;border-radius:0!important;margin:0!important}}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--bdr)}
.modal-title{font-family:var(--fontc);font-size:17px;font-weight:800}
.modal-close{background:none;border:none;color:var(--mut);font-size:18px;cursor:pointer;padding:4px;line-height:1}
.modal-body{padding:18px 20px}
/* VERLOREN */
.vlr-card{background:var(--s1);border:1px solid var(--bdr);border-radius:10px;padding:16px;transition:border-color .2s;cursor:pointer}
.vlr-card:hover{border-color:var(--acc)}
.vlr-boosted{border-color:var(--acc)!important;box-shadow:0 0 0 1px rgba(240,120,24,.3),0 4px 20px rgba(240,120,24,.12)}
.vlr-status{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:2px 8px;border-radius:4px}
.vlr-status.actief{background:rgba(34,197,94,.15);color:#22c55e}
.vlr-status.in_behandeling{background:rgba(59,130,246,.15);color:#3b82f6}
.vlr-status.gevonden{background:rgba(34,197,94,.2);color:#16a34a}
.vlr-status.gesloten{background:rgba(120,120,120,.15);color:var(--mut)}
.vlr-status.concept{background:rgba(240,120,24,.15);color:var(--acc)}
.vlr-status.betaling{background:rgba(240,120,24,.15);color:var(--acc)}
/* PERCEEL DETAIL MODAL */
.pdm-tab{background:none;border:none;border-bottom:2px solid transparent;padding:10px 18px;font-size:13px;font-weight:600;color:var(--mut);cursor:pointer;transition:color .15s,border-color .15s}
.pdm-tab.active{color:var(--acc);border-bottom-color:var(--acc)}.pdm-tab:hover:not(.active){color:var(--txt)}
/* TEKENMODUS */
.kaart-view.teken-actief{cursor:crosshair!important}
.kaart-view.teken-actief *{cursor:crosshair!important}
#teken-balk{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);z-index:600;background:rgba(22,24,30,.95);border:1px solid var(--acc);border-radius:10px;padding:8px 14px;display:flex;align-items:center;gap:10px;font-size:12px;color:var(--txt2);display:none;box-shadow:0 4px 20px rgba(0,0,0,.6)}
#cat-filter-balk{position:absolute;bottom:40px;left:10px;z-index:600;background:none;border:none;padding:0;display:none;box-shadow:none}
#cat-filter-balk.show{display:block}
.cat-fb{padding:6px 12px;border:none;border-radius:6px;background:none;color:var(--txt2);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;flex-shrink:0;white-space:nowrap}
.cat-fb:hover{color:var(--txt);background:rgba(255,255,255,.06)}
.cat-fb.act{background:rgba(240,120,24,.18);color:var(--acc);border-radius:6px}
.feed-scope-tab{padding:8px 18px;border:none;border-bottom:2px solid transparent;background:none;color:rgba(255,255,255,0.4);font-family:var(--font);font-size:13px;font-weight:700;cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap;margin-bottom:-1px}
.feed-scope-tab:hover{color:rgba(255,255,255,0.75)}
.feed-scope-tab.act{color:#fff;border-bottom-color:var(--acc)}
#teken-balk.show{display:flex}
.teken-vertex{background:var(--acc);border:2px solid #fff;border-radius:50%;width:10px;height:10px;margin:-5px -5px;cursor:pointer!important}
.perceel-eigen{stroke:var(--grn)!important;stroke-width:2.5!important;fill-opacity:.12!important}
.perceel-eigen-label{background:transparent;border:none;box-shadow:none;color:var(--grn);font-size:11px;font-weight:700;white-space:nowrap}
.meld-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:2px 7px;border-radius:4px}
.meld-badge.niet_gemeld{background:rgba(120,120,120,.15);color:var(--mut)}
.meld-badge.in_behandeling{background:rgba(59,130,246,.15);color:#3b82f6}
.meld-badge.gemeld{background:rgba(34,197,94,.15);color:#22c55e}
/* WIZARD */
.vw-step-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;border:2px solid var(--bdr);color:var(--mut);transition:all .2s;flex-shrink:0}
.vw-step-dot.done{background:var(--grn);border-color:var(--grn);color:#fff}
.vw-step-dot.active{background:var(--acc);border-color:var(--acc);color:#fff}
.vw-step-line{flex:1;height:2px;background:var(--bdr);transition:background .2s}
.vw-step-line.done{background:var(--grn)}
.vw-foto-prev{width:80px;height:80px;object-fit:cover;border-radius:6px;border:1px solid var(--bdr)}
.vw-foto-wrap{position:relative;display:inline-block}
.vw-foto-del{position:absolute;top:-6px;right:-6px;background:#ef4444;color:#fff;border:none;border-radius:50%;width:18px;height:18px;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}
/* LOC */
.loc-pulse{position:relative;width:22px;height:22px}
.loc-pulse::before{content:'';position:absolute;inset:-7px;border-radius:50%;background:rgba(59,130,246,.25);animation:gps 2s ease-out infinite}
.loc-pulse::after{content:'';position:absolute;inset:2px;border-radius:50%;background:#3b82f6;border:2.5px solid #fff;box-shadow:0 2px 10px rgba(59,130,246,.6)}
.srm-pin{width:20px;height:20px;background:#4285f4;border:3px solid #fff;border-radius:50%;box-shadow:0 2px 6px rgba(0,0,0,.4)}
.search-result-marker{background:transparent;border:none}
@keyframes gps{0%{transform:scale(.8);opacity:.8}70%{transform:scale(2.2);opacity:0}100%{transform:scale(2.2);opacity:0}}
#loc-balk{position:absolute;bottom:44px;left:50%;transform:translateX(-50%);background:rgba(15,16,20,.95);border:1px solid #3b82f6;border-radius:12px;padding:10px 16px;z-index:600;display:none;align-items:center;gap:12px;backdrop-filter:blur(10px);min-width:280px}
#loc-balk.show{display:flex}
/* SCROLLBAR */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--s1)}
::-webkit-scrollbar-thumb{background:var(--bdr);border-radius:3px}
/* AUTH */
#auth-modal{display:none;position:fixed;inset:0;z-index:9000;overflow-y:auto;background:linear-gradient(180deg,#0a0c10 0%,#1a1008 30%,#3d1f04 60%,#6b2e06 80%,#8b3a08 100%)}
#auth-modal.show{display:block}
/* STATUS */
.status-btn{padding:6px 10px;border-radius:6px;border:1px solid var(--bdr);background:none;color:var(--txt2);font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;font-family:var(--font)}
.status-btn:hover,.status-btn.sel{border-color:var(--acc);color:var(--acc);background:rgba(240,120,24,.12)}
/* FAV */
.fav-item{padding:10px;border:1px solid var(--bdr);border-radius:8px;cursor:pointer;transition:all .15s;margin-bottom:8px;background:var(--s2);display:flex;align-items:center;gap:10px}
.fav-item:hover{border-color:var(--acc)}
@media(max-width:900px){.ontdek-main{grid-template-columns:1fr!important}.ontdek-sub{grid-template-columns:1fr!important}}
@media(max-width:767px){.ontdek-layout{padding:12px 16px 80px}}
@media(max-width:680px){#feed-grid{grid-template-columns:1fr!important}#vdw-img-wrap{display:none!important}.feed-grid-3col{grid-template-columns:1fr!important}}
@media(max-width:600px){.feed-grid-3col{gap:10px}}
@media(max-width:1024px){.ontdek-sidebar{display:none!important}}
.ontdek-layout{max-width:1380px;margin:0 auto;padding:20px clamp(12px,3vw,24px) 80px;display:flex;gap:24px;align-items:flex-start}
.ontdek-sidebar-right{width:210px;flex-shrink:0;display:none;flex-direction:column;gap:4px}
@media(min-width:1025px){.ontdek-sidebar-right{display:flex}}
.sidebar-section{background:var(--s1);border:1px solid var(--bdr);border-radius:12px;padding:12px 14px;margin-bottom:8px}
.sidebar-section-title{font-size:10px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--mut);margin-bottom:8px}
.sidebar-stats{display:flex;flex-direction:column;gap:6px}
.sidebar-stat-row{display:flex;align-items:center;justify-content:space-between}
.sidebar-stat-label{font-size:12px;color:var(--txt2)}
.sidebar-stat-val{font-family:var(--fontc);font-size:15px;font-weight:900;color:var(--acc)}
.ontdek-search-mobiel{display:none}
@keyframes likePopIn{0%{transform:scale(1)}40%{transform:scale(1.45)}70%{transform:scale(.9)}100%{transform:scale(1)}}
/* ═══ FEED CARD — premium dark editorial ═══ */
.feed-card{background:#1e1e1e;border:1px solid rgba(255,255,255,0.11);border-radius:14px;overflow:hidden;position:relative;transition:transform .22s,box-shadow .22s;box-shadow:0 2px 16px rgba(0,0,0,.45);display:flex;flex-direction:column;-webkit-tap-highlight-color:transparent}
.feed-card:hover{transform:translateY(-3px);box-shadow:0 10px 36px rgba(0,0,0,.55)}
.feed-card:active:not(:has(.fc-dot-menu:active)){transform:scale(0.98)!important;box-shadow:none!important}
/* Feed categorie tabs — pill stijl */
.feed-cat-tab{padding:7px 16px;border:none;border-radius:99px;background:rgba(255,255,255,0.07);color:var(--txt2);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;flex-shrink:0;white-space:nowrap}
.feed-cat-tab:hover{background:rgba(255,255,255,0.12);color:var(--txt)}
.feed-cat-tab.act{background:linear-gradient(135deg,var(--acc),#c85e00);color:#000;font-weight:800;box-shadow:0 2px 12px rgba(240,120,24,.4)}
/* Trending cards */
.trending-card{flex-shrink:0;width:108px;border-radius:10px;overflow:hidden;position:relative;cursor:pointer;background:var(--s1);border:1px solid rgba(255,255,255,0.1);box-shadow:0 4px 20px rgba(0,0,0,.5);transition:transform .18s,box-shadow .18s}
.trending-card:hover{transform:translateY(-4px) scale(1.01);box-shadow:0 12px 32px rgba(0,0,0,.6)}
.trending-card-img{height:70px;overflow:hidden;background:var(--s2);position:relative}
@media(min-width:769px){.trending-card{width:160px}.trending-card-img{height:100px}}
@media(min-width:1281px){.trending-card{width:180px}.trending-card-img{height:110px}}
.tbadge{position:absolute;top:4px;left:4px;font-size:6px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:2px 5px;border-radius:3px;font-family:var(--fontc);z-index:2}
.tbadge.badge-v{background:var(--acc);color:#fff}
.tbadge.badge-p{background:var(--blue,#2563eb);color:#fff}
.trank{position:absolute;top:4px;right:4px;background:rgba(0,0,0,.65);border-radius:3px;padding:1px 4px;font-size:7px;font-weight:800;color:#fff;font-family:var(--fontc);z-index:2}
.trank.top{background:var(--acc)}
/* ═══ FEED GRID 3-KOLOM ═══ */
.feed-grid-3col{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;align-items:stretch}
.feed-grid-3col > div{display:flex;flex-direction:column;min-width:0}
.feed-grid-3col > div > .feed-card{flex:1}
@media(max-width:900px){.feed-grid-3col{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.feed-grid-3col{grid-template-columns:1fr}}
/* FC: feed card componenten */
.fc-badge{position:absolute;top:9px;left:9px;padding:3px 9px;border-radius:6px;font-size:10px;font-weight:800;letter-spacing:.4px;z-index:2;text-transform:uppercase}
.fc-badge.vondst{background:#E07B20;color:#000}
.fc-badge.post{background:#185FA5;color:#fff}
.fc-badge.event{background:#3B6D11;color:#fff}
.fc-dot-menu{position:absolute;top:9px;right:9px;width:28px;height:28px;border-radius:50%;background:rgba(0,0,0,.55);border:none;cursor:pointer;display:grid;place-items:center;color:#fff;font-size:16px;z-index:2;transition:background .15s;touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.fc-dot-menu:hover{background:rgba(0,0,0,.75)}
.fc-header .fc-dot-menu{position:static;background:transparent;color:var(--mut);width:44px;height:44px;margin-left:auto;flex-shrink:0;border-radius:50%;touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.fc-header .fc-dot-menu:hover{background:rgba(255,255,255,.06);color:var(--txt)}
.fc-dot-menu-dropdown button:hover{background:rgba(255,255,255,.06)!important}
/* confirm dialog */
#confirm-dialog{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px}
#confirm-dialog .cd-box{background:var(--s1);border:1px solid var(--bdr);border-radius:12px;padding:22px 22px 18px;max-width:340px;width:100%;box-shadow:0 12px 40px rgba(0,0,0,.7)}
#confirm-dialog .cd-tekst{font-size:14px;color:var(--txt);line-height:1.5;margin-bottom:18px}
#confirm-dialog .cd-btns{display:flex;gap:8px;justify-content:flex-end}
#confirm-dialog .cd-cancel{padding:8px 16px;background:var(--s2);border:1px solid var(--bdr);border-radius:8px;color:var(--txt2);font-size:13px;cursor:pointer;font-family:var(--font)}
#confirm-dialog .cd-ok{padding:8px 16px;background:var(--red,#ef4444);border:none;border-radius:8px;color:#fff;font-size:13px;font-weight:700;cursor:pointer;font-family:var(--font)}
/* FC header: author row */
.fc-header{display:flex;align-items:center;padding:10px 12px 8px;gap:8px}
.fc-author{display:flex;align-items:center;gap:8px;min-width:0;cursor:pointer;flex:1}
.fc-author-info{display:flex;flex-direction:column;gap:1px;min-width:0}
.fc-username{font-size:12px;font-weight:700;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fc-meta-row{display:flex;align-items:center;gap:5px}
.fc-time{font-size:10px;color:var(--mut)}
/* FC foto grid — Facebook-stijl, aspect-ratio gestuurd */
.fc-foto-grid{position:relative;overflow:hidden;background:var(--bg3)}
.fc-foto-item{position:relative;overflow:hidden;cursor:pointer;background:var(--s2)}
.fc-foto-item img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
/* 1 foto — 16:9 */
.fc-foto-grid--1 .fc-foto-item{aspect-ratio:16/9;width:100%}
/* 2 foto's — naast elkaar, vierkant */
.fc-foto-grid--2{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.fc-foto-grid--2 .fc-foto-item{aspect-ratio:1/1}
/* 3 foto's — groot links + 2 rechts gestapeld */
.fc-foto-grid--3{display:flex;gap:2px}
.fc-foto-item--main{flex:2;aspect-ratio:1/1}
.fc-foto-grid-side{flex:1;display:flex;flex-direction:column;gap:2px}
.fc-foto-grid-side .fc-foto-item{flex:1}
/* 4+ foto's — 2×2 grid */
.fc-foto-grid--4{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.fc-foto-grid--4 .fc-foto-item{aspect-ratio:1/1}
/* "+X meer" overlay */
.fc-foto-meer{position:absolute;inset:0;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;color:#fff;pointer-events:none}
.fc-img-accent{position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--acc);z-index:2}
/* FC body */
.fc-body{padding:10px 12px 8px;display:flex;flex-direction:column;gap:4px;flex:1}
.fc-title{font-family:var(--fontc);font-size:14px;font-weight:800;color:#f0f0f0;line-height:1.2;margin-bottom:3px}
.fc-subcat{font-size:10px;font-weight:600;color:var(--acc);text-transform:uppercase;letter-spacing:.5px}
.fc-desc{font-size:12px;color:var(--txt);line-height:1.5}
.fc-meer{font-size:10px;color:var(--acc);margin-top:6px;opacity:.7;align-self:flex-start}
/* FC actions bar */
.fc-actions{display:flex;align-items:center;justify-content:space-between;padding:7px 10px 9px;border-top:1px solid rgba(255,255,255,.06)}
.fc-actions-left{display:flex;align-items:center;gap:6px}
.fc-like-btn,.fc-react-btn{display:flex;align-items:center;gap:4px;background:transparent;border:none;padding:5px 8px;border-radius:8px;cursor:pointer;font-size:11px;font-weight:600;color:var(--mut);font-family:var(--font);transition:background .15s,color .15s}
.fc-like-btn:hover{background:rgba(239,68,68,.08);color:#ef4444}
.fc-like-btn.on{color:#ef4444}
.fc-react-btn:hover{background:rgba(255,255,255,.06);color:var(--txt)}
.fc-save{background:none;border:none;cursor:pointer;color:var(--mut);padding:5px 8px;line-height:1;transition:color .15s;display:grid;place-items:center}
.fc-save:hover{color:var(--acc)}
/* pbadge — feed card inline badge */
.pbadge{padding:2px 6px;border-radius:3px;font-size:9px;font-weight:800;letter-spacing:.3px;text-transform:uppercase;font-family:var(--fontc)}
.pbadge.badge-v{background:var(--acc);color:#000}
.pbadge.badge-p{background:var(--blue,#2563eb);color:#fff}
/* advertentie card */
.fc-ad-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px 8px}
.fc-ad-brand{display:flex;align-items:center;gap:8px}
.fc-ad-brand span{font-weight:700;font-size:13px;color:var(--txt)}
.fc-ad-label{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--mut)}
.fc-ad-banner{width:100%;max-height:200px;object-fit:cover;display:block}
.fc-ad-body{padding:10px 14px 14px;display:flex;flex-direction:column;gap:8px}
.fc-ad-body>div{font-size:12px;color:var(--txt2);line-height:1.45}
.fc-ad-cta{padding:8px 16px;background:var(--acc);color:#000;border:none;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;align-self:flex-start;font-family:var(--fontc)}
/* legacy fc-meta kept for post cards */
.fc-meta{display:flex;align-items:center;justify-content:space-between;padding:7px 12px;border-top:1px solid rgba(255,255,255,.06);margin-top:auto}
.fc-meta-left{display:flex;align-items:center;gap:5px;min-width:0;overflow:hidden}
.fc-meta-right{display:flex;align-items:center;gap:4px;flex-shrink:0}
/* SORT PILLS */
.sort-pill{padding:4px 12px;border-radius:20px;border:1px solid var(--bdr);background:transparent;color:var(--txt2);font-family:var(--font);font-size:11px;font-weight:700;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}
.sort-pill:hover{border-color:var(--acc);color:var(--acc)}
.sort-pill.act{background:var(--acc);border-color:var(--acc);color:#fff}
/* ONTDEK PILLS */
.ontdek-pill{padding:4px 12px;border-radius:20px;font-size:11px;font-weight:500;cursor:pointer;border:1px solid var(--bdr);background:transparent;color:var(--txt2);white-space:nowrap;transition:all .12s;flex-shrink:0;font-family:var(--font)}
.ontdek-pill:hover:not(.active){color:var(--txt);border-color:#333}
.ontdek-pill.active{background:var(--acc);color:#fff;border-color:var(--acc)}
/* EVENT STRIP */
.event-strip-wrap{margin-bottom:16px}
.event-strip{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;scrollbar-width:none;-webkit-overflow-scrolling:touch}.event-strip::-webkit-scrollbar{display:none}
.event-strip-card{flex-shrink:0;width:180px;background:var(--s1);border:1px solid var(--bdr);border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .15s}
.event-strip-card:hover{transform:translateY(-2px)}
/* ═══ BOTTOM NAV ═══ */
#bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:60px;background:var(--s1);border-top:1px solid var(--bdr);z-index:2000;align-items:center;justify-content:space-around;padding-bottom:env(safe-area-inset-bottom);overflow:visible}
.bnav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:none;border:none;color:var(--txt2);font-family:var(--font);font-size:10px;font-weight:600;cursor:pointer;padding:8px 0;position:relative;transition:color .15s}
.bnav-item.active{color:var(--acc)}
.bnav-item.active::after{content:'';position:absolute;bottom:4px;width:4px;height:4px;border-radius:50%;background:var(--acc)}
.bnav-item-ico{font-size:20px;line-height:1}
.bnav-item-ico svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;display:block}
.bnav-item-lbl{font-size:10px;font-weight:600;letter-spacing:.3px}
.bnav-badge{position:absolute;top:4px;right:calc(50% - 18px);min-width:16px;height:16px;background:var(--red);border-radius:8px;font-size:10px;font-weight:700;color:#fff;line-height:16px;text-align:center;padding:0 3px;display:none}
.bnav-fab{width:54px;height:54px;border-radius:50%;background:var(--acc);border:none;color:#fff;font-size:28px;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 18px rgba(240,120,24,.5);margin-top:-20px;flex-shrink:0;transition:transform .25s,background .15s;line-height:1}
.bnav-fab.open{transform:rotate(45deg)}
/* ═══ FAB SPEED DIAL ═══ */
#fab-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:1900;backdrop-filter:blur(2px)}
#fab-overlay.open{display:block}
#fab-menu{display:none;position:fixed;bottom:72px;left:50%;transform:translateX(-50%);z-index:1950;flex-direction:column-reverse;align-items:flex-end;gap:12px;padding-bottom:4px}
#fab-menu.open{display:flex}
.fab-item{display:flex;align-items:center;gap:12px;animation:fabUp .22s ease both;cursor:pointer}
.fab-item:active{opacity:.8}
.fab-item-ico{font-size:24px;width:44px;text-align:center;flex-shrink:0}
@keyframes fabUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@keyframes pdFadeIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.fab-item:nth-child(1){animation-delay:.04s}
.fab-item:nth-child(2){animation-delay:.08s}
.fab-item:nth-child(3){animation-delay:.12s}
.fab-item:nth-child(4){animation-delay:.16s}
.fab-item:nth-child(5){animation-delay:.20s}
.fab-item:nth-child(6){animation-delay:.24s}
.fab-item:nth-child(7){animation-delay:.28s}
.fab-item-lbl{background:var(--s1);border:1px solid var(--bdr);border-radius:8px;padding:7px 14px;font-size:13px;font-weight:600;color:var(--txt);white-space:nowrap;box-shadow:0 4px 16px rgba(0,0,0,.45)}
.fab-item-btn{width:50px;height:50px;border-radius:50%;background:var(--s1);border:1px solid var(--bdr);color:var(--txt);font-size:22px;cursor:pointer;display:grid;place-items:center;box-shadow:0 4px 16px rgba(0,0,0,.4);transition:all .15s;flex-shrink:0}
.fab-item-btn:hover,.fab-item-btn:active{border-color:var(--acc);color:var(--acc)}
/* FAB sheet-style (ontdek + overige views) */
#fab-menu.sheet-style{left:16px;right:16px;transform:none;width:auto;align-items:stretch;flex-direction:column}
#fab-menu.sheet-style .fab-item{width:100%;flex-direction:row;align-items:center;gap:14px;padding:14px 16px;background:var(--s1);border:1px solid var(--bdr);border-radius:12px}
#fab-menu.sheet-style .fab-item-btn{background:var(--s2);box-shadow:none;font-size:24px}
#fab-menu.sheet-style .fab-item-lbl{background:none;border:none;padding:0;box-shadow:none;font-size:14px;font-weight:700;white-space:normal}
.fab-item-txt{display:flex;flex-direction:column;gap:2px;flex:1;text-align:left}
.fab-item-sub{font-size:12px;color:var(--txt2)}
/* ═══ MOBILE (≤767px) ═══ */
@media(max-width:767px){
  /* Topbar */
  #bottom-nav{display:flex;height:68px}
  #app{bottom:calc(68px + env(safe-area-inset-bottom))}
  .nav-tabs{display:none}
  #gp-actions button{padding:5px 10px!important;font-size:12px!important}
  .logo-name{display:none}
  .logo-img{height:28px}
  #btn-basemap,#btn-lucht,#btn-ahn{display:none}
  /* Verberg topbar-knoppen op mobiel — zitten in actie-dropdown */
  #tab-zoek,#tab-dm{display:none!important}
  /* Toon mobiel actie-icoon */
  #mob-actions-wrap{display:block!important}
  /* Verberg gebruikersnaam naast avatar */
  #uname{display:none!important}
  /* Avatar groter + beter klikbaar */
  .user-avatar{width:34px!important;height:34px!important;font-size:14px!important}
  /* Avatar dropdown — breed + mooi op mobiel */
  #profiel-panel{position:fixed!important;top:54px!important;right:8px!important;width:220px!important}
  /* Feed card tap feedback — uitgesloten wanneer ⋮ wordt ingedrukt */
  .feed-card:active:not(:has(.fc-dot-menu:active)){transform:scale(0.97)!important;box-shadow:none!important}
  /* Profiel dropdown quick-items: altijd tonen (hidden op desktop via aparte regel) */
  /* Map controls inklapbaar */
  .map-ctrl-btn{width:44px;height:44px;font-size:19px}
  #btn-ctrl-toggle{display:grid!important}
  #map-ctrl-btns{overflow:hidden;max-height:0;opacity:0;transition:max-height .3s ease,opacity .2s ease;gap:6px;pointer-events:none}
  #map-ctrl-btns.open{max-height:600px;opacity:1;pointer-events:auto}
  #btn-ctrl-toggle.open{background:rgba(240,120,24,.2);border-color:var(--acc);color:var(--acc)}
  #cbadge{bottom:70px}
  /* Zoom hint links uitgelijnd zodat hij het tandwiel rechts niet overlapt */
  #znote{top:8px;left:10px;transform:none;max-width:calc(100% - 70px)}
  /* Zoom-level indicator verbergen (zwart vlak rechtsonder) */
  #zind{display:none}
  /* Leaflet +/- zoom-knoppen verbergen op mobiel (pinch-to-zoom werkt altijd) */
  .leaflet-control-zoom{display:none!important}
  /* Leaflet attributie container volledig verbergen op mobiel (zwart vlak rechtsonder) */
  .leaflet-bottom.leaflet-right{display:none!important}
  .leaflet-control-attribution{display:none!important}
  #sidebar.open{position:fixed;top:54px;left:0;right:0;bottom:60px;width:100%;z-index:2500}
  #rpanel.open{position:fixed;top:54px;left:0;right:0;bottom:60px;width:100%;z-index:2500}
  #teken-balk{bottom:70px;left:10px;right:10px;transform:none;width:auto}
  #teken-balk .btn{padding:6px 10px;font-size:12px;min-height:36px}
  #cat-filter-balk{bottom:6px;left:10px;right:auto;width:auto;transform:none;overflow-x:visible;-webkit-overflow-scrolling:unset}
  #loc-balk{bottom:74px}
  #zind{bottom:70px}
  /* Modals als bottom sheets */
  .modal-bg{align-items:flex-end;padding:0}
  .modal{max-width:100%;width:100%;border-radius:18px 18px 0 0;max-height:90dvh;margin:0}
  #vondst-modal .modal,#perceel-detail-modal .modal,#dm-modal .modal,#zm-uitnodig-modal .modal{border-radius:0;max-height:100dvh;height:100dvh}
  /* Vondst detail: altijd gecentreerd, nooit bottom sheet */
  #vdetail-modal{align-items:center!important;justify-content:center!important;padding:16px!important}
  #vdetail-modal .modal{width:calc(100vw - 32px)!important;max-width:520px!important;border-radius:16px!important;height:auto!important;max-height:88dvh!important;margin:0 auto!important}
  /* Bevestigingsdialoog (annuleren/bezig/afgerond): gecentreerd, niet als bottom sheet */
  #confirm-modal{align-items:center!important;justify-content:center!important;padding:16px!important}
  #confirm-modal .modal{width:calc(100vw - 48px)!important;max-width:360px!important;border-radius:16px!important;height:auto!important;max-height:80dvh!important;margin:0 auto!important}
  /* Boost-modal: gecentreerd, niet als bottom sheet */
  #boost-modal{align-items:center!important;justify-content:center!important;padding:16px!important}
  #boost-modal .modal{width:calc(100vw - 48px)!important;max-width:420px!important;border-radius:16px!important;height:auto!important;max-height:80dvh!important;margin:0 auto!important}
  /* DM inbox + zoeken: gecentreerd bovenaan, geen fullscreen bottom sheet */
  #dm-inbox-modal,#zoek-modal,#volgers-modal,#volgend-modal,#vrienden-modal{align-items:flex-start!important;padding:12px 0 0!important}
  #dm-inbox-modal .modal,#zoek-modal .modal,#volgers-modal .modal,#volgend-modal .modal,#vrienden-modal .modal{border-radius:16px!important;max-height:82dvh!important;height:auto!important;width:calc(100vw - 24px)!important;margin:0 auto!important}
  /* Panels */
  #zoekmoment-detail-panel{width:100%!important;bottom:60px!important}
  #notif-panel{position:fixed!important;top:54px!important;left:0!important;right:0!important;width:100%!important;border-radius:0 0 16px 16px!important;max-height:80dvh!important;overflow-y:auto!important}
  #notif-items{max-height:none!important}
  #fab-menu{bottom:calc(68px + env(safe-area-inset-bottom))}
  /* Mijn sub-tabs */
  .mijn-subtabs{padding:0 6px!important}
  .mijn-sub{padding:8px 10px!important;font-size:12px!important}
  /* Formulier grids */
  .form-row{grid-template-columns:1fr!important}
  /* Ontdek view */
  .ontdek-sidebar{display:none!important}
  .ontdek-search-wrap{display:none!important}
  .ontdek-search-mobiel{display:block}
  #vdw-container{display:none!important}
  #trending-prev,#trending-next,#trending-strip-meta{display:none!important}
  #trending-section-header{border-bottom:1px solid rgba(255,255,255,0.08);padding-bottom:10px!important;margin-bottom:14px!important}
  #feed-section-header{margin:16px 0 12px!important}
  #feed-container{grid-template-columns:1fr!important;gap:8px!important}
  .trending-card{width:calc(50vw - 20px)!important}
  .feed-card [id^="fc-"]{aspect-ratio:16/9!important;max-height:none!important}

  /* Vondsten & locaties grid */
  #vondsten-lijst{grid-template-columns:repeat(2,1fr)!important}
  #locaties-grid{grid-template-columns:1fr!important}
  /* Verloren grid */
  #verloren-view [style*="minmax(300px"]{grid-template-columns:1fr!important}
  /* Profiel stats: 4-col → 2-col op mobiel */
  #profiel-stats-grid{grid-template-columns:repeat(2,1fr)!important}
  /* Alle inline 2-koloms grids in views → 1 kolom */
  #dashboard-view [style*="grid-template-columns:1fr 1fr"],
  #profiel-view [style*="grid-template-columns:1fr 1fr"],
  #instellingen-view [style*="grid-template-columns:1fr 1fr"],
  #statistieken-view [style*="grid-template-columns:1fr 1fr"],
  #zoekmomenten-view [style*="grid-template-columns:1fr 1fr"],
  .modal-bg [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
  /* 3-kolom grids → 1 kolom */
  #instellingen-view [style*="grid-template-columns:1fr 1fr 1fr"],
  .modal-bg [style*="grid-template-columns:1fr 1fr 1fr"]{grid-template-columns:1fr!important}
  /* Perceel detail modal: 4 stat-vakjes → 2x2 */
  #perceel-detail-modal [style*="repeat(4,1fr)"]{grid-template-columns:repeat(2,1fr)!important}
  /* Statistieken chart grids → 1 kolom */
  #statistieken-view [style*="gap:16px"]{grid-template-columns:1fr!important}
  /* Dashboard header padding */
  #dashboard-view [style*="padding:24px 28px"]{padding:16px 16px 14px!important}
  #dashboard-view [style*="padding:16px 28px"]{padding:12px 16px 20px!important}
  /* 1. "+ Nieuwe vondst" knop verbergen in filterbalk — FAB is genoeg */
  #vondsten-view .btn.primary{display:none!important}
  /* 2. Touch targets: sluit-knoppen vergroten */
  .rp-close{padding:10px!important;font-size:20px!important}
  .modal-close{padding:10px!important}
  #sidebar .top-btn{min-width:44px!important;min-height:44px!important}
  /* 3. View-headers: actie-knop onder de titel bij smal scherm */
  .page-hd{flex-direction:column!important;align-items:flex-start!important;gap:10px!important}
  .page-hd .btn{width:100%!important;justify-content:center!important}
  /* 4. Dashboard actie-knoppen: min-width opheffen zodat ze passen op 320px */
  #dashboard-view .dash-action{min-width:unset!important}
  /* 5. VLR-panel breedte responsief */
  #vlr-panel{width:calc(100vw - 32px)!important;right:16px!important;left:auto!important}
  /* 6. Filter-rijen in verloren & locaties wrappen */
  #verloren-view [style*="display:flex"],
  #locaties-view [style*="display:flex"]{flex-wrap:wrap}
  /* 7. Dashboard actie-grid: 3 kolommen blijven op mobiel */
  .dash-actions-grid{grid-template-columns:repeat(3,1fr)!important}
}
/* ═══ LIGHTBOX — twee-kolom ═══ */
#lb-img-wrap{width:100%!important;height:100%!important;max-width:none!important;max-height:none!important}
#lb-img{max-width:100%!important;max-height:100%!important;width:auto!important;height:auto!important;border-radius:0!important;object-fit:contain!important}
#lightbox-overlay{background:rgba(0,0,0,.95)!important}
@media(max-width:768px){#lb-right{display:none!important}}
/* ═══ TABLET (768–1023px) ═══ */
@media(min-width:768px) and (max-width:1023px){
  #bottom-nav{display:flex;height:68px}
  #app{bottom:68px}
  .nav-tabs{display:none}
  #sidebar{width:260px}
  #rpanel{width:260px}
  .modal{max-width:90vw}
  #fab-menu{bottom:calc(78px + env(safe-area-inset-bottom))}
  .mijn-subtabs{padding:0 8px!important}
  .ontdek-sidebar{display:none!important}
  #feed-container{grid-template-columns:1fr!important}
}

/* === section 2 === */
@keyframes obOrb1{from{transform:translate(0,0) scale(1)}to{transform:translate(40px,30px) scale(1.15)}}
@keyframes obOrb2{from{transform:translate(0,0) scale(1)}to{transform:translate(-30px,20px) scale(1.1)}}
@keyframes obCardIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.ob-sample-card{background:#131313;border:1px solid rgba(255,255,255,.08);border-radius:14px;overflow:hidden;text-align:left;animation:obCardIn .4s ease both}
.ob-loc-btn{display:flex;align-items:center;gap:12px;width:100%;max-width:320px;padding:14px 18px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);color:#fff;font-family:var(--font);font-size:14px;font-weight:600;cursor:pointer;transition:border-color .18s,background .18s}
.ob-loc-btn:hover{border-color:var(--acc);background:rgba(240,120,24,.08)}
.ob-success-check{width:56px;height:56px;border-radius:50%;background:rgba(34,197,94,.15);border:2px solid #22c55e;display:grid;place-items:center;font-size:26px;margin:0 auto 16px}

/* === section 3 === */
  body{font-family:Arial,sans-serif;max-width:720px;margin:40px auto;color:#1a1a1a;font-size:14px;line-height:1.5}
  h1{font-size:22px;margin:0 0 2px;color:#111}
  h2{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#666;margin:24px 0 8px;border-bottom:1px solid #e5e7eb;padding-bottom:4px}
  table{width:100%;border-collapse:collapse;margin-bottom:4px}
  .header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #111}
  .meta{font-size:11px;color:#999;text-align:right}
  .badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;background:#f3f4f6;color:#374151}
  .badge.gemeld{background:#dcfce7;color:#166534}
  .badge.in_behandeling{background:#dbeafe;color:#1e40af}
  .footer{margin-top:48px;font-size:11px;color:#aaa;border-top:1px solid #e5e7eb;padding-top:10px;text-align:center}
  p{margin:0;line-height:1.7}
  @media print{body{margin:16px}}
}
@media(min-width:1024px){#btn-vondst-snel{display:flex}}
/* === v3 HAMBURGER === */
#hamburger-btn{display:none;flex-direction:column;gap:4px;cursor:pointer;padding:8px 10px;background:none;border:none;color:var(--txt);flex-shrink:0;line-height:0}
.hb{height:2px;width:20px;background:currentColor;border-radius:1px;transition:all .2s;display:block}
#hamburger-btn.open .hb:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
#hamburger-btn.open .hb:nth-child(2){opacity:0}
#hamburger-btn.open .hb:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}
/* === v3 DRAWER === */
#v3-backdrop{position:fixed;top:54px;left:0;right:0;bottom:0;background:rgba(0,0,0,.65);z-index:3499;opacity:0;pointer-events:none;transition:opacity .26s}
#v3-backdrop.open{opacity:1;pointer-events:auto}
#v3-drawer{position:fixed;top:54px;left:0;bottom:0;width:260px;background:var(--s1);z-index:3500;transform:translateX(-100%);transition:transform .26s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;border-right:1px solid var(--bdr);overflow:hidden}
#v3-drawer.open{transform:translateX(0)}
.drawer-top{padding:16px 16px 14px;border-bottom:1px solid var(--bdr);flex-shrink:0}
.drawer-nav{padding:6px;flex:1;overflow-y:auto;scrollbar-width:none}
.drawer-nav::-webkit-scrollbar{display:none}
.nav-section{padding:4px 0}
.nav-lbl{font-family:var(--fh);font-size:8px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--text5);padding:6px 10px 2px}
.nav-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:background .12s;margin-bottom:1px}
.nav-item:hover{background:var(--s2)}
.nav-item.active{background:rgba(249,115,22,.1)}
.nav-item svg{width:15px;height:15px;flex-shrink:0;color:var(--txt2)}
.nav-item.active svg{color:var(--accent)}
.nav-item-lbl{font-size:13px;color:var(--txt2)}
.nav-item.active .nav-item-lbl{color:var(--accent);font-weight:500}
.nav-div{height:1px;background:var(--bdr);margin:4px 8px}
.nav-user{display:flex;align-items:center;gap:10px;padding:12px 14px;border-top:1px solid var(--bdr);flex-shrink:0}
.nav-av{width:32px;height:32px;border-radius:50%;background:var(--acc);display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:12px;font-weight:800;color:#fff;flex-shrink:0;overflow:hidden}
.nav-av img{width:100%;height:100%;object-fit:cover}
.nav-uname{font-size:13px;font-weight:600;color:var(--txt)}
.nav-handle{font-size:10px;color:var(--mut)}
.drawer-logout-btn{background:none;border:none;cursor:pointer;color:#ef4444;padding:6px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .12s}
.drawer-logout-btn:hover{background:rgba(220,38,38,.1)}
.drawer-logout-btn svg{width:16px;height:16px}
#dt-sidebar-left{display:none;width:200px;flex-shrink:0;background:var(--s1);border-right:1px solid var(--bdr);overflow-y:auto;flex-direction:column}
@media(min-width:769px){#v3-drawer,#v3-backdrop{display:none!important}#sugs{position:absolute;top:44px;left:0;right:0}#dt-sidebar-left{display:flex}}
/* === v3 MOBILE TOPBAR (≤768px) === */
@media(max-width:768px){
  #hamburger-btn{display:flex}
  .nav-tabs{display:none!important}
  #sinp-wrap{flex:1;max-width:unset;margin:0 8px;opacity:0;pointer-events:none;clip-path:inset(0 100% 0 0);transition:clip-path .25s ease,opacity .15s ease}
  body:has(#kaart-view.active) #sinp-wrap{opacity:1;pointer-events:auto;clip-path:inset(0 0% 0 0);max-width:unset;flex:1}
  #sugs{position:fixed;top:54px;left:8px;right:8px;width:auto;z-index:4000}
  #btn-basemap,#btn-lucht,#btn-ahn{display:none!important}
  .logo-wrap{border-right:none;padding-right:0;position:absolute;left:50%;transform:translateX(-50%)}
  body:has(#kaart-view.active) .logo-wrap{display:none}
  #topbar{padding:0 8px}
}
#maintenance-banner{display:none;position:sticky;top:0;z-index:9999;background:#f07818;color:#000;font-weight:600;font-size:13px;padding:9px 16px;gap:12px;align-items:center;justify-content:center;font-family:var(--font,'Barlow',sans-serif)}
#maintenance-banner button{background:none;border:1px solid rgba(0,0,0,.3);border-radius:50%;width:22px;height:22px;cursor:pointer;font-size:12px;line-height:1;padding:0;flex-shrink:0;color:#000;display:grid;place-items:center}
