/* =========================================================
   Finora Admin Panel — admin.css
   Helle Admin-Oberfläche, klare Dichte, Finora Grün/Carbon Akzente
   ========================================================= */

:root {
  --finora-blue: #14B86A;
  --finora-blue-dark: #0D7D4A;
  --finora-blue-soft: #EAFBF2;
  --finora-carbon: #0E1511;
  --finora-carbon-soft: #18241D;
  --finora-sky: #38BDF8;
  --finora-sky-soft: #E0F2FE;
  --finora-peach: #FB923C;
  --finora-peach-soft: #FFF1E6;
  --finora-bg: #F4F7F5;
  --finora-card: #FFFFFF;
  --finora-text: #0F172A;
  --finora-text-soft: #64748B;
  --finora-text-mute: #94A3B8;
  --finora-border: #E5E8F0;
  --finora-border-soft: #EFF1F6;
  --finora-success: #10B981;
  --finora-success-soft: #D1FAE5;
  --finora-warning: #F59E0B;
  --finora-warning-soft: #FEF3C7;
  --finora-danger:  #EF4444;
  --finora-danger-soft: #FEE2E2;
  --finora-purple:  #8B5CF6;
  --finora-purple-soft: #F3E8FF;
  --finora-cyan:    #06B6D4;
  --finora-cyan-soft: #CFFAFE;

  --shadow-sm: 0 1px 2px rgba(15,23,42,.06);
  --shadow-md: 0 4px 14px rgba(15,23,42,.08);
  --shadow-lg: 0 14px 40px rgba(15,23,42,.10);
  --shadow-green: 0 16px 36px rgba(20,184,106,.18);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; height: 100%; }
body {
  font: 14px/1.5 -apple-system, BlinkMacSystemFont, "Inter", "SF Pro Text", "Segoe UI", system-ui, sans-serif;
  color: var(--finora-text);
  background: var(--finora-bg);
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }
input, select, textarea { font: inherit; color: inherit; }
h1, h2, h3, h4 { margin: 0; letter-spacing: -.01em; }
p { margin: 0; }

/* ===== shell ===== */
.shell {
  display: grid;
  grid-template-columns: 248px 1fr;
  min-height: 100vh;
}

/* ===== sidebar ===== */
.side {
  background: #fff;
  border-right: 1px solid var(--finora-border);
  padding: 18px 14px;
  display: flex; flex-direction: column;
  gap: 18px;
  position: sticky; top: 0; align-self: start;
  height: 100vh;
  overflow-y: auto;
}
.side-brand {
  display: flex; align-items: center; gap: 10px;
  padding: 6px 8px;
  font-weight: 800; font-size: 16px;
}
.side-brand .brand-mark {
  width: 28px; height: 28px; border-radius: 8px; overflow: hidden;
}
.side-brand .brand-mark svg { width: 100%; height: 100%; display: block; }
.side-brand .brand-mark {
  background: transparent url("../assets/finora-logo-mark.png") center / contain no-repeat !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}
.side-brand .brand-mark svg,
.side-brand .brand-mark::after {
  display: none !important;
}
.side-brand .brand-tag {
  margin-left: auto;
  font-size: 10px; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--finora-blue);
  background: var(--finora-blue-soft);
  padding: 3px 8px; border-radius: 999px;
}

.side-group {
  display: flex; flex-direction: column; gap: 2px;
}
.side-group-title {
  padding: 8px 12px 4px;
  font-size: 10px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--finora-text-mute);
}
.nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px;
  border-radius: 8px;
  color: var(--finora-text-soft);
  font-weight: 600; font-size: 13.5px;
  transition: background .12s, color .12s;
}
.nav-item .ic {
  width: 18px; height: 18px;
  display: grid; place-items: center;
  color: var(--finora-text-mute);
}
.nav-item .ic svg { width: 16px; height: 16px; }
.nav-item:hover { background: var(--finora-border-soft); color: var(--finora-text); }
.nav-item.active {
  background: var(--finora-blue-soft);
  color: var(--finora-blue);
}
.nav-item.active .ic { color: var(--finora-blue); }
.nav-item .pill {
  margin-left: auto;
  font-size: 10px; font-weight: 800;
  padding: 2px 6px;
  border-radius: 999px;
  background: var(--finora-danger-soft);
  color: var(--finora-danger);
}

.side-user {
  margin-top: auto;
  padding: 10px 12px;
  border-radius: 10px;
  background: var(--finora-bg);
  border: 1px solid var(--finora-border-soft);
  display: flex; align-items: center; gap: 10px;
}
.avatar {
  width: 30px; height: 30px; border-radius: 50%;
  background: linear-gradient(135deg, var(--finora-blue), var(--finora-purple));
  color: #fff; font-weight: 800; font-size: 12px;
  display: grid; place-items: center;
}
.side-user .name { font-weight: 700; font-size: 13px; }
.side-user .role { font-size: 11px; color: var(--finora-text-mute); }

/* ===== main ===== */
.main {
  display: flex; flex-direction: column;
  min-width: 0;
}
.topbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px;
  padding: 14px 28px;
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--finora-border-soft);
  position: sticky; top: 0; z-index: 20;
}
.topbar-title { display: flex; align-items: baseline; gap: 12px; }
.topbar-title h1 { font-size: 18px; font-weight: 800; }
.topbar-title .crumb { font-size: 12px; color: var(--finora-text-mute); }

.topbar-tools { display: flex; align-items: center; gap: 10px; }
.search {
  display: flex; align-items: center; gap: 8px;
  background: #fff; border: 1px solid var(--finora-border);
  border-radius: 10px;
  padding: 7px 12px;
  width: 280px;
  color: var(--finora-text-soft);
  font-size: 13px;
}
.search input { border: none; outline: none; background: none; width: 100%; }
.iconbtn {
  width: 34px; height: 34px;
  border-radius: 10px;
  border: 1px solid var(--finora-border);
  background: #fff;
  display: grid; place-items: center;
  color: var(--finora-text-soft);
  position: relative;
}
.iconbtn:hover { color: var(--finora-text); border-color: var(--finora-text-mute); }
.iconbtn .bell-dot {
  position: absolute; top: 6px; right: 7px;
  width: 8px; height: 8px;
  background: var(--finora-danger);
  border-radius: 50%; border: 2px solid #fff;
}

