/* ══════════════════════════════════════════════════════════════════
   MAFIA: The Underground — Main Stylesheet
   Dark, atmospheric, performance-first
══════════════════════════════════════════════════════════════════ */

:root{
  --bg:       #0f0a04;
  --bg2:      #1a1209;
  --bg3:      #221810;
  --parch:    #f5ead0;
  --parch2:   #d4c49a;
  --parch3:   #a89060;
  --blood:    #8b1a1a;
  --blood2:   #c0392b;
  --gold:     #c9a84c;
  --gold2:    #e8c96a;
  --fog:      #7a6a50;
  --border:   rgba(201,168,76,.15);
  --border2:  rgba(201,168,76,.25);
  --green:    #2d6e3a;
  --topbar-h: 52px;
  --bnav-h:   60px;
  --sheet-z:  500;
}

/* ── RESET ── */
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{height:100%;font-size:16px;background:var(--bg)}
body{
  height:100%;background:var(--bg);color:var(--parch);
  font-family:'Crimson Text',Georgia,serif;
  overflow:hidden;
  -webkit-font-smoothing:antialiased;
}
button{cursor:pointer;font-family:inherit;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit;color:inherit;background:none;border:none;outline:none}
a{color:var(--gold);text-decoration:none}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}

/* ══════════════════════════════════════════════════════════════════
   TOPBAR
══════════════════════════════════════════════════════════════════ */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:200;
  height:var(--topbar-h);
  background:rgba(12,8,3,.97);backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(201,168,76,.18);
  box-shadow:0 2px 24px rgba(0,0,0,.55);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 1rem;gap:.75rem;
}
.topbar-left{display:flex;align-items:center;gap:.5rem;flex-shrink:0;min-width:0}
.topbar-logo{
  font-family:'Share Tech Mono',monospace;font-size:.72rem;letter-spacing:.4em;
  color:var(--gold);text-transform:uppercase;font-weight:bold;
  text-shadow:0 0 18px rgba(201,168,76,.35);
}
.topbar-city{
  font-family:'Crimson Text',serif;font-size:.85rem;color:var(--parch3);
  font-style:italic;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
/* City-wide heat indicator — topbar left, next to city name */
.topbar-city-heat{
  font-family:'Share Tech Mono',monospace;font-size:.55rem;
  padding:.12rem .35rem;border-radius:2px;letter-spacing:.05em;white-space:nowrap;
  background:rgba(74,69,53,.25);color:var(--parch3);border:1px solid rgba(201,168,76,.12);
  transition:color .3s,background .3s,border-color .3s;
}
.topbar-city-heat.warm{background:rgba(201,168,76,.12);color:var(--gold);border-color:rgba(201,168,76,.28)}
.topbar-city-heat.hot{background:rgba(139,26,26,.18);color:var(--blood2);border-color:rgba(139,26,26,.35)}
.topbar-nav{display:flex;gap:0;flex:1;justify-content:center}
.tnav-btn{
  font-family:'Share Tech Mono',monospace;font-size:.6rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--fog);padding:.35rem .85rem;
  border-bottom:2px solid transparent;transition:all .2s;position:relative;
}
.tnav-btn:hover{color:var(--parch2)}
.tnav-btn.active{color:var(--gold);border-bottom-color:var(--gold)}
.badge{
  display:inline-block;background:var(--blood2);color:#fff;
  font-size:.5rem;padding:.1rem .3rem;border-radius:8px;
  font-family:'Share Tech Mono',monospace;margin-left:.3rem;vertical-align:middle;
}
/* ── topbar-right: unified 3-column chip ─────────────────────────────────── */
.topbar-right{
  display:flex;align-items:stretch;flex-shrink:0;gap:0;
  background:var(--bg3);border:1px solid var(--border);border-radius:4px;
}

/* player chip = col 1 (identity) + col 2 (stats) side by side */
.player-chip{display:flex;align-items:stretch;gap:0;cursor:pointer}
.player-chip:hover{background:rgba(201,168,76,.05)}

.chip-col{display:flex;flex-direction:column;justify-content:center;padding:.3rem .55rem}
.chip-col-id{min-width:0}
.chip-col-stats{
  border-left:1px solid var(--border);
  align-items:flex-end;gap:.1rem;
}

.chip-alias{
  font-family:'Crimson Text',serif;font-size:.88rem;color:var(--parch2);
  max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2;
}
.chip-org{
  font-family:'Share Tech Mono',monospace;font-size:.48rem;letter-spacing:.09em;
  text-transform:uppercase;color:var(--gold);opacity:.65;
  white-space:nowrap;max-width:110px;overflow:hidden;text-overflow:ellipsis;
  margin-top:.1rem;
}
.chip-stat{
  font-family:'Share Tech Mono',monospace;font-size:.54rem;
  letter-spacing:.04em;white-space:nowrap;line-height:1.35;
}
.chip-cash{color:var(--gold);opacity:.85}
.chip-sc{color:var(--parch2);opacity:.65}
.chip-heat{
  font-family:'Share Tech Mono',monospace;font-size:.52rem;
  letter-spacing:.05em;line-height:1.35;
  transition:color .3s;
}
.chip-heat.warm{color:var(--gold)}
.chip-heat.hot{color:var(--blood2)}
/* Legacy heat classes — kept for compat */
.heat-low{background:rgba(45,110,58,.18);color:#5cb85c;border:1px solid rgba(45,110,58,.3)}
.heat-med{background:rgba(201,168,76,.15);color:var(--gold);border:1px solid rgba(201,168,76,.3)}
.heat-high{background:rgba(139,26,26,.2);color:var(--blood2);border:1px solid rgba(139,26,26,.35)}

/* col 3: notification bell — sits right inside topbar-right */
#notifWrap{border-left:1px solid var(--border)}
.notif-btn{
  display:flex;align-items:center;justify-content:center;
  position:relative;padding:.3rem .55rem;cursor:pointer;height:100%;box-sizing:border-box;
}
.notif-btn:hover{background:rgba(201,168,76,.05)}
.notif-icon{font-size:.95rem;opacity:.7;transition:opacity .2s,filter .2s}
.notif-btn:hover .notif-icon{opacity:1}
.notif-btn.has-unread .notif-icon{opacity:1;filter:sepia(1) saturate(4) hue-rotate(5deg)}
.notif-count{
  position:absolute;top:4px;right:4px;
  background:var(--blood2);color:#fff;
  font-size:.44rem;min-width:13px;height:13px;line-height:13px;
  text-align:center;padding:0 2px;border-radius:7px;
  font-family:'Share Tech Mono',monospace;
}

/* ══════════════════════════════════════════════════════════════════
   MAIN CONTENT
══════════════════════════════════════════════════════════════════ */
.main-content{
  position:fixed;
  top:var(--topbar-h);
  left:0;right:0;
  bottom:var(--bnav-h);
  overflow:hidden;
}
.tab-panel{
  position:absolute;inset:0;
  display:none;overflow:hidden;
}
.tab-panel.active{display:flex;flex-direction:column}

/* Panel with scrollable content */
.panel-scroll{
  flex:1;overflow-y:auto;
  padding:.75rem 1rem calc(1.5rem);
  overscroll-behavior:contain;
}

/* ══════════════════════════════════════════════════════════════════
   MAP
══════════════════════════════════════════════════════════════════ */
/* ── MAP OP OVERLAY ──────────────────────────────────────────────────── */
.map-op-overlay{
  display:flex;align-items:center;gap:6px;
  height:24px;min-height:24px;padding:0 10px;flex-shrink:0;
  background:linear-gradient(90deg,rgba(139,26,26,.88),rgba(20,8,3,.92));
  border-bottom:1px solid rgba(139,26,26,.45);
  font-family:'Share Tech Mono',monospace;font-size:.6rem;
  letter-spacing:.07em;color:var(--parch);overflow:hidden;z-index:11;
}
.moo-pulse{color:var(--blood2);animation:moo-blink 1.2s ease-in-out infinite}
.moo-sep{color:rgba(245,234,208,.3);margin:0 2px}
#mooTarget{color:rgba(245,234,208,.6);font-style:italic}
#mooTimer{color:var(--gold);letter-spacing:.1em}
@keyframes moo-blink{0%,100%{opacity:1}50%{opacity:.3}}
/* ── MAP TICKER ──────────────────────────────────────────────────────── */
.map-ticker{
  display:flex;align-items:center;gap:0;
  height:26px;min-height:26px;
  background:rgba(10,5,2,.92);
  border-bottom:1px solid var(--border2);
  overflow:hidden;flex-shrink:0;z-index:10;position:relative;
}
.ticker-label{
  flex-shrink:0;
  padding:0 8px;
  font-family:'Share Tech Mono',monospace;
  font-size:.6rem;letter-spacing:.12em;color:var(--gold);
  background:rgba(20,10,4,.98);
  border-right:1px solid var(--border2);
  height:100%;display:flex;align-items:center;white-space:nowrap;
}
.ticker-viewport{flex:1;overflow:hidden;height:100%;position:relative}
.ticker-track{
  display:flex;align-items:center;height:100%;
  white-space:nowrap;
  will-change:transform;
  animation:tickerScroll 40s linear infinite;
}
.ticker-track:hover{animation-play-state:paused}
.ticker-item{
  display:inline-flex;align-items:center;
  font-family:'Crimson Text',serif;font-size:.72rem;
  color:var(--fg2);padding:0 1.5rem;
  border-right:1px solid var(--border2);
  white-space:nowrap;
}
.ticker-item .ti-section{
  font-family:'Share Tech Mono',monospace;font-size:.55rem;
  letter-spacing:.1em;color:var(--gold);margin-right:.4rem;opacity:.8;
}
@keyframes tickerScroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
/* ── /MAP TICKER ─────────────────────────────────────────────────────── */
#mapContainer{flex:1;width:100%;position:relative}
/* Cinematic vignette — dark edges, no pointer interference */
#mapContainer::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:2;
  background:radial-gradient(ellipse at 50% 46%,transparent 48%,rgba(5,2,1,.72) 100%);
}
.leaflet-container{
  background:var(--bg2) !important;
  font-family:'Crimson Text',serif !important;
}
/* Dark tile filter — noir/cinematic */
.leaflet-tile-pane{filter:brightness(.38) contrast(1.08) sepia(.55) saturate(.75) hue-rotate(5deg)}
.leaflet-control-zoom{
  border:1px solid var(--border2) !important;
  background:var(--bg2) !important;
}
.leaflet-control-zoom a{
  background:var(--bg2) !important;color:var(--gold) !important;
  border-bottom:1px solid var(--border) !important;
}
.leaflet-control-zoom a:hover{background:var(--bg3) !important}
.leaflet-control-attribution{background:rgba(15,10,4,.7) !important;color:var(--fog) !important;font-size:.5rem !important}
.leaflet-control-attribution a{color:var(--fog) !important}
.leaflet-popup-content-wrapper{
  background:var(--bg2) !important;color:var(--parch) !important;
  border:1px solid var(--border2) !important;border-radius:2px !important;
  box-shadow:0 4px 20px rgba(0,0,0,.6) !important;
}
.leaflet-popup-tip{background:var(--bg2) !important}
.leaflet-popup-content{margin:.6rem .8rem !important;font-family:'Crimson Text',serif}

