/* ===== MzansiShield — refined design system (light + dark) ===== */
:root{
  color-scheme:light;               /* native controls/scrollbars match the theme */
  --topbar-h:56px;
  /* surfaces */
  --bg:#f3f6fb;
  --bg-elev:#ffffff;
  --bg-subtle:#f7f9fc;
  --bg-alt:#eef2f8;
  --text:#0d1b2a;
  --muted:#5b6b7c;
  --line:#e7edf4;
  --line-strong:#d8e0ea;
  /* brand / accent */
  --accent:#0A1F44;
  --accent-2:#1c3e7e;
  --on-accent:#ffffff;
  --ring:rgba(28,62,126,.35);
  /* action colours */
  --like:#f6347b;
  --confirm:#10b981;
  --reply:#2f6df6;
  /* badges */
  --issue:#2356c8;
  --crime:#d8392e;
  --utility:#0a8f5b;
  /* SA flag */
  --sa-red:#E03C31; --sa-blue:#002395; --sa-green:#007749; --sa-gold:#FFB81C;
  /* notes */
  --note-bg:#fff7e3; --note-bd:#ffe6a0; --note-fg:#8a6400;
  /* effects — softer, layered, more modern */
  --shadow-sm:0 1px 2px rgba(13,27,42,.05), 0 1px 1px rgba(13,27,42,.03);
  --shadow:0 6px 22px -6px rgba(13,27,42,.16), 0 2px 6px rgba(13,27,42,.06);
  --shadow-lg:0 24px 60px -12px rgba(13,27,42,.30), 0 8px 20px rgba(13,27,42,.10);
  --shimmer:rgba(255,255,255,.55);
  --radius:18px;
  --radius-lg:24px;
  --ease:cubic-bezier(.2,.9,.25,1);
  --max:600px;
}
[data-theme="dark"]{
  color-scheme:dark;
  --bg:#0a101d;
  --bg-elev:#121a2b;
  --bg-subtle:#0f1827;
  --bg-alt:#1b2740;
  --text:#e8eef7;
  --muted:#93a3b8;
  --line:#1e2a40;
  --line-strong:#293750;
  --accent:#4f7fff;
  --accent-2:#6b9bff;
  --on-accent:#ffffff;
  --ring:rgba(79,127,255,.45);
  --like:#ff5a98;
  --confirm:#34d399;
  --reply:#6ea8fe;
  --issue:#7aa6ff;
  --crime:#ff7a70;
  --utility:#34d399;
  --note-bg:#2a2410; --note-bd:#4a3f17; --note-fg:#ffd479;
  --shadow-sm:0 1px 2px rgba(0,0,0,.4);
  --shadow:0 10px 30px rgba(0,0,0,.45);
  --shadow-lg:0 18px 48px rgba(0,0,0,.6);
  --shimmer:rgba(255,255,255,.06);
}

*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{min-height:100%}
body{
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--text);
  font-size:15px;line-height:1.45;letter-spacing:-.011em;
  padding-bottom:64px;overscroll-behavior-y:none;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  transition:background .25s ease,color .25s ease;
}
.hidden,[hidden]{display:none !important}