.content { padding: 24px 28px 56px; max-width: 1400px; }

/* ===== buttons (admin) ===== */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 8px 14px;
  border-radius: 9px;
  font-weight: 600;
  font-size: 13px;
  transition: background .12s, color .12s, border-color .12s, box-shadow .12s;
  border: 1px solid transparent;
  white-space: nowrap;
}
.btn-primary { background: var(--finora-blue); color: #fff; box-shadow: 0 4px 12px rgba(20,184,106,.22); }
.btn-primary:hover { background: var(--finora-blue-dark); box-shadow: var(--shadow-green); }
.btn-ghost   { background: #fff; color: var(--finora-text); border-color: var(--finora-border); }
.btn-ghost:hover { border-color: var(--finora-text-mute); }
.btn-danger  { background: var(--finora-danger); color: #fff; }
.btn-danger:hover { background: #DC2626; }
.btn-warning { background: var(--finora-warning); color: #fff; }
.btn-sm      { padding: 5px 10px; font-size: 12px; border-radius: 8px; }

/* ===== page header ===== */
.page-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 24px; margin-bottom: 22px;
}
.page-head h2 { font-size: 22px; font-weight: 800; }
.page-head .lead { color: var(--finora-text-soft); font-size: 14px; margin-top: 4px; }
.page-actions { display: flex; gap: 10px; }

/* ===== admin command center ===== */
.admin-command-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  padding: 22px;
  margin-bottom: 22px;
  border-radius: 22px;
  border: 1px solid rgba(20,184,106,.18);
  background:
    linear-gradient(135deg, rgba(14,21,17,.98), rgba(24,36,29,.96) 48%, rgba(15,23,42,.94)),
    #0E1511;
  color: #fff;
  box-shadow: 0 22px 56px rgba(15,23,42,.18);
  position: relative;
  overflow: hidden;
}
.admin-command-panel::before {
  content: "";
  position: absolute;
  inset: -80px -120px auto auto;
  width: 320px;
  height: 320px;
  background: radial-gradient(circle, rgba(120,255,53,.32), transparent 62%);
  pointer-events: none;
}
.admin-command-copy,
.admin-command-actions,
.admin-command-metrics { position: relative; z-index: 1; }
.admin-command-copy .eyebrow {
  display: inline-flex;
  margin-bottom: 8px;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: #78FF35;
}
.admin-command-copy h2 {
  max-width: 760px;
  font-size: clamp(25px, 3vw, 38px);
  line-height: 1.08;
  letter-spacing: -.03em;
}
.admin-command-copy p {
  max-width: 760px;
  margin-top: 10px;
  color: rgba(255,255,255,.74);
  font-size: 14px;
  line-height: 1.65;
}
.admin-command-actions {
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}
.admin-command-actions .btn-primary {
  background: #78FF35;
  color: #07100B;
  border-color: transparent;
  box-shadow: 0 16px 34px rgba(120,255,53,.18);
}
.admin-command-actions .btn-ghost {
  color: #fff;
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.18);
}
.admin-command-metrics {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.admin-command-metrics > div {
  padding: 13px 14px;
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 15px;
  background: rgba(255,255,255,.08);
}
.admin-command-metrics span,
.account-generator-result span {
  display: block;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .11em;
  text-transform: uppercase;
}
.admin-command-metrics span { color: rgba(255,255,255,.56); }
.admin-command-metrics strong {
  display: block;
  margin-top: 2px;
  font-size: 16px;
}
.admin-command-metrics small {
  display: block;
  margin-top: 2px;
  color: rgba(255,255,255,.62);
}
.account-command-panel { margin-bottom: 16px; }

.account-generator-result {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 16px;
  margin-bottom: 16px;
  border-radius: 16px;
  border: 1px solid rgba(20,184,106,.24);
  background: linear-gradient(135deg, #F0FFF6, #FFFFFF);
  box-shadow: var(--shadow-sm);
}
.account-generator-result[hidden] { display: none; }
.account-generator-result.compact {
  margin: 0;
  grid-template-columns: 1fr;
}
.account-generator-result span { color: var(--finora-blue-dark); }
.account-generator-result strong {
  display: block;
  margin-top: 2px;
  font-size: 17px;
}
.account-generator-result p {
  margin-top: 4px;
  color: var(--finora-text-soft);
}
.account-generator-result .handoff-security {
  color: var(--finora-green-dark);
  font-weight: 700;
}
.handoff-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 9px;
  margin-top: 10px;
}
.handoff-grid code {
  display: block;
  padding: 9px 10px;
  border: 1px solid var(--finora-border);
  border-radius: 10px;
  background: #fff;
  color: var(--finora-text);
  font-size: 12px;
  overflow: auto;
}
.generator-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.generator-presets {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.preset-card {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--finora-border);
  border-radius: 13px;
  background: #fff;
  cursor: pointer;
  transition: border-color .12s, box-shadow .12s, background .12s;
}
.preset-card:hover {
  border-color: rgba(20,184,106,.5);
  box-shadow: var(--shadow-sm);
}
.preset-card input {
  width: 16px;
  height: 16px;
  margin-top: 2px;
  accent-color: var(--finora-blue);
}
.preset-card:has(input:checked) {
  border-color: rgba(20,184,106,.55);
  background: var(--finora-blue-soft);
  box-shadow: 0 0 0 3px rgba(20,184,106,.1);
}
.preset-card strong,
.preset-card small { display: block; }
.preset-card small {
  margin-top: 2px;
  color: var(--finora-text-soft);
  font-size: 11px;
}

/* ===== cards ===== */
.card {
  background: var(--finora-card);
  border: 1px solid var(--finora-border);
  border-radius: 14px;
  box-shadow: var(--shadow-sm);
}
.card-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--finora-border-soft);
}
.card-head h3 { font-size: 14px; font-weight: 700; }
.card-head .sub { color: var(--finora-text-mute); font-size: 12px; }
.card-body { padding: 18px; }

/* ===== stat tiles ===== */
.stat-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px;
  margin-bottom: 22px;
}
.stat {
  background: #fff; border: 1px solid var(--finora-border);
  border-radius: 14px; padding: 16px 18px;
  display: flex; flex-direction: column; gap: 6px;
  position: relative;
}
.stat .label { font-size: 11px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--finora-text-mute); }
.stat .value { font-size: 26px; font-weight: 800; letter-spacing: -.02em; }
.stat .meta  { font-size: 12px; color: var(--finora-text-soft); }
.stat .trend { font-size: 12px; font-weight: 700; }
.stat .trend.up   { color: var(--finora-success); }
.stat .trend.down { color: var(--finora-danger); }
.stat .ic {
  position: absolute; top: 14px; right: 14px;
  width: 28px; height: 28px; border-radius: 8px;
  display: grid; place-items: center;
}
.stat .ic.blue   { background: var(--finora-blue-soft);    color: var(--finora-blue); }
.stat .ic.green  { background: var(--finora-success-soft); color: var(--finora-success); }
.stat .ic.peach  { background: var(--finora-peach-soft);   color: var(--finora-peach); }
.stat .ic.purple { background: var(--finora-purple-soft);  color: var(--finora-purple); }
.stat .ic.cyan   { background: var(--finora-cyan-soft);    color: var(--finora-cyan); }
.stat .ic.warn   { background: var(--finora-warning-soft); color: var(--finora-warning); }
.stat .ic.red    { background: var(--finora-danger-soft);  color: var(--finora-danger); }

