/* KZNWatch — mobile-first, Google-Maps-style UI */
:root{
  --ink:#0f1722; --mut:#5a6b7b; --line:#e3e8ee; --panel:#ffffff;
  --accent:#1a73e8; --accent-d:#1558b0; --danger:#d93025; --ok:#188038;
  --fab:#ffffff; --shadow:0 2px 10px rgba(0,0,0,.18); --shadow-lg:0 6px 24px rgba(0,0,0,.22);
  --safe-b:env(safe-area-inset-bottom,0px); --safe-t:env(safe-area-inset-top,0px);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{height:100%;margin:0}
body{
  font:16px/1.45 system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;color:var(--ink);
  overflow:hidden;background:#e9eef3;overscroll-behavior:none;
}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
a{color:var(--accent)}
.hidden{display:none !important}

/* ---- Map ---- */
#map{position:fixed;inset:0;z-index:0;background:#dfe6ec}
.leaflet-control-attribution{font-size:10px}

/* ---- Top bar (floating) ---- */
.topbar{
  position:fixed;left:10px;right:10px;top:calc(10px + var(--safe-t));z-index:20;
  display:flex;align-items:center;gap:8px;
}
.topbar .brand{
  display:flex;align-items:center;gap:8px;background:var(--panel);box-shadow:var(--shadow);
  border-radius:28px;padding:9px 14px;font-weight:700;flex:1;min-width:0;
}
.topbar .brand .dot{width:12px;height:12px;border-radius:50%;background:var(--danger);flex:none;box-shadow:0 0 0 4px rgba(217,48,37,.18)}
.topbar .brand .name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.iconbtn{
  width:44px;height:44px;border-radius:50%;background:var(--panel);box-shadow:var(--shadow);
  display:grid;place-items:center;flex:none;font-size:20px
}
.legend-chip{
  background:var(--panel);box-shadow:var(--shadow);border-radius:28px;padding:9px 12px;
  display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;white-space:nowrap
}
.legend-grad{width:64px;height:10px;border-radius:6px;
  background:linear-gradient(90deg,hsl(120,75%,45%),hsl(60,75%,45%),hsl(30,80%,48%),hsl(0,75%,45%))}

/* Menu popover */
.menu{
  position:fixed;right:10px;top:calc(64px + var(--safe-t));z-index:30;background:var(--panel);
  box-shadow:var(--shadow-lg);border-radius:14px;overflow:hidden;min-width:220px
}
.menu button,.menu a{display:flex;width:100%;gap:10px;align-items:center;padding:14px 16px;border-bottom:1px solid var(--line);font-size:15px;text-decoration:none;color:var(--ink)}
.menu :last-child{border-bottom:0}

/* ---- FABs ---- */
.fabs{position:fixed;right:14px;bottom:calc(108px + var(--safe-b));z-index:20;display:flex;flex-direction:column;gap:12px;align-items:center}
.fab{width:52px;height:52px;border-radius:16px;background:var(--fab);box-shadow:var(--shadow-lg);display:grid;place-items:center;font-size:22px}
.fab.primary{width:60px;height:60px;border-radius:18px;background:var(--accent);color:#fff;font-size:26px}
.fab.primary:active{background:var(--accent-d)}

/* ---- Disclaimer banner ---- */
.disclaimer{
  position:fixed;left:8px;right:8px;bottom:calc(8px + var(--safe-b));z-index:18;
  background:#1f2a36;color:#e7eef6;border-radius:12px;box-shadow:var(--shadow-lg);
  padding:10px 12px;display:flex;gap:10px;align-items:flex-start;font-size:12.5px;line-height:1.35
}
.disclaimer b{color:#ffd27a}
.disclaimer .x{margin-left:auto;font-size:18px;flex:none;color:#9fb0c0;padding:0 4px}

/* ---- Bottom sheet (area feed) ---- */
.sheet{
  position:fixed;left:0;right:0;bottom:0;z-index:25;height:88vh;background:var(--panel);
  border-radius:18px 18px 0 0;box-shadow:0 -6px 24px rgba(0,0,0,.22);
  transform:translateY(100%);transition:transform .28s cubic-bezier(.22,.61,.36,1);
  display:flex;flex-direction:column;touch-action:none;will-change:transform
}
.sheet.dragging{transition:none}
.sheet .grip{padding:10px 0 4px;display:grid;place-items:center;flex:none;cursor:grab}
.sheet .grip span{width:40px;height:5px;border-radius:3px;background:#cfd8e2}
.sheet .head{padding:2px 16px 10px;flex:none;border-bottom:1px solid var(--line)}
.sheet .body{padding:8px 16px calc(20px + var(--safe-b));overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1;touch-action:pan-y}
.area-title{display:flex;align-items:center;gap:10px}
.area-title h2{margin:0;font-size:1.15rem;flex:1;min-width:0}
.danger-badge{flex:none;color:#fff;font-weight:800;border-radius:12px;padding:6px 12px;font-size:.95rem;line-height:1.1;text-align:center;min-width:64px}
.danger-badge small{display:block;font-weight:600;font-size:.62rem;opacity:.9}
.sheet .actions{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.chipbtn{background:#eef3f9;border-radius:22px;padding:9px 14px;font-size:14px;font-weight:600;display:flex;gap:6px;align-items:center;min-height:40px}
.chipbtn.primary{background:var(--accent);color:#fff}

/* Feed items */
.post{padding:12px 0;border-bottom:1px solid var(--line)}
.post:last-child{border-bottom:0}
.post .meta{display:flex;gap:8px;align-items:center;font-size:12px;color:var(--mut);margin-bottom:4px;flex-wrap:wrap}
.tagpill{background:#eef3f9;border-radius:999px;padding:1px 8px;font-weight:600;color:#42546a}
.tagpill.report{background:#fde7e6;color:#b3261e}
.tagpill.media{background:#e6f0fd;color:#1558b0}
.sev{font-weight:700}
.post .body{white-space:pre-wrap;word-wrap:break-word}
.post .media{margin-top:8px}
.post .media a{display:inline-flex;gap:8px;align-items:center;background:#f1f5fa;border-radius:10px;padding:8px 12px;font-weight:600;text-decoration:none}
.post .flagbtn{font-size:12px;color:var(--mut);margin-top:6px;display:inline-flex;gap:5px;align-items:center}
.empty{color:var(--mut);text-align:center;padding:30px 10px}

/* Danger rating chips */
.rate-row{display:flex;gap:6px;flex-wrap:wrap;margin:8px 0}
.rate{width:38px;height:38px;border-radius:10px;font-weight:700;color:#fff;display:grid;place-items:center;opacity:.45;transition:transform .1s,opacity .1s}
.rate.on{opacity:1;transform:scale(1.06);outline:2px solid #0f1722}

/* ---- Modal sheets (report / generic) ---- */
.backdrop{position:fixed;inset:0;background:rgba(8,15,22,.45);z-index:40;opacity:0;pointer-events:none;transition:opacity .2s}
.backdrop.show{opacity:1;pointer-events:auto}
.modal{
  position:fixed;left:0;right:0;bottom:0;z-index:41;background:var(--panel);
  border-radius:18px 18px 0 0;box-shadow:0 -8px 30px rgba(0,0,0,.3);
  transform:translateY(100%);transition:transform .26s cubic-bezier(.22,.61,.36,1);
  max-height:92vh;display:flex;flex-direction:column
}
.modal.show{transform:translateY(0)}
.modal .grip{padding:10px 0 2px;display:grid;place-items:center}
.modal .grip span{width:40px;height:5px;border-radius:3px;background:#cfd8e2}
.modal h3{margin:4px 16px 0;font-size:1.15rem}
.modal .mbody{padding:8px 16px calc(18px + var(--safe-b));overflow-y:auto}
.field{margin-top:12px}
.field label{display:block;font-size:13px;color:var(--mut);margin-bottom:5px;font-weight:600}
.field input,.field textarea,.field select{
  width:100%;padding:12px;border:1px solid var(--line);border-radius:12px;font:inherit;background:#fafcff
}
.field textarea{min-height:84px;resize:vertical}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.sevseg{display:flex;gap:6px;flex-wrap:wrap}
.sevseg button{flex:1;min-width:60px;border:1px solid var(--line);border-radius:10px;padding:10px 6px;font-size:13px;font-weight:600;background:#fafcff}
.sevseg button.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.submit{margin-top:16px;width:100%;background:var(--accent);color:#fff;padding:14px;border-radius:14px;font-size:16px;font-weight:700}
.submit:disabled{opacity:.5}
.loc-note{font-size:13px;color:var(--mut);background:#f1f5fa;border-radius:10px;padding:10px 12px;display:flex;gap:8px;align-items:center}

/* File upload */
.field input[type=file]{padding:10px;background:#fafcff;border:1px dashed #c4d0dd}
.filechip{display:flex;align-items:center;gap:8px;margin-top:8px;background:#e6f0fd;color:#1558b0;border-radius:10px;padding:9px 12px;font-size:13px;font-weight:600}
.filechip span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.filechip button{margin-left:auto;font-size:20px;line-height:1;color:#1558b0;flex:none}
.submit.busy{opacity:.6}

/* Feed inline media */
.post .vid{width:100%;max-height:340px;border-radius:12px;margin-top:8px;background:#000;display:block}
.post .vimg{width:100%;max-height:340px;object-fit:cover;border-radius:12px;margin-top:8px;display:block}

/* Verification badges */
.vbadge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;white-space:nowrap}
.vbadge.auth{background:#dff3e6;color:#0c7a3d}
.vbadge.tru{background:#e3f0ff;color:#1558b0}
.vbadge.mis{background:#fff1d6;color:#9a6700}
.vbadge.fak{background:#ffe0e0;color:#b3261e}

/* "Is this true?" vote row */
.istrue{display:flex;align-items:center;gap:8px;margin-top:10px;flex-wrap:wrap}
.it-label{font-size:12px;color:var(--mut);font-weight:600}
.votebtn{font-size:13px;font-weight:600;border-radius:999px;padding:7px 12px;background:#eef3f9;color:#26384c;min-height:36px}
.votebtn.yes.on{background:#dff3e6;color:#0c7a3d}
.votebtn.no.on{background:#ffe0e0;color:#b3261e}

/* YouTube facade + embed */
.embed.yt{position:relative;border-radius:12px;overflow:hidden;margin-top:8px;cursor:pointer;background:#000;aspect-ratio:16/9}
.embed.yt .ytthumb{width:100%;height:100%;object-fit:cover;display:block;opacity:.92}
.embed.yt .ytplay{position:absolute;inset:0;margin:auto;width:60px;height:42px;border-radius:10px;background:rgba(0,0,0,.65);color:#fff;display:grid;place-items:center;font-size:20px;pointer-events:none}
.ytframe{width:100%;aspect-ratio:16/9;border:0;border-radius:12px;margin-top:8px;display:block;background:#000}
.vsrc{font-size:11px;color:var(--mut);margin-top:4px}

/* Allow-listed link preview card (shows the real destination — anti-scam) */
.linkcard{display:flex;flex-direction:column;gap:2px;margin-top:8px;background:#f1f5fa;border:1px solid var(--line);border-radius:12px;padding:10px 12px;text-decoration:none}
.linkcard .lc-plat{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#1558b0}
.linkcard .lc-url{font-size:12.5px;color:#26384c;word-break:break-all}
.linkcard .lc-open{font-size:12px;color:var(--accent);font-weight:600}

/* Main Feed area label */
.mf-arearow{margin-bottom:6px}
.mf-area{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;color:#fff;background:var(--c,#777);border-radius:999px;padding:4px 10px}

/* Reason buttons */
.reasons{display:flex;flex-direction:column}
.reasons button{text-align:left;padding:15px 16px;border-bottom:1px solid var(--line);font-size:15px}

/* ---- Toast ---- */
.toast{
  position:fixed;left:50%;bottom:calc(120px + var(--safe-b));transform:translateX(-50%) translateY(20px);
  background:#11202e;color:#fff;padding:11px 16px;border-radius:24px;box-shadow:var(--shadow-lg);
  z-index:60;font-size:14px;max-width:90vw;text-align:center;opacity:0;pointer-events:none;transition:opacity .2s,transform .2s
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.err{background:#7a1d1a}

/* ---- Demo badge ---- */
.demo{
  position:fixed;left:50%;top:calc(64px + var(--safe-t));transform:translateX(-50%);z-index:19;
  background:#5a3b16;color:#ffd9a8;font-size:11.5px;font-weight:600;padding:5px 12px;border-radius:999px;box-shadow:var(--shadow)
}

/* Placing-pin mode banner */
.placing{
  position:fixed;left:10px;right:10px;top:calc(64px + var(--safe-t));z-index:22;background:var(--accent);color:#fff;
  border-radius:12px;box-shadow:var(--shadow-lg);padding:10px 14px;display:flex;gap:10px;align-items:center;font-size:14px;font-weight:600
}
.placing .cancel{margin-left:auto;background:rgba(255,255,255,.2);border-radius:8px;padding:6px 10px;font-size:13px}
.center-pin{position:fixed;left:50%;top:50%;transform:translate(-50%,-100%);z-index:21;font-size:40px;pointer-events:none;filter:drop-shadow(0 3px 3px rgba(0,0,0,.35))}

/* ---- Search bar in top bar ---- */
.searchbar{flex:1;display:flex;align-items:center;gap:6px;background:var(--panel);box-shadow:var(--shadow);border-radius:28px;padding:0 12px;min-width:0;height:44px}
.searchbar .s-icon{font-size:15px;flex:none;opacity:.7}
.searchbar input{border:0;background:none;outline:none;flex:1;min-width:0;font-size:15px;color:var(--ink);height:100%}
.iconbtn.sm{width:34px;height:34px;font-size:16px;box-shadow:none;background:#eef3f9}

/* ---- Left drawer (Main Feed) ---- */
.drawer-backdrop{position:fixed;inset:0;background:rgba(8,15,22,.4);z-index:34;opacity:0;pointer-events:none;transition:opacity .2s}
.drawer-backdrop.show{opacity:1;pointer-events:auto}
.drawer{
  position:fixed;top:0;left:0;bottom:0;z-index:35;width:min(86vw,400px);background:var(--panel);
  box-shadow:6px 0 24px rgba(0,0,0,.25);transform:translateX(-105%);
  transition:transform .26s cubic-bezier(.22,.61,.36,1);display:flex;flex-direction:column;
  padding-top:var(--safe-t)
}
.drawer.open{transform:translateX(0)}
.drawer-head{display:flex;align-items:center;gap:8px;padding:14px 14px;border-bottom:1px solid var(--line);font-size:15px}
.drawer-head .dot{width:11px;height:11px;border-radius:50%;background:var(--danger);flex:none}
.drawer-head strong{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.drawer-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:6px 14px calc(20px + var(--safe-b))}
.mf-post{cursor:pointer}
.mf-post:active{background:#f6f9fc}

/* ---- Pin bar (tapped/searched location) ---- */
.pinbar{
  position:fixed;left:10px;right:10px;bottom:calc(96px + var(--safe-b));z-index:23;
  background:var(--panel);box-shadow:var(--shadow-lg);border-radius:14px;padding:10px 12px;
  display:flex;align-items:center;gap:8px;font-size:14px
}
.pinbar-pin{flex:none;font-size:18px}
.pinbar-addr{flex:1;min-width:0;font-weight:600;line-height:1.25;max-height:2.5em;overflow:hidden}
.pinbar-add{flex:none;background:var(--accent);color:#fff;border-radius:22px;padding:9px 13px;font-weight:700;font-size:13px}
.pinbar-x{flex:none;font-size:18px;color:var(--mut);padding:0 4px}

/* ---- Admin badge ---- */
.adminbadge{position:fixed;left:50%;top:calc(64px + var(--safe-t));transform:translateX(-50%);z-index:19;background:#0c3b6b;color:#cfe6ff;font-size:11.5px;font-weight:700;padding:5px 12px;border-radius:999px;box-shadow:var(--shadow)}

/* ---- Sheet close + draggable header ---- */
.area-title .iconbtn.sm{margin-left:4px}
.sheet .head{cursor:grab}
.sheet .head:active{cursor:grabbing}

/* ---- Owner + admin post controls ---- */
.post-tools{display:flex;gap:10px;align-items:center;margin-top:8px;flex-wrap:wrap}
.post-tools button{font-size:12px;font-weight:600;color:var(--mut);display:inline-flex;gap:5px;align-items:center}
.post-tools .ownerbtn{color:#1558b0}
.post-tools .delbtn{color:var(--danger)}
.post-tools .adminbtn{color:#fff;background:var(--danger);border-radius:8px;padding:5px 9px}
.post-tools .adminverify{color:#fff;background:var(--ok);border-radius:8px;padding:5px 9px}

/* ---- Desktop: sheet becomes a left panel ---- */
@media (min-width:820px){
  .sheet{left:12px;right:auto;bottom:12px;top:78px;width:380px;height:auto;border-radius:18px;
    transform:translateX(-110%);transition:transform .28s cubic-bezier(.22,.61,.36,1)}
  .sheet.open{transform:translateX(0)}
  .sheet.dragging{transition:none}
  .sheet .grip{display:none}
  .modal{left:auto;right:12px;width:400px;border-radius:18px;bottom:12px;top:78px;max-height:none}
  .fabs{bottom:24px}
  .disclaimer{left:auto;right:12px;max-width:360px}
}
