/* ───────────────────────── Reset & base ────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{
  --bg:#0a0f0c;
  --bg-2:#101814;
  --surf:#131c17;
  --surf-2:#1a2620;
  --surf-3:#23332b;
  --border:rgba(255,255,255,.08);
  --border-2:rgba(255,255,255,.16);
  --text:#e8f0eb;
  --muted:#8aa19a;
  --accent:#5eead4;
  --accent-warm:#fbbf24;
  --water:#38bdf8;
  --fire:#ef4444;
  --warn:#f59e0b;
  --good:#22c55e;
  --shadow-lg:0 -10px 40px rgba(0,0,0,.5);
  --shadow:0 6px 24px rgba(0,0,0,.35);
  --radius:14px;
  --radius-sm:10px;
  --topbar-h:58px;
  --sheet-peek:140px;       /* visible peek of bottom sheet on mobile */
  --safe-bottom:env(safe-area-inset-bottom,0px);
  --safe-top:env(safe-area-inset-top,0px);
}
html,body{height:100%;height:-webkit-fill-available}
body{
  font-family:'Inter',system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
  background:var(--bg);
  color:var(--text);
  font-size:14px;
  line-height:1.5;
  overflow:hidden;
  letter-spacing:-0.005em;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:'Fraunces','Georgia',serif;font-weight:600;letter-spacing:-0.01em}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer;touch-action:manipulation}
input,select{font:inherit;color:inherit}
.muted{color:var(--muted)}
.small{font-size:12px}
.hide-mobile{display:none}
.show-mobile{display:inline-flex}

/* ───────────────────────── MOBILE-FIRST: stacking layout ────────────────────────── */
/* Map fills full viewport behind everything; bottom sheet peeks up. */