.billing-panel {
  margin-bottom: 22px;
  padding: 18px;
  border-radius: 18px;
  border: 1px solid rgba(61,99,245,.16);
  background:
    radial-gradient(circle at top left, rgba(61,99,245,.13), transparent 28%),
    radial-gradient(circle at bottom right, rgba(251,146,60,.16), transparent 32%),
    #fff;
  box-shadow: var(--shadow-sm);
}
.billing-hero {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 18px;
  margin-bottom: 16px;
}
.billing-hero .eyebrow {
  display: inline-flex;
  margin-bottom: 5px;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--finora-blue);
}
.billing-hero h2 { font-size: 21px; }
.billing-hero p { margin-top: 4px; max-width: 720px; color: var(--finora-text-soft); font-size: 13px; }
.billing-metrics {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px;
  margin-bottom: 18px;
}
.billing-metric {
  padding: 13px 14px;
  border-radius: 14px;
  background: rgba(255,255,255,.78);
  border: 1px solid var(--finora-border-soft);
}
.billing-metric span { display: block; font-size: 10px; font-weight: 800; letter-spacing: .09em; text-transform: uppercase; color: var(--finora-text-mute); }
.billing-metric strong { display: block; margin-top: 3px; font-size: 22px; letter-spacing: -.02em; }
.billing-metric small { color: var(--finora-text-soft); }
.billing-metric.good strong { color: var(--finora-success); }
.profit-chart {
  display: grid;
  grid-template-columns: repeat(6, minmax(74px, 1fr));
  gap: 10px;
  min-height: 180px;
}
.profit-month {
  display: grid;
  grid-template-rows: 1fr auto auto;
  gap: 7px;
  min-height: 176px;
  padding: 10px;
  border: 1px solid var(--finora-border-soft);
  border-radius: 14px;
  background: rgba(255,255,255,.76);
}
.profit-bars {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 5px;
  min-height: 112px;
}
.profit-bar {
  width: 16px;
  border-radius: 999px 999px 4px 4px;
  background: var(--finora-border);
}
.profit-bar.revenue { background: linear-gradient(to top, var(--finora-blue), #8EA2FF); }
.profit-bar.ai { background: linear-gradient(to top, var(--finora-peach), #FDBA74); }
.profit-bar.profit { background: linear-gradient(to top, var(--finora-success), #6EE7B7); }
.profit-month strong { text-align: center; font-size: 12px; color: var(--finora-text-soft); }
.profit-month small { text-align: center; font-weight: 800; font-size: 12px; }
.chart-empty { color: var(--finora-text-soft); font-size: 13px; }

.usage-calculator-panel {
  margin-bottom: 22px;
  padding: 18px;
  border-radius: 18px;
  border: 1px solid rgba(20,184,106,.2);
  background:
    linear-gradient(135deg, rgba(234,251,242,.9), rgba(255,255,255,.92) 46%, rgba(224,242,254,.76)),
    #fff;
  box-shadow: var(--shadow-sm);
}
.usage-calculator-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}
.usage-calculator-head .eyebrow {
  display: inline-flex;
  margin-bottom: 5px;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--finora-blue-dark);
}
.usage-calculator-head h2 {
  max-width: 780px;
  font-size: 22px;
}
.usage-calculator-head p {
  max-width: 820px;
  margin-top: 4px;
  color: var(--finora-text-soft);
  font-size: 13px;
}
.usage-card-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
}
.usage-card,
.usage-formula-strip > div {
  padding: 13px 14px;
  border-radius: 14px;
  background: rgba(255,255,255,.86);
  border: 1px solid var(--finora-border-soft);
  box-shadow: 0 1px 2px rgba(15,23,42,.04);
}
.usage-card span,
.usage-formula-strip span {
  display: block;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--finora-text-mute);
}
.usage-card strong,
.usage-formula-strip strong {
  display: block;
  margin-top: 3px;
  font-size: 21px;
  letter-spacing: -.02em;
}
.usage-card small,
.usage-formula-strip small {
  display: block;
  margin-top: 2px;
  color: var(--finora-text-soft);
  font-size: 11.5px;
}
.usage-formula-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 10px;
}
.admin-security-grid {
  margin-bottom: 22px;
}
.admin-ai-grid {
  margin-bottom: 18px;
}
.ai-policy-stack,
.ai-surface-list {
  display: grid;
  gap: 10px;
}
.ai-policy-row,
.ai-surface-row {
  display: grid;
  gap: 4px;
  padding: 12px;
  border: 1px solid var(--finora-border-soft);
  border-radius: 12px;
  background: rgba(255,255,255,.86);
}
.ai-policy-row span,
.ai-policy-row small,
.ai-surface-row small,
.ai-security-metrics span {
  color: var(--finora-text-soft);
  font-size: 11.5px;
}
.ai-policy-row strong,
.ai-surface-copy strong {
  color: var(--finora-text);
  font-size: 13.5px;
}
.ai-policy-note {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  margin-top: 10px;
  color: var(--finora-text-soft);
  font-size: 11.5px;
}
.ai-surface-row {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}
.ai-surface-copy {
  min-width: 0;
  display: grid;
  gap: 2px;
}
.ai-surface-copy small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ai-switch {
  width: 42px;
  height: 24px;
  border: 0;
  border-radius: 999px;
  background: var(--finora-danger-soft);
  color: transparent;
  cursor: pointer;
  position: relative;
  transition: background .18s ease, opacity .18s ease;
}
.ai-switch::after {
  content: "";
  position: absolute;
  width: 18px;
  height: 18px;
  left: 3px;
  top: 3px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 2px 7px rgba(15,23,42,.18);
  transition: transform .18s ease;
}
.ai-switch[aria-pressed="true"] {
  background: var(--finora-success);
}
.ai-switch[aria-pressed="true"]::after {
  transform: translateX(18px);
}
.ai-switch:disabled {
  cursor: progress;
  opacity: .62;
}
.ai-security-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 10px;
}
.ai-security-metrics > div {
  padding: 10px;
  border: 1px solid var(--finora-border-soft);
  border-radius: 12px;
  background: var(--finora-bg);
}
.ai-security-metrics strong {
  display: block;
  margin-top: 2px;
  font-size: 18px;
}
.ai-security-scroll {
  max-height: 245px;
  overflow: auto;
}
.ai-security-table td {
  vertical-align: top;
}
.ai-security-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
  background: var(--finora-warning-soft);
  color: var(--finora-warning);
}
.ai-security-chip.danger {
  background: var(--finora-danger-soft);
  color: var(--finora-danger);
}
.security-table .country-chip {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 4px 9px;
  border-radius: 999px;
  background: var(--finora-bg);
  color: var(--finora-text);
  font-weight: 700;
  white-space: nowrap;
}
.security-table .location-chip {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  max-width: 260px;
  padding: 7px 10px;
  border: 1px solid var(--finora-border-soft);
  border-radius: 14px;
  background: linear-gradient(135deg, #fff, var(--finora-bg));
}
.location-flag {
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  border-radius: 10px;
  background: #fff;
  border: 1px solid var(--finora-border-soft);
  font-size: 16px;
}
.location-copy {
  display: grid;
  gap: 1px;
  min-width: 0;
}
.location-copy strong,
.location-copy small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.location-copy strong {
  color: var(--finora-text);
  font-size: 12.5px;
}
.location-copy small {
  color: var(--finora-text-soft);
  font-size: 11px;
}
.session-stack {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.session-card {
  padding: 12px;
  border: 1px solid var(--finora-border-soft);
  border-radius: 14px;
  background: #FBFCFE;
}
.session-card.current {
  border-color: rgba(20,184,106,.32);
  background: linear-gradient(135deg, var(--finora-blue-soft), #fff);
}
.session-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}
.session-top strong,
.session-top span {
  display: block;
}
.session-top strong {
  font-size: 13px;
}
.session-top span {
  margin-top: 1px;
  color: var(--finora-text-soft);
  font-size: 11.5px;
}
.country-flag {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 11px;
  background: #fff;
  border: 1px solid var(--finora-border-soft);
  font-size: 17px;
}
.session-meta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5px 8px;
  margin-top: 10px;
  color: var(--finora-text-soft);
  font-size: 11.5px;
}
.session-meta span:last-child {
  grid-column: 1 / -1;
}

.account-money-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin: 0 0 14px;
}
.account-money-strip > div {
  padding: 12px 14px;
  border-radius: 13px;
  background: #fff;
  border: 1px solid var(--finora-border);
  box-shadow: var(--shadow-sm);
}
.account-money-strip span {
  display: block;
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--finora-text-mute);
}
.account-money-strip strong { display: block; margin-top: 2px; font-size: 18px; }
.money-cell { display: grid; gap: 1px; min-width: 116px; }
.money-cell strong { font-size: 13px; }
.money-cell span { font-size: 11px; color: var(--finora-text-soft); white-space: nowrap; }
.danger-link { color: var(--finora-danger); }
.account-mini-line {
  margin-top: 3px;
  color: var(--finora-text-mute);
  font-size: 11px;
}
.access-cell {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  min-width: 110px;
}
.access-cell > span {
  color: var(--finora-text-soft);
  font-size: 11px;
  font-weight: 700;
}
.account-edit-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 12px;
  background: var(--finora-blue-soft);
  color: var(--finora-blue);
  font-size: 12px;
}
.account-edit-summary span { color: var(--finora-text-soft); }
.feature-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.feature-grid.compact {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.feature-toggle {
  display: grid;
  grid-template-columns: 18px 1fr auto;
  align-items: center;
  gap: 10px;
  min-height: 72px;
  padding: 12px;
  border-radius: 12px;
  border: 1px solid var(--finora-border);
  background: #fff;
  transition: border-color .12s, background .12s, box-shadow .12s;
}
.feature-toggle:hover {
  border-color: rgba(61,99,245,.34);
  box-shadow: var(--shadow-sm);
}
.feature-toggle.active {
  background: linear-gradient(135deg, rgba(61,99,245,.08), rgba(16,185,129,.08));
  border-color: rgba(61,99,245,.28);
}
.feature-toggle.locked {
  background: #FAFBFE;
}
.feature-toggle input {
  width: 17px;
  height: 17px;
  accent-color: var(--finora-blue);
}
.feature-toggle-copy {
  display: grid;
  gap: 3px;
}
.feature-toggle-copy strong {
  font-size: 13px;
}
.feature-toggle-copy small {
  color: var(--finora-text-soft);
  font-size: 11.5px;
  line-height: 1.35;
}
.feature-toggle-state {
  justify-self: end;
  min-width: 38px;
  padding: 3px 8px;
  border-radius: 999px;
  background: var(--finora-bg);
  color: var(--finora-text-soft);
  font-size: 10.5px;
  font-weight: 800;
  text-align: center;
}
.feature-toggle.active .feature-toggle-state {
  background: var(--finora-success-soft);
  color: var(--finora-success);
}
.admin-session-card {
  border-color: var(--finora-border);
}
.session-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 10px;
}