/* Custom markers */
.estab-marker{
  cursor:pointer;
  overflow:visible !important;
}
/* Scale only the pin circle on hover, not the label */
.estab-marker:hover .em-pin{transform:scale(1.18);filter:brightness(1.3)}

/* ── MARKER WRAP & LABEL ── */
.em-wrap{
  display:flex;flex-direction:column;align-items:center;
  position:relative;
}

.em-label{
  margin-top:3px;
  background:rgb(11 9 5 / 27%);
  border:0px solid rgba(201,168,76,.22);
  border-top:0px solid #c9a84c; /* overridden inline per establishment color */
  padding:2px 6px 3px;
  border-radius:2px;
  text-align:center;
  max-width:110px;
  overflow:visible;
  position:relative;
  box-shadow:0 2px 8px rgba(0,0,0,.75);
  cursor:pointer;
}

.em-label-name{
  display:block;
  font-family:'Share Tech Mono',monospace;
  font-size:7px;letter-spacing:.06em;
  text-transform:uppercase;
  color:#f5ead0;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  max-width:108px;
  line-height:1.4;
}

.em-label-ctrl{
  display:none;
  font-family:'Share Tech Mono',monospace;
  font-size:6.5px;letter-spacing:.05em;
  text-transform:uppercase;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  max-width:108px;
  line-height:1.3;
  opacity:.88;
}

/* ── HOVER TOOLTIP ── */
.em-tooltip{
  display:none;
  position:absolute;
  bottom:calc(100% + 7px);
  left:50%;transform:translateX(-50%) translateY(-50%) scale(1.5);
  background:rgba(11,9,5,.97);
  border:1px solid rgba(201,168,76,.42);
  padding:6px 9px;border-radius:3px;
  z-index:9999;
  text-align:left;
  min-width:160px;max-width:210px;
  box-shadow:0 4px 18px rgba(0,0,0,.9);
  pointer-events:none;
  white-space:normal;
}
/* small caret */
.em-tooltip::after{
  content:'';
  position:absolute;bottom:-5px;left:50%;transform:translateX(-50%);
  border:5px solid transparent;
  border-top-color:rgba(201,168,76,.42);
  border-bottom:0;
}

.em-label:hover .em-tooltip{ display:block; }

.em-tt-row{ margin-bottom:5px; }
.em-tt-row:last-child{ margin-bottom:0; }

.em-tt-lbl{
  display:block;
  font-family:'Share Tech Mono',monospace;
  font-size:6px;letter-spacing:.1em;
  text-transform:uppercase;
  color:rgba(201,168,76,.6);
  margin-bottom:2px;
}

.em-tt-val{
  display:block;
  font-family:'Share Tech Mono',monospace;
  font-size:8px;letter-spacing:.03em;
  color:#f5ead0;line-height:1.45;
}

.em-tt-unknown{
  color:rgba(245,234,208,.32);
  font-style:italic;
}

.em-tt-ops{
  font-size:6.8px;
  color:rgba(245,234,208,.72);
  line-height:1.5;
}

/* ── BOTTOM SHEET ── */
.sheet{
  position:absolute;bottom:0;left:0;right:0;z-index:var(--sheet-z);
  background:var(--bg2);border-top:1px solid rgba(201,168,76,.22);
  border-radius:16px 16px 0 0;
  transform:translateY(100%);
  transition:transform .28s cubic-bezier(.4,0,.2,1);
  max-height:80%;overflow:hidden;display:flex;flex-direction:column;
  box-shadow:0 -4px 32px rgba(0,0,0,.65);
}
.sheet.open{transform:translateY(0)}
.sheet-handle{width:40px;height:4px;background:rgba(201,168,76,.28);border-radius:2px;margin:.7rem auto .2rem;box-shadow:0 0 6px rgba(201,168,76,.15)}
.sheet-inner{overflow-y:auto;padding:0 1rem 1.5rem;flex:1;overscroll-behavior:contain}
.sheet-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:.75rem;padding-top:.25rem}
.sheet-title{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700;color:var(--parch);line-height:1.2}
.sheet-sub{font-family:'Share Tech Mono',monospace;font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--fog);margin-top:.25rem}
.sheet-close{color:var(--fog);font-size:1rem;padding:.25rem;flex-shrink:0}
.sheet-close:hover{color:var(--parch)}
.sheet-status-row{display:flex;gap:.5rem;margin-bottom:.85rem;flex-wrap:wrap}
.control-badge{
  font-family:'Share Tech Mono',monospace;font-size:.55rem;letter-spacing:.1em;
  text-transform:uppercase;padding:.2rem .5rem;border-radius:2px;
}
.control-free{background:rgba(106,90,64,.2);color:var(--fog);border:1px solid rgba(106,90,64,.3)}
.control-controlled{background:rgba(139,26,26,.15);color:var(--blood2);border:1px solid rgba(139,26,26,.3)}
.control-contested{background:rgba(201,168,76,.12);color:var(--gold);border:1px solid rgba(201,168,76,.3)}
.income-badge{font-family:'Share Tech Mono',monospace;font-size:.55rem;color:var(--parch3);padding:.2rem .4rem;border:1px solid var(--border)}
.sheet-lore{font-family:'Crimson Text',serif;font-size:.9rem;font-style:italic;color:var(--parch3);line-height:1.55;margin-bottom:1rem}
.sheet-npcs{margin-bottom:1rem}
.npc-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:.4rem 0;border-bottom:1px solid rgba(201,168,76,.08);
  font-size:.85rem;
}
.npc-name{color:var(--parch2);font-style:italic}
.npc-role{font-family:'Share Tech Mono',monospace;font-size:.55rem;letter-spacing:.1em;text-transform:uppercase;color:var(--fog)}
.npc-bars{display:flex;gap:.3rem;align-items:center}
.bar-wrap{width:40px;height:4px;background:rgba(245,234,208,.1);border-radius:2px;overflow:hidden}
.bar-fill{height:100%;border-radius:2px;transition:width .4s}
.bar-compliance{background:var(--green)}
.bar-hostility{background:var(--blood)}
.sheet-actions{display:flex;flex-direction:column;gap:.5rem}

/* ── CONTROL BADGE STATUS VARIANTS ── */
.control-solo{background:rgba(201,168,76,.12);color:var(--gold);border:1px solid rgba(201,168,76,.3)}

/* ── ESTABLISHMENT ACTION BUTTONS ── */
.btn-op{
  display:flex;flex-direction:column;gap:.2rem;
  background:var(--bg3);border:1px solid var(--border);
  padding:.65rem .85rem;cursor:pointer;
  text-align:left;transition:border-color .18s,background .18s;
  width:100%;
}
.btn-op:hover:not([disabled]){border-color:var(--gold);background:rgba(201,168,76,.05)}
.btn-op:active:not([disabled]){transform:scale(.99)}
.btn-op[disabled]{opacity:.45;cursor:not-allowed}
.bop-name{
  font-family:'Playfair Display',serif;font-size:.9rem;font-weight:700;
  color:var(--parch);line-height:1.2;
}
.bop-meta{
  font-family:'Share Tech Mono',monospace;font-size:.52rem;
  letter-spacing:.08em;text-transform:uppercase;color:var(--fog);
}
.no-actions{
  font-family:'Share Tech Mono',monospace;font-size:.6rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--fog);text-align:center;
  padding:.75rem 0;opacity:.6;
}

/* ── ESTABLISHMENT MARKER ICONS ── */
.em-pin{
  width:var(--ps,22px);height:var(--ps,22px);
  border-radius:50%;
  background:var(--pc,#4a4535);
  display:flex;align-items:center;justify-content:center;
  bRox-shadow:0 2px 8px rgba(0,0,0,.8),0 0 0 1.5px rgba(0,0,0,.4);
  box-shadow: 0 2px 8px rgba(0,0,0,.2);
  border:1px solid rgba(255,255,255,.18);
  position:relative;
  transition:transform .18s,box-shadow .18s,filter .18s;
}
.em-emoji{font-size:16px;line-height:1;user-select:none;filter:drop-shadow(0 1px 2px rgba(0,0,0,.6))}
/* Contested: purple pulse */
.em-contested{
  animation:pin-contested 2.2s ease-in-out infinite;
}
@keyframes pin-contested{
  0%,100%{box-shadow:0 2px 10px rgba(0,0,0,.85),inset 0 1px 0 rgba(255,255,255,.14),0 0 0 2px rgba(0,0,0,.45)}
  50%{box-shadow:0 2px 10px rgba(0,0,0,.85),inset 0 1px 0 rgba(255,255,255,.14),0 0 12px 4px rgba(139,58,139,.6)}
}

.em-mine{
  animation:pin-mine 2.8s ease-in-out infinite;
}
@keyframes pin-mine{
  0%,100%{/* box-shadow:0 2px 10px rgba(0,0,0,.85),inset 0 1px 0 rgba(255,255,255,.14),0 0 0 2px rgba(0,0,0,.45);**/}
}
/* Enemy: red striped overlay — this location is controlled by an opponent */
.em-enemy::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: repeating-linear-gradient(
    45deg,
    transparent,
    transparent 2px,
    rgba(139, 26, 26, 0.5) 2px,
    rgba(139, 26, 26, 0.5) 4px
  );
  pointer-events: none;
  z-index: 1;
}


/* ══════════════════════════════════════════════════════════════════
   OPERATIONS
══════════════════════════════════════════════════════════════════ */
.section-head{
  display:flex;align-items:baseline;justify-content:space-between;
  margin:.25rem 0 .75rem;padding-bottom:.5rem;
  border-bottom:1px solid var(--border);
}
.section-title{font-family:'Playfair Display',serif;font-size:1rem;font-weight:700;color:var(--parch)}
.section-sub{font-family:'Share Tech Mono',monospace;font-size:.55rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold)}

