/* ─────────────────────────────────────────────────────────────────────────────
   BaseRate Superadmin · Godfather control plane
   Standalone, self-contained dark "ops" theme. CSP-safe: no inline styles or
   scripts anywhere; bar widths use SVG geometry attributes, not style="".
   ───────────────────────────────────────────────────────────────────────────── */

:root {
  --sa-bg: #0a1729;
  --sa-bg-2: #0f2138;
  --sa-panel: #122a47;
  --sa-panel-2: #16314f;
  --sa-line: #1f3c5e;
  --sa-text: #e7eefb;
  --sa-muted: #8ba0c0;
  --sa-accent: #26c6a8;
  --sa-accent-soft: rgba(38, 198, 168, 0.14);
  --sa-danger: #ff6b6b;
  --sa-warn: #f5b455;
  --sa-radius: 12px;
  --sa-radius-sm: 8px;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: radial-gradient(1200px 600px at 80% -10%, #14365c 0%, var(--sa-bg) 55%);
  color: var(--sa-text);
  font-family: 'Plus Jakarta Sans', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  min-height: 100vh;
}

.hidden { display: none !important; }
.sa-muted { color: var(--sa-muted); }

/* ── Topbar ───────────────────────────────────────────────────────────────── */
.sa-topbar {
  border-bottom: 1px solid var(--sa-line);
  background: rgba(10, 23, 41, 0.85);
  backdrop-filter: blur(8px);
  position: sticky;
  top: 0;
  z-index: 10;
}
.sa-topbar-inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0.85rem 1.25rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.sa-brand { display: flex; align-items: center; gap: 0.7rem; }
.sa-brand-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: var(--sa-accent-soft);
  color: var(--sa-accent);
  font-weight: 700;
  font-size: 1.4rem;
  line-height: 1;
}
.sa-brand-text { display: flex; flex-direction: column; line-height: 1.2; }
.sa-brand-text strong { font-size: 1rem; letter-spacing: 0.01em; }
.sa-brand-sub { font-size: 0.74rem; color: var(--sa-muted); text-transform: uppercase; letter-spacing: 0.08em; }

.sa-topbar-right { display: flex; align-items: center; gap: 0.75rem; }
.sa-who { font-size: 0.85rem; color: var(--sa-muted); font-family: 'Spline Sans Mono', monospace; }
.sa-pill {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 0.25rem 0.6rem;
  border-radius: 999px;
  border: 1px solid var(--sa-line);
}
.sa-pill.is-live { color: var(--sa-accent); border-color: rgba(38, 198, 168, 0.5); background: var(--sa-accent-soft); }
.sa-pill.is-sim { color: var(--sa-warn); border-color: rgba(245, 180, 85, 0.4); background: rgba(245, 180, 85, 0.1); }

/* ── Main / views ─────────────────────────────────────────────────────────── */
.sa-main { max-width: 1180px; margin: 0 auto; padding: 1.75rem 1.25rem 4rem; }
.sa-view { animation: sa-fade 0.25s ease; }
@keyframes sa-fade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

.sa-card {
  background: linear-gradient(180deg, var(--sa-panel) 0%, var(--sa-bg-2) 100%);
  border: 1px solid var(--sa-line);
  border-radius: var(--sa-radius);
  padding: 1.6rem;
}
.sa-card h1 { margin: 0 0 0.35rem; font-size: 1.35rem; }

/* ── Sign-in ──────────────────────────────────────────────────────────────── */
.sa-signin-card, .sa-denied-card { max-width: 440px; margin: 5vh auto 0; }
.sa-form { margin-top: 1.1rem; display: flex; flex-direction: column; gap: 0.55rem; }
.sa-form label { font-size: 0.8rem; font-weight: 600; color: var(--sa-muted); }
.sa-form input {
  background: var(--sa-bg);
  border: 1px solid var(--sa-line);
  border-radius: var(--sa-radius-sm);
  color: var(--sa-text);
  padding: 0.7rem 0.85rem;
  font-size: 1rem;
  font-family: inherit;
}
.sa-form input:focus { outline: none; border-color: var(--sa-accent); box-shadow: 0 0 0 3px var(--sa-accent-soft); }
.sa-form-row { display: flex; gap: 0.6rem; flex-wrap: wrap; }
.sa-form-row .sa-btn { flex: 1 1 auto; }

.sa-btn {
  appearance: none;
  border: 1px solid transparent;
  border-radius: var(--sa-radius-sm);
  padding: 0.7rem 1.1rem;
  font-size: 0.92rem;
  font-weight: 700;
  font-family: inherit;
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease, opacity 0.15s ease;
}
.sa-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.sa-btn-primary { background: var(--sa-accent); color: #04221c; }
.sa-btn-primary:hover:not(:disabled) { background: #34d9ba; }
.sa-btn-ghost { background: transparent; border-color: var(--sa-line); color: var(--sa-text); }
.sa-btn-ghost:hover:not(:disabled) { border-color: var(--sa-accent); color: var(--sa-accent); }

.sa-devcode {
  margin: 0.2rem 0 0;
  font-size: 0.82rem;
  color: var(--sa-accent);
  font-family: 'Spline Sans Mono', monospace;
}
.sa-msg { margin-top: 0.9rem; font-size: 0.85rem; }
.sa-msg.is-error { color: var(--sa-danger); }
.sa-msg.is-ok { color: var(--sa-accent); }

/* ── Console head ─────────────────────────────────────────────────────────── */
.sa-console-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.25rem;
  flex-wrap: wrap;
}
.sa-console-head h1 { margin: 0 0 0.2rem; font-size: 1.45rem; }
.sa-console-head p { margin: 0; }
.sa-console-actions { display: flex; align-items: center; gap: 0.8rem; }
.sa-live { display: inline-flex; align-items: center; gap: 0.4rem; font-size: 0.8rem; font-weight: 700; color: var(--sa-accent); text-transform: uppercase; letter-spacing: 0.06em; }
.sa-live-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--sa-accent); animation: sa-pulse 1.6s ease-in-out infinite; }
@keyframes sa-pulse { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.35; transform: scale(0.7); } }