/* ===== grid layouts ===== */
.grid-12 { display: grid; grid-template-columns: repeat(12, 1fr); gap: 14px; }
.grid-12 > .card { min-width: 0; }
.col-8 { grid-column: span 8; }
.col-7 { grid-column: span 7; }
.col-6 { grid-column: span 6; }
.col-5 { grid-column: span 5; }
.col-4 { grid-column: span 4; }
.col-12 { grid-column: span 12; }

/* ===== tables ===== */
.tbl {
  width: 100%; border-collapse: collapse;
  font-size: 13px;
}
.tbl th, .tbl td {
  padding: 11px 14px;
  border-bottom: 1px solid var(--finora-border-soft);
  text-align: left;
  vertical-align: middle;
}
.tbl thead th {
  font-size: 11px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
  color: var(--finora-text-mute);
  background: #FAFBFE;
}
.tbl tbody tr { transition: background .1s; }
.tbl tbody tr:hover { background: #FAFBFE; }
.tbl tbody tr.account-row-focus {
  background: #FFF7ED;
  box-shadow: inset 4px 0 0 #F97316;
}
.tbl tbody tr.account-row-focus:hover {
  background: #FFEDD5;
}
.tbl .cell-strong { font-weight: 700; }
.tbl .cell-mute   { color: var(--finora-text-soft); }
.tbl .row-actions {
  display: flex; gap: 6px; justify-content: flex-end;
}
.tbl .row-actions .btn-sm { padding: 4px 9px; }

.tbl-wrap { overflow: auto; }

.ops-offsite-setup {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 12px 0;
  padding: 12px 14px;
  border-radius: 8px;
  border: 1px solid #BFDBFE;
  background: #EFF6FF;
  color: #1D4ED8;
}
.ops-offsite-setup[hidden] {
  display: none;
}
.ops-offsite-setup.is-required {
  border-color: #FED7AA;
  background: #FFF7ED;
  color: #9A3412;
}
.ops-offsite-setup > div {
  display: grid;
  gap: 3px;
  min-width: 0;
}
.ops-offsite-setup strong {
  font-size: 12px;
  font-weight: 900;
}
.ops-offsite-setup span {
  color: inherit;
  font-size: 11px;
  line-height: 1.45;
}

/* ===== badges ===== */
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 9px;
  border-radius: 999px;
  font-size: 11px; font-weight: 700;
  letter-spacing: .02em;
}
.badge .dot { width: 6px; height: 6px; border-radius: 50%; }
.badge-success { background: var(--finora-success-soft); color: var(--finora-success); }
.badge-success .dot { background: var(--finora-success); }
.badge-warn    { background: var(--finora-warning-soft); color: var(--finora-warning); }
.badge-warn .dot { background: var(--finora-warning); }
.badge-danger  { background: var(--finora-danger-soft); color: var(--finora-danger); }
.badge-danger .dot { background: var(--finora-danger); }
.badge-info    { background: var(--finora-blue-soft); color: var(--finora-blue); }
.badge-info .dot { background: var(--finora-blue); }
.badge-mute    { background: var(--finora-bg); color: var(--finora-text-soft); }
.badge-mute .dot { background: var(--finora-text-soft); }
.badge-purple  { background: var(--finora-purple-soft); color: var(--finora-purple); }
.badge-purple .dot { background: var(--finora-purple); }