/* Active op banner */
.active-op-banner{
  background:linear-gradient(135deg,rgba(139,26,26,.18),rgba(26,18,9,.9));
  border:1px solid rgba(139,26,26,.35);
  padding:1rem;margin-bottom:1rem;
}
.aob-label{font-family:'Share Tech Mono',monospace;font-size:.55rem;letter-spacing:.22em;text-transform:uppercase;color:var(--blood2);margin-bottom:.35rem}
.aob-name{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:var(--parch);margin-bottom:.35rem}
.aob-timer{font-family:'Share Tech Mono',monospace;font-size:1.3rem;color:var(--gold);letter-spacing:.08em;margin-bottom:.5rem}
.aob-progress{height:3px;background:rgba(245,234,208,.1);border-radius:2px;margin-bottom:.75rem;overflow:hidden}
.aob-bar{height:100%;background:var(--blood);border-radius:2px;transition:width 1s linear}
.btn-cancel-op{
  font-family:'Share Tech Mono',monospace;font-size:.58rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--fog);border:1px solid var(--border);
  padding:.35rem .75rem;transition:all .2s;
}
.btn-cancel-op:hover{border-color:var(--blood2);color:var(--blood2)}

/* Incapacitated banner */
.incap-banner{
  background:rgba(139,26,26,.12);border:1px solid rgba(139,26,26,.3);
  padding:1rem;margin-bottom:1rem;text-align:center;
}
.incap-icon{font-size:1.5rem;margin-bottom:.5rem}
.incap-msg{font-family:'Playfair Display',serif;font-size:1rem;font-weight:700;color:var(--blood2)}
.incap-sub{font-size:.82rem;color:var(--parch3);margin-top:.35rem}

/* Op history — matches class names emitted by ops.js renderHistory() */
.ops-history-list{max-height: 240px;
    margin-bottom: 2rem;
    overflow-y: scroll;}
.op-history-row{
  display:flex;align-items:flex-start;gap:.5rem;
  padding:.45rem 0;border-bottom:1px solid rgba(201,168,76,.07);
  min-width:0;
}
.ohr-icon{font-size:1rem;flex-shrink:0;width:1.4rem;text-align:center}
.ohr-info{flex:1;min-width:0}
.ohr-name{display:block;font-family:'Share Tech Mono',monospace;font-size:.6rem;
  letter-spacing:.05em;text-transform:uppercase;color:var(--parch2);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ohr-target{display:block;font-size:.75rem;font-style:italic;color:var(--fog);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ohr-result{flex-shrink:0;text-align:right}
.ohr-outcome{display:block;font-family:'Share Tech Mono',monospace;font-size:.52rem;
  letter-spacing:.06em;text-transform:uppercase}
.ohr-gains{display:block;font-family:'Share Tech Mono',monospace;font-size:.55rem;color:var(--gold)}
.ohr-ago{display:block;font-size:.65rem;color:var(--fog)}
.out-success{color:#5cb85c}
.out-partial{color:var(--gold)}
.out-fail{color:var(--fog)}
.out-critical{color:var(--blood2)}
.out-cancel{color:var(--fog);opacity:.6}

/* op-card sub-elements */
.op-card-dur{font-family:'Share Tech Mono',monospace;font-size:.52rem;color:var(--fog);margin-top:.15rem}
.op-card-sc{font-family:'Share Tech Mono',monospace;font-size:.5rem;color:var(--gold);opacity:.7}
.op-card.locked{opacity:.35;cursor:not-allowed}
.op-card.disabled{opacity:.45;cursor:not-allowed}
.op-lock{
  position:absolute;top:.4rem;right:.5rem;
  font-family:'Share Tech Mono',monospace;font-size:.48rem;
  letter-spacing:.06em;text-transform:uppercase;color:var(--fog);
}

/* Available ops grid — single column inside narrow sidebars */
.ops-grid{display:grid;grid-template-columns:1fr;gap:.4rem;margin-bottom:1.5rem}
.op-card{
  background:var(--bg3);border:1px solid var(--border);
  padding:.55rem .75rem;cursor:pointer;transition:all .2s;
  position:relative;display:flex;align-items:center;gap:.6rem;
  min-width:0;
}
.op-card:hover{border-color:var(--gold);background:rgba(201,168,76,.05)}
.op-card:active{transform:scale(.98)}
.op-card-icon{font-size:1.1rem;flex-shrink:0}
.op-card-body{min-width:0;flex:1}
.op-card-name{font-family:'Share Tech Mono',monospace;font-size:.62rem;font-weight:700;
  color:var(--parch);letter-spacing:.06em;text-transform:uppercase;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.op-card-meta{display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:.4rem}
.op-tag{
  font-family:'Share Tech Mono',monospace;font-size:.48rem;letter-spacing:.08em;
  text-transform:uppercase;padding:.1rem .3rem;border-radius:2px;
}
.op-tag-time{background:rgba(26,58,92,.2);color:#6ba4d4;border:1px solid rgba(26,58,92,.3)}
.op-tag-cost{background:rgba(45,110,58,.15);color:#7dcf7d;border:1px solid rgba(45,110,58,.25)}
.op-tag-heat{background:rgba(139,26,26,.15);color:var(--blood2);border:1px solid rgba(139,26,26,.25)}
.op-tag-instant{background:rgba(201,168,76,.12);color:var(--gold2);border:1px solid rgba(201,168,76,.25)}

/* Op confirm panel */
.op-confirm{
  position:fixed;inset:0;z-index:600;
  background:transparent;backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;
  padding:1rem;
}
.op-confirm-inner{
  background:var(--bg2);border:1px solid var(--border2);
  padding:1.5rem 1.25rem 2rem;width:100%;max-width:420px;
  border-radius:4px;
  max-height:80vh;overflow-y:auto;
}
.opc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.opc-title{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700;color:var(--parch)}
.opc-close{color:var(--fog);font-size:1rem;padding:.25rem}
.opc-close:hover{color:var(--parch)}
.opc-details{margin-bottom:1rem}
.opc-detail-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:.4rem 0;border-bottom:1px solid rgba(201,168,76,.07);
  font-size:.88rem;
}
.odc-label{color:var(--fog);font-family:'Share Tech Mono',monospace;font-size:.6rem;letter-spacing:.12em;text-transform:uppercase}
.odc-val{color:var(--parch2)}
.opc-target{margin-bottom:1rem}

/* ══════════════════════════════════════════════════════════════════
   CHAT
══════════════════════════════════════════════════════════════════ */
.chat-layout{
  flex:1;display:flex;flex-direction:column;overflow:hidden;
}
.chat-channels{
  display:flex;gap:0;border-bottom:1px solid var(--border);
  background:var(--bg2);flex-shrink:0;overflow-x:auto;
}
.ch-btn{
  font-family:'Share Tech Mono',monospace;font-size:.6rem;letter-spacing:.15em;
  text-transform:uppercase;color:var(--fog);padding:.6rem .9rem;
  border-bottom:2px solid transparent;transition:all .18s;white-space:nowrap;
  position:relative;
}
.ch-btn:hover{color:var(--parch2)}
.ch-btn.active{color:var(--gold);border-bottom-color:var(--gold)}
.ch-badge{
  display:inline-block;background:var(--blood2);color:#fff;
  font-size:.45rem;padding:.08rem .25rem;border-radius:6px;margin-left:.25rem;
}
.dm-header{
  display:flex;align-items:center;gap:.5rem;
  padding:.4rem .85rem;
  background:rgba(195,29,29,.08);
  border-bottom:1px solid rgba(195,29,29,.2);
  flex-shrink:0;
}
.dm-header-icon{font-size:.75rem;opacity:.7}
.dm-header-alias{
  flex:1;font-family:'Share Tech Mono',monospace;font-size:.65rem;
  letter-spacing:.12em;text-transform:uppercase;color:var(--parch2);
}
.dm-header-back{
  font-size:.65rem;color:var(--fog);padding:.1rem .3rem;
  border:1px solid var(--border);border-radius:2px;opacity:.7;
}
.dm-header-back:hover{opacity:1;color:var(--parch2)}
.chat-messages{
  flex:1;padding:.6rem .85rem;
  display:flex;flex-direction:column;gap:.25rem;
    overflow-x:scroll;max-height: 240px;
  
}
.chat-msg{
  display:flex;flex-direction:column;
  animation:fadeSlideUp .2s ease;
}
@keyframes fadeSlideUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.msg-header{display:flex;align-items:baseline;gap:.45rem;margin-bottom:.1rem}
.msg-alias{
  font-family:'Share Tech Mono',monospace;font-size:.62rem;letter-spacing:.08em;
  color:var(--gold);flex-shrink:0;
}
.msg-alias.me{color:var(--blood2)}
.msg-alias.system{color:var(--fog)}
.msg-time{font-family:'Share Tech Mono',monospace;font-size:.5rem;color:rgba(122,106,80,.6)}
.msg-text{font-size:.9rem;color:var(--parch2);line-height:1.45}
.msg-text.system-text{font-style:italic;color:var(--fog);font-size:.82rem}

.chat-input-row{
  display:flex;border-top:1px solid var(--border);
  background:var(--bg2);flex-shrink:0;
}
.chat-input{
  flex:1;background:transparent;color:var(--parch);
  font-family:'Crimson Text',serif;font-size:.95rem;
  padding:.6rem .85rem;
}
.chat-input::placeholder{color:var(--fog);font-style:italic}
.chat-send{
  background:transparent;color:var(--gold);
  padding:.6rem 1rem;font-size:1.1rem;border-left:1px solid var(--border);
  transition:background .2s;
}
.chat-send:hover{background:rgba(201,168,76,.08)}

/* ══════════════════════════════════════════════════════════════════
   NEWSPAPER (GAZETTE)
══════════════════════════════════════════════════════════════════ */
.gazette-masthead{
  text-align:center;padding:1rem 0 .75rem;
  border-bottom:3px double rgba(245,234,208,.15);
  margin-bottom:1rem;
}
.gm-title{
  font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:900;
  letter-spacing:.15em;color:var(--parch);line-height:1;
  text-transform:uppercase;
}
.gm-rule{border-top:1px solid var(--border);margin:.4rem 2rem}
.gm-sub{font-family:'Share Tech Mono',monospace;font-size:.55rem;letter-spacing:.22em;color:var(--fog);text-transform:uppercase}

.news-feed{display:flex;flex-direction:column;gap:.75rem}
.news-story{
  background:var(--bg3);border:1px solid var(--border);
  padding:.85rem 1rem;
  transition:border-color .2s;
}
.news-story:hover{border-color:var(--border2)}
.news-section-tag{
  font-family:'Share Tech Mono',monospace;font-size:.52rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--blood2);margin-bottom:.35rem;
}
.news-section-tag.front_page{color:var(--blood2)}
.news-section-tag.city_desk{color:var(--gold)}
.news-section-tag.business{color:var(--green)}
.news-section-tag.bulletin{color:var(--fog)}
.news-headline{
  font-family:'Playfair Display',serif;font-size:1rem;font-weight:700;
  color:var(--parch);line-height:1.3;margin-bottom:.5rem;
}
.news-body{font-size:.88rem;color:var(--parch3);line-height:1.55;font-style:italic}
.news-meta{
  font-family:'Share Tech Mono',monospace;font-size:.5rem;letter-spacing:.1em;
  color:var(--fog);margin-top:.5rem;display:flex;gap:.75rem;align-items:center;
}
.news-planted{color:var(--gold);font-size:.48rem}

.news-empty{text-align:center;padding:3rem 1rem;font-style:italic;color:var(--fog)}

/* ══════════════════════════════════════════════════════════════════
   PROFILE
══════════════════════════════════════════════════════════════════ */
.profile-card{
  background:linear-gradient(135deg,rgba(26,18,9,.9),rgba(15,10,4,.9));
  border:1px solid var(--border2);padding:1.25rem;margin-bottom:1rem;text-align:center;
}
.profile-alias{
  font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:700;
  color:var(--parch);margin-bottom:.25rem;
}
.profile-tier{
  font-family:'Share Tech Mono',monospace;font-size:.58rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold);margin-bottom:.25rem;
}
.profile-org{
  font-family:'Share Tech Mono',monospace;font-size:.62rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--gold);margin-bottom:.2rem;
}
.profile-rank{
  font-family:'Crimson Text',serif;font-size:.88rem;font-style:italic;color:var(--parch3);
  margin-bottom:.2rem;
}

.stats-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:1rem;
}
.stat-box{
  background:var(--bg3);border:1px solid var(--border);
  padding:.65rem .75rem;text-align:center;
}
.sb-val{
  display:block;font-family:'Playfair Display',serif;font-size:1.15rem;
  font-weight:700;color:var(--parch);line-height:1;margin-bottom:.25rem;
}
.sb-lbl{
  display:block;font-family:'Share Tech Mono',monospace;font-size:.5rem;
  letter-spacing:.12em;text-transform:uppercase;color:var(--fog);
}

.profile-section{margin-bottom:1.25rem}
.ps-head{
  font-family:'Share Tech Mono',monospace;font-size:.58rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--gold);
  padding:.5rem 0;border-bottom:1px solid var(--border);margin-bottom:.75rem;
  display:flex;align-items:center;justify-content:space-between;
}
.ps-body{font-size:.9rem;color:var(--parch3);line-height:1.5;margin-bottom:.75rem}

