:root{
  --bg: #ffffff;
  --fg: #101828;
  --muted: #475467;
  --faint: #667085;
  --border: #eaecf0;
  --panel: #f9fafb;
  --accent: #1d4ed8;
  --accent-2: #0ea5e9;
  --danger: #b42318;
  --warn: #b54708;
  --ok: #027a48;
  --info: #0b4a6f;
  --focus: rgba(29,78,216,.22);
  --shadow: 0 1px 2px rgba(16,24,40,.06);
  --radius: 12px;
  --radius-sm: 10px;
  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
}

*{ box-sizing: border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family: var(--sans);
  color: var(--fg);
  background: var(--bg);
  line-height: 1.35;
}

a{ color: var(--accent); text-decoration: none; }
a:hover{ text-decoration: underline; }

.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.divider{
  width: 1px;
  height: 22px;
  background: var(--border);
}

.container{
  max-width: 1200px;
  margin: 0 auto;
  padding: 20px;
}


.container.wide{
  max-width: 1440px;
}

.container.full{
  max-width: 1680px;
}

.topbar{
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}

.topbar.is-sticky{
  position: sticky;
  top: 0;
  z-index: 20;
}

.brand{
  display:flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 20px;
}

.brand-left{ display:flex; align-items:center; gap: 10px; }
.mark{
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  box-shadow: var(--shadow);
}

.brand-title{
  display:flex;
  flex-direction: column;
}

.brand-title strong{ font-size: 14px; letter-spacing: .2px; }
.brand-title span{ font-size: 12px; color: var(--faint); }

.env{
  font-family: var(--mono);
  font-size: 12px;
  color: var(--muted);
  background: var(--panel);
  border: 1px solid var(--border);
  padding: 6px 10px;
  border-radius: 999px;
}

.nav{
  display:flex;
  gap: 8px;
  padding: 0 20px 12px;
  flex-wrap: wrap;
}

.nav a{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 10px;
  color: var(--muted);
  border: 1px solid transparent;
}

.nav a[aria-current="page"]{
  background: var(--panel);
  border-color: var(--border);
  color: var(--fg);
}

.nav a[aria-disabled="true"]{
  opacity: .55;
  pointer-events:none;
}

.breadcrumb{
  font-size: 12px;
  color: var(--faint);
  margin: 14px 0;
}

.statusbar{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items:center;
  justify-content: space-between;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 12px 14px;
  box-shadow: var(--shadow);
}

.contextbar{
  position: sticky;
  top: 0;
  z-index: 10;
  backdrop-filter: blur(6px);
}

.contextbar .meta{
  display:flex;
  align-items:center;
  gap: 10px;
  flex-wrap: wrap;
}

.contextbar .meta .title{
  font-weight: 650;
  font-size: 13px;
  color: var(--fg);
}

.statusbar .left,
.statusbar .right{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items:center;
}

.pill{
  font-size: 12px;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: #fff;
  color: var(--muted);
}

.pill strong{ color: var(--fg); font-weight: 600; }

.pill.ok{ border-color: rgba(2,122,72,.25); background: rgba(2,122,72,.06); color: var(--ok); }
.pill.warn{ border-color: rgba(181,71,8,.25); background: rgba(181,71,8,.06); color: var(--warn); }
.pill.danger{ border-color: rgba(180,35,24,.25); background: rgba(180,35,24,.06); color: var(--danger); }
.pill.info{ border-color: rgba(11,74,111,.25); background: rgba(11,74,111,.06); color: var(--info); }
.pill.neutral{ background: var(--panel); color: var(--muted); }