/* ===== role chip ===== */
.role-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 9px; border-radius: 6px;
  font-size: 11px; font-weight: 700;
  background: var(--finora-bg);
  color: var(--finora-text-soft);
  border: 1px solid var(--finora-border);
}
.role-chip.owner   { background: var(--finora-blue-soft);    color: var(--finora-blue);    border-color: transparent; }
.role-chip.admin   { background: var(--finora-purple-soft);  color: var(--finora-purple);  border-color: transparent; }
.role-chip.support { background: var(--finora-cyan-soft);    color: var(--finora-cyan);    border-color: transparent; }
.role-chip.buch    { background: var(--finora-peach-soft);   color: var(--finora-peach);   border-color: transparent; }
.role-chip.staff   { background: var(--finora-success-soft); color: var(--finora-success); border-color: transparent; }
.role-chip.readonly{ background: var(--finora-bg);           color: var(--finora-text-soft); }

/* ===== privacy banner ===== */
.privacy {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px;
  background: var(--finora-warning-soft);
  border: 1px solid #FDE68A;
  color: #92400E;
  border-radius: 12px;
  font-size: 13px;
  margin-bottom: 18px;
}
.privacy .ic {
  width: 28px; height: 28px; border-radius: 8px;
  display: grid; place-items: center;
  background: rgba(255,255,255,.6);
  color: var(--finora-warning);
}