/* Tier track */
.tier-track{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap}
.tier-node{
  flex:1;min-width:60px;
  background:var(--bg3);border:1px solid var(--border);
  padding:.5rem .4rem;text-align:center;
}
.tier-node.active{border-color:var(--gold);background:rgba(201,168,76,.07)}
.tier-node.done{border-color:rgba(45,110,58,.4);background:rgba(45,110,58,.07)}
.tn-num{font-family:'Share Tech Mono',monospace;font-size:.5rem;letter-spacing:.1em;color:var(--fog);display:block}
.tn-name{font-family:'Playfair Display',serif;font-size:.72rem;color:var(--parch);display:block;line-height:1.2}
.tn-sc{font-family:'Share Tech Mono',monospace;font-size:.48rem;color:var(--gold);display:block;margin-top:.2rem}

/* Family info */
.family-info-block{}
.fi-name{font-family:'Playfair Display',serif;font-size:1rem;font-weight:700;color:var(--parch);margin-bottom:.35rem}
.fi-tier{font-family:'Share Tech Mono',monospace;font-size:.55rem;letter-spacing:.12em;color:var(--gold);margin-bottom:.35rem}
.fi-rank{font-size:.88rem;color:var(--parch3);font-style:italic}

/* Contacts */
.contacts-list{display:flex;flex-direction:column;gap:.4rem}
.contact-item{
  display:flex;align-items:center;gap:.75rem;
  padding:.5rem .75rem;background:var(--bg3);border:1px solid var(--border);
}
.contact-type{
  font-family:'Share Tech Mono',monospace;font-size:.55rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--gold);flex-shrink:0;
}
.contact-npc{font-size:.88rem;color:var(--parch2)}
.contact-role{font-size:.78rem;color:var(--fog);font-style:italic}

/* Notifications */
.notif-item{
  padding:.6rem .75rem;border-bottom:1px solid rgba(201,168,76,.07);
  display:flex;align-items:flex-start;gap:.6rem;
}
.notif-item.unread{background:rgba(201,168,76,.04)}
.notif-dot{width:6px;height:6px;border-radius:50%;background:var(--blood2);flex-shrink:0;margin-top:.35rem}
.notif-msg{font-size:.88rem;color:var(--parch3);line-height:1.4}
.notif-time{font-family:'Share Tech Mono',monospace;font-size:.5rem;color:var(--fog);margin-top:.2rem;display:block}

/* ══════════════════════════════════════════════════════════════════
   BOTTOM NAV
══════════════════════════════════════════════════════════════════ */
.bottom-nav{
  position:fixed;bottom:0;left:0;right:0;z-index:200;
  height:var(--bnav-h);
  background:rgba(12,8,3,.97);backdrop-filter:blur(20px);
  border-top:1px solid rgba(201,168,76,.18);
  box-shadow:0 -2px 20px rgba(0,0,0,.5);
  display:flex;
}
.bnav-btn{
  flex:1;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:.2rem;padding:.4rem .25rem;
  color:var(--fog);transition:color .2s;position:relative;
}
.bnav-btn.active{color:var(--gold)}
.bnav-btn.active .bnav-icon{text-shadow:0 0 14px rgba(201,168,76,.55)}
.bnav-btn.active .bnav-label{text-shadow:0 0 8px rgba(201,168,76,.3)}
.bnav-icon{font-size:.9rem;line-height:1}
.bnav-label{font-family:'Share Tech Mono',monospace;font-size:.46rem;letter-spacing:.12em;text-transform:uppercase}
.bnav-badge{
  position:absolute;top:4px;right:calc(50% - 18px);
  background:var(--blood2);color:#fff;
  font-size:.44rem;min-width:14px;height:14px;line-height:14px;
  text-align:center;padding:0 3px;border-radius:7px;
  font-family:'Share Tech Mono',monospace;
}

/* ══════════════════════════════════════════════════════════════════
   SHARED COMPONENTS
══════════════════════════════════════════════════════════════════ */
/* Buttons */
.btn-primary{
  display:block;width:100%;
  background:var(--blood);border:none;color:var(--parch);
  font-family:'Playfair Display',serif;font-size:.9rem;font-weight:700;
  padding:.75rem 1rem;cursor:pointer;letter-spacing:.06em;
  transition:background .2s;text-align:center;
}
.btn-primary:hover:not(:disabled){background:var(--blood2)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed}

.btn-ghost{
  background:transparent;border:1px solid var(--border2);color:var(--parch3);
  font-family:'Share Tech Mono',monospace;font-size:.6rem;letter-spacing:.14em;
  text-transform:uppercase;padding:.5rem .9rem;cursor:pointer;transition:all .2s;
}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}

.btn-sm{
  font-family:'Share Tech Mono',monospace;font-size:.52rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--fog);border:1px solid var(--border);
  padding:.2rem .5rem;cursor:pointer;transition:all .2s;
}
.btn-sm:hover{border-color:var(--gold);color:var(--gold)}

/* Form elements */
.form-label{
  font-family:'Share Tech Mono',monospace;font-size:.58rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--fog);display:block;margin-bottom:.4rem;
}
.form-input{
  background:rgba(245,234,208,.06);border:1px solid var(--border2);
  color:var(--parch);font-family:'Crimson Text',serif;font-size:1rem;
  padding:.6rem .8rem;width:100%;transition:border-color .2s;
}
.form-input::placeholder{color:var(--fog);font-style:italic}
.form-input:focus{border-color:var(--gold)}

.form-select{
  background:var(--bg3);border:1px solid var(--border2);
  color:var(--parch);font-family:'Crimson Text',serif;font-size:.95rem;
  padding:.55rem .75rem;width:100%;
}
.form-select option{background:var(--bg2)}

/* Error message */
.error-msg{
  background:rgba(139,26,26,.12);border:1px solid rgba(139,26,26,.3);
  color:#e57373;font-family:'Share Tech Mono',monospace;font-size:.6rem;
  letter-spacing:.1em;padding:.5rem .75rem;margin-top:.5rem;display:none;
}
.error-msg.show{display:block}

/* Toast */
.toast{
  position:fixed;bottom:calc(var(--bnav-h) + .75rem);left:50%;
  transform:translateX(-50%) translateY(100px);
  background:var(--bg2);border:1px solid var(--border2);
  color:var(--parch2);font-family:'Crimson Text',serif;font-size:.9rem;
  padding:.6rem 1.2rem;z-index:1000;
  transition:transform .28s cubic-bezier(.4,0,.2,1),opacity .28s;
  pointer-events:none;opacity:0;white-space:nowrap;max-width:90vw;
  box-shadow:0 4px 20px rgba(0,0,0,.5);
}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}

/* ══════════════════════════════════════════════════════════════════
   OPS SIDEBAR — mobile (slide-out drawer from left)
══════════════════════════════════════════════════════════════════ */
.ops-sidebar{
  position:fixed;
  left:0;top:var(--topbar-h);bottom:var(--bnav-h);
  width:280px;z-index:450;
  background:var(--bg2);
  border-right:1px solid var(--border2);
  transform:translateX(-100%);
  transition:transform .28s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;
  overflow:hidden;
}
.ops-sidebar.open{transform:translateX(0)}
.ops-sidebar .panel-scroll{
  flex:1;overflow-y:auto;overflow-x:hidden;
  padding:.6rem .85rem 2rem;
  overscroll-behavior:contain;
}
/* Close button — visible on mobile only */
.ops-sidebar-close{
  display:flex;align-items:center;justify-content:flex-end;
  padding:.5rem .75rem .25rem;color:var(--fog);font-size:.9rem;
  flex-shrink:0;
}
.ops-sidebar-close:hover{color:var(--parch)}