/* Top bar */
.topbar{
  position:fixed;top:0;left:0;right:0;
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 12px;padding-top:calc(8px + var(--safe-top));
  height:calc(var(--topbar-h) + var(--safe-top));
  background:linear-gradient(180deg,rgba(20,30,24,.95),rgba(10,15,12,.85));
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  z-index:1000;
  gap:10px;
}
.brand{display:flex;align-items:center;gap:10px;min-width:0;flex:1}
.brand-mark{
  flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:10px;
  background:linear-gradient(135deg,#1a3a2b,#2d5d44);
  color:var(--accent);font-size:18px;font-weight:700;
  border:1px solid rgba(94,234,212,.25);
}
.brand-text{min-width:0}
.brand h1{font-size:15px;color:var(--text);line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.brand p{font-size:11px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}
.sync-badge{
  font-size:11px;padding:4px 10px;border-radius:99px;font-weight:500;
  white-space:nowrap;cursor:default;user-select:none;
}
.sync-badge.synced{background:rgba(34,197,94,.13);color:var(--good);border:1px solid rgba(34,197,94,.25)}
.sync-badge.local{background:rgba(245,158,11,.13);color:var(--warn);border:1px solid rgba(245,158,11,.25)}
.sync-badge.offline{background:rgba(239,68,68,.12);color:var(--fire);border:1px solid rgba(239,68,68,.22)}
@media (max-width:899px){.sync-badge{padding:3px 7px;font-size:10px}}

.user-pill{
  display:flex;align-items:center;gap:6px;
  background:var(--surf-2);border:1px solid var(--border);
  padding:6px 10px;border-radius:10px;font-size:12px;
}
.user-pill label{color:var(--muted);font-size:11px}
.user-pill input{
  background:none;border:none;outline:none;color:var(--text);
  width:70px;font-size:13px;
}
.btn{
  padding:8px 12px;border-radius:10px;font-weight:500;font-size:13px;
  transition:all .15s ease;border:1px solid var(--border);
  background:var(--surf-2);min-height:36px;display:inline-flex;align-items:center;justify-content:center;
}
.btn:hover,.btn:active{background:var(--surf-3);border-color:var(--border-2)}
.btn-primary{
  background:linear-gradient(135deg,#1a3a2b,#2d5d44);
  border-color:rgba(94,234,212,.3);color:var(--accent);
}
.btn-primary:hover,.btn-primary:active{background:linear-gradient(135deg,#234a37,#357654)}
.btn-icon{
  width:38px;height:38px;display:grid;place-items:center;
  background:rgba(20,30,24,.85);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid var(--border);border-radius:10px;
  font-size:15px;flex-shrink:0;
}
.btn-icon:hover,.btn-icon:active{background:rgba(35,51,43,.95)}
.link-btn{font-size:11.5px;color:var(--accent);background:none;padding:4px 6px;min-height:28px}
.link-btn:active{background:var(--surf-3);border-radius:6px}

/* Map fills entire body below topbar */
.map-area{
  position:fixed;
  top:calc(var(--topbar-h) + var(--safe-top));
  left:0;right:0;bottom:0;
  background:#0a0f0c;
  z-index:1;
}
#map{width:100%;height:100%}
.leaflet-container{background:#0a0f0c;font-family:inherit}

.map-legend{
  position:absolute;left:10px;top:10px;z-index:500;
  background:rgba(10,15,12,.88);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:8px 10px;font-size:11px;
  display:flex;flex-direction:column;gap:4px;
}
.legend-row{display:flex;align-items:center;gap:7px;color:var(--text)}
.dot{width:9px;height:9px;border-radius:50%;display:inline-block;border:1.5px solid #fff}
.dot-disp{background:var(--accent)}
.dot-paid{background:#c4b5fd}
.dot-gold{background:var(--accent-warm)}
.ring{width:10px;height:10px;border:1.5px dashed var(--accent);border-radius:50%}
.map-controls{
  position:absolute;right:10px;top:10px;z-index:500;
  display:flex;flex-direction:column;gap:6px;
}
.map-controls .btn-icon{width:42px;height:42px}

/* Bottom sheet (mobile) / Sidebar (desktop) */
.sidebar{
  position:fixed;
  left:0;right:0;bottom:0;
  height:calc(100vh - var(--topbar-h) - var(--safe-top));
  max-height:calc(100% - var(--topbar-h) - var(--safe-top) - 8px);
  background:linear-gradient(180deg,var(--bg-2),var(--bg));
  border-top:1px solid var(--border);
  border-top-left-radius:18px;
  border-top-right-radius:18px;
  z-index:900;
  display:flex;flex-direction:column;
  transform:translateY(100%);                                /* fully hidden by default */
  transition:transform .3s cubic-bezier(.2,.9,.2,1);
  box-shadow:var(--shadow-lg);
  pointer-events:none;                                       /* hidden = not interactive */
}
.sidebar.open{transform:translateY(0);pointer-events:auto}

.sheet-handle{
  display:flex;align-items:center;gap:12px;
  padding:8px 18px 12px;
  position:relative;
  flex-shrink:0;
  width:100%;
}
.handle-bar{
  position:absolute;top:7px;left:50%;transform:translateX(-50%);
  width:42px;height:4px;border-radius:2px;background:var(--surf-3);
}
.handle-label{
  display:flex;flex-direction:column;flex:1;text-align:left;margin-top:6px;
}
.handle-label strong{font-size:14px;color:var(--text);font-weight:600}
.handle-label span{font-size:11px;color:var(--muted)}
.handle-count{
  font-family:'Fraunces',serif;font-size:18px;font-weight:700;color:var(--accent);
  margin-top:6px;
}

.sidebar-scroll{
  flex:1;
  overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;
  padding:0 12px 30px;
  display:flex;flex-direction:column;gap:12px;
  scrollbar-width:thin;scrollbar-color:var(--surf-3) transparent;
}
.sidebar-scroll::-webkit-scrollbar{width:6px}
.sidebar-scroll::-webkit-scrollbar-thumb{background:var(--surf-3);border-radius:6px}

.panel{
  background:var(--surf);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:14px;
}
.panel-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:10px;gap:8px;
}
.panel-head h2{font-size:15px}
.count-badge{
  font-family:'Inter',sans-serif;
  background:var(--surf-3);font-size:11px;font-weight:500;
  padding:2px 7px;border-radius:8px;color:var(--muted);
  margin-left:4px;
}

/* Filters */
.filters{display:flex;flex-direction:column;gap:4px}
.range-row{
  display:grid;grid-template-columns:1fr auto;align-items:center;gap:8px;
  font-size:13px;color:var(--muted);
  padding:6px 0;
}
.range-row span{grid-column:1}
.range-row output{
  grid-column:2;color:var(--accent);font-weight:600;font-size:12px;min-width:46px;text-align:right;
}
.range-row input[type=range]{
  grid-column:1/-1;width:100%;
  accent-color:var(--accent);height:24px;
}
.toggle-row{
  display:flex;align-items:center;gap:10px;
  font-size:14px;cursor:pointer;
  padding:8px 0;min-height:36px;
}
.filter-hint{
  margin-left:auto;font-size:11px;color:var(--accent-warm);
  background:rgba(251,191,36,.10);padding:2px 8px;border-radius:99px;
  white-space:nowrap;opacity:0;transition:opacity .2s;
  border:1px solid rgba(251,191,36,.18);
}
.filter-hint.show{opacity:.85}
.toggle-row input[type=checkbox]{
  width:18px;height:18px;accent-color:var(--accent);
  cursor:pointer;flex-shrink:0;
}
.filter-divider{
  height:1px;background:var(--border);margin:4px 0;
}

/* Fire ban list */
.fire-ban-list{display:flex;flex-direction:column;gap:7px;margin-top:6px}
.auto-fire-banner{
  background:linear-gradient(135deg,rgba(94,234,212,.06),rgba(56,189,248,.04));
  border:1px solid rgba(94,234,212,.2);border-radius:10px;
  padding:10px 12px;margin-bottom:4px;
}
.auto-fire-head{
  display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:13px;
}
.auto-fire-status{display:flex;align-items:center;gap:6px;color:var(--text)}
.auto-fire-status strong{color:var(--accent);font-weight:600}
.auto-fire-sub{font-size:11px;color:var(--muted);margin-top:4px}
.auto-fire-sub a{color:var(--accent);text-decoration:none}
.auto-fire-sub a:hover{text-decoration:underline}
.restricted-list{
  margin-top:6px;padding-top:6px;border-top:1px dashed var(--border);
  font-size:11px;color:var(--warn);line-height:1.4;
}
.manual-fire-head{
  font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;
  margin-top:10px;margin-bottom:2px;padding:0 4px;
}
.fire-ban-item{
  display:flex;align-items:center;justify-content:space-between;
  padding:9px 11px;background:var(--surf-2);border-radius:8px;
  border:1px solid var(--border);font-size:12.5px;gap:8px;
}
.fire-ban-item .label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.fire-ban-item select{
  background:var(--bg-2);border:1px solid var(--border);
  border-radius:6px;padding:5px 7px;font-size:11.5px;
  min-height:32px;
}
.fire-ban-item.s0{border-left:3px solid var(--good)}
.fire-ban-item.s1{border-left:3px solid var(--warn)}
.fire-ban-item.s2{border-left:3px solid var(--fire)}
.fire-ban-item.unknown{border-left:3px solid var(--muted)}

/* Weights */
.weights{display:grid;grid-template-columns:1fr 1fr;gap:8px 12px;margin-top:6px}
.weight-row{display:flex;flex-direction:column;gap:3px}
.weight-row label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.weight-row input{accent-color:var(--accent-warm);width:100%;height:20px}
.weight-row .val{font-size:11px;color:var(--accent-warm);text-align:right}

/* Top picks */
.top-picks-panel{
  background:linear-gradient(135deg,var(--surf),#1c2924);
  border:1px solid rgba(94,234,212,.2);
}
#top-picks{display:flex;flex-direction:column;gap:8px}
.top-pick-card{
  display:grid;grid-template-columns:42px 1fr auto;gap:10px;align-items:center;
  background:var(--surf-2);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:11px;cursor:pointer;transition:all .15s ease;
  position:relative;overflow:hidden;
}
.top-pick-card:active{transform:scale(.99)}
.top-pick-card .rank{
  width:34px;height:34px;border-radius:10px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--accent-warm),#d97706);
  color:#1a1206;font-weight:700;font-size:15px;
}
.top-pick-card .body{min-width:0}
.top-pick-card .body h3{font-size:13.5px;font-family:'Inter',sans-serif;font-weight:600;color:var(--text);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.top-pick-card .meta{font-size:11px;color:var(--muted);display:flex;gap:6px;flex-wrap:wrap}
.top-pick-card .score-stack{display:flex;flex-direction:column;align-items:flex-end;gap:2px;font-size:11px}
.top-pick-card .score-stack .total{font-size:18px;color:var(--accent);font-weight:700;font-family:'Fraunces',serif;line-height:1}

/* Site list */
.site-list{
  display:flex;flex-direction:column;gap:8px;
  max-height:520px;overflow-y:auto;
  padding-right:4px;
  scrollbar-width:thin;scrollbar-color:var(--surf-3) transparent;
}
.site-list::-webkit-scrollbar{width:6px}
.site-list::-webkit-scrollbar-thumb{background:var(--surf-3);border-radius:6px}
@media (max-width:899px){.site-list{max-height:none}}
.site-card{
  background:var(--surf-2);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:12px;cursor:pointer;transition:all .15s ease;
  display:grid;grid-template-columns:1fr auto;gap:6px 10px;
  align-items:start;
}
.site-card:active{background:var(--surf-3)}
.site-card.active{border-color:var(--accent);background:var(--surf-3)}
.site-card h3{font-family:'Inter',sans-serif;font-size:14px;font-weight:600;line-height:1.25}
.site-card .badges{display:flex;flex-wrap:wrap;gap:4px;margin-top:5px;grid-column:1}
.site-card .score{
  font-family:'Fraunces',serif;font-size:20px;font-weight:700;
  color:var(--accent);grid-column:2;grid-row:1/3;
  display:flex;flex-direction:column;align-items:flex-end;line-height:1;
}
.site-card .score small{font-size:9px;color:var(--muted);font-family:'Inter',sans-serif;font-weight:500;text-transform:uppercase;letter-spacing:.05em;margin-top:3px}
.site-card .vote-row{
  display:flex;align-items:center;gap:6px;font-size:11.5px;
  grid-column:1/-1;margin-top:8px;padding-top:8px;border-top:1px dashed var(--border);flex-wrap:wrap;
}
.site-jurisdiction{
  grid-column:1;font-size:11.5px;color:var(--muted);margin-top:3px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.fire-breakdown{margin-bottom:6px}
.fire-breakdown dt{padding-top:4px}

.badge{
  font-size:10.5px;padding:3px 8px;border-radius:99px;
  font-weight:500;letter-spacing:.01em;
  background:var(--surf-3);color:var(--muted);
  white-space:nowrap;
}
.badge.water{background:rgba(56,189,248,.12);color:var(--water)}
.badge.trout{background:rgba(251,146,60,.13);color:#fb923c}
.badge.gold{background:linear-gradient(135deg,rgba(251,191,36,.18),rgba(217,119,6,.18));color:var(--accent-warm)}
.badge.group{background:rgba(94,234,212,.12);color:var(--accent)}
.badge.fire-ok{background:rgba(34,197,94,.13);color:var(--good)}
.badge.fire-warn{background:rgba(245,158,11,.13);color:var(--warn)}
.badge.fire-ban{background:rgba(239,68,68,.13);color:var(--fire)}
.badge.paid{background:rgba(168,85,247,.13);color:#c4b5fd}
.badge.dispersed{background:rgba(94,234,212,.08);color:var(--accent)}

.vote-btn{
  display:flex;align-items:center;gap:4px;
  padding:7px 11px;border-radius:8px;font-size:12px;
  background:var(--surf-3);border:1px solid var(--border);
  min-height:36px;
}
.vote-btn:active{background:var(--surf-2)}
.vote-btn.active-up{background:rgba(34,197,94,.18);color:var(--good);border-color:rgba(34,197,94,.4)}
.vote-btn.active-down{background:rgba(239,68,68,.15);color:var(--fire);border-color:rgba(239,68,68,.4)}
.vote-tally{font-size:11px;color:var(--muted);margin-left:auto}
.vote-tally strong{color:var(--text)}

.select-mini{
  background:var(--surf-2);border:1px solid var(--border);border-radius:8px;
  padding:6px 10px;font-size:12px;color:var(--text);
  min-height:32px;
}

.footer-note{padding:8px 4px}

/* ───────────────────────── Map markers ────────────────────────── */
.cs-marker{
  display:flex;align-items:center;justify-content:center;
  border-radius:50% 50% 50% 0;
  transform:rotate(-45deg);
  background:var(--accent);border:2px solid #0a0f0c;
  box-shadow:0 4px 10px rgba(0,0,0,.5);
  font-size:11px;font-weight:700;color:#0a0f0c;
  font-family:'Fraunces',serif;
  width:100%;height:100%;
}
.cs-marker > span{transform:rotate(45deg)}
.cs-marker.lg{font-size:11px}
.cs-marker.md{font-size:9px;opacity:.92;border-width:1.5px}
.cs-marker.sm{font-size:0;opacity:.75;border-width:1px}
.cs-marker.sm > span{display:none}
.cs-marker.paid{background:#c4b5fd}
.cs-marker.gold{background:var(--accent-warm)}
.cs-marker.banned{background:var(--fire);opacity:.7}

/* Cluster markers */
.cluster-marker-wrap{background:transparent !important}
.cluster-marker{
  width:36px;height:36px;border-radius:50%;
  background:linear-gradient(135deg,#1a3a2b,#2d5d44);
  border:2px solid var(--accent);
  box-shadow:0 4px 14px rgba(0,0,0,.45);
  display:flex;align-items:center;justify-content:center;
  color:var(--accent);font-weight:700;font-size:13px;
  font-family:'Fraunces',serif;
}
.marker-cluster-small,.marker-cluster-medium,.marker-cluster-large{background:transparent !important}
.marker-cluster-small div,.marker-cluster-medium div,.marker-cluster-large div{background:transparent !important;color:transparent !important}

/* ───────────────────────── Detail drawer ────────────────────────── */
.detail{
  position:fixed;
  top:0;left:0;right:0;bottom:0;
  background:linear-gradient(180deg,var(--bg-2),var(--bg));
  z-index:1500;
  transform:translateY(100%);
  transition:transform .3s cubic-bezier(.16,1,.3,1);
  overflow-y:auto;-webkit-overflow-scrolling:touch;
  padding-top:var(--safe-top);
  padding-bottom:var(--safe-bottom);
}
.detail.open{transform:translateY(0)}
.detail-close{
  position:sticky;top:10px;float:right;margin:10px 14px 0 0;
  width:40px;height:40px;border-radius:50%;
  background:rgba(35,51,43,.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  font-size:22px;line-height:1;
  display:grid;place-items:center;z-index:10;
  border:1px solid var(--border);
}
.detail-close:active{background:var(--surf-2)}
#detail-body{padding:20px 18px 60px;clear:both}
.detail-hero h2{font-size:24px;line-height:1.15;margin-bottom:6px}
.detail-hero .subtitle{color:var(--muted);font-size:12.5px;margin-bottom:14px}
.detail-scores{
  display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
  margin-bottom:14px;
}
.detail-score{
  background:var(--surf-2);border:1px solid var(--border);
  border-radius:10px;padding:10px 6px;text-align:center;
}
.detail-score .v{font-family:'Fraunces',serif;font-size:22px;font-weight:700;color:var(--accent);line-height:1}
.detail-score .l{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-top:4px}

.detail-section{margin-bottom:18px}
.detail-section h3{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);margin-bottom:8px;font-family:'Inter',sans-serif;font-weight:600}
.detail-section p{font-size:13px;color:var(--text)}
.kv-grid{display:grid;grid-template-columns:auto 1fr;gap:6px 12px;font-size:12.5px}
.kv-grid dt{color:var(--muted)}
.kv-grid dd{color:var(--text);word-break:break-word}

.pros-cons{display:grid;grid-template-columns:1fr;gap:14px}
.pros-cons ul{list-style:none;font-size:12.5px}
.pros-cons li{padding:3px 0;display:flex;gap:6px;line-height:1.4}
.pros-cons .pro::before{content:'+';color:var(--good);font-weight:700;flex-shrink:0}
.pros-cons .con::before{content:'−';color:var(--fire);font-weight:700;flex-shrink:0}

.weather-block{
  display:flex;align-items:center;gap:12px;
  background:var(--surf-2);border:1px solid var(--border);border-radius:10px;padding:12px;
}
.weather-block .icon{font-size:30px}
.weather-block .now{font-family:'Fraunces',serif;font-size:20px}
.weather-block .desc{font-size:11.5px;color:var(--muted)}
.forecast{display:flex;gap:6px;margin-top:8px;overflow-x:auto;padding-bottom:4px}
.forecast::-webkit-scrollbar{height:4px}
.forecast::-webkit-scrollbar-thumb{background:var(--surf-3);border-radius:4px}
.forecast-day{
  flex:0 0 auto;
  background:var(--surf-2);border:1px solid var(--border);border-radius:8px;
  padding:8px 10px;text-align:center;min-width:62px;font-size:11px;
}
.forecast-day .d{color:var(--muted);font-size:10px;text-transform:uppercase}
.forecast-day .t{font-size:12.5px;margin-top:2px}
.forecast-day .ic{font-size:18px;margin:2px 0}

.action-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.action-row .btn{font-size:12.5px;padding:9px 12px}

.badge.rating{background:rgba(245,158,11,.13);color:var(--accent-warm)}
.badge.src-BLM{background:rgba(168,85,247,.12);color:#c4b5fd}
.badge.src-freecampsitesnet{background:rgba(56,189,248,.1);color:var(--water)}

.excerpt-block{
  font-size:13px;color:var(--muted);line-height:1.5;
  padding:10px 12px;background:var(--surf-2);border-radius:8px;
  border-left:3px solid var(--accent);margin-bottom:10px;
}

.photo-strip{
  display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;
  scrollbar-width:thin;
}
.photo-thumb{
  flex:0 0 auto;width:120px;height:90px;border-radius:8px;
  background-size:cover;background-position:center;background-color:var(--surf-2);
  border:1px solid var(--border);transition:transform .15s;
}
.photo-thumb:hover{transform:scale(1.03);border-color:var(--border-2)}

.review{
  background:var(--surf-2);border:1px solid var(--border);
  border-radius:10px;padding:11px 13px;margin-bottom:8px;
}
.review-head{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  font-size:12.5px;margin-bottom:5px;
}
.review-head strong{color:var(--text);font-weight:600}
.review-date{color:var(--muted);font-size:11.5px}
.review-tag{
  background:linear-gradient(135deg,rgba(251,191,36,.18),rgba(217,119,6,.18));
  color:var(--accent-warm);font-size:10.5px;padding:2px 7px;border-radius:99px;
}
.review-karma{
  margin-left:auto;background:var(--surf-3);padding:1px 7px;border-radius:99px;
  font-size:11px;color:var(--muted);
}
.review-text{
  font-size:12.5px;color:var(--text);line-height:1.5;margin:0;
  white-space:pre-wrap;
}
.link{color:var(--accent);font-size:12px;text-decoration:none}
.link:hover{text-decoration:underline}

.detail-votes{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  background:var(--surf-2);border:1px solid var(--border);border-radius:10px;padding:12px;
  margin-bottom:18px;
}
.detail-votes .vote-btn{padding:9px 14px;font-size:13px;min-height:40px}

.vote-as{
  display:flex;align-items:center;gap:6px;margin-left:auto;
  background:var(--bg-2);border:1px solid var(--border);border-radius:8px;
  padding:5px 10px;font-size:12px;
  transition:border-color .15s, box-shadow .15s;
}
.vote-as:focus-within{border-color:var(--accent);box-shadow:0 0 0 2px rgba(94,234,212,.15)}
.vote-as-input{
  background:none;border:none;outline:none;color:var(--text);
  font-size:13px;width:110px;min-width:80px;font-weight:600;
}
.vote-as-input::placeholder{color:var(--muted);font-weight:400}

@keyframes flash-attention{
  0%,100%{box-shadow:0 0 0 0 rgba(251,191,36,0)}
  50%{box-shadow:0 0 0 4px rgba(251,191,36,.45)}
}
.flash, .vote-as:has(.flash){animation:flash-attention .6s ease-in-out 2}
.voter-list{font-size:11.5px;color:var(--muted);width:100%;margin-top:6px;padding-top:8px;border-top:1px dashed var(--border)}
.voter-list .up-list{color:var(--good)}
.voter-list .down-list{color:var(--fire);margin-top:2px}

/* Toast */
.toast{
  position:fixed;left:50%;bottom:calc(var(--sheet-peek) + 20px);transform:translateX(-50%) translateY(20px);
  background:var(--surf-3);border:1px solid var(--border-2);
  padding:11px 18px;border-radius:10px;
  font-size:13px;z-index:9999;box-shadow:var(--shadow);
  opacity:0;pointer-events:none;
  transition:opacity .3s ease,transform .3s ease;
  max-width:92vw;text-align:center;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

.spinner{
  display:inline-block;width:10px;height:10px;border-radius:50%;
  border:2px solid var(--muted);border-top-color:transparent;
  animation:spin 1s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* When sheet is open, fade the map for emphasis */
.sidebar.open ~ .map-area{filter:brightness(.5);transition:filter .3s ease}

/* ───────────────────────── TABLET ≥ 700px ────────────────────────── */
@media (min-width:700px){
  :root{--sheet-peek:160px}
  .brand h1{font-size:16px}
  .pros-cons{grid-template-columns:1fr 1fr}
}

/* ───────────────────────── DESKTOP ≥ 900px ────────────────────────── */
@media (min-width:900px){
  :root{--topbar-h:62px}
  .hide-mobile{display:inline}
  .show-mobile{display:none}

  .topbar{padding:12px 20px;height:var(--topbar-h)}
  .brand h1{font-size:17px}
  .brand p{font-size:11.5px}

  .map-area{
    top:var(--topbar-h);
    left:440px;right:0;bottom:0;
  }
  .map-legend{left:14px;top:14px}
  .map-controls{right:14px;top:14px}

  .sidebar{
    position:fixed;
    top:var(--topbar-h);left:0;bottom:0;
    width:440px;height:auto;max-height:none;
    border-top:none;border-right:1px solid var(--border);
    border-radius:0;
    transform:none !important;
    pointer-events:auto !important;
    box-shadow:none;
    background:var(--bg-2);
  }
  .sheet-handle{display:none}
  .sidebar-scroll{padding:14px;padding-bottom:30px}

  /* Detail slides from the right on desktop */
  .detail{
    top:var(--topbar-h);left:auto;right:0;bottom:0;
    width:540px;max-width:100vw;
    transform:translateX(100%);
    border-left:1px solid var(--border);
    box-shadow:var(--shadow-lg);
  }
  .detail.open{transform:translateX(0)}
  .detail-close{margin:18px 18px 0 0;width:34px;height:34px}
  #detail-body{padding:24px 28px 60px}
  .detail-hero h2{font-size:26px}

  .toast{bottom:30px}

  .user-pill input{width:90px}
}

/* ───────────────────────── DESKTOP WIDE ≥ 1200px ────────────────────────── */
@media (min-width:1200px){
  .sidebar{width:460px}
  .map-area{left:460px}
}