.badge{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 4px 8px;
  border-radius: 8px;
  border: 1px solid var(--border);
  font-size: 12px;
  color: var(--muted);
  background: #fff;
}
.badge strong{ color: var(--fg); font-weight: 650; }
.badge.ok{ border-color: rgba(2,122,72,.25); background: rgba(2,122,72,.06); color: var(--ok); }
.badge.warn{ border-color: rgba(181,71,8,.25); background: rgba(181,71,8,.06); color: var(--warn); }
.badge.danger{ border-color: rgba(180,35,24,.25); background: rgba(180,35,24,.06); color: var(--danger); }
.badge.info{ border-color: rgba(11,74,111,.25); background: rgba(11,74,111,.06); color: var(--info); }

.grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 16px;
}

@media (min-width: 980px){
  .grid.two{ grid-template-columns: 2fr 1fr; }
  .grid.three{ grid-template-columns: 1fr 1fr 1fr; }
}

.card{
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 14px;
}

.card h2,
.card h3{
  margin: 0 0 10px;
}

.card h2{ font-size: 16px; }
.card h3{ font-size: 14px; color: var(--fg); }

.subtle{ color: var(--muted); font-size: 13px; }

.muted{ color: var(--muted); }
.faint{ color: var(--faint); }

.kpi{
  display:flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 0;
  border-top: 1px solid var(--border);
}
.kpi:first-of-type{ border-top: none; }
.kpi .label{ color: var(--muted); font-size: 13px; }
.kpi .value{ font-weight: 650; }
.kpi .delta{ font-family: var(--mono); font-size: 12px; color: var(--faint); }