/* ══════════════════════════════════════════════════════════════════
   CHAT SIDEBAR — right column on desktop, drawer on mobile
══════════════════════════════════════════════════════════════════ */
.chat-sidebar{
  position:fixed;
  right:0;top:var(--topbar-h);bottom:var(--bnav-h);
  width:280px;z-index:450;
  background:var(--bg2);
  border-left:1px solid var(--border2);
  transform:translateX(100%);
  transition:transform .28s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;
  overflow:hidden;
}
.chat-sidebar.open{transform:translateX(0)}

/* Shared sidebar topbar (used by chat-sidebar and could extend ops) */
.sidebar-topbar{
  display:flex;align-items:center;gap:.5rem;
  padding:.45rem .85rem;
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.sidebar-label{
  font-family:'Share Tech Mono',monospace;font-size:.6rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--gold);
  flex:1;
}
.sidebar-close{color:var(--fog);font-size:.85rem;padding:.2rem;flex-shrink:0}
.sidebar-close:hover{color:var(--parch)}
.notif-badge-chat{
  background:var(--blood2);color:#fff;
  font-family:'Share Tech Mono',monospace;font-size:.48rem;
  padding:.1rem .35rem;border-radius:8px;
}

/* ══════════════════════════════════════════════════════════════════
   RIGHT COLUMN SECTIONS — news + presence (desktop only)
══════════════════════════════════════════════════════════════════ */
/* Hidden on mobile — shown only inside desktop right column */
.rc-section{display:none;flex-direction:column;flex-shrink:0;overflow:hidden}
.rc-section-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:.4rem .85rem;border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.rc-section-title{
  font-family:'Share Tech Mono',monospace;font-size:.58rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--gold);
}
.rc-presence-count{
  font-family:'Share Tech Mono',monospace;font-size:.52rem;
  color:var(--fog);letter-spacing:.05em;
}
.rc-empty{
  font-family:'Crimson Text',serif;font-style:italic;
  font-size:.8rem;color:var(--fog);padding:.6rem .85rem;
}

/* News feed in right panel — preserves newspaper aesthetic, scaled for 280px col */
.rc-news-feed{
  overflow-y:auto;overscroll-behavior:contain;flex:1;
  padding:.35rem 0;
}
/* Keep the card look but tighten padding */
.rc-news-feed .news-story{
  margin:0;border-left:none;border-right:none;border-radius:0;
  padding:.6rem .85rem;
  border-top:none;border-bottom:1px solid var(--border);
}
.rc-news-feed .news-story:last-child{border-bottom:none}
/* Scale down headline sizes for narrow column */
.rc-news-feed .ns-headline{font-size:.92rem;margin-bottom:.2rem}
.rc-news-feed .news-story.lead .ns-headline{font-size:1.05rem}
.rc-news-feed .ns-section-tag{font-size:.56rem;margin-bottom:.25rem}
.rc-news-feed .ns-byline{font-size:.6rem;margin-bottom:.35rem}
.rc-news-feed .ns-body{font-size:.82rem;line-height:1.45}
.rc-news-feed .ns-sub{font-size:.8rem}
/* Hide lead icon + divider — they need full-width treatment */
.rc-news-feed .ns-icon,.news-feed .ns-icon,.rc-news-feed .ns-divider{display:none}
/* Compact masthead inside the rc-news section */
.rc-gazette-sub{
  font-family:'Share Tech Mono',monospace;font-size:.5rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--fog);
  padding:.2rem .85rem .35rem;border-bottom:1px solid var(--border);
  text-align:center;
}