/* ── Godfather layout ─────────────────────────────────────────────────────── */
.sa-godfather { display: grid; gap: 1.1rem; }
.sa-kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.sa-kpi {
  background: var(--sa-panel);
  border: 1px solid var(--sa-line);
  border-radius: var(--sa-radius);
  padding: 1.1rem 1.2rem;
}
.sa-kpi-value { display: block; font-size: 1.8rem; font-weight: 800; font-family: 'Spline Sans Mono', monospace; }
.sa-kpi-label { display: block; margin-top: 0.2rem; font-size: 0.78rem; color: var(--sa-muted); text-transform: uppercase; letter-spacing: 0.05em; }

.sa-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 1.1rem; }
.sa-panel {
  background: var(--sa-panel);
  border: 1px solid var(--sa-line);
  border-radius: var(--sa-radius);
  padding: 1.2rem 1.3rem;
}
.sa-panel h2 { margin: 0 0 0.9rem; font-size: 0.95rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--sa-muted); }
.sa-mt { margin-top: 1.1rem; }

/* ── Event stream ─────────────────────────────────────────────────────────── */
.sa-stream { display: flex; flex-direction: column; max-height: 560px; overflow-y: auto; }
.sa-ev {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: 0.7rem;
  padding: 0.6rem 0.2rem;
  border-bottom: 1px solid rgba(31, 60, 94, 0.5);
}
.sa-ev:last-child { border-bottom: none; }
.sa-ev-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--sa-muted); flex: none; }
.sa-ev-main { display: flex; flex-direction: column; min-width: 0; }
.sa-ev-label { font-weight: 600; font-size: 0.9rem; }
.sa-ev-summary { font-size: 0.78rem; color: var(--sa-muted); font-family: 'Spline Sans Mono', monospace; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sa-ev-app { font-size: 0.74rem; font-family: 'Spline Sans Mono', monospace; color: var(--sa-accent); }
.sa-ev-time { font-size: 0.74rem; color: var(--sa-muted); white-space: nowrap; }

/* ── By-type ──────────────────────────────────────────────────────────────── */
.sa-type-row { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 0.6rem; padding: 0.4rem 0; }
.sa-type-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--sa-muted); }
.sa-type-label { font-size: 0.82rem; }
.sa-type-count { font-size: 0.85rem; font-weight: 700; font-family: 'Spline Sans Mono', monospace; min-width: 2ch; text-align: right; }
.sa-type-bar { grid-column: 1 / -1; }
.sa-bar { width: 100%; height: 6px; display: block; }
.sa-bar-track { fill: rgba(31, 60, 94, 0.6); }
.sa-bar-fill { fill: var(--sa-accent); }

/* ── Bus detail ───────────────────────────────────────────────────────────── */
.sa-bus { display: grid; gap: 0.55rem; }
.sa-bus-row { display: flex; justify-content: space-between; gap: 1rem; font-size: 0.85rem; }
.sa-bus-row span:first-child { color: var(--sa-muted); }
.sa-bus-row span:last-child { font-family: 'Spline Sans Mono', monospace; }

/* ── Event family colours ─────────────────────────────────────────────────── */
.gf-lead { background: #5ac8fa; }
.gf-quote { background: #c9923b; }
.gf-status { background: #26c6a8; }
.gf-certified { background: #7c5cff; }
.gf-doc { background: #4caf78; }
.gf-review { background: #f5b455; }
.gf-financer { background: #ff8a65; }
.gf-settled { background: #34d9ba; }
.gf-rate { background: #ec6f9c; }
.gf-default { background: #8ba0c0; }
.sa-ev-dot.gf-status, .sa-type-dot.gf-status { background: #26c6a8; }

/* ── Loading / spinner ────────────────────────────────────────────────────── */
.sa-loading { display: flex; justify-content: center; padding: 3rem 0; }
.sa-spinner {
  width: 28px; height: 28px; border-radius: 50%;
  border: 3px solid var(--sa-line);
  border-top-color: var(--sa-accent);
  animation: sa-spin 0.8s linear infinite;
}
@keyframes sa-spin { to { transform: rotate(360deg); } }

/* ── Responsive ───────────────────────────────────────────────────────────── */
@media (max-width: 860px) {
  .sa-kpis { grid-template-columns: repeat(2, 1fr); }
  .sa-grid { grid-template-columns: 1fr; }
}
@media (max-width: 520px) {
  .sa-brand-sub { display: none; }
  .sa-ev { grid-template-columns: auto 1fr auto; }
  .sa-ev-time { display: none; }
}