/* ===== timeline (audit / activity) ===== */
.timeline { display: flex; flex-direction: column; gap: 14px; padding: 4px 4px 4px 10px; }
.tl-item {
  display: grid; grid-template-columns: 28px 1fr auto; gap: 12px;
  align-items: start;
}
.tl-ic {
  width: 28px; height: 28px; border-radius: 8px;
  display: grid; place-items: center;
  background: var(--finora-blue-soft); color: var(--finora-blue);
  font-weight: 700; font-size: 13px;
}
.tl-ic.green { background: var(--finora-success-soft); color: var(--finora-success); }
.tl-ic.warn  { background: var(--finora-warning-soft); color: var(--finora-warning); }
.tl-ic.red   { background: var(--finora-danger-soft);  color: var(--finora-danger); }
.tl-ic.purple{ background: var(--finora-purple-soft);  color: var(--finora-purple); }
.tl-body .t { font-weight: 700; font-size: 13px; }
.tl-body .d { font-size: 12px; color: var(--finora-text-soft); margin-top: 2px; }
.tl-time { font-size: 11px; color: var(--finora-text-mute); white-space: nowrap; padding-top: 4px; }

/* ===== mini bar / chart ===== */
.bar-chart { display: flex; align-items: flex-end; gap: 6px; height: 140px; padding: 4px 0; }
.bar {
  flex: 1;
  background: linear-gradient(to top, var(--finora-blue), #7B92F8);
  border-radius: 6px 6px 2px 2px;
  position: relative;
  min-width: 0;
}
.bar .bar-label {
  position: absolute; bottom: -18px;
  width: 100%; text-align: center;
  font-size: 10px; color: var(--finora-text-mute);
}
.bar.peach { background: linear-gradient(to top, var(--finora-peach), #FCB373); }

.chart-row { display: flex; align-items: center; gap: 10px; padding: 6px 0; }
.chart-row .label { width: 140px; font-size: 12px; color: var(--finora-text-soft); }
.chart-row .label strong { display: block; color: var(--finora-text); font-size: 12px; line-height: 1.2; }
.chart-row .label small { display: block; margin-top: 2px; color: var(--finora-text-mute); font-size: 10px; line-height: 1.2; }
.chart-row .meter { flex: 1; height: 8px; background: var(--finora-border-soft); border-radius: 4px; overflow: hidden; }
.chart-row .meter > span { display: block; height: 100%; background: var(--finora-blue); border-radius: 4px; }
.chart-row .meter > span.peach { background: var(--finora-peach); }
.chart-row .meter > span.green { background: var(--finora-success); }
.chart-row .num { width: 56px; text-align: right; font-weight: 700; font-size: 12px; }
.traffic-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 12px;
}
.traffic-summary div {
  padding: 10px;
  border-radius: 12px;
  background: var(--finora-bg-soft);
  border: 1px solid var(--finora-border-soft);
}
.traffic-summary span {
  display: block;
  color: var(--finora-text-soft);
  font-size: 10px;
  line-height: 1.2;
}
.traffic-summary strong {
  display: block;
  margin-top: 4px;
  font-size: 18px;
  line-height: 1.1;
}
.traffic-row .label { width: 150px; }
.traffic-note {
  margin-top: 10px;
  color: var(--finora-text-soft);
  font-size: 11px;
  line-height: 1.45;
}

/* ===== filters ===== */
.filters {
  display: flex; gap: 8px; flex-wrap: wrap;
  margin-bottom: 14px;
}
.filters .chip {
  padding: 6px 11px;
  background: #fff; border: 1px solid var(--finora-border);
  border-radius: 999px;
  font-size: 12.5px; font-weight: 600;
  color: var(--finora-text-soft);
  transition: background .1s, border-color .1s, color .1s;
}
.filters .chip:hover { color: var(--finora-text); border-color: var(--finora-text-mute); }
.filters .chip.active {
  background: var(--finora-blue-soft); color: var(--finora-blue); border-color: transparent;
}

.input, .select {
  background: #fff; border: 1px solid var(--finora-border);
  border-radius: 9px; padding: 8px 11px;
  font-size: 13px;
  width: 100%;
  outline: none;
  transition: border-color .12s, box-shadow .12s;
}
.input:focus, .select:focus, textarea.input:focus {
  border-color: var(--finora-blue);
  box-shadow: 0 0 0 3px rgba(61,99,245,.16);
}
.field { display: flex; flex-direction: column; gap: 6px; }
.field label { font-size: 12px; font-weight: 700; color: var(--finora-text-soft); }
.field .hint { font-size: 11px; color: var(--finora-text-mute); }
.req { color: var(--finora-danger); }

/* ===== modal ===== */
.modal-overlay {
  position: fixed; inset: 0;
  background: rgba(15,23,42,.42);
  z-index: 100;
  display: grid; place-items: center;
  padding: 20px;
  opacity: 0;
  transition: opacity .15s;
}
.modal-overlay[hidden] { display: none; }
.modal-overlay.show { opacity: 1; }

.modal {
  width: min(520px, 100%);
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 30px 80px rgba(15,23,42,.32);
  border: 1px solid var(--finora-border);
  display: flex; flex-direction: column;
  max-height: calc(100vh - 40px);
  overflow: hidden;
  transform: scale(.96) translateY(8px);
  opacity: 0;
  transition: transform .15s, opacity .15s;
}
.modal-overlay.show .modal { transform: none; opacity: 1; }
.modal.wide { width: min(720px, 100%); }
.modal-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 18px 20px;
  border-bottom: 1px solid var(--finora-border-soft);
  flex-shrink: 0;
}
.modal-head h3 { font-size: 17px; font-weight: 800; }
.modal-head .sub { font-size: 12px; color: var(--finora-text-soft); margin-top: 4px; max-width: 420px; }
.modal-close {
  width: 32px; height: 32px; border-radius: 8px;
  display: grid; place-items: center;
  font-size: 20px; line-height: 1;
  color: var(--finora-text-soft);
  flex-shrink: 0;
}
.modal-close:hover { background: var(--finora-bg); color: var(--finora-text); }
.modal-body {
  padding: 18px 20px;
  overflow: auto;
  display: flex; flex-direction: column; gap: 14px;
  min-height: 0;
  flex: 1 1 auto;
  max-height: calc(100vh - 260px);
}
.modal-foot {
  display: flex; justify-content: space-between; align-items: center; gap: 10px;
  padding: 14px 20px;
  border-top: 1px solid var(--finora-border-soft);
  background: #FAFBFE;
  flex-shrink: 0;
}
.modal-foot .left { font-size: 11px; color: var(--finora-text-mute); }
.modal-foot .right { display: flex; gap: 8px; }

.modal-warning {
  display: flex; gap: 12px;
  padding: 12px 14px;
  background: var(--finora-warning-soft);
  border: 1px solid #FDE68A;
  color: #92400E;
  border-radius: 10px;
  font-size: 12.5px;
}
.modal-warning.danger {
  background: var(--finora-danger-soft);
  border-color: #FECACA;
  color: #991B1B;
}
.modal-warning .ic {
  width: 22px; height: 22px; flex-shrink: 0;
  border-radius: 6px;
  background: rgba(255,255,255,.6);
  display: grid; place-items: center; font-weight: 800;
}

.check-line {
  display: flex; align-items: center; gap: 10px;
  font-size: 13px;
  color: var(--finora-text-soft);
}
.check-line input { width: 16px; height: 16px; accent-color: var(--finora-blue); }

/* ===== toast ===== */
.toast-stack {
  position: fixed; bottom: 22px; right: 22px;
  z-index: 200;
  display: flex; flex-direction: column; gap: 8px;
}
.toast {
  background: #0F172A; color: #fff;
  padding: 10px 14px; border-radius: 10px;
  font-size: 13px; font-weight: 600;
  box-shadow: 0 14px 28px rgba(15,23,42,.32);
  display: flex; align-items: center; gap: 10px;
  animation: toast-in .2s ease-out;
}
.toast.success { background: var(--finora-success); }
.toast.warn    { background: var(--finora-warning); }
.toast.danger  { background: var(--finora-danger); }
@keyframes toast-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: none; }
}