/* ===== Icons ===== */
.ico{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;vertical-align:middle}
.ico svg{display:block;width:100%;height:100%}
.ico-16{width:16px;height:16px}.ico-18{width:18px;height:18px}.ico-20{width:20px;height:20px}
.ico-22{width:22px;height:22px}.ico-24{width:24px;height:24px}.ico-26{width:26px;height:26px}
.sa-blue{color:var(--sa-blue)} .sa-green{color:var(--sa-green)}
[data-theme="dark"] .sa-blue{color:#6ea8ff}

/* ===== Top bar (with chips/search inside, all sticky) ===== */
.topbar{
  position:sticky;top:0;z-index:30;
  background:var(--bg-elev);   /* opaque: scrolled content must never show through */
  border-bottom:1px solid var(--line);
}
.topbar-row{max-width:var(--max);margin:0 auto;display:flex;align-items:center;gap:10px;padding:10px 16px}
.brand-logo{width:32px;height:32px;display:inline-flex;filter:drop-shadow(0 2px 4px rgba(10,31,68,.25))}
.brand-logo svg{width:100%;height:100%}
.brand-name{font-weight:800;font-size:1.18rem;letter-spacing:-.02em}
.topbar-actions{margin-left:auto;display:flex;align-items:center;gap:2px}
.icon-btn{background:none;border:none;color:var(--text);cursor:pointer;padding:7px;border-radius:50%;display:inline-flex;align-items:center;transition:background .15s,transform .1s}
.icon-btn:hover{background:var(--bg-alt)}
.icon-btn:active{transform:scale(.9)}
.mini-avatar{width:30px;height:30px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.78rem;overflow:hidden;box-shadow:0 0 0 2px var(--bg-elev)}
.mini-avatar img{width:100%;height:100%;object-fit:cover}
.signin-label{font-weight:700;font-size:.82rem;color:var(--on-accent);background:linear-gradient(135deg,var(--accent),var(--accent-2));padding:7px 14px;border-radius:999px;box-shadow:var(--shadow-sm)}

/* ===== Sub-header bars ===== */
.chips{background:transparent;max-width:var(--max);margin:0 auto;display:flex;gap:8px;padding:2px 12px 10px;overflow-x:auto;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{flex:0 0 auto;border:1px solid var(--line-strong);background:var(--bg-elev);color:var(--text);font-weight:600;font-size:.85rem;padding:7px 16px;border-radius:999px;cursor:pointer;transition:transform .12s,background .15s,color .15s,border-color .15s}
.chip:active{transform:scale(.95)}
.chip.active{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--on-accent);border-color:transparent;box-shadow:var(--shadow-sm)}
.search-wrap{background:transparent;max-width:var(--max);margin:0 auto;display:flex;align-items:center;gap:8px;padding:2px 16px 10px}
.search-wrap .ico{color:var(--muted)}
.search-wrap input{flex:1;border:1px solid var(--line);background:var(--bg-alt);border-radius:999px;padding:10px 16px;font-size:.95rem;font-family:inherit;color:var(--text)}
.search-wrap input:focus{outline:none;border-color:var(--accent);background:var(--bg-elev);box-shadow:0 0 0 4px var(--ring)}

/* ===== Screens ===== */
main{max-width:var(--max);margin:0 auto}
.screen{display:none}
.screen.active{display:block;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.screen-pad{padding:18px 16px}
.screen-title{font-size:1.3rem;font-weight:800;letter-spacing:-.02em;margin-bottom:2px}
.muted{color:var(--muted);font-size:.9rem;margin-bottom:16px}
.hint{color:var(--muted);text-align:center;padding:40px 24px;font-size:.92rem}

/* ===== Feed / posts ===== */
.feed{display:flex;flex-direction:column}
.post{display:flex;gap:12px;padding:14px 16px;border-bottom:1px solid var(--line);animation:pop .25s ease;transition:background .15s}
@keyframes pop{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.post:hover{background:var(--bg-subtle)}
.post-highlight{animation:postFlash 2.4s ease}
@keyframes postFlash{0%,100%{background:transparent}15%,55%{background:color-mix(in srgb,var(--accent) 14%,transparent)}}
.avatar{width:46px;height:46px;border-radius:50%;flex:0 0 auto;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:1rem;box-shadow:var(--shadow-sm)}
.avatar img{width:100%;height:100%;object-fit:cover}
.avatar svg{width:100%;height:100%}
.post-body{flex:1;min-width:0}
.post-head{display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.post-name{font-weight:700}
.verified{width:15px;height:15px;border-radius:50%;background:var(--sa-gold);display:inline-flex;align-items:center;justify-content:center;color:#fff}
.verified .ico{width:10px;height:10px}
.post-handle{color:var(--muted);font-size:.9rem}
.post-badge{margin-left:auto;font-size:.68rem;font-weight:800;padding:3px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.4px}
.badge-issue{background:rgba(43,108,214,.14);color:var(--issue)}
.badge-crime{background:rgba(224,60,49,.14);color:var(--crime)}
.badge-utility{background:rgba(10,143,91,.16);color:var(--utility)}
.post-loc{display:flex;align-items:center;flex-wrap:wrap;gap:3px 7px;color:var(--muted);font-size:.85rem;margin:3px 0}
.post-loc .ico{width:14px;height:14px;flex:0 0 auto}
.loc-name{min-width:0;word-break:break-word}
/* Small screens: keep the kebab pinned top-right and let the type badge flow inline
   after the handle instead of being pushed onto its own line. */
@media (max-width:520px){
  .post-head{position:relative;padding-right:26px}
  .post-menu{position:absolute;top:-2px;right:0;margin:0}
  .post-badge{margin-left:0}
  .post-loc{font-size:.82rem}
}
.post-text{font-size:.97rem;margin:2px 0 4px;white-space:pre-wrap;word-wrap:break-word}
.post-photo{display:block;margin:8px 0 4px;border-radius:14px;width:100%;max-height:340px;object-fit:cover;border:1px solid var(--line)}
.map-toggle{background:none;border:none;color:var(--reply);font-weight:600;font-size:.8rem;cursor:pointer;padding:0 4px}
.post-map{height:150px;border-radius:14px;overflow:hidden;border:1px solid var(--line);margin:6px 0;position:relative;z-index:0;isolation:isolate}
[data-theme="dark"] .post-map .leaflet-tile{filter:brightness(.85) contrast(1.05) saturate(.9)}

/* post overflow menu */
.post-menu{position:relative;margin-left:6px}
.kebab{background:none;border:none;color:var(--muted);cursor:pointer;padding:2px 4px;border-radius:50%;display:inline-flex}
.kebab:hover{background:var(--bg-alt);color:var(--text)}
.kebab .ico{width:18px;height:18px}
.post-menu .menu{position:absolute;right:0;top:26px;z-index:15;background:var(--bg-elev);border:1px solid var(--line-strong);border-radius:12px;box-shadow:var(--shadow);min-width:150px;overflow:hidden;animation:fade .12s ease}
.post-menu .menu button{display:flex;align-items:center;gap:8px;width:100%;text-align:left;background:none;border:none;padding:11px 14px;font-size:.9rem;color:var(--text);cursor:pointer}
.post-menu .menu button:hover{background:var(--bg-alt)}
.post-menu .menu button.danger{color:var(--sa-red)}
.post-menu .menu .ico{width:16px;height:16px}

/* sort bar */
.sortbar{display:flex;align-items:center;gap:8px;padding:10px 16px;border-bottom:1px solid var(--line)}
.sortbtn{background:none;border:1px solid var(--line-strong);color:var(--muted);font-weight:600;font-size:.82rem;padding:6px 14px;border-radius:999px;cursor:pointer}
.sortbtn.active{background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent);border-color:transparent}
.refresh-btn{margin-left:auto;background:none;border:none;color:var(--muted);cursor:pointer;padding:6px;border-radius:50%;display:inline-flex}
.refresh-btn:hover{background:var(--bg-alt);color:var(--accent)}
.refresh-btn.spinning{animation:spin .8s linear infinite}

/* composer photo + char count */
.compose-foot{display:flex;align-items:center;justify-content:space-between;margin-top:4px}
.ghost-chip{display:inline-flex;align-items:center;gap:6px;background:none;border:1px solid var(--line-strong);color:var(--accent);font-weight:600;font-size:.85rem;padding:7px 12px;border-radius:999px;cursor:pointer}
.ghost-chip:hover{background:color-mix(in srgb,var(--accent) 8%,transparent)}
.char-count{font-size:.78rem;color:var(--muted)}
.char-count.over{color:var(--sa-red)}
.photo-preview{position:relative;margin-top:10px;display:inline-block}
.photo-preview img{max-height:200px;max-width:100%;border-radius:12px;border:1px solid var(--line)}
.photo-remove{position:absolute;top:6px;right:6px;width:26px;height:26px;border-radius:50%;border:none;background:rgba(0,0,0,.6);color:#fff;font-size:1.1rem;line-height:1;cursor:pointer}

/* actions */
.post-actions{display:flex;gap:8px;margin-top:10px;align-items:center}
.act{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:var(--muted);font-size:.82rem;cursor:pointer;padding:6px 8px;border-radius:999px;transition:color .15s,background .15s,border-color .15s}
.act .ico{width:18px;height:18px;transition:transform .15s}
.act:active .ico{transform:scale(.85)}
.act.reply:hover{color:var(--reply);background:color-mix(in srgb,var(--reply) 14%,transparent)}
.act.share{margin-left:auto}
.act.share:hover{color:var(--reply);background:color-mix(in srgb,var(--reply) 14%,transparent)}
/* Confirm = primary engagement pill */
.act.confirm{border:1.5px solid var(--line-strong);padding:5px 14px;font-weight:600;color:var(--muted)}
.act.confirm .ct{opacity:.8}
.act.confirm:hover{color:var(--confirm);border-color:var(--confirm);background:color-mix(in srgb,var(--confirm) 8%,transparent)}
.act.confirm.confirmed{background:var(--confirm);border-color:var(--confirm);color:#fff}
.act.confirm.confirmed .ct{opacity:.9}
.act.confirm.confirmed .ico svg{stroke:#fff}
.act.confirm.confirmed .ico{animation:pops .4s ease}
@keyframes pops{0%{transform:scale(1)}40%{transform:scale(1.3)}70%{transform:scale(.9)}100%{transform:scale(1)}}

/* comments */
.comments{margin-top:12px;border-top:1px solid var(--line);padding-top:12px;animation:fade .2s ease}
.comment{display:flex;gap:8px;margin-bottom:10px}
.comment .avatar{width:30px;height:30px;font-size:.75rem}
.comment-body{flex:1;min-width:0}
.comment-head{font-size:.82rem}.comment-head b{font-weight:700}.comment-head span{color:var(--muted)}
.comment-text{font-size:.9rem}
.comment-actions{margin-left:8px;display:inline-flex;gap:8px}
.clink{background:none;border:none;padding:0;cursor:pointer;color:var(--muted);font-size:.78rem;font-weight:600;font-family:inherit}
.clink:hover{color:var(--accent)}
.clink.danger:hover{color:var(--danger,#dc2626)}
.comment-edit{display:flex;gap:8px;margin-top:4px;align-items:center;flex-wrap:wrap}
.comment-edit input{flex:1;min-width:140px;border:1px solid var(--line-strong);border-radius:999px;padding:8px 13px;font-size:.9rem;font-family:inherit;background:var(--bg-alt);color:var(--text)}
.comment-edit input:focus{outline:none;border-color:var(--accent);background:var(--bg-elev);box-shadow:0 0 0 4px var(--ring)}
.comment-edit button[type=submit]{border:none;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--on-accent);font-weight:600;border-radius:999px;padding:7px 15px;cursor:pointer;font-size:.82rem}
.comment-form{display:flex;gap:8px;margin-top:4px}
.comment-form input{flex:1;border:1px solid var(--line-strong);border-radius:999px;padding:9px 14px;font-size:.9rem;font-family:inherit;background:var(--bg-alt);color:var(--text)}
.comment-form input:focus{outline:none;border-color:var(--accent);background:var(--bg-elev);box-shadow:0 0 0 4px var(--ring)}
.comment-form button{border:none;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--on-accent);font-weight:600;border-radius:999px;padding:0 16px;cursor:pointer;font-size:.85rem}
.empty{color:var(--muted);font-size:.9rem;text-align:center;padding:22px}

/* ===== Utilities ===== */
.field-label{display:block;font-weight:600;font-size:.85rem;margin:6px 0 4px}
.field{width:100%;padding:12px 14px;font-size:1rem;font-family:inherit;border:1px solid var(--line-strong);border-radius:14px;background:var(--bg-alt);color:var(--text);transition:border-color .15s,box-shadow .15s,background .15s}
.field:focus{outline:none;border-color:var(--accent);background:var(--bg-elev);box-shadow:0 0 0 4px var(--ring)}
.area-search{position:relative}
.area-suggest{list-style:none;position:absolute;left:0;right:0;top:calc(100% + 6px);z-index:25;background:var(--bg-elev);border:1px solid var(--line-strong);border-radius:14px;box-shadow:var(--shadow);max-height:320px;overflow-y:auto}
.area-suggest li{display:flex;align-items:baseline;justify-content:space-between;gap:10px;padding:11px 14px;cursor:pointer;border-bottom:1px solid var(--line)}
.area-suggest li:last-child{border-bottom:none}
.area-suggest li:hover{background:var(--bg-alt)}
.area-suggest li span{font-weight:600}
.area-suggest small{color:var(--muted);font-size:.78rem;white-space:nowrap}
.area-empty{color:var(--muted);padding:12px 14px;font-size:.9rem;cursor:default}
.demo-note{margin-top:10px;font-size:.78rem;color:var(--note-fg);background:var(--note-bg);border:1px solid var(--note-bd);border-radius:12px;padding:9px 12px}
.util-prov{color:var(--muted);font-size:.82rem;margin:-2px 0 8px}
.util-card{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius-lg);padding:18px;margin-top:16px;box-shadow:var(--shadow-sm)}
.util-row{display:flex;align-items:center;gap:14px;padding:12px 0;border-top:1px solid var(--line)}
.util-row:first-of-type{border-top:none}
.util-label{display:block;font-size:.75rem;color:var(--muted)}
.util-value{display:block;font-weight:600}
/* Stable / Unstable status pill + supporting line */
.status-pill{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;font-weight:700;letter-spacing:.01em;padding:3px 11px;border-radius:999px;border:1px solid transparent;line-height:1.3}
.status-pill::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}
.status-pill.stable{color:#0f7a3d;background:color-mix(in srgb,#16a34a 16%,transparent);border-color:color-mix(in srgb,#16a34a 32%,transparent)}
.status-pill.unstable{color:#b42318;background:color-mix(in srgb,#ef4444 15%,transparent);border-color:color-mix(in srgb,#ef4444 32%,transparent)}
.status-pill.unknown{color:var(--muted);background:color-mix(in srgb,var(--muted) 14%,transparent);border-color:var(--line-strong)}
[data-theme="dark"] .status-pill.stable{color:#4ade80}
[data-theme="dark"] .status-pill.unstable{color:#fca5a5}
.util-value .util-sub{display:block;margin-top:4px;font-weight:500;font-size:.86rem;color:var(--text)}
.util-value .ls-win{display:inline-block;margin-right:8px}

/* ===== Profile ===== */
.profile-head{display:flex;align-items:center;gap:14px;padding:20px 16px 12px}
.avatar-edit{position:relative;display:inline-flex;flex:0 0 auto;cursor:pointer}
.profile-avatar{width:68px;height:68px;border-radius:50%;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.5rem;box-shadow:var(--shadow-sm)}
.profile-avatar img{width:100%;height:100%;object-fit:cover}
.profile-avatar svg{width:100%;height:100%}
.avatar-cam{position:absolute;right:-2px;bottom:-2px;width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;border:2px solid var(--bg);display:flex;align-items:center;justify-content:center}
.avatar-cam svg{width:13px;height:13px}
.profile-name{display:block;font-weight:800;font-size:1.18rem;letter-spacing:-.02em}
.profile-handle{color:var(--muted)}
.remove-photo{background:none;border:none;color:var(--reply);font-size:.8rem;cursor:pointer;padding:2px 0;text-align:left}
.profile-stats{display:flex;gap:22px;padding:6px 16px 16px;border-bottom:1px solid var(--line)}
.profile-stats div{display:flex;gap:5px;align-items:baseline;font-size:.9rem;color:var(--muted)}
.profile-stats strong{color:var(--text);font-size:1.05rem}
.profile-tab{padding:14px 16px;font-weight:700;border-bottom:1px solid var(--line)}
/* profile tabs */
/* Not sticky — the tabs scroll away with the content, so accordion text can never overlap them. */
.profile-tabs{display:flex;border-bottom:1px solid var(--line);background:var(--bg-elev)}
.ptab{flex:1;background:none;border:none;padding:14px 8px;font-weight:700;color:var(--muted);cursor:pointer;position:relative;font-size:.92rem;transition:color .15s}
.ptab:hover{color:var(--text)}
.ptab.active{color:var(--text)}
.ptab.active::after{content:"";position:absolute;left:50%;transform:translateX(-50%);bottom:-1px;width:54%;height:3px;border-radius:3px;background:linear-gradient(90deg,var(--accent),var(--accent-2))}
/* settings */
.settings{padding-bottom:20px}
.set-item{border-bottom:1px solid var(--line)}
.set-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:16px;cursor:pointer;font-weight:600}
.set-row .chev{color:var(--muted);transition:transform .2s}
.set-item.open .chev{transform:rotate(90deg)}
.set-body{display:none;padding:0 16px 16px;color:var(--muted);font-size:.88rem;line-height:1.55}
.set-item.open .set-body{display:block;animation:fade .2s ease}
.set-body p{margin-bottom:9px}
.set-body strong{color:var(--text)}
.set-danger{padding:20px 16px}
.danger-btn{width:100%;background:none;border:1.5px solid var(--sa-red);color:var(--sa-red);font-weight:700;padding:12px;border-radius:14px;cursor:pointer;transition:background .15s}
.danger-btn:hover{background:color-mix(in srgb,var(--sa-red) 8%,transparent)}
.danger-btn.solid{background:var(--sa-red);color:#fff}
.delete-confirm{margin-top:12px;background:color-mix(in srgb,var(--sa-red) 8%,transparent);border:1px solid color-mix(in srgb,var(--sa-red) 32%,transparent);border-radius:14px;padding:14px;animation:fade .2s ease}
.delete-confirm p{font-size:.86rem;color:var(--text);margin-bottom:12px}
.delete-actions{display:flex;gap:10px}
.delete-actions .danger-btn{flex:1;width:auto}
.btn-ghost{flex:1;background:var(--bg-elev);border:1px solid var(--line-strong);color:var(--text);border-radius:12px;padding:10px;font-weight:600;cursor:pointer}
.btn-ghost:hover{background:var(--bg-alt)}
.logout-btn{margin-left:auto;align-self:center;background:var(--bg-elev);border:1px solid var(--line-strong);color:var(--text);border-radius:999px;padding:7px 15px;font-weight:600;cursor:pointer;font-size:.85rem;transition:background .15s}
.logout-btn:hover{background:var(--bg-alt)}
.signin-prompt{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center;padding:56px 24px}
.signin-prompt .ico{color:var(--muted)}
.signin-prompt p{color:var(--muted);max-width:300px}

/* ===== FAB ===== */
.fab{position:fixed;right:max(16px,calc(50vw - var(--max)/2 + 16px));bottom:78px;z-index:40;width:58px;height:58px;border-radius:50%;border:none;cursor:pointer;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;box-shadow:var(--shadow-lg);display:flex;align-items:center;justify-content:center;transition:transform .12s,box-shadow .2s}
.fab:hover{transform:translateY(-2px)}
.fab:active{transform:scale(.92)}

/* ===== Bottom nav ===== */
.tabbar{position:fixed;bottom:0;left:0;right:0;z-index:35;display:flex;background:var(--bg-elev);background:color-mix(in srgb,var(--bg-elev) 88%,transparent);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-top:1px solid var(--line)}
.tabbar .tab{flex:1;background:none;border:none;cursor:pointer;color:var(--muted);padding:12px 0 14px;display:flex;align-items:center;justify-content:center;transition:color .15s,transform .1s}
.tabbar .tab:active{transform:scale(.9)}
.tabbar .tab.active{color:var(--accent)}

/* ===== Modals ===== */
.modal-overlay{position:fixed;inset:0;z-index:50;background:rgba(8,16,29,.5);display:flex;align-items:flex-end;justify-content:center;animation:fadein .18s ease}
@keyframes fadein{from{opacity:0}to{opacity:1}}
.sheet{width:100%;max-width:var(--max);background:var(--bg-elev);border-radius:22px 22px 0 0;box-shadow:var(--shadow-lg);animation:slideup .26s cubic-bezier(.2,.85,.2,1);max-height:92vh;max-height:92dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding-bottom:calc(env(safe-area-inset-bottom) + 14px)}
@keyframes slideup{from{transform:translateY(100%)}to{transform:none}}
.sheet-bar{position:sticky;top:0;z-index:3;background:var(--bg-elev);display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-bottom:1px solid var(--line)}
.sheet-title{font-weight:700}
.link-btn{background:none;border:none;color:var(--text);font-size:.95rem;cursor:pointer}
.post-btn{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--on-accent);border:none;font-weight:700;border-radius:999px;padding:9px 22px;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform .1s,filter .15s}
.post-btn:hover{filter:brightness(1.06)}
.post-btn:active{transform:scale(.96)}
.post-btn:disabled{opacity:.5;cursor:not-allowed}
.composer{display:flex;gap:11px;padding:14px 16px}
.composer-avatar{width:46px;height:46px;border-radius:50%;overflow:hidden;flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:700}
.composer-avatar img{width:100%;height:100%;object-fit:cover}
.composer-avatar svg{width:100%;height:100%}
.composer-body{flex:1;display:flex;flex-direction:column;gap:10px}
.seg{display:flex;gap:8px}
.seg-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid var(--line-strong);background:var(--bg-elev);color:var(--muted);font-weight:600;font-size:.88rem;padding:10px;border-radius:14px;cursor:pointer;transition:.15s}
.seg-btn.active{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent)}
.compose-error{color:var(--sa-red);font-size:.85rem}

/* GPS location */
.locate-row{display:flex;gap:8px;align-items:stretch}
.locate-row .field{flex:1}
.locate-btn{flex:0 0 auto;width:48px;border:1px solid var(--line-strong);background:var(--bg-elev);color:var(--accent);border-radius:14px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:border-color .15s,background .15s,transform .1s}
.locate-btn:hover{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent)}
.locate-btn:active{transform:scale(.94)}
.locate-btn .ico{width:21px;height:21px}
.locate-cta{margin-top:10px;width:100%;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent);color:var(--accent);font-weight:600;font-size:.92rem;padding:11px;border-radius:14px;cursor:pointer;transition:background .15s,transform .1s}
.locate-cta:hover{background:color-mix(in srgb,var(--accent) 15%,transparent)}
.locate-cta:active{transform:scale(.98)}
.locate-cta .ico{width:18px;height:18px}
.locate-status{font-size:.8rem;display:flex;align-items:center;gap:6px;min-height:16px;margin-top:6px}
.locate-status.busy{color:var(--muted)}
.locate-status.ok{color:var(--confirm)}
.locate-status.err{color:var(--sa-red)}
.locate-status .ico{width:14px;height:14px}
.spin{width:13px;height:13px;border:2px solid var(--line-strong);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}

/* Map pin (Leaflet) */
.compose-map{height:190px;border-radius:14px;overflow:hidden;border:1px solid var(--line-strong);margin-top:6px}
.compose-map .leaflet-container{height:100%;background:var(--bg-alt);font-family:inherit}
.map-hint{font-size:.78rem;color:var(--muted);margin-top:5px;display:flex;align-items:center;gap:6px}
.map-hint .ico{width:14px;height:14px;color:var(--accent)}
.map-pin-inner svg{filter:drop-shadow(0 2px 3px rgba(0,0,0,.35))}
.map-pin-inner svg path{fill:var(--accent);stroke:#fff;stroke-width:1.4}
.map-pin-inner svg circle{fill:#fff}
[data-theme="dark"] .compose-map .leaflet-tile{filter:brightness(.85) contrast(1.05) saturate(.9)}

/* ===== Auth ===== */
.auth-note{margin:13px 16px 4px;font-size:.9rem;color:var(--text);background:var(--bg-alt);border-radius:12px;padding:11px 13px}
.auth-fields{display:flex;flex-direction:column;gap:10px;padding:14px 16px 4px}
.auth-toggleText{padding:12px 16px 18px;font-size:.88rem;color:var(--muted)}
/* ---- Passwordless auth modal ---- */
.sheet-bar-spacer{width:52px}
.auth-body{padding:16px 18px 22px}
.oauth-list{display:flex;flex-direction:column;gap:10px}
.oauth-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:13px 16px;font-size:.95rem;font-weight:600;font-family:inherit;color:var(--text);background:var(--bg-elev);border:1px solid var(--line-strong);border-radius:14px;cursor:pointer;transition:background .15s,border-color .15s,transform .1s}
.oauth-btn:hover{background:var(--bg-alt)}
.oauth-btn:active{transform:scale(.985)}
.oauth-btn:focus-visible{outline:none;box-shadow:0 0 0 4px var(--ring);border-color:var(--accent)}
.oauth-ico{flex:0 0 auto}
.auth-divider{display:flex;align-items:center;gap:12px;margin:18px 0;color:var(--muted);font-size:.82rem}
.auth-divider::before,.auth-divider::after{content:"";flex:1;height:1px;background:var(--line)}
.auth-lbl{display:block;font-weight:600;font-size:.85rem;margin:0 0 7px}
.auth-opt{color:var(--muted);font-weight:400}
.turnstile-box{margin-top:12px;display:flex;justify-content:center;min-height:0}
.turnstile-box:empty{margin:0}
.auth-primary{width:100%;margin-top:12px;padding:13px;font-size:.97rem}
.auth-fineprint{margin-top:12px;font-size:.8rem;color:var(--muted);text-align:center;line-height:1.5}
.auth-code-to{font-size:.95rem;color:var(--text);margin-bottom:14px;line-height:1.5}
.auth-code-input{text-align:center;font-size:1.6rem;letter-spacing:.5em;font-weight:700;padding:14px 10px}
.auth-code-input::placeholder{letter-spacing:.4em}
.auth-devcode{margin-top:12px;font-size:.85rem;color:var(--note-fg);background:var(--note-bg);border:1px solid var(--note-bd);border-radius:12px;padding:10px 12px;line-height:1.5}
.auth-code-actions{display:flex;justify-content:space-between;gap:12px;margin-top:16px;flex-wrap:wrap}
/* Admin moderation queue */
.admin-item{border:1px solid var(--line);border-radius:14px;padding:13px;margin-bottom:12px;background:var(--bg-elev)}
.admin-meta{font-size:.82rem;color:var(--muted);margin-bottom:6px}
.admin-loc{font-size:.8rem;color:var(--muted);display:flex;align-items:center;gap:5px;margin-bottom:6px}
.admin-text{font-size:.92rem;margin-bottom:10px;white-space:pre-wrap;word-break:break-word}
.admin-photo{display:block;width:100%;max-height:280px;object-fit:cover;border-radius:12px;border:1px solid var(--line);margin-bottom:10px}
.admin-actions{display:flex;gap:10px;flex-wrap:wrap}
.admin-flag{display:inline-block;margin-left:6px;font-size:.72rem;font-weight:700;color:#b42318;background:color-mix(in srgb,#ef4444 15%,transparent);border:1px solid color-mix(in srgb,#ef4444 32%,transparent);border-radius:999px;padding:1px 8px}
.admin-flag.hidden-flag{color:#fff;background:#b42318;border-color:#b42318}
.admin-flag.pending-flag{color:#fff;background:#b45309;border-color:#b45309}
.admin-pending{border-color:color-mix(in srgb,#f59e0b 55%,transparent);box-shadow:0 0 0 2px color-mix(in srgb,#f59e0b 18%,transparent)}
.post-pending{display:inline-block;margin-left:6px;font-size:.7rem;font-weight:700;color:#b45309;background:color-mix(in srgb,#f59e0b 16%,transparent);border:1px solid color-mix(in srgb,#f59e0b 34%,transparent);border-radius:999px;padding:1px 8px;vertical-align:middle}
.admin-comments{border-top:1px solid var(--line);margin:0 0 10px;padding-top:8px;display:flex;flex-direction:column;gap:6px}
.admin-comment{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;font-size:.85rem}
.admin-ctext{color:var(--text);word-break:break-word}
.admin-comment .clink{flex:0 0 auto}
.link-accent{background:none;border:none;color:var(--reply);font-weight:700;cursor:pointer;font-size:.88rem;padding:0}

/* ===== Toast ===== */
.toast{position:fixed;bottom:88px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--accent);color:#fff;padding:11px 20px;border-radius:999px;font-size:.9rem;opacity:0;pointer-events:none;transition:.3s cubic-bezier(.2,.85,.2,1);z-index:60;box-shadow:var(--shadow-lg);display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast .ico{width:16px;height:16px}

/* ===== Skeleton loading ===== */
.skel-post{display:flex;gap:12px;padding:14px 16px;border-bottom:1px solid var(--line)}
.skel-lines{flex:1;display:flex;flex-direction:column;gap:9px;padding-top:4px}
.skeleton{position:relative;overflow:hidden;background:var(--bg-alt);border-radius:8px}
.skeleton::after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,var(--shimmer),transparent);animation:shimmer 1.4s infinite}
@keyframes shimmer{100%{transform:translateX(100%)}}
.skel-ava{width:46px;height:46px;border-radius:50%}
.skel-line{height:11px}
.skel-line.w30{width:30%}.skel-line.w50{width:50%}.skel-line.w90{width:90%}.skel-line.w70{width:70%}

/* ===== Empty state ===== */
.empty-state{display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center;padding:54px 24px;color:var(--muted)}
.empty-state .ico{color:var(--line-strong);width:46px;height:46px}
.empty-state p{max-width:280px;font-size:.92rem}

/* ===== Desktop ===== */
@media(min-width:601px){
  body{background:var(--bg)}
  main,.topbar-row{border-left:1px solid var(--line);border-right:1px solid var(--line)}
  main{background:var(--bg-elev);min-height:100vh}
}

/* ===== Modern polish (2025 refresh) ===== */
.field{border-radius:16px;transition:border-color .15s,box-shadow .2s var(--ease),background .2s}
.post-btn,.chip,.sortbtn,.ghost-chip,.locate-cta,.danger-btn,.btn-ghost{transition:transform .14s var(--ease),background .18s,border-color .15s,filter .15s,box-shadow .2s}
.post-btn:hover{transform:translateY(-1px)}
.chip:hover,.sortbtn:hover{transform:translateY(-1px)}
.fab{box-shadow:0 16px 32px -10px color-mix(in srgb,var(--accent) 55%,transparent), var(--shadow-lg);transition:transform .18s var(--ease),box-shadow .25s}
.fab:hover{transform:translateY(-3px) scale(1.03)}
.tabbar .tab{position:relative;isolation:isolate}
.tabbar .tab.active::before{content:"";position:absolute;top:7px;left:50%;transform:translateX(-50%);width:46px;height:30px;border-radius:14px;background:color-mix(in srgb,var(--accent) 13%,transparent);z-index:0}
.tabbar .tab .ico{position:relative;z-index:1}
.post{transition:background .18s var(--ease)}
.util-card{border-radius:var(--radius-lg)}
.area-suggest,.post-menu .menu,.compose-map,.post-map{border-radius:16px}
.avatar,.profile-avatar,.composer-avatar,.mini-avatar{box-shadow:0 2px 8px rgba(13,27,42,.14)}
.brand-name{letter-spacing:-.03em}
.screen-title,.profile-name{letter-spacing:-.03em}
@media (prefers-reduced-motion: reduce){
  .fab:hover,.post-btn:hover,.chip:hover,.sortbtn:hover{transform:none}
}

/* ===== Slick refresh (premium pass) ===== */
body{font-feature-settings:"cv11","ss01"}
/* header: soft elevation instead of a hard line */
.topbar{border-bottom:1px solid color-mix(in srgb,var(--line) 70%,transparent);box-shadow:0 10px 24px -20px rgba(13,27,42,.35)}
/* bottom sheets: bigger radius + grab handle */
.sheet{border-radius:26px 26px 0 0}
.sheet::before{content:"";display:block;width:40px;height:4px;border-radius:999px;background:var(--line-strong);margin:8px auto 2px}
/* posts: more breathing room + avatar ring */
.post{padding:16px;gap:13px}
.avatar{box-shadow:0 0 0 1px var(--line),0 2px 8px rgba(13,27,42,.12)}
.act{padding:7px 10px}
/* crisper controls + larger touch targets */
.chip{padding:8px 16px}
.seg-btn{border-radius:14px;padding:11px}
.field{padding:13px 15px}
.post-btn{padding:10px 22px}
.tabbar .tab{padding:13px 0 15px}
.tabbar .tab .ico{transition:transform .18s var(--ease)}
.tabbar .tab.active .ico{transform:translateY(-1px)}
/* accessible, modern focus ring */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
button:focus:not(:focus-visible),input:focus:not(:focus-visible),select:focus:not(:focus-visible){outline:none}
/* glassy toast */
.toast{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:color-mix(in srgb,var(--accent) 92%,transparent)}
/* desktop: app column floats with a soft shadow */
@media(min-width:601px){ main{box-shadow:0 0 70px -24px rgba(13,27,42,.30)} }
/* never float the compose button over the Utilities map */
body[data-screen="utilities"] .fab{display:none !important}
/* Reserve enough bottom space that the last post clears BOTH the bottom nav and the
   floating compose button (FAB sits ~78–136px up), so nothing overlaps the last card. */
body{padding-bottom:calc(74px + env(safe-area-inset-bottom,0px))}
.screen-pad{padding-bottom:28px}
/* trap Leaflet's internal z-index:1000 controls inside the map box so they
   can't paint over the fixed top bar / bottom nav while scrolling */
#util-map,#compose-map{margin-bottom:4px;position:relative;z-index:0;isolation:isolate}
/* flat, opaque bottom nav — active tab is just a coloured icon (no floating pill) */
.tabbar{background:var(--bg-elev);backdrop-filter:none;-webkit-backdrop-filter:none}
.tabbar .tab.active::before{display:none !important}

/* ===== Premium polish pass (cosmetic; hover-guarded) ===== */
html{scroll-behavior:smooth}
body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}
.screen-title,.brand-name,.profile-name,.sheet-title{letter-spacing:-.012em}

/* Interactive transitions */
.post{transition:background .2s var(--ease)}
.post-actions .act{transition:color .16s var(--ease),transform .12s var(--ease)}
.kebab{transition:background .15s,transform .1s}
.fab{transition:transform .18s var(--ease),box-shadow .25s var(--ease)}
.fab:active{transform:scale(.93)}
.field{transition:border-color .18s var(--ease),box-shadow .22s var(--ease),background .18s}
.post-btn,.auth-primary,.ghost-chip,.oauth-btn,.locate-cta{transition:transform .12s var(--ease),box-shadow .22s var(--ease),filter .2s,background .15s,border-color .15s}
.post-btn:active,.auth-primary:active,.ghost-chip:active,.oauth-btn:active,.locate-cta:active{transform:translateY(1px) scale(.99)}
.tabbar .tab .ico{transition:transform .2s var(--ease),color .15s}
.tabbar .tab.active .ico{transform:translateY(-1px) scale(1.06)}

/* Depth & finish */
.status-pill{box-shadow:var(--shadow-sm)}
.avatar,.profile-avatar,.mini-avatar{box-shadow:0 0 0 1px color-mix(in srgb,var(--line-strong) 55%,transparent),var(--shadow-sm)}
.post-badge{letter-spacing:.015em}
.toast{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.util-card,.admin-item{transition:box-shadow .22s var(--ease),border-color .2s}

/* Hover states (pointer devices only, so touch never sticks) */
@media (hover:hover){
  .post:hover{background:color-mix(in srgb,var(--accent) 3%,var(--bg-elev))}
  .post-actions .act:hover{transform:translateY(-1px)}
  .act.reply:hover{color:var(--reply)}
  .act.confirm:hover{color:var(--confirm)}
  .act.share:hover{color:var(--accent)}
  .kebab:hover{background:var(--bg-alt)}
  .fab:hover{transform:translateY(-2px) scale(1.03);box-shadow:var(--shadow-lg)}
  .post-btn:hover,.auth-primary:hover{filter:brightness(1.06);box-shadow:0 8px 22px -8px var(--ring)}
  .ghost-chip:hover,.oauth-btn:hover,.locate-cta:hover{transform:translateY(-1px);border-color:var(--line-strong)}
  .chip:hover{border-color:var(--line-strong)}
  .util-card:hover,.admin-item:hover{box-shadow:var(--shadow)}
  .map-toggle:hover{text-decoration:underline}
  .link-accent:hover,.clink:hover{opacity:.85}
}

/* ==========================================================================
   BOLD & VIBRANT REDESIGN (SA energy) — self-contained override, revertable
   ========================================================================== */
:root{
  --grad-brand:linear-gradient(120deg,#0a1f44 0%,#153a7a 55%,#1c56c9 100%);
  --grad-accent:linear-gradient(135deg,#1c56c9,#0a8f5b);
  --card-radius:20px;
}
[data-theme="dark"]{ --grad-brand:linear-gradient(120deg,#0a1424 0%,#132a54 60%,#1c3e7e 100%); }

/* App background is a soft tint so white cards pop */
body{background:var(--bg)}
main{background:var(--bg) !important;min-height:100vh}
@media(min-width:601px){ main{box-shadow:0 0 80px -30px rgba(13,27,42,.35)} }

/* ---- Vibrant gradient header ---- */
.topbar{background:var(--grad-brand) !important;border-bottom:none;box-shadow:0 8px 26px -14px rgba(10,31,68,.65)}
.topbar-row{padding:12px 16px}
.brand-name{color:#fff;font-size:1.24rem;letter-spacing:-.01em;text-shadow:0 1px 8px rgba(0,0,0,.25)}
.brand-logo{filter:drop-shadow(0 3px 8px rgba(0,0,0,.4))}
.icon-btn{color:#fff}
.icon-btn:hover{background:rgba(255,255,255,.16)}
.mini-avatar{box-shadow:0 0 0 2px rgba(255,255,255,.85)}
.signin-label{background:#fff;color:#0a1f44;box-shadow:0 4px 14px rgba(0,0,0,.25)}
/* chips + search sit ON the gradient */
.chip{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.28);backdrop-filter:blur(4px)}
.chip.active{background:#fff;color:#0a1f44;border-color:#fff;box-shadow:0 4px 12px rgba(0,0,0,.2)}
.search-wrap .ico{color:rgba(255,255,255,.85)}
.search-wrap input{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.28);color:#fff}
.search-wrap input::placeholder{color:rgba(255,255,255,.7)}
.search-wrap input:focus{background:#fff;color:#0d1b2a;caret-color:#0d1b2a;border-color:#fff;box-shadow:0 0 0 4px rgba(255,255,255,.25)}
.search-wrap input:focus::placeholder{color:#6b7686}

/* ---- Light mode: clean light header instead of the gradient ---- */
[data-theme="light"] .topbar{background:var(--bg-elev) !important;border-bottom:1px solid var(--line);box-shadow:0 2px 16px -10px rgba(13,27,42,.25)}
[data-theme="light"] .brand-name{color:var(--text);text-shadow:none}
[data-theme="light"] .brand-logo{filter:drop-shadow(0 2px 4px rgba(10,31,68,.2))}
[data-theme="light"] .icon-btn{color:var(--text)}
[data-theme="light"] .icon-btn:hover{background:var(--bg-alt)}
[data-theme="light"] .mini-avatar{box-shadow:0 0 0 2px var(--line-strong)}
[data-theme="light"] .signin-label{background:var(--accent);color:#fff;box-shadow:var(--shadow-sm)}
[data-theme="light"] .chip{background:var(--bg-alt);color:var(--text);border-color:var(--line-strong);backdrop-filter:none}
[data-theme="light"] .chip.active{background:var(--accent);color:#fff;border-color:transparent;box-shadow:var(--shadow-sm)}
[data-theme="light"] .search-wrap .ico{color:var(--muted)}
[data-theme="light"] .search-wrap input{background:var(--bg-alt);border-color:var(--line);color:var(--text)}
[data-theme="light"] .search-wrap input::placeholder{color:var(--muted)}
[data-theme="light"] .search-wrap input:focus{background:var(--bg-elev);color:var(--text);caret-color:var(--text);border-color:var(--accent);box-shadow:0 0 0 4px var(--ring)}

/* ---- Home feed loading indicator (sticky at the top) ---- */
.feed-loading{
  position:sticky; top:calc(var(--topbar-h,52px) + 4px); z-index:12;
  display:flex; align-items:center; justify-content:center; gap:8px;
  margin:6px auto 2px; padding:7px 16px; width:max-content; max-width:90%;
  background:var(--bg-elev); border:1px solid var(--line-strong); border-radius:999px;
  box-shadow:var(--shadow-sm); color:var(--muted); font-size:.82rem; font-weight:600;
}
.feed-loading.hidden{display:none}
.feed-loading .spin{width:15px;height:15px;border:2px solid var(--line-strong);border-top-color:var(--accent);border-radius:50%;animation:feedspin .7s linear infinite;display:inline-block}
@keyframes feedspin{to{transform:rotate(360deg)}}

/* ---- End-of-feed "all caught up" marker ---- */
.feed-end{display:flex;align-items:center;justify-content:center;gap:8px;padding:22px 16px 30px;color:var(--muted);font-size:.88rem;font-weight:600}
.feed-end .ico{width:18px;height:18px;color:var(--utility)}

/* ---- Feed as cards ---- */
.feed{gap:12px;padding:14px 12px 4px}
.post{background:var(--bg-elev);border:1px solid var(--line);border-left:5px solid var(--issue);border-bottom:1px solid var(--line);border-radius:var(--card-radius);box-shadow:var(--shadow-sm);padding:15px 16px 13px}
.post:has(.badge-crime){border-left-color:var(--crime)}
.post:has(.badge-utility){border-left-color:var(--utility)}
.post:hover{background:var(--bg-elev)}
@media(hover:hover){ .post:hover{box-shadow:var(--shadow);transform:translateY(-1px)} }
.post-name{font-weight:800}
/* vivid filled category badges */
.post-badge{color:#fff;font-size:.66rem;padding:4px 11px;box-shadow:var(--shadow-sm)}
.badge-issue{background:var(--issue)}
.badge-crime{background:var(--crime)}
.badge-utility{background:var(--utility)}

/* profile feeds also get the tinted gutter */
#profile-feed,#history-feed{padding:14px 12px 4px;gap:12px;display:flex;flex-direction:column}

/* ---- Punchier primary buttons + FAB ---- */
.post-btn,.auth-primary{background:var(--grad-brand);color:#fff;font-weight:700;border:none}
.fab{width:62px;height:62px;background:var(--grad-accent);box-shadow:0 18px 34px -10px rgba(28,86,201,.6),0 8px 20px rgba(10,143,91,.35)}
.fab .ico{filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}

/* ---- Cleaner bottom nav with a top indicator (not a button pill) ---- */
.tabbar{box-shadow:0 -8px 24px -16px rgba(13,27,42,.4)}
.tabbar .tab{position:relative}
.tabbar .tab.active::after{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:26px;height:3px;border-radius:0 0 4px 4px;background:var(--grad-accent)}
.tabbar .tab.active{color:var(--accent)}

/* ---- Utilities / cards a touch bolder ---- */
.util-card{border-radius:var(--card-radius);box-shadow:var(--shadow-sm)}
.screen-title{font-size:1.5rem}
.status-pill{font-weight:800}

/* ---- Section headings / sort bar ---- */
.sortbar{padding:12px 14px 4px}
.sortbtn.active{color:#fff;background:var(--grad-brand);border-color:transparent}

/* ---- Reports map (Explore) ---- */
.explore-maptools{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 8px}
.explore-maptitle{font-weight:800;font-size:1.05rem}
.map-legend{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--muted)}
.map-legend .dot{width:10px;height:10px;border-radius:50%;display:inline-block;box-shadow:0 0 0 2px var(--bg-elev)}
.map-legend .dot-crime{background:var(--crime)}
.map-legend .dot-issue{background:var(--issue);margin-left:8px}
.reports-map{height:300px;margin:0 12px;border-radius:16px;overflow:hidden;border:1px solid var(--line);position:relative;z-index:0;isolation:isolate}
.reports-map .leaflet-container{height:100%;background:var(--bg-alt);font-family:inherit}
[data-theme="dark"] .reports-map .leaflet-tile{filter:brightness(.85) contrast(1.05) saturate(.9)}
.reports-map + .map-hint{padding:6px 16px 2px}
.post-name[data-user]{cursor:pointer}
.post-name[data-user]:hover{text-decoration:underline}
/* user profile modal */
.user-head{display:flex;align-items:center;gap:12px;padding:16px}
.user-name{font-weight:800;font-size:1.05rem}
.user-meta{color:var(--muted);font-size:.85rem}

/* ---- First-run onboarding ---- */
.onboard{padding:26px 22px calc(env(safe-area-inset-bottom) + 22px);text-align:center}
.onboard-logo{width:64px;height:64px;margin:0 auto 12px;filter:drop-shadow(0 6px 14px rgba(10,31,68,.3))}
.onboard-logo svg{width:100%;height:100%}
.onboard-title{font-size:1.4rem;font-weight:800;letter-spacing:-.01em;margin-bottom:4px}
.onboard-sub{color:var(--muted);margin-bottom:18px}
.onboard-list{list-style:none;text-align:left;display:flex;flex-direction:column;gap:14px;margin:0 0 22px;padding:0}
.onboard-list li{display:flex;gap:12px;align-items:flex-start;font-size:.95rem;line-height:1.45}
.onboard-list li .ico{flex:0 0 auto;color:var(--accent);margin-top:1px}
.onboard-list li b{font-weight:800}
.onboard .auth-primary{width:100%}

/* ===== Reduced motion ===== */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
}

/* ===== POPIA consent banner ===== */
.consent-banner{
  position:fixed; left:12px; right:12px; bottom:calc(72px + env(safe-area-inset-bottom,0px));
  z-index:1200; max-width:640px; margin:0 auto;
  display:flex; gap:12px; align-items:center; flex-wrap:wrap;
  background:var(--bg-elev); color:var(--text);
  border:1px solid var(--line-strong); border-radius:14px;
  padding:14px 16px; box-shadow:var(--shadow);
}
.consent-banner p{margin:0; flex:1 1 240px; font-size:13px; line-height:1.45; color:var(--text)}
.consent-banner .post-btn{flex:0 0 auto}
.consent-banner.hidden{display:none}

/* ===== Post trust signals & status ===== */
.dist-chip{
  display:inline-block; margin-left:0; padding:1px 8px; border-radius:999px;
  font-size:11px; font-weight:600; background:var(--bg-alt); color:var(--muted); white-space:nowrap; flex:0 0 auto;
}
.map-toggle{flex:0 0 auto}
.post-cverified{
  display:inline-flex; align-items:center; gap:3px; margin-left:6px; padding:1px 8px;
  border-radius:999px; font-size:11px; font-weight:700;
  background:rgba(10,125,60,.12); color:#0a7d3c;
}
.post-cverified svg{width:12px;height:12px}
.post-resolved{
  display:inline-block; margin-left:6px; padding:1px 8px; border-radius:999px;
  font-size:11px; font-weight:700; background:rgba(10,125,60,.14); color:#0a7d3c;
}
.trusted-badge{
  display:inline-flex; align-items:center; gap:3px; margin-left:5px; padding:1px 8px; border-radius:999px;
  font-size:11px; font-weight:700; background:rgba(28,86,201,.13); color:var(--accent);
}
.trusted-badge svg{width:12px;height:12px}
.post.is-resolved{opacity:.82}
/* dark mode: the hardcoded greens above are unreadable on dark surfaces */
[data-theme="dark"] .post-cverified,[data-theme="dark"] .post-resolved{color:#4ade80;background:rgba(74,222,128,.14)}

/* ===== Load-shedding home widget ===== */
.ls-widget{
  display:flex; align-items:center; gap:12px; margin:10px 12px 4px;
  padding:12px 14px; border-radius:14px; border:1px solid var(--line-strong);
  background:var(--bg-elev); color:var(--text); box-shadow:var(--shadow); width:calc(100% - 24px);
}
.ls-widget.hidden{display:none}
.ls-dot{width:12px;height:12px;border-radius:50%;flex:0 0 auto;background:#9aa5b1}
.ls-widget.stable .ls-dot{background:#1fa254;box-shadow:0 0 0 4px rgba(31,162,84,.18)}
.ls-widget.unstable .ls-dot{background:#d8392e;box-shadow:0 0 0 4px rgba(216,57,46,.18)}
.ls-text{flex:1 1 auto;min-width:0;text-align:left}
.ls-title{font-weight:700;font-size:14px;color:var(--text)}
.ls-sub{display:block;font-size:12px;color:var(--muted)}
.ls-widget .ls-cta{flex:0 0 auto;font-size:12px;font-weight:600;color:var(--accent);background:none;border:0;cursor:pointer}

/* ===== Admin activity log ===== */
.audit-log{display:flex;flex-direction:column;gap:2px}
.audit-row{display:flex;justify-content:space-between;gap:10px;padding:10px 12px;border-bottom:1px solid var(--line);font-size:13px;color:var(--text)}
.audit-act{font-weight:600}
.audit-meta{color:var(--muted);font-size:12px;white-space:nowrap}

/* ===== Admin: official announcement composer ===== */
.admin-announce{margin:0 0 14px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.admin-ann-form{display:flex;flex-direction:column;gap:10px;margin-top:10px}
.admin-ann-form.hidden{display:none}
.adm-ann-cat{display:flex;gap:6px;flex-wrap:wrap}
.adm-ann-cat .seg-btn{flex:1 1 auto;padding:8px 10px;border-radius:10px;border:1px solid var(--line-strong);background:var(--bg-alt);color:var(--text);font-weight:600;font-size:.85rem;cursor:pointer}
.adm-ann-cat .seg-btn.active{background:var(--accent);color:#fff;border-color:transparent}

/* ===== Suburb scope selector ===== */
.suburb-btn{
  display:inline-flex;align-items:center;gap:5px;margin-left:auto;
  padding:5px 12px;border-radius:999px;border:1px solid var(--line-strong);
  background:var(--bg-elev);color:var(--text);font-size:13px;font-weight:600;cursor:pointer;
}
.suburb-btn .ico{opacity:.7}
.suburb-btn.active{background:var(--accent);border-color:transparent;color:#fff}
.suburb-btn.active .ico{opacity:1}
.sortbar .refresh-btn{margin-left:8px}
.sub-list{display:flex;flex-direction:column;gap:2px;margin-top:10px;max-height:52vh;overflow:auto}
.sub-item{
  display:flex;justify-content:space-between;align-items:center;gap:10px;width:100%;
  padding:12px 14px;border:0;border-bottom:1px solid var(--line);
  background:none;text-align:left;font-size:15px;font-weight:600;color:var(--text);cursor:pointer;
}
.sub-item span{font-size:12px;font-weight:500;color:var(--muted)}
.sub-item:hover{background:var(--bg-alt)}
.link-inline{background:none;border:0;padding:0;color:var(--accent);font:inherit;font-weight:600;text-decoration:underline;cursor:pointer}

/* ===== Post detail view ===== */
.detail-feed{padding:6px 0}
.detail-feed .post{border-bottom:0}
.detail-feed .post-map{height:220px}
.detail-feed [data-comments]{padding:0 14px 14px}

/* ===== Composer safety notices ===== */
.compose-emergency{
  display:block;margin:8px 0 0;padding:9px 12px;border-radius:12px;
  font-size:12.5px;font-weight:600;line-height:1.5;
  background:rgba(216,57,46,.12);color:#c62f24;border:1px solid rgba(216,57,46,.3);
}
[data-theme="dark"] .compose-emergency{color:#ff8a80;background:rgba(216,57,46,.16)}
.compose-emergency.hidden{display:none}
.compose-emergency .ico{display:inline-block;vertical-align:-3px;margin-right:5px;width:15px;height:15px}
.compose-emergency a{color:inherit;font-weight:800;text-decoration:underline;white-space:nowrap}
.compose-guideline{margin:6px 0 0;font-size:12px;line-height:1.4;color:var(--muted)}

/* ===== Terms consent (sign-in) ===== */
.auth-consent{display:flex;align-items:flex-start;gap:8px;margin:12px 0 4px;font-size:13px;line-height:1.4;color:var(--text)}
.auth-consent input{margin-top:2px;flex:0 0 auto;width:16px;height:16px;accent-color:var(--accent)}
.auth-consent .link-accent{font-weight:600}

/* ===== Policy modal (Terms / Privacy, pre-signup) ===== */
.policy-body{max-height:70vh;overflow:auto}
.policy-body p{margin:0 0 12px;font-size:14px;line-height:1.55;color:var(--text)}
.policy-body strong{color:var(--text)}

/* ===== Profile search ===== */
.profile-search{display:flex;align-items:center;gap:8px;margin:10px 12px 4px;padding:8px 14px;border-radius:999px;background:var(--bg-alt);border:1px solid var(--line)}
.profile-search.hidden{display:none}
.profile-search .ico{color:var(--muted);flex:0 0 auto}
.profile-search input{flex:1;border:none;background:none;font:inherit;color:var(--text);outline:none}

/* ===== PWA install prompt ===== */
.install-banner{
  position:fixed; left:12px; right:12px; bottom:calc(72px + env(safe-area-inset-bottom,0px));
  z-index:1250; max-width:520px; margin:0 auto;
  display:flex; align-items:center; gap:12px;
  background:var(--bg-elev); color:var(--text);
  border:1px solid var(--line-strong); border-radius:16px; padding:12px 14px; box-shadow:var(--shadow);
}
.install-banner.hidden{display:none}
.install-brand{width:38px;height:38px;flex:0 0 auto}
.install-brand svg{width:100%;height:100%}
.install-txt{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;line-height:1.3}
.install-txt b{font-size:14px}
.install-txt span{font-size:12px;color:var(--muted)}
.install-actions{flex:0 0 auto;display:flex;align-items:center;gap:6px}
.install-actions .post-btn{padding:8px 16px}
/* Step-by-step guide (iOS / manual) */
.install-guide ol{margin:6px 0 0;padding-left:20px;display:flex;flex-direction:column;gap:12px}
.install-guide li{font-size:14.5px;line-height:1.45;color:var(--text)}
.install-guide .guide-note{margin-top:14px;font-size:12.5px;color:var(--muted)}
.install-guide .ios-share{display:inline-flex;vertical-align:-3px;width:17px;height:17px}

/* ==========================================================================
   SLEEK PASS — safe-area, glass, micro-typography, considered motion
   ========================================================================== */

/* Notched phones (installed PWA with viewport-fit=cover): keep the header + nav
   out of the notch / home-indicator zones. */
.topbar{padding-top:env(safe-area-inset-top,0px)}
.tabbar{padding-bottom:env(safe-area-inset-bottom,0px)}

/* Header elevation appears only once you scroll (flat at rest = calmer). */
.topbar{box-shadow:none;transition:box-shadow .25s var(--ease)}
body.scrolled .topbar{box-shadow:0 10px 30px -16px rgba(10,20,40,.5)}

/* Frosted modal backdrop — content recedes, the sheet feels layered. */
.modal-overlay{background:rgba(8,16,29,.45);backdrop-filter:blur(7px) saturate(1.1);-webkit-backdrop-filter:blur(7px) saturate(1.1)}

/* Sheet dismiss: slide back down instead of vanishing. */
.modal-overlay.out{animation:fadeout .2s ease forwards}
.modal-overlay.out .sheet{animation:slidedown .22s cubic-bezier(.4,0,.7,.4) forwards}
@keyframes fadeout{to{opacity:0}}
@keyframes slidedown{to{transform:translateY(100%)}}

/* Counts and timestamps don't jiggle as digits change. */
.ct,.ts,.char-count,.profile-stats strong{font-variant-numeric:tabular-nums}

/* First cards ease in with a gentle stagger on load. */
.feed .post:nth-child(1){animation-delay:.02s}
.feed .post:nth-child(2){animation-delay:.06s}
.feed .post:nth-child(3){animation-delay:.10s}
.feed .post:nth-child(4){animation-delay:.14s}

/* Filter chips snap to position while swiping. */
.chips{scroll-snap-type:x proximity;scroll-padding-left:12px}
.chip{scroll-snap-align:start}

/* Desktop: slim, unobtrusive scrollbars. */
@media(min-width:601px){
  *{scrollbar-width:thin;scrollbar-color:var(--line-strong) transparent}
  *::-webkit-scrollbar{width:8px;height:8px}
  *::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:8px}
  *::-webkit-scrollbar-track{background:transparent}
}

/* Respect reduced-motion for the new animations too. */
@media (prefers-reduced-motion: reduce){
  .modal-overlay,.modal-overlay.out,.modal-overlay.out .sheet{animation:none}
  .feed .post{animation-delay:0s}
}

/* Off-screen feed cards aren't rendered until scrolled near — keeps long feeds fast. */
.feed .post{content-visibility:auto;contain-intrinsic-size:auto 170px}

/* Offline indicator (shown while navigator.onLine is false) */
.offline-pill{
  position:fixed;top:calc(env(safe-area-inset-top,0px) + 8px);left:50%;transform:translateX(-50%);
  z-index:80;display:none;align-items:center;gap:7px;
  background:#b45309;color:#fff;font-size:.78rem;font-weight:700;
  padding:6px 14px;border-radius:999px;box-shadow:var(--shadow);white-space:nowrap;
}
.offline-pill::before{content:"";width:7px;height:7px;border-radius:50%;background:#fff;opacity:.9}
body.is-offline .offline-pill{display:inline-flex;animation:fade .2s ease}