/* Who's here list */
.rc-presence-list{
  overflow-y:auto;overscroll-behavior:contain;flex:1;
  padding:.2rem 0;
}
.rc-player-row{
  display:flex;align-items:center;gap:.55rem;
  padding:.32rem .85rem;
  border-bottom:1px solid rgba(201,168,76,.05);
}
.rc-player-row:last-child{border-bottom:none}
.rc-player-dot{
  width:7px;height:7px;border-radius:50%;flex-shrink:0;
  box-shadow:0 0 4px currentColor;
}
.rc-dot-online{background:#5cb85c;color:#5cb85c}
.rc-dot-recent{background:rgba(122,106,80,.4);color:transparent;border:1px solid var(--fog)}
.rc-player-name{
  flex:1;font-family:'Crimson Text',serif;font-size:.85rem;
  color:var(--parch2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  font-style:italic;
}
.rc-player-sc{
  font-family:'Share Tech Mono',monospace;font-size:.48rem;
  letter-spacing:.04em;color:var(--fog);flex-shrink:0;
  border:1px solid rgba(201,168,76,.15);padding:.1rem .3rem;
}
.rc-dm{flex-shrink:0;opacity:.6}
.rc-dm:hover{opacity:1}

/* ── DM Inbox ── */
.dm-inbox-row{
  display:flex;align-items:center;gap:.6rem;
  padding:.55rem .85rem;cursor:pointer;
  border-bottom:1px solid rgba(201,168,76,.06);
  transition:background .15s;
}
.dm-inbox-row:hover{background:rgba(201,168,76,.06)}
.dir-avatar{
  width:28px;height:28px;border-radius:50%;flex-shrink:0;
  background:rgba(201,168,76,.15);border:1px solid rgba(201,168,76,.25);
  display:flex;align-items:center;justify-content:center;
  font-family:'Share Tech Mono',monospace;font-size:.7rem;color:var(--gold);
}
.dir-body{flex:1;display:flex;flex-direction:column;gap:.1rem;min-width:0}
.dir-name{
  font-family:'Crimson Text',serif;font-style:italic;
  font-size:.85rem;color:var(--parch2);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.dir-time{font-family:'Share Tech Mono',monospace;font-size:.48rem;color:var(--fog)}
.dir-unread{
  flex-shrink:0;background:var(--blood2);color:#fff;
  font-size:.5rem;padding:.1rem .3rem;border-radius:8px;
  font-family:'Share Tech Mono',monospace;
}

/* ── FAB: floating ops button on the map (mobile only) ── */
.fab-ops{
  position:absolute;bottom:1.25rem;left:1rem;z-index:400;
  width:46px;height:46px;border-radius:50%;
  background:rgba(15,10,4,.92);border:1px solid rgba(201,168,76,.35);
  color:var(--gold);font-size:1.15rem;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 3px 16px rgba(0,0,0,.7),0 0 0 0 rgba(201,168,76,.3);
  transition:border-color .2s,background .2s,box-shadow .2s;
  backdrop-filter:blur(8px);
}
.fab-ops:hover{background:var(--bg3);border-color:var(--gold);box-shadow:0 3px 16px rgba(0,0,0,.7),0 0 12px 2px rgba(201,168,76,.2)}
.fab-ops:active{transform:scale(.93)}

/* ── MOBILE OPS OVERLAY backdrop ── */
.ops-backdrop{
  display:none;position:fixed;inset:0;z-index:440;
  background:rgba(5,3,1,.55);
}
.ops-backdrop.show{display:block}

/* ── MOBILE CHAT OVERLAY backdrop ── */
.chat-backdrop{
  display:none;position:fixed;inset:0;z-index:440;
  background:rgba(5,3,1,.55);
}
.chat-backdrop.show{display:block}

/* ══════════════════════════════════════════════════════════════════
   DESKTOP LAYOUT  (≥ 900px) — ops column LEFT | map center | detail RIGHT
══════════════════════════════════════════════════════════════════ */
@media(min-width:900px){
  :root{--bnav-h:0px}
  .bottom-nav{display:none}
  .fab-ops{display:none}           /* FAB not needed on desktop */
  .ops-sidebar-close{display:none} /* close btn not needed on desktop */
  .ops-backdrop{display:none !important}
  .chat-backdrop{display:none !important}

  /* Three-column flex row */
  .main-content{
    display:flex;flex-direction:row;
    bottom:0;overflow:hidden;
  }

  /* ── OPS SIDEBAR: always visible, LEFT column ── */
  .ops-sidebar{
    position:static;transform:none;transition:none;
    width:260px;flex-shrink:0;order:-1;
    border-right:1px solid var(--border);border-left:none;
    overflow-y:auto;overflow-x:hidden;
    z-index:auto;top:auto;bottom:auto;
  }
  .ops-sidebar-close{display:none}

  /* ── CHAT SIDEBAR: always visible, RIGHT column ── */
  .chat-sidebar{
    position:static;transform:none;transition:none;
    width:280px;flex-shrink:0;order:1;
    border-left:1px solid var(--border);border-right:none;
    overflow:hidden;
    z-index:auto;top:auto;bottom:auto;
  }
  .sidebar-close{display:none} /* no close btn on desktop */

  /* ── RIGHT COLUMN: news + presence sections visible on desktop ── */
  .rc-section{display:flex}
  .rc-news{height:81%;border-bottom:1px solid var(--border)}
  .rc-presence{height:18%;border-bottom:1px solid var(--border)}
  /* Chat layout fills the rest */
  .chat-sidebar .chat-layout{flex:1;min-height:0}

  /* All tab-panels: static, hidden by default */
  .tab-panel{position:static;display:none;overflow:hidden}

  /* ── MAP: always visible, fills CENTER ── */
  #tabMap{
    display:flex !important;
    flex:1;position:relative;min-width:0;overflow:hidden;
  }

  /* ── News (mobile tab): hidden on desktop — news lives in right col ── */
  #tabNews{display:none !important}

  /* ── Profile: overlay panel, triggered by username click ── */
  #tabProfile{
    position:fixed;
    top:var(--topbar-h);right:280px;bottom:0;
    width:340px;z-index:350;
    border-left:1px solid var(--border2);
    background:var(--bg2);overflow:hidden;
  }
  #tabProfile.active{display:flex;flex-direction:column}

  /* ── ESTABLISHMENT SHEET: slides in from RIGHT edge of map ── */
  .sheet{
    position:absolute;
    right:0;top:0;bottom:0;left:auto;
    width:280px;max-height:100%;
    transform:translateX(100%);
    border-radius:0;border-top:none;
    border-left:1px solid var(--border2);border-right:none;
  }
  .sheet.open{transform:translateX(0)}
  .sheet-handle{display:none}

  /* ── OP CONFIRM MODAL ── */
  .op-confirm{align-items:center}
  .op-confirm-inner{max-width:480px;border-radius:2px;border:1px solid var(--border2)}

  /* Map tab button dimmed (always visible) */
  .tnav-btn[data-tab="map"]{opacity:.45;pointer-events:none}
}

/* ── Tablet (768–899px): no sidebar, just hide bottom nav ── */
@media(min-width:768px) and (max-width:899px){
  .bottom-nav{display:none}
  :root{--bnav-h:0px}
  .main-content{bottom:0}
  .sheet{max-width:400px;right:auto;border-radius:0;border-top:none;border-right:1px solid var(--border2)}
  .op-confirm{align-items:center}
  .op-confirm-inner{max-width:460px;border-radius:2px;border:1px solid var(--border2)}
}

/* ══════════════════════════════════════════════════════════════════
   ANIMATIONS
══════════════════════════════════════════════════════════════════ */
@keyframes spin{to{transform:rotate(360deg)}}
.spinner{
  width:24px;height:24px;border:2px solid var(--border);
  border-top-color:var(--gold);border-radius:50%;
  animation:spin .7s linear infinite;display:inline-block;
}

/* Pulsing indicator */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.pulse{animation:pulse 2s infinite}

/* Op running indicator */
.op-running-dot{
  display:inline-block;width:6px;height:6px;border-radius:50%;
  background:var(--blood2);animation:pulse 1.2s infinite;margin-right:.4rem;vertical-align:middle;
}

/* ══════════════════════════════════════════════════════════════════
   CHAT MESSAGES
══════════════════════════════════════════════════════════════════ */
.chat-msg{padding:.5rem .75rem;border-bottom:1px solid rgba(201,168,76,.06);font-size:.9rem}
.chat-msg.system{color:var(--fog);font-style:italic;font-size:.8rem;text-align:center;padding:.3rem}
.chat-msg.mine .msg-alias{color:var(--gold)}
.chat-msg.theirs .msg-alias{color:var(--parch2)}
.msg-meta{display:flex;align-items:center;gap:.4rem;margin-bottom:.2rem;flex-wrap:wrap}
.msg-alias{font-family:'Share Tech Mono',monospace;font-size:.75rem;letter-spacing:.04em;cursor:pointer}
.msg-alias:hover{color:var(--gold2)}
.msg-ts{font-size:.7rem;color:var(--fog);margin-left:auto}
.msg-body{color:var(--parch2);line-height:1.4;word-break:break-word}
.msg-dm{font-size:.65rem;padding:.1rem .3rem;border:1px solid var(--border);border-radius:2px;
  opacity:.5;transition:opacity .2s}
.msg-dm:hover{opacity:1}
.msg-tier{font-family:'Share Tech Mono',monospace;font-size:.65rem;padding:.1rem .3rem;
  border-radius:2px;letter-spacing:.05em}
.msg-tier.t0{background:rgba(74,69,53,.6);color:var(--fog)}
.msg-tier.t1{background:rgba(139,26,26,.4);color:#e06060}
.msg-tier.t2{background:rgba(201,168,76,.2);color:var(--gold)}
.msg-tier.t3{background:rgba(139,26,26,.6);color:#ff9090}
.msg-tier.t4{background:rgba(201,168,76,.4);color:var(--gold2)}
.chat-empty{color:var(--fog);font-style:italic;font-size:.85rem;text-align:center;padding:2rem 1rem}

/* Optimistic pending message — shown instantly while send is in-flight */
.chat-msg.msg-pending .msg-body{opacity:.6}
.msg-sending{
  display:inline-block;
  margin-left:.35rem;
  font-size:.65rem;
  color:var(--fog);
  letter-spacing:.12em;
  vertical-align:middle;
  animation:msg-pulse 1.1s ease-in-out infinite;
}
@keyframes msg-pulse{
  0%,100%{opacity:.25}
  50%    {opacity:.85}
}

/* ══════════════════════════════════════════════════════════════════
   NOTIFICATIONS
══════════════════════════════════════════════════════════════════ */
.notif-row{display:flex;align-items:flex-start;gap:.6rem;padding:.6rem 0;
  border-bottom:1px solid var(--border);cursor:pointer}
.notif-row.unread .nr-msg{color:var(--parch)}
.notif-row .nr-msg{color:var(--parch2);font-size:.85rem}
.notif-row .nr-icon{font-size:1rem;flex-shrink:0;width:1.2rem;text-align:center}
.nr-body{display:flex;flex-direction:column;gap:.2rem}
.nr-time{font-size:.7rem;color:var(--fog)}

/* ══════════════════════════════════════════════════════════════════
   PROFILE — FAMILY INFO BLOCK
══════════════════════════════════════════════════════════════════ */
.family-info-block{padding:.5rem 0}
.fi-name{font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--gold);margin-bottom:.3rem}
.fi-tier{font-family:'Share Tech Mono',monospace;font-size:.7rem;letter-spacing:.1em;
  color:var(--fog);text-transform:uppercase;margin-bottom:.5rem}
.fi-stats{display:flex;gap:1rem;flex-wrap:wrap;font-size:.8rem;color:var(--parch2);margin-bottom:.5rem}
.fi-boss{font-size:.8rem;color:var(--fog)}
.fi-actions{display:flex;gap:.5rem;margin-top:.75rem;flex-wrap:wrap}
.family-solo p{color:var(--parch2);font-size:.85rem;margin-bottom:.75rem}
.family-row{display:flex;align-items:center;gap:.75rem;padding:.6rem 0;
  border-bottom:1px solid var(--border);flex-wrap:wrap}
.fr-name{font-family:'Playfair Display',serif;color:var(--parch);font-size:.95rem;flex:1}
.fr-meta{font-size:.75rem;color:var(--fog)}
.family-loading{color:var(--fog);font-style:italic;font-size:.85rem}
.family-members-panel{border-top:1px solid var(--border);margin-top:.75rem;padding-top:.75rem}
.fmp-head{font-family:'Share Tech Mono',monospace;font-size:.7rem;letter-spacing:.1em;
  color:var(--fog);text-transform:uppercase;display:flex;justify-content:space-between;margin-bottom:.5rem}
.fm-row{display:flex;gap:.75rem;padding:.4rem 0;border-bottom:1px solid rgba(201,168,76,.05);
  font-size:.82rem}
.fm-alias{color:var(--parch);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.fm-rank{color:var(--parch3);font-size:.78rem}
.fm-sc{color:var(--gold);font-family:'Share Tech Mono',monospace;font-size:.75rem}
.fm-you{color:var(--gold);font-style:normal;font-size:.72rem}
.fm-rank-sel{background:var(--ink);border:1px solid var(--border);color:var(--parch3);
  font-family:'Share Tech Mono',monospace;font-size:.65rem;padding:.2rem .3rem;cursor:pointer;
  border-radius:2px;max-width:90px}
.fm-pay,.fm-kick{padding:.15rem .45rem;font-size:.65rem;flex-shrink:0}

/* ── ORG MANAGEMENT PANEL ─────────────────────────────────────────────────── */
.org-mgmt{margin-top:.85rem;border-top:1px solid var(--border);padding-top:.75rem}
.fi-treasury-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;flex-wrap:wrap}
.treasury-label{font-family:'Share Tech Mono',monospace;font-size:.65rem;
  letter-spacing:.08em;color:var(--fog);text-transform:uppercase}
.treasury-val{font-family:'Share Tech Mono',monospace;font-size:.75rem;color:var(--gold);flex:1}
.treasury-input{width:80px;background:var(--ink);border:1px solid var(--border);color:var(--parch);
  padding:.3rem .4rem;font-family:'Share Tech Mono',monospace;font-size:.72rem;border-radius:2px}
.treasury-input:focus{outline:none;border-color:var(--gold)}
.org-tabs{display:flex;gap:.3rem;margin-bottom:.6rem;flex-wrap:wrap}
.org-tab{background:none;border:1px solid var(--border);color:var(--fog);
  font-family:'Share Tech Mono',monospace;font-size:.62rem;letter-spacing:.06em;
  padding:.3rem .55rem;cursor:pointer;transition:border-color .15s,color .15s;border-radius:2px}
.org-tab:hover{border-color:var(--gold);color:var(--gold)}
.org-tab.active{border-color:var(--gold);color:var(--gold);background:rgba(201,168,76,.07)}
.req-badge{display:inline-block;background:var(--blood);color:#fff;border-radius:8px;
  padding:0 .35rem;font-size:.6rem;margin-left:.25rem;line-height:1.4}
.org-panel{display:none;padding-top:.35rem}
.org-panel.active{display:block}
.org-msg-input{width:100%;min-height:56px;background:var(--ink);border:1px solid var(--border);
  color:var(--parch);padding:.45rem .55rem;font-family:inherit;font-size:.83rem;
  resize:vertical;box-sizing:border-box;border-radius:2px;margin-bottom:.45rem}
.org-msg-input:focus{outline:none;border-color:var(--gold)}
.org-invite-row{display:flex;gap:.45rem;align-items:center}
.org-invite-input{flex:1;background:var(--ink);border:1px solid var(--border);
  color:var(--parch);padding:.35rem .55rem;font-family:inherit;font-size:.83rem;
  border-radius:2px}
.org-invite-input:focus{outline:none;border-color:var(--gold)}
.req-row{padding:.5rem 0;border-bottom:1px solid rgba(201,168,76,.06)}
.req-alias{color:var(--parch);font-size:.83rem;font-weight:600;margin-bottom:.15rem}
.req-msg{color:var(--fog);font-size:.75rem;font-style:italic;margin-bottom:.35rem}
.req-actions{display:flex;gap:.35rem}

/* ══════════════════════════════════════════════════════════════════
   PROFILE — TIER TRACK
══════════════════════════════════════════════════════════════════ */
.tier-track{padding:.25rem 0}
.tt-label{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.5rem}
.tt-current{font-family:'Playfair Display',serif;color:var(--gold);font-size:1rem}
.tt-next{font-size:.8rem;color:var(--parch3)}
.tt-max{font-size:.8rem;color:var(--blood2)}
.tt-bar-bg{height:4px;background:var(--bg3);border-radius:2px;overflow:hidden;margin-bottom:.4rem}
.tt-bar{height:100%;background:linear-gradient(90deg,var(--blood),var(--gold));
  border-radius:2px;transition:width .6s ease}
.tt-sub{font-size:.75rem;color:var(--fog);margin-bottom:.75rem}
.tt-tiers{display:flex;gap:.4rem}
.tt-pip{width:24px;height:24px;border-radius:50%;border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;font-size:.7rem;
  font-family:'Share Tech Mono',monospace;color:var(--fog)}
.tt-pip.done{background:var(--blood);border-color:var(--blood);color:var(--parch)}

/* ══════════════════════════════════════════════════════════════════
   PROFILE — CONTACTS
══════════════════════════════════════════════════════════════════ */
.contacts-list{display:flex;flex-direction:column;gap:0}
.contact-row{display:flex;align-items:center;gap:.6rem;padding:.5rem 0;
  border-bottom:1px solid var(--border);font-size:.82rem;flex-wrap:wrap}
.cr-alias{color:var(--parch);font-weight:600;flex:1;min-width:80px}
.cr-role{color:var(--gold);font-family:'Share Tech Mono',monospace;font-size:.7rem;letter-spacing:.04em}
.cr-bonus{color:var(--parch3);font-size:.75rem;flex:2}

/* ══════════════════════════════════════════════════════════════════
   NEWSPAPER — STORY CARDS
══════════════════════════════════════════════════════════════════ */
.news-story{padding:1.25rem 0;border-bottom:1px solid var(--border)}
.news-story.lead{padding-bottom:1.5rem}
.ns-section-tag{font-family:'Share Tech Mono',monospace;font-size:.65rem;letter-spacing:.15em;
  color:var(--blood2);text-transform:uppercase;margin-bottom:.4rem}
.ns-headline{font-family:'Playfair Display',serif;font-size:1.15rem;
  color:var(--parch);line-height:1.25;margin-bottom:.3rem}
.news-story.lead .ns-headline{font-size:1.4rem}
.ns-sub{font-family:'Crimson Text',serif;font-style:italic;font-size:.9rem;
  color:var(--parch2);margin-bottom:.3rem}
.ns-byline{font-family:'Share Tech Mono',monospace;font-size:.68rem;letter-spacing:.05em;
  color:var(--fog);margin-bottom:.6rem}
.ns-icon{margin:.5rem 0;opacity:.6}
.ns-icon svg{width:36px;height:36px}
.ns-body{color:var(--parch2);font-size:.9rem;line-height:1.55}
.ns-tag{display:inline-block;margin-top:.5rem;font-family:'Share Tech Mono',monospace;
  font-size:.65rem;letter-spacing:.08em;color:var(--gold);
  border:1px solid var(--border);padding:.15rem .4rem}
.ns-divider{border:none;border-top:2px solid var(--border2);margin:1rem 0}

/* ══════════════════════════════════════════════════════════════════
   MAP — ESTABLISHMENT MARKERS
══════════════════════════════════════════════════════════════════ */
.estab-marker{background:none;border:none}
.em-dot{border-radius:50%;display:flex;align-items:center;justify-content:center;
  border:1.5px solid rgba(255,255,255,.15);transition:transform .15s;cursor:pointer}
.em-dot:hover{transform:scale(1.4)}
.em-emoji{font-size:8px;line-height:1;user-select:none;pointer-events:none}

/* Control status color reference */
.status-family{background:var(--blood)!important}
.status-solo{background:var(--gold)!important}
.status-free{background:#4a4535!important}
.status-contested{background:#6b3a6b!important}

/* NPC list in sheet */
.npc-row{display:flex;align-items:center;gap:.5rem;padding:.35rem 0;
  border-bottom:1px solid rgba(201,168,76,.06);font-size:.8rem}
.npc-name{color:var(--parch);flex:1;font-family:'Playfair Display',serif;font-size:.85rem}
.npc-role{color:var(--fog);flex:1}
.npc-corr{font-family:'Share Tech Mono',monospace;font-size:.72rem;color:var(--gold);
  text-align:right;min-width:50px}
.no-actions{color:var(--fog);font-style:italic;font-size:.8rem}

/* ══════════════════════════════════════════════════════════════════
   OPS — DETAIL MODAL ROWS
══════════════════════════════════════════════════════════════════ */
.opc-row{display:flex;justify-content:space-between;align-items:baseline;
  padding:.4rem 0;border-bottom:1px solid rgba(201,168,76,.06);font-size:.85rem}
.opc-row span{color:var(--fog)}
.opc-row b{color:var(--parch)}
.risk-low{color:#7dcf7d}
.risk-mid{color:var(--gold)}
.risk-high{color:#e08060}
.risk-extreme{color:var(--blood2)}
.out-success{color:#7dcf7d}
.out-partial{color:var(--gold)}
.out-fail{color:#e08060}
.out-critical{color:var(--blood2)}

/* ══════════════════════════════════════════════════════════════════
   TOPBAR POPOVERS — profile chip + notification bell
══════════════════════════════════════════════════════════════════ */
.tp-wrap{position:relative}

.profile-popover,.notif-popover{
  position:absolute;
  top:calc(100% + 10px);
  right:0;
  z-index:700;
  min-width:240px;
  background:var(--bg2);
  border:1px solid var(--border2);
  box-shadow:0 10px 36px rgba(0,0,0,.7);
  animation:popoverIn .15s ease;
}

@keyframes popoverIn{
  from{opacity:0;transform:translateY(-5px)}
  to{opacity:1;transform:none}
}

/* Caret pointing up toward the button */
.profile-popover::before,.notif-popover::before{
  content:'';
  position:absolute;
  top:-6px;right:14px;
  width:10px;height:10px;
  background:var(--bg2);
  border-left:1px solid var(--border2);
  border-top:1px solid var(--border2);
  transform:rotate(45deg);
}

/* ── Profile popover ── */
.pp-card{
  padding:.7rem 1rem .6rem;
  border-bottom:1px solid var(--border);
  text-align:center;
}
.pp-alias{
  font-family:'Playfair Display',serif;
  font-size:1rem;font-weight:700;color:var(--parch);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.pp-meta{
  font-family:'Share Tech Mono',monospace;
  font-size:.5rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold);margin-top:.2rem;
}
.pp-org-wrap{
  display:flex;align-items:center;gap:.4rem;margin-top:.35rem;
}
.pp-org-name{
  font-family:'Share Tech Mono',monospace;font-size:.52rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--gold);opacity:.85;
  border:1px solid rgba(201,168,76,.3);border-radius:2px;padding:.1rem .35rem;
  max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.pp-org-leave{
  font-family:'Share Tech Mono',monospace;font-size:.46rem;letter-spacing:.08em;
  text-transform:uppercase;background:transparent;border:1px solid rgba(139,26,26,.5);
  color:var(--blood,#8b1a1a);border-radius:2px;padding:.1rem .3rem;cursor:pointer;
  opacity:0;transition:opacity .15s;pointer-events:none;
}
.pp-org-wrap:hover .pp-org-leave{opacity:1;pointer-events:auto;}
.pp-stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-bottom:1px solid var(--border);
}
.pp-stat{
  padding:.5rem .2rem;text-align:center;
  border-right:1px solid var(--border);
}
.pp-stat:last-child{border-right:none}
.pp-sv{
  display:block;
  font-family:'Playfair Display',serif;
  font-size:.82rem;font-weight:700;color:var(--parch);line-height:1;
}
.pp-sl{
  display:block;
  font-family:'Share Tech Mono',monospace;
  font-size:.42rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--fog);margin-top:.2rem;
}
.pp-nav-hint{
  display:block;width:100%;
  padding:.4rem 1rem;text-align:center;
  font-family:'Share Tech Mono',monospace;
  font-size:.46rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--fog);
  border-top:1px solid var(--border);
  opacity:.6;
}

/* ── Notification popover ── */
.notif-popover{min-width:260px}
.np-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:.45rem .75rem;
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.np-title{
  font-family:'Share Tech Mono',monospace;
  font-size:.56rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);
}
.np-list{
  max-height:320px;overflow-y:auto;
  overscroll-behavior:contain;
}
.np-empty{
  font-family:'Crimson Text',serif;font-style:italic;
  font-size:.85rem;color:var(--fog);
  padding:1rem .75rem;text-align:center;
}
.np-item{
  display:flex;align-items:flex-start;gap:.45rem;
  padding:.5rem .75rem;
  border-bottom:1px solid rgba(201,168,76,.06);
  cursor:pointer;transition:background .15s;
}
.np-item:last-child{border-bottom:none}
.np-item.unread{background:rgba(201,168,76,.04)}
.np-item.unread:hover{background:rgba(201,168,76,.09)}
.np-item:not(.unread):hover{background:rgba(245,234,208,.03)}
.np-unread-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--blood2);flex-shrink:0;margin-top:.4rem;
}
.np-icon{font-size:.9rem;flex-shrink:0;width:1.1rem;text-align:center;margin-top:.1rem}
.np-body{flex:1;min-width:0}
.np-msg{
  display:block;font-size:.8rem;color:var(--parch3);line-height:1.4;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.np-time{
  display:block;
  font-family:'Share Tech Mono',monospace;
  font-size:.44rem;color:var(--fog);margin-top:.15rem;letter-spacing:.04em;
}

/* Mobile: full-width drop from topbar */
@media(max-width:899px){
  .news-story {
    border-top: 0;
    border-left: 0;
    border-right: 0;
    background: none;
}
  .topbar-nav{display: none;}
  .profile-popover,.notif-popover{
    position:fixed;
    top:var(--topbar-h);
    right:0;left:0;
    min-width:0;width:100%;
    border-left:none;border-right:none;
  }
  .profile-popover::before,.notif-popover::before{display:none}
  .np-list{max-height:55vh}
}


/* ── CITIES PANEL ──────────────────────────────────────────────────────────── */

/* Full-screen overlay on ALL sizes — covers sidebars, map, everything */
#tabCities{
  position:fixed!important;
  top:var(--topbar-h);left:0;right:0;bottom:0;
  z-index:490;
  background:var(--bg,#0c0803);
  display:none;flex-direction:column;
  overflow:hidden;
}
#tabCities.active{display:flex!important}

/* Panel header: title + close btn */
.cities-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:.75rem 1.5rem;
  border-bottom:1px solid rgba(201,168,76,.15);
  flex-shrink:0;
}
.cities-head-titles{display:flex;flex-direction:column;gap:.15rem;}
.cities-head-title{
  font-family:'Playfair Display',serif;font-size:1.1rem;
  color:var(--gold,#c9a84c);letter-spacing:.06em;
}
.cities-head-sub{
  font-family:'Crimson Text',serif;font-style:italic;
  font-size:.78rem;color:var(--fog,#6b5d3f);
}
.cities-close-btn{
  background:none;border:1px solid rgba(201,168,76,.2);
  color:var(--fog,#6b5d3f);cursor:pointer;
  font-size:.8rem;padding:.3rem .7rem;
  font-family:'Share Tech Mono',monospace;letter-spacing:.08em;
  transition:color .2s,border-color .2s;
}
.cities-close-btn:hover{color:var(--parch3,#c8b89a);border-color:var(--gold,#c9a84c);}

/* Cards row: horizontal scroll like reference image */
.cities-grid{
  display:flex;flex-direction:row;
  flex:1;overflow-x:auto;overflow-y:hidden;
  gap:0;
}
.city-card{
  flex:0 0 300px;
  display:flex;flex-direction:column;
  border-right:1px solid rgba(201,168,76,.1);
  overflow-y:auto;
  padding:1.5rem 1.25rem 2rem;
  transition:background .2s;
}
.city-card:last-child{border-right:none;}
.city-card:hover{background:rgba(201,168,76,.03);}
.cc-header{
  margin-bottom:.75rem;
  padding-bottom:.6rem;
  border-bottom:1px solid rgba(201,168,76,.12);
}
.cc-name{
  font-family:'Playfair Display',serif;font-size:1.2rem;
  color:var(--gold,#c9a84c);letter-spacing:.04em;margin-bottom:.2rem;
}
.cc-pop{
  font-family:'Share Tech Mono',monospace;font-size:.58rem;
  color:var(--fog,#6b5d3f);letter-spacing:.1em;
}
.cc-headlines{margin-bottom:1rem;}
.cc-headline{
  font-family:'Crimson Text',serif;font-style:italic;
  font-size:.85rem;color:var(--parch3,#c8b89a);line-height:1.5;
  margin-bottom:.3rem;
}
.cc-section-title{
  font-family:'Share Tech Mono',monospace;font-size:.52rem;
  color:var(--fog,#6b5d3f);letter-spacing:.14em;text-transform:uppercase;
  margin:.75rem 0 .35rem;
  padding-bottom:.25rem;border-bottom:1px solid rgba(201,168,76,.08);
}
.cc-family,.cc-player{
  display:flex;align-items:center;gap:.5rem;
  font-family:'Share Tech Mono',monospace;font-size:.68rem;
  padding:.3rem 0;border-bottom:1px solid rgba(58,46,26,.35);
}
.cc-family:last-child,.cc-player:last-child{border-bottom:none}
.cc-fam-tier{color:var(--gold,#c9a84c);font-size:.58rem;letter-spacing:.06em;min-width:52px;}
.cc-fam-name{flex:1;color:var(--parch3,#c8b89a);}
.cc-fam-inf{color:var(--fog,#6b5d3f);font-size:.6rem;}
.cc-rank{color:var(--fog,#6b5d3f);min-width:22px;font-size:.6rem;}
.cc-pname{flex:1;color:var(--parch3,#c8b89a);}
.cc-sc{color:var(--gold,#c9a84c);font-size:.6rem;}
.cc-empty-row{
  font-family:'Share Tech Mono',monospace;font-size:.63rem;
  color:var(--fog,#6b5d3f);font-style:italic;padding:.25rem 0;
}

/* Mobile: cards still scroll horizontally, but slightly narrower */
@media(max-width:899px){
  .city-card{flex:0 0 85vw;}
}

/* ── CITY CARD VISUAL ENHANCEMENTS ───────────────────────────────────────── */
.city-card{cursor:pointer;}
.city-card:hover{background:rgba(201,168,76,.05);}

/* Visual header — cityscape SVG bleeds to card edges */
.cc-visual{
  height:110px;
  margin:-1.5rem -1.25rem .9rem;
  position:relative;flex-shrink:0;overflow:hidden;
}

/* Badge (HOT / NEW / CLASSIC) */
.cc-badge{
  position:absolute;top:.55rem;right:.55rem;
  font-family:'Share Tech Mono',monospace;
  font-size:.5rem;letter-spacing:.13em;
  padding:.18rem .45rem;
  background:rgba(5,3,1,.85);
  text-transform:uppercase;
  border:1px solid;
}
.badge-hot    {color:#c0392b;border-color:#c0392b;}
.badge-new    {color:#c9a84c;border-color:#c9a84c;}
.badge-classic{color:rgba(120,103,73,.7);border-color:rgba(120,103,73,.35);}

/* Location line under city name */
.cc-location{
  font-family:'Share Tech Mono',monospace;
  font-size:.5rem;letter-spacing:.12em;
  text-transform:uppercase;
  margin:.12rem 0 .4rem;
}
.cc-loc-badge-hot    {color:#8b2500;}
.cc-loc-badge-new    {color:var(--gold,#c9a84c);}
.cc-loc-badge-classic{color:var(--fog,#6b5d3f);}

/* Description quote (first headline) */
.cc-desc{
  font-family:'Crimson Text',serif;font-style:italic;
  font-size:.82rem;color:var(--parch3,#c8b89a);
  line-height:1.5;margin-bottom:.8rem;
  border-left:2px solid rgba(201,168,76,.2);
  padding-left:.55rem;
}

/* ── CITY NEWSPAPER OVERLAY ──────────────────────────────────────────────── */
.city-newspaper-overlay{
  position:fixed;inset:0;z-index:500;
  background:rgba(10,7,2,.97);
  display:flex;flex-direction:column;
  overflow:hidden;
}
.cn-anim{animation:cnFadeIn .22s ease;}
@keyframes cnFadeIn{
  from{opacity:0;transform:translateY(10px);}
  to  {opacity:1;transform:translateY(0);}
}
.cn-close{
  position:absolute;top:.85rem;right:1.1rem;
  background:none;border:none;
  color:var(--fog,#6b5d3f);font-size:1.3rem;
  cursor:pointer;z-index:1;line-height:1;
  font-family:'Share Tech Mono',monospace;
  transition:color .2s;padding:.2rem .4rem;
}
.cn-close:hover{color:var(--parch,#f5ead0);}
.cn-scroll{
  overflow-y:auto;flex:1;
  padding:2rem 1.5rem 3rem;
  max-width:680px;margin:0 auto;width:100%;
}
.cn-masthead{
  text-align:center;margin-bottom:1.8rem;
  padding-bottom:1rem;
  border-bottom:2px solid var(--cn-accent,#c9a84c);
}
.cn-paper-name{
  font-family:'Playfair Display',serif;
  font-size:2.2rem;letter-spacing:.06em;line-height:1.1;
  margin-bottom:.4rem;
  color:var(--cn-accent,#c9a84c);
}
.cn-paper-rule{
  height:1px;background:var(--cn-accent,#c9a84c);
  opacity:.2;margin:.4rem 0;
}
.cn-paper-tagline{
  font-family:'Share Tech Mono',monospace;
  font-size:.54rem;letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--cn-accent,#c9a84c);opacity:.6;
}
.cn-paper-date{
  font-family:'Share Tech Mono',monospace;
  font-size:.5rem;letter-spacing:.1em;
  color:var(--fog,#6b5d3f);margin-top:.3rem;
}
.cn-section-label{
  font-family:'Share Tech Mono',monospace;
  font-size:.52rem;letter-spacing:.16em;
  text-transform:uppercase;
  border-top:1px solid rgba(201,168,76,.12);
  border-bottom:1px solid rgba(201,168,76,.12);
  padding:.35rem 0;margin:1.5rem 0 .75rem;
  color:var(--fog,#6b5d3f);
}
.cn-row{
  display:flex;align-items:center;gap:.5rem;
  font-family:'Share Tech Mono',monospace;font-size:.68rem;
  padding:.3rem 0;border-bottom:1px solid rgba(58,46,26,.35);
}
.cn-row:last-child{border-bottom:none;}

@media(max-width:899px){
  .cn-paper-name{font-size:1.6rem;}
  .cn-scroll{padding:1.5rem 1rem 2.5rem;}
}

/* ══════════════════════════════════════════════════════════════════
   CITY EXPANSION MODAL
   Minimalist, dark, gold-bordered aesthetic
══════════════════════════════════════════════════════════════════ */
.expand-modal {
  position: fixed; inset: 0; z-index: 900;
  background: rgba(10,7,2,0.95);
  backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  padding: 1.5rem;
  animation: fadeIn 0.3s ease;
}
.expand-modal-inner {
  background: var(--bg2, #1a1209);
  border: 1px solid var(--border, rgba(201,168,76,0.18));
  max-width: 440px; width: 100%;
  display: flex; flex-direction: column;
  box-shadow: 0 15px 50px rgba(0,0,0,0.8);
}
.em-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--border);
}
.em-title {
  font-family: 'Playfair Display', serif; font-size: 1.2rem;
  font-weight: 700; color: var(--parch, #f5ead0);
}
.em-close {
  background: none; border: none; color: var(--fog, #7a6a50);
  font-size: 1.1rem; cursor: pointer; transition: color 0.15s;
}
.em-close:hover { color: var(--parch); }

.em-body { padding: 1.25rem; }
.em-intro {
  font-family: 'Crimson Text', serif; font-size: 0.95rem;
  color: var(--parch3, #a89060); font-style: italic;
  line-height: 1.5; margin-bottom: 1.25rem;
}
.em-list {
  display: flex; flex-direction: column; gap: 0.5rem;
  max-height: 280px; overflow-y: auto;
  padding-right: 0.5rem;
}
.em-city-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0.75rem 1rem;
  background: rgba(245,234,208,0.03);
  border: 1px solid rgba(201,168,76,0.08);
  cursor: pointer; transition: all 0.2s;
}
.em-city-item:hover {
  background: rgba(201,168,76,0.08);
  border-color: rgba(201,168,76,0.3);
}
.em-city-item.selected {
  background: rgba(139,26,26,0.15);
  border-color: var(--blood, #8b1a1a);
}
.eci-name {
  font-family: 'Playfair Display', serif; font-size: 1.05rem;
  font-weight: 700; color: var(--parch);
}
.eci-pop {
  font-family: 'Share Tech Mono', monospace; font-size: 0.65rem;
  color: var(--fog); letter-spacing: 0.05em;
}

.em-footer {
  padding: 1rem 1.25rem;
  border-top: 1px solid var(--border);
  display: flex; justify-content: center;
}
.em-loading {
  text-align: center; color: var(--fog); font-style: italic;
  padding: 2rem 0; font-size: 0.9rem;
}

@media (max-width: 480px) {
  .expand-modal { padding: 1rem; }
  .expand-modal-inner { max-height: 90vh; }
}