.table{
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.table th{
  text-align:left;
  font-size: 12px;
  color: var(--faint);
  font-weight: 600;
  padding: 10px 8px;
  border-bottom: 1px solid var(--border);
}
.table td{
  padding: 10px 8px;
  border-bottom: 1px solid var(--border);
  vertical-align: top;
}

.table tbody tr:hover{
  background: rgba(16,24,40,.02);
}

.table tbody tr[aria-selected="true"]{
  background: rgba(29,78,216,.08);
  outline: 1px solid rgba(29,78,216,.22);
  outline-offset: -1px;
}

.table.sticky thead th{
  position: sticky;
  top: 0;
  background: #fff;
  z-index: 2;
}

.table .mono{ font-family: var(--mono); font-size: 12px; color: var(--faint); }

.row-actions{
  display:flex;
  gap: 8px;
  flex-wrap: wrap;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 8px;
  border-radius: 10px;
  padding: 8px 10px;
  font-size: 13px;
  border: 1px solid var(--border);
  background: #fff;
  color: var(--fg);
  cursor: pointer;
}

.btn.primary{
  background: var(--accent);
  border-color: rgba(29,78,216,.25);
  color: #fff;
}

.btn.ghost{
  background: transparent;
  color: var(--muted);
}

.btn.danger{
  background: rgba(180,35,24,.08);
  border-color: rgba(180,35,24,.25);
  color: var(--danger);
}

.btn[aria-disabled="true"],
.btn:disabled{
  opacity: .55;
  cursor: not-allowed;
  pointer-events: none;
}

.btn:focus-visible,
.input:focus-visible,
.select:focus-visible,
button:focus-visible,
a:focus-visible{
  outline: 3px solid var(--focus);
  outline-offset: 2px;
}

.input,
.select{
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 9px 10px;
  font-size: 13px;
  background: #fff;
  color: var(--fg);
}

.toolbar{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
}

.toolbar .left,
.toolbar .right{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}

.placeholder{
  background: repeating-linear-gradient(
    45deg,
    #f2f4f7,
    #f2f4f7 12px,
    #f9fafb 12px,
    #f9fafb 24px
  );
  border: 1px dashed #d0d5dd;
  border-radius: var(--radius);
  padding: 14px;
  color: var(--muted);
}

.callout{
  border: 1px solid var(--border);
  background: #fff;
  border-radius: var(--radius);
  padding: 12px 14px;
  box-shadow: var(--shadow);
}

.callout.danger{ border-color: rgba(180,35,24,.25); background: rgba(180,35,24,.04); }
.callout.warn{ border-color: rgba(181,71,8,.25); background: rgba(181,71,8,.04); }
.callout.info{ border-color: rgba(11,74,111,.25); background: rgba(11,74,111,.04); }

.banner{
  display:flex;
  align-items:flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: #fff;
  box-shadow: var(--shadow);
}
.banner .title{ font-weight: 650; }
.banner .body{ color: var(--muted); font-size: 13px; }
.banner.danger{ border-color: rgba(180,35,24,.25); background: rgba(180,35,24,.04); }
.banner.warn{ border-color: rgba(181,71,8,.25); background: rgba(181,71,8,.04); }
.banner.info{ border-color: rgba(11,74,111,.25); background: rgba(11,74,111,.04); }

.footer{
  margin-top: 26px;
  padding: 18px 0;
  border-top: 1px solid var(--border);
  color: var(--faint);
  font-size: 12px;
}

.small{ font-size: 12px; color: var(--faint); }

code{ font-family: var(--mono); font-size: 12px; }

.brand-right{
  display:flex;
  align-items:center;
  gap: 10px;
}

.role-switch{
  display:flex;
  gap: 6px;
  align-items:center;
}

.role-switch a{
  font-size: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: #fff;
  color: var(--muted);
}

.role-switch a[aria-current="true"]{
  background: var(--panel);
  color: var(--fg);
  border-color: var(--border);
}

.density-switch{
  display:flex;
  gap: 6px;
  align-items:center;
}

.density-switch button{
  font-size: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: #fff;
  color: var(--muted);
}

.density-switch button[aria-pressed="true"]{
  background: var(--panel);
  color: var(--fg);
  border-color: var(--border);
}

/* ===== Visual placeholders (map/charts) ===== */

.visual{
  background: #0b1220;
  border: 1px solid rgba(234,236,240,.18);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  color: rgba(255,255,255,.86);
}

.map{
  position: relative;
  min-height: 360px;
  overflow: hidden;
  background:
    radial-gradient(900px 500px at 10% 20%, rgba(14,165,233,.18), transparent 55%),
    radial-gradient(700px 500px at 70% 25%, rgba(29,78,216,.18), transparent 55%),
    radial-gradient(800px 600px at 40% 80%, rgba(239,68,68,.14), transparent 55%),
    linear-gradient(180deg, #0b1220, #0a0f1a);
}

.map .map-grid{
  position:absolute;
  inset: 0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size: 48px 48px;
  opacity: .25;
  pointer-events:none;
}

.map .watermark{
  position:absolute;
  right: 14px;
  bottom: 12px;
  font-size: 12px;
  color: rgba(255,255,255,.55);
}

.map .overlay{
  position:absolute;
  background: rgba(2,6,23,.62);
  border: 1px solid rgba(148,163,184,.25);
  border-radius: 12px;
  padding: 10px;
  backdrop-filter: blur(6px);
}

.map .overlay h4{
  margin: 0 0 8px;
  font-size: 12px;
  color: rgba(255,255,255,.86);
  letter-spacing: .2px;
}

.map .overlay .row{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  font-size: 12px;
  color: rgba(255,255,255,.74);
  padding: 6px 0;
  border-top: 1px solid rgba(148,163,184,.18);
}
.map .overlay .row:first-of-type{ border-top: 0; }

.map .overlay .dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(14,165,233,.9);
  box-shadow: 0 0 0 3px rgba(14,165,233,.15);
}
.map .overlay .dot.red{ background: rgba(239,68,68,.92); box-shadow: 0 0 0 3px rgba(239,68,68,.18); }
.map .overlay .dot.amber{ background: rgba(245,158,11,.92); box-shadow: 0 0 0 3px rgba(245,158,11,.18); }

.map .overlay.top-left{ top: 12px; left: 12px; width: 260px; }
.map .overlay.bottom-left{ bottom: 12px; left: 12px; width: 260px; }
.map .overlay.top-right{ top: 12px; right: 12px; width: 300px; }

.map-marker{
  position:absolute;
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: rgba(14,165,233,.9);
  box-shadow: 0 0 0 4px rgba(14,165,233,.15);
  cursor: pointer;
}
.map-marker.drop{ background: rgba(239,68,68,.92); box-shadow: 0 0 0 4px rgba(239,68,68,.18); }
.map-marker.surge{ background: rgba(14,165,233,.92); box-shadow: 0 0 0 4px rgba(14,165,233,.18); }
.map-marker.shelter{ background: rgba(245,158,11,.92); box-shadow: 0 0 0 4px rgba(245,158,11,.18); }
.map-marker.is-selected{
  transform: scale(1.2);
  box-shadow: 0 0 0 6px rgba(29,78,216,.22);
}

.viz-stack{
  display:grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

.chart{
  padding: 12px;
}

.chart .title{
  display:flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.chart .title strong{ font-size: 13px; }
.chart .title span{ font-size: 12px; color: rgba(255,255,255,.62); font-family: var(--mono); }

.chart svg{
  display:block;
  width: 100%;
  height: 180px;
}

.chart .caption{
  margin-top: 8px;
  font-size: 12px;
  color: rgba(255,255,255,.62);
}

.split{
  display:grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media (min-width: 980px){
  .split.two{ grid-template-columns: 2fr 1fr; }
}

/* ===== COP layout ===== */
.grid > *,
.cop > *,
.split > *{
  min-width: 0;
}

.map .overlay .row > *{
  min-width: 0;
}

.map .overlay .row > *:last-child{
  text-align: right;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}


.cop{
  display:grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

@media (min-width: 1100px){
  .cop{
    grid-template-columns: 290px 1fr 380px;
    grid-template-rows: auto auto;
    align-items: start;
  }
  .cop .left{ grid-column: 1; grid-row: 1 / span 2; }
  .cop .center{ grid-column: 2; grid-row: 1; }
  .cop .right{ grid-column: 3; grid-row: 1; }
  .cop .bottom{ grid-column: 2 / span 2; grid-row: 2; }
}

.sticky-bottom{
  position: sticky;
  bottom: 12px;
  z-index: 5;
}

.panel{
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 14px;
}

.panel h2{ margin:0 0 10px; font-size: 14px; }
.panel .section{ margin-top: 12px; }
.panel .section:first-of-type{ margin-top: 0; }
.panel .section h3{ margin:0 0 8px; font-size: 12px; color: var(--faint); }

.filter{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  padding: 8px 0;
  border-top: 1px solid var(--border);
}
.filter:first-of-type{ border-top: 0; }

.bar{
  height: 8px;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 999px;
  overflow: hidden;
}
.bar > span{ display:block; height: 100%; background: rgba(29,78,216,.65); width: 50%; }

.timeline{
  display:flex;
  align-items:center;
  gap: 10px;
  margin: 0;
}
.timeline input{ width: 100%; }
.timeline .stamp{ font-family: var(--mono); font-size: 12px; color: rgba(255,255,255,.7); }

/* ===== Dialogs ===== */
dialog{
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 0;
  box-shadow: 0 12px 40px rgba(16,24,40,.18);
  max-width: min(720px, calc(100vw - 40px));
}
dialog::backdrop{
  background: rgba(16,24,40,.35);
}
.dialog{
  padding: 16px;
}
.dialog h3{
  margin: 0 0 8px;
  font-size: 15px;
}
.dialog p{
  margin: 0 0 12px;
  color: var(--muted);
  font-size: 13px;
}
.dialog .actions{
  display:flex;
  gap: 10px;
  justify-content: flex-end;
  padding-top: 10px;
}

/* ===== Evidence pack viewer ===== */
.pack{
  position: relative;
}
.pack-watermark{
  position: absolute;
  inset: 0;
  display:flex;
  align-items:center;
  justify-content:center;
  pointer-events:none;
  opacity: .10;
  font-size: 92px;
  font-weight: 800;
  color: var(--danger);
  transform: rotate(-18deg);
}

/* ===== Tabs ===== */
.tabs{
  display:flex;
  gap: 0;
  border-bottom: 1px solid var(--border);
  margin-bottom: 16px;
}
.tab{
  padding: 10px 16px;
  font-size: 13px;
  color: var(--muted);
  border: none;
  background: none;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}
.tab[aria-selected="true"]{
  color: var(--accent);
  border-bottom-color: var(--accent);
  font-weight: 600;
}
.tab:hover{ color: var(--fg); }
.tab-panel{ display:none; }
.tab-panel[aria-hidden="false"]{ display:block; }

/* ===== Incident selector (inline dropdown) ===== */
.incident-selector{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px 14px;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  margin-bottom: 12px;
}
.incident-selector .incident-name{
  font-weight: 650;
  font-size: 14px;
}
.incident-selector .incident-meta{
  font-size: 12px;
  color: var(--faint);
}

/* ===== New-count badge ===== */
.nav-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 999px;
  background: var(--danger);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  margin-left: 6px;
}

/* ===== Trust summary (compact) ===== */
.trust-summary{
  display:flex;
  gap: 8px;
  align-items:center;
  flex-wrap: wrap;
}
.trust-dot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
}
.trust-dot.ok{ background: var(--ok); }
.trust-dot.warn{ background: var(--warn); }
.trust-dot.fail{ background: var(--danger); }

/* ===== Sidebar panels (collapsible) ===== */
.sidebar-panel{
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: #fff;
  box-shadow: var(--shadow);
  margin-bottom: 12px;
}
.sidebar-panel-header{
  display:flex;
  align-items:center;
  justify-content: space-between;
  padding: 12px 14px;
  cursor: pointer;
  user-select: none;
}
.sidebar-panel-header h3{
  margin: 0;
  font-size: 13px;
}
.sidebar-panel-body{
  padding: 0 14px 14px;
}
.sidebar-panel[aria-expanded="false"] .sidebar-panel-body{
  display: none;
}

/* ===== Situation layout ===== */
.situation-layout{
  display:grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media (min-width: 1100px){
  .situation-layout{
    grid-template-columns: 1fr 360px;
    align-items: start;
  }
}

/* ===== Alert layout (two-column with sticky header) ===== */
.alert-layout{
  display:grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media (min-width: 1100px){
  .alert-layout{
    grid-template-columns: 1fr 380px;
    align-items: start;
  }
}

/* ===== Pack modes ===== */
.pack-mode-switch{
  display:flex;
  gap: 0;
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
}
.pack-mode-btn{
  padding: 8px 14px;
  font-size: 13px;
  border: none;
  background: #fff;
  color: var(--muted);
  cursor: pointer;
}
.pack-mode-btn[aria-pressed="true"]{
  background: var(--panel);
  color: var(--fg);
  font-weight: 600;
}

/* ===== New alert banner ===== */
.new-alerts-banner{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 14px;
  background: rgba(11,74,111,.06);
  border: 1px solid rgba(11,74,111,.18);
  border-radius: var(--radius);
  margin-bottom: 12px;
}
.new-alerts-banner .count{
  font-weight: 700;
  color: var(--info);
}

/* ===== Density modes ===== */
body.density-compact .container{ padding: 14px; }
body.density-compact .brand{ padding: 12px 14px; }
body.density-compact .nav{ padding: 0 14px 10px; }
body.density-compact .card{ padding: 12px; }
body.density-compact .panel{ padding: 12px; }
body.density-compact .btn{ padding: 7px 9px; font-size: 12px; }
body.density-compact .input, body.density-compact .select{ padding: 8px 9px; font-size: 12px; }
body.density-compact .table td{ padding: 8px 6px; }
body.density-compact .table th{ padding: 8px 6px; }