/* ===== empty / health items ===== */
.health-list { display: flex; flex-direction: column; gap: 8px; }
.health-row {
  display: grid; grid-template-columns: 32px 1fr auto auto; align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border: 1px solid var(--finora-border-soft);
  border-radius: 10px;
  background: #FBFCFE;
}
.health-row .h-ic {
  width: 32px; height: 32px; border-radius: 8px;
  display: grid; place-items: center;
  background: var(--finora-blue-soft); color: var(--finora-blue);
  font-weight: 800;
}
.health-row .h-name { font-weight: 700; font-size: 13.5px; }
.health-row .h-meta { font-size: 12px; color: var(--finora-text-soft); }
.health-row .h-num  { font-variant-numeric: tabular-nums; font-weight: 700; }
.health-row-danger .h-ic { background: var(--finora-danger-soft); color: var(--finora-danger); }
.health-row-warn .h-ic { background: var(--finora-warning-soft); color: var(--finora-warning); }

.ops-banner {
  margin-bottom: 18px;
}
.ops-agent-gate-card {
  margin-bottom: 18px;
  border-left: 5px solid var(--finora-border);
}
.ops-agent-gate-card.ops-agent-gate-ok { border-left-color: var(--finora-success); }
.ops-agent-gate-card.ops-agent-gate-warn { border-left-color: var(--finora-warning); }
.ops-agent-gate-card.ops-agent-gate-danger { border-left-color: var(--finora-danger); }
.ops-agent-gate-summary {
  display: grid;
  gap: 4px;
  margin-bottom: 14px;
}
.ops-agent-gate-summary strong {
  font-size: 15px;
  font-weight: 800;
}
.ops-agent-gate-summary span,
.ops-agent-gate-metrics small {
  color: var(--finora-text-soft);
}
.ops-agent-gate-checks {
  margin-top: 14px;
}
.ops-readiness-card {
  margin-bottom: 18px;
  border-left: 5px solid var(--finora-border);
}
.ops-readiness-card.ops-readiness-ok { border-left-color: var(--finora-success); }
.ops-readiness-card.ops-readiness-warn { border-left-color: var(--finora-warning); }
.ops-readiness-card.ops-readiness-danger { border-left-color: var(--finora-danger); }
.ops-readiness-summary {
  display: grid;
  grid-template-columns: 86px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  margin-bottom: 14px;
}
.ops-readiness-score {
  width: 74px;
  height: 74px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: #F8FAFC;
  border: 1px solid var(--finora-border-soft);
  color: var(--finora-carbon);
  font-size: 22px;
  font-weight: 900;
  font-variant-numeric: tabular-nums;
}
.ops-readiness-summary strong {
  display: block;
  font-size: 15px;
  font-weight: 800;
}
.ops-readiness-summary span,
.ops-readiness-metrics small,
.ops-readiness-sections small {
  color: var(--finora-text-soft);
}
.ops-readiness-sections {
  margin-top: 14px;
}
.ops-readiness-sections .ops-check div:last-child {
  display: grid;
  gap: 2px;
}
.ops-readiness-sections small {
  font-size: 11px;
}
.ops-readiness-items {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin: 4px 0;
}
.ops-readiness-items span,
.ops-readiness-items a,
.ops-readiness-items button {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  max-width: 100%;
  padding: 4px 8px;
  border-radius: 7px;
  background: #FFF7ED;
  border: 1px solid #FED7AA;
  color: #9A3412;
  font-size: 11px;
  font-weight: 800;
  text-decoration: none;
}
.ops-readiness-items button {
  cursor: pointer;
  font-family: inherit;
}
.ops-readiness-items a:hover,
.ops-readiness-items button:hover {
  background: #FFEDD5;
  border-color: #FDBA74;
}
.ops-readiness-items em {
  max-width: min(220px, 52vw);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: #9A3412;
  font-style: normal;
  font-weight: 700;
}
.ops-readiness-items small {
  padding: 2px 6px;
  border-radius: 999px;
  background: #FFFFFF;
  border: 1px solid #FED7AA;
  color: #9A3412;
  font-size: 10px;
  font-weight: 900;
}
.ops-banner .card-body {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.ops-status-head {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 260px;
}
.ops-status-icon {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  font-weight: 800;
  background: var(--finora-blue-soft);
  color: var(--finora-blue);
}
.ops-banner-ok .ops-status-icon {
  background: var(--finora-success-soft);
  color: var(--finora-success);
}
.ops-banner-warn .ops-status-icon {
  background: var(--finora-warning-soft);
  color: var(--finora-warning);
}
.ops-banner-danger .ops-status-icon {
  background: var(--finora-danger-soft);
  color: var(--finora-danger);
}
.ops-status-title {
  font-weight: 800;
  font-size: 15px;
}
.ops-status-detail {
  color: var(--finora-text-soft);
  font-size: 13px;
}
.ops-status-actions {
  margin-left: auto;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.ops-inline-metrics {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}
.ops-inline-metrics > div {
  min-width: 0;
  border: 1px solid var(--finora-border-soft);
  border-radius: 8px;
  padding: 10px;
  background: #FBFCFE;
}
.ops-inline-metrics span,
.ops-inline-metrics small {
  display: block;
  color: var(--finora-text-soft);
  font-size: 11px;
}
.ops-inline-metrics strong {
  display: block;
  margin: 4px 0;
  font-size: 13px;
  overflow-wrap: anywhere;
}
.ops-alert-metrics {
  margin-bottom: 16px;
}
.ops-alert-timeline {
  max-height: 260px;
  overflow: auto;
  padding-right: 8px;
}
.ops-audit-line {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
  color: var(--finora-text-soft);
  font-size: 13px;
}
.ops-check-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.ops-check {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  align-items: start;
  min-width: 0;
  border: 1px solid var(--finora-border-soft);
  border-radius: 8px;
  padding: 10px;
  background: #FBFCFE;
}
.ops-check strong,
.ops-check span {
  display: block;
}
.ops-check strong {
  font-size: 13px;
}
.ops-check span {
  color: var(--finora-text-soft);
  font-size: 12px;
  line-height: 1.45;
}
.ops-backup-table {
  table-layout: fixed;
}
.ops-backup-table th,
.ops-backup-table td {
  overflow-wrap: anywhere;
}
.ops-backup-table th:nth-child(1) { width: 44%; }
.ops-backup-table th:nth-child(2) { width: 15%; }
.ops-backup-table th:nth-child(3) { width: 21%; }
.ops-backup-table th:nth-child(4) { width: 20%; }

/* ===== responsive ===== */
@media (max-width: 1024px) {
  .shell { grid-template-columns: 70px 1fr; }
  .side { padding: 16px 6px; }
  .side-brand .brand-name, .side-brand .brand-tag,
  .side-group-title, .nav-item span.label, .side-user .meta { display: none; }
  .nav-item { justify-content: center; }
  .stat-grid { grid-template-columns: repeat(2, 1fr); }
  .billing-metrics, .account-money-strip { grid-template-columns: repeat(2, 1fr); }
  .usage-card-grid { grid-template-columns: repeat(3, 1fr); }
  .usage-formula-strip { grid-template-columns: repeat(2, 1fr); }
  .profit-chart { grid-template-columns: repeat(3, 1fr); }
  .col-8, .col-7, .col-6, .col-5, .col-4 { grid-column: span 12; }
  .search { width: 180px; }
  .admin-command-panel { grid-template-columns: 1fr; }
  .admin-command-actions { justify-content: flex-start; }
  .ops-inline-metrics,
  .ops-check-grid { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .shell { grid-template-columns: 1fr; }
  .side {
    position: relative;
    height: auto;
    flex-direction: row;
    align-items: center;
    overflow-x: auto;
    border-right: 0;
    border-bottom: 1px solid var(--finora-border);
  }
  .side-group {
    flex-direction: row;
    flex: 0 0 auto;
  }
  .side-user { margin-top: 0; }
  .topbar {
    align-items: stretch;
    flex-direction: column;
    padding: 12px 16px;
  }
  .topbar-title {
    flex-wrap: wrap;
  }
  .topbar-tools {
    width: 100%;
    flex-wrap: wrap;
  }
  .topbar-tools .btn {
    flex: 1 1 130px;
    white-space: normal;
  }
  .content { padding: 18px 16px 40px; }
  .search { display: none; }
  .stat-grid { grid-template-columns: 1fr; }
  .grid-12 { grid-template-columns: minmax(0, 1fr); }
  .col-8, .col-7, .col-6, .col-5, .col-4 { grid-column: 1 / -1; }
  .card { min-width: 0; }
  .card-head,
  .card-body { padding-left: 14px; padding-right: 14px; }
  .tbl th,
  .tbl td { padding: 10px 8px; }
  .tbl-wrap,
  .ai-security-scroll {
    max-width: 100%;
    overflow-x: auto;
  }
  .ai-security-metrics { grid-template-columns: 1fr; }
  .ai-policy-note { flex-direction: column; }
  .billing-hero { flex-direction: column; }
  .usage-calculator-head { flex-direction: column; }
  .billing-metrics, .account-money-strip, .profit-chart { grid-template-columns: 1fr; }
  .usage-card-grid, .usage-formula-strip { grid-template-columns: 1fr; }
  .traffic-summary { grid-template-columns: 1fr; }
  .traffic-row .label { width: 132px; }
  .session-meta { grid-template-columns: 1fr; }
  .admin-command-panel { padding: 18px; border-radius: 18px; }
  .admin-command-copy h2 { font-size: 26px; }
  .admin-command-metrics, .generator-layout, .generator-presets, .handoff-grid, .feature-grid, .feature-grid.compact { grid-template-columns: 1fr; }
  .account-generator-result { grid-template-columns: 1fr; }
  .modal-foot {
    align-items: stretch;
    flex-direction: column;
  }
  .modal-foot .right {
    flex-wrap: wrap;
    justify-content: flex-end;
  }
  .modal-foot .right .btn {
    flex: 1 1 130px;
  }
  .ops-status-actions {
    margin-left: 0;
    width: 100%;
  }
  .ops-status-actions .btn {
    flex: 1 1 140px;
  }
  .ops-readiness-summary {
    grid-template-columns: 1fr;
  }
  .ops-readiness-score {
    width: 100%;
    height: 58px;
  }
}

@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; animation: none !important; }
}
