* { box-sizing: border-box; }
body {
  margin: 0; font-family: -apple-system, "Segoe UI", Roboto, sans-serif;
  background: #f4f6f9; color: #1f2933;
}
.wrap { max-width: 1200px; margin: 0 auto; padding: 0 20px; }

header { background: #1a3a5c; color: #fff; }
header .wrap { display: flex; align-items: center; justify-content: space-between; height: 60px; }
.logo { color: #fff; text-decoration: none; font-weight: 700; font-size: 18px; }
nav a { color: #cfe0f0; text-decoration: none; margin-left: 18px; font-size: 14px; }
nav a:hover { color: #fff; }
.btn-nav { background: #2e7d32; color: #fff !important; padding: 8px 14px; border-radius: 6px; }

main { padding: 24px 20px 60px; }
h1 { font-size: 22px; margin: 18px 0 14px; }
h2 { font-size: 17px; margin: 18px 0 10px; }
h3 { font-size: 15px; margin: 18px 0 10px; }

.flash { padding: 10px 14px; border-radius: 6px; margin-bottom: 12px; font-size: 14px; }
.flash.ok  { background: #e6f4ea; color: #1e7e34; }
.flash.erro { background: #fde8e8; color: #c0392b; }

.vazio { color: #6b7280; }
.opt { color: #94a3b8; font-weight: 400; font-size: 12px; }
.dica { color: #475569; font-size: 14px; background: #eef2f7; padding: 10px 14px; border-radius: 6px; }

.cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 16px; }
.card-link { text-decoration: none; color: inherit; }
.card { background: #fff; border: 1px solid #e2e8f0; border-radius: 10px; padding: 16px;
        transition: transform .1s, box-shadow .1s; }
.card-link:hover .card { transform: translateY(-2px); box-shadow: 0 4px 14px rgba(26,58,92,.10); }
.card.inativo { opacity: .55; }
.card-head { display: flex; justify-content: space-between; align-items: center; }
.card-head h3 { margin: 0; font-size: 16px; }
.leads-count { font-size: 12px; background: #eef2f7; padding: 3px 8px; border-radius: 10px; color: #475569; }
.meta { margin-top: 8px; font-size: 13px; }
.meta.small { color: #6b7280; font-size: 11px; }
.tag.off { background: #fde8e8; color: #c0392b; font-size: 11px; padding: 2px 6px; border-radius: 4px; }

.topo-empresa { display: flex; align-items: center; justify-content: space-between; }
.acoes { display: flex; gap: 8px; flex-wrap: wrap; }
.inline { display: inline; }

.btn { display: inline-block; background: #e2e8f0; color: #1f2933; text-decoration: none;
       border: none; padding: 8px 12px; border-radius: 6px; font-size: 13px; cursor: pointer; }
.btn:hover { background: #cbd5e1; }
.btn.primary { background: #1a3a5c; color: #fff; }
.btn.primary:hover { background: #15314d; }
.btn.danger { background: #fde8e8; color: #c0392b; }
.btn.danger:hover { background: #f9c8c8; }
.btn.small { padding: 4px 8px; font-size: 12px; }

input, select, textarea { font: inherit; padding: 7px 9px; border: 1px solid #cbd5e1;
  border-radius: 6px; background: #fff; }

.form-empresa { background: #fff; border: 1px solid #e2e8f0; border-radius: 10px; padding: 20px; max-width: 640px; }
.form-empresa label { display: block; margin-bottom: 14px; font-size: 14px; font-weight: 600; }
.form-empresa label.check { font-weight: 400; }
.form-empresa input[type=text], .form-empresa textarea {
  width: 100%; margin-top: 5px; font-weight: 400;
}

.bloco { background: #fff; border: 1px solid #e2e8f0; border-radius: 10px; padding: 18px; margin-top: 20px; }
.bloco-head { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; }
.bloco-head h2 { margin: 0; }
.upload-form { display: flex; gap: 8px; align-items: center; }
.upload-form input[type=file] { font-size: 12px; }

.seletor-periodo { display: flex; gap: 12px; align-items: center;
  margin: 14px 0; padding: 10px; background: #f4f6f9; border-radius: 6px; flex-wrap: wrap; }
.seletor-periodo select { min-width: 320px; }

.kpis { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px; margin: 18px 0; }
.kpi { background: #f4f6f9; border-radius: 8px; padding: 12px 14px; }
.kpi span { display: block; font-size: 11px; color: #64748b; text-transform: uppercase; letter-spacing: .05em; }
.kpi strong { display: block; font-size: 18px; color: #1a3a5c; margin-top: 4px; }
.kpi.destaque { background: #1a3a5c; }
.kpi.destaque span { color: #cfe0f0; }
.kpi.destaque strong { color: #fff; }

.acoes-export { display: flex; gap: 10px; margin: 18px 0; }
.grupo-titulo { font-size: 14px; color: #64748b; text-transform: uppercase;
  letter-spacing: .08em; margin: 28px 0 10px; padding-bottom: 6px;
  border-bottom: 2px solid #1a3a5c; }

.visao-geral { background: linear-gradient(180deg, #fff 0%, #f4f6f9 100%);
  border-left: 4px solid #1a3a5c; }
.visao-geral h2 { color: #1a3a5c; margin-top: 0; }

.insights { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 12px; margin: 14px 0; }
.insight { padding: 12px 14px; border-radius: 8px; border-left: 4px solid #cbd5e1;
  background: #f8fafc; }
.insight-titulo { font-weight: 600; font-size: 14px; margin-bottom: 6px; }
.insight-texto { font-size: 13px; color: #334155; line-height: 1.45; }
.insight-itens { margin: 8px 0 0; padding-left: 18px; font-size: 12px;
  color: #475569; line-height: 1.5; }
.insight-itens li { margin-bottom: 2px; }

.insight-alerta { border-left-color: #c0392b; background: #fef2f2; }
.insight-alerta .insight-titulo { color: #c0392b; }
.insight-atencao { border-left-color: #d97706; background: #fffbeb; }
.insight-atencao .insight-titulo { color: #b45309; }
.insight-ok { border-left-color: #1e7e34; background: #f0fdf4; }
.insight-ok .insight-titulo { color: #15803d; }
.insight-info { border-left-color: #0369a1; background: #f0f9ff; }
.insight-info .insight-titulo { color: #0369a1; }

/* ─── Dashboard novo ─── */
.dash-topo { display: flex; justify-content: space-between; align-items: flex-start;
  gap: 16px; margin-bottom: 18px; flex-wrap: wrap; }
.dash-topo h1 { margin: 0 0 6px; }
.subtle { color: #94a3b8; font-weight: 400; }

.vazio-estado { background: #fff; border: 2px dashed #cbd5e1; border-radius: 12px;
  padding: 48px; text-align: center; }
.vazio-estado h2 { margin-top: 0; color: #475569; }
.btn.big { padding: 14px 24px; font-size: 15px; margin-top: 16px; }

/* KPIs hero */
.kpis-hero { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 12px; margin-bottom: 24px; }
.kpi-card { background: #fff; border: 1px solid #e2e8f0; border-radius: 10px;
  padding: 16px 18px; box-shadow: 0 1px 3px rgba(15,23,42,.04); }
.kpi-card span { display: block; font-size: 11px; color: #64748b;
  text-transform: uppercase; letter-spacing: .05em; }
.kpi-card strong { display: block; font-size: 22px; color: #1a3a5c; margin-top: 6px;
  font-variant-numeric: tabular-nums; }
.kpi-destaque { background: linear-gradient(135deg, #1a3a5c 0%, #15314d 100%); }
.kpi-destaque span { color: #cfe0f0; }
.kpi-destaque strong { color: #fff; }
.kpi-ga4 { background: #f0f9ff; border-color: #bae6fd; }
.kpi-ga4 strong { color: #0369a1; }

/* Recomendações */
.recomendacoes { background: #fff; border: 1px solid #e2e8f0; border-radius: 12px;
  padding: 20px; margin-bottom: 24px; box-shadow: 0 1px 3px rgba(15,23,42,.04); }
.recom-head { display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 14px; }
.recom-head h2 { margin: 0; font-size: 18px; }
.contagem { font-size: 12px; color: #94a3b8; background: #f1f5f9;
  padding: 4px 10px; border-radius: 10px; }
.recom-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(330px, 1fr));
  gap: 12px; }
.recom { padding: 14px 16px; border-radius: 8px; border-left: 4px solid #cbd5e1;
  background: #f8fafc; }
.recom-titulo { font-weight: 600; font-size: 14px; margin-bottom: 4px; }
.recom-origem { font-size: 11px; color: #94a3b8; text-transform: uppercase;
  letter-spacing: .03em; margin-bottom: 6px; }
.recom-texto { font-size: 13px; color: #334155; line-height: 1.5; }
.recom-itens { margin: 8px 0 0; padding-left: 18px; font-size: 12px;
  color: #475569; line-height: 1.6; }
.recom-alerta  { border-left-color: #c0392b; background: #fef2f2; }
.recom-alerta .recom-titulo  { color: #c0392b; }
.recom-atencao { border-left-color: #d97706; background: #fffbeb; }
.recom-atencao .recom-titulo { color: #b45309; }
.recom-ok      { border-left-color: #1e7e34; background: #f0fdf4; }
.recom-ok .recom-titulo      { color: #15803d; }
.recom-info    { border-left-color: #0369a1; background: #f0f9ff; }
.recom-info .recom-titulo    { color: #0369a1; }

/* Charts */
.charts { margin-bottom: 24px; }
.charts h2 { margin: 24px 0 12px; }
.chart-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(420px, 1fr));
  gap: 14px; }
.chart-card { background: #fff; border: 1px solid #e2e8f0; border-radius: 10px;
  padding: 16px; box-shadow: 0 1px 3px rgba(15,23,42,.04); }
.chart-card h3 { margin: 0 0 12px; font-size: 14px; color: #334155; }
.chart-wide { grid-column: 1 / -1; margin-bottom: 14px; }
.chart-head { display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 8px; flex-wrap: wrap; gap: 8px; }
.chart-toggle { display: flex; gap: 4px; }
.chart-toggle button { background: #f1f5f9; border: 1px solid #cbd5e1;
  color: #475569; padding: 5px 12px; border-radius: 6px; font-size: 12px;
  cursor: pointer; transition: all .15s; }
.chart-toggle button:hover { background: #e2e8f0; }
.chart-toggle button.active { background: #1a3a5c; color: #fff; border-color: #1a3a5c; }

.termos-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.termos-titulo { font-size: 13px; margin: 4px 0 8px; font-weight: 600; }
.termos-ruim { color: #c0392b; }
.termos-bom  { color: #15803d; }
@media (max-width: 800px) { .termos-2col { grid-template-columns: 1fr; }}

/* Drawer */
.drawer-overlay { position: fixed; inset: 0; background: rgba(15,23,42,.4);
  opacity: 0; pointer-events: none; transition: opacity .2s; z-index: 100; }
.drawer-overlay.open { opacity: 1; pointer-events: auto; }
.drawer { position: fixed; top: 0; right: 0; height: 100vh; width: 440px; max-width: 100vw;
  background: #fff; box-shadow: -8px 0 28px rgba(15,23,42,.18); z-index: 101;
  transform: translateX(100%); transition: transform .25s ease;
  display: flex; flex-direction: column; }
.drawer.open { transform: translateX(0); }
.drawer-head { display: flex; justify-content: space-between; align-items: center;
  padding: 18px 22px; border-bottom: 1px solid #e2e8f0; background: #1a3a5c; color: #fff; }
.drawer-head h2 { margin: 0; font-size: 17px; color: #fff; }
.drawer-close { background: transparent; border: none; color: #fff;
  font-size: 24px; cursor: pointer; line-height: 1; padding: 0 4px; }
.drawer-body { padding: 18px 22px; overflow-y: auto; flex: 1; }
.drawer-dica { font-size: 12px; color: #64748b; margin: 0 0 18px; line-height: 1.5; }
.drawer-grupo { font-size: 11px; color: #64748b; text-transform: uppercase;
  letter-spacing: .05em; margin: 18px 0 8px; padding-bottom: 4px;
  border-bottom: 2px solid #e2e8f0; }
.upload-box { background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 8px;
  padding: 10px 12px; margin-bottom: 10px; }
.upload-box-head { display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 8px; font-size: 13px; flex-wrap: wrap; gap: 4px; }
.upload-status { font-size: 11px; color: #15803d; }
.upload-status.upload-vazio { color: #94a3b8; }
.upload-box .upload-form { display: flex; gap: 6px; align-items: center; }
.upload-box input[type=file] { font-size: 11px; flex: 1; min-width: 0; }
.btn.small { padding: 4px 10px; font-size: 12px; }

/* Detalhes (page) */
.bloco-det { background: #fff; border: 1px solid #e2e8f0; border-radius: 10px;
  padding: 14px 18px; margin-bottom: 12px; }
.bloco-det summary { cursor: pointer; font-size: 15px; padding: 4px 0; }
.bloco-det summary:hover { color: #1a3a5c; }
.bloco-det[open] summary { margin-bottom: 14px; }

.qs-badge { display: inline-block; width: 22px; height: 22px; line-height: 20px;
  border-radius: 50%; font-weight: 700; font-size: 13px; text-align: center;
  border: 1px solid; }
.qs-bom   { background: #dcfce7; color: #166534; border-color: #86efac; }
.qs-medio { background: #f1f5f9; color: #64748b; border-color: #cbd5e1; }
.qs-ruim  { background: #fee2e2; color: #991b1b; border-color: #fca5a5; }
.qs-na    { background: transparent; color: #cbd5e1; border-color: #e2e8f0;
  font-weight: 400; }
td.centro { text-align: center; }

/* Diagnóstico avançado */
.diag { margin-bottom: 24px; }
.diag h2 { margin: 24px 0 12px; }
.diag-card { background: #fff; border: 1px solid #e2e8f0; border-radius: 10px;
  padding: 16px 18px; margin-bottom: 14px; box-shadow: 0 1px 3px rgba(15,23,42,.04); }
.diag-card h3 { margin: 0 0 10px; font-size: 15px; color: #334155; }
.diag-card .dica { margin: 0 0 12px; font-size: 12px; color: #64748b;
  background: #f8fafc; padding: 8px 10px; border-radius: 6px; }
.diag-table { width: 100%; font-size: 12px; border: 1px solid #e2e8f0;
  border-radius: 8px; overflow: hidden; }
.diag-table th { background: #f0f4f8; font-size: 11px; text-transform: uppercase;
  letter-spacing: .03em; color: #475569; padding: 8px 10px; text-align: left;
  white-space: nowrap; }
.diag-table td { padding: 7px 10px; border-bottom: 1px solid #eef2f7;
  font-variant-numeric: tabular-nums; }
.diag-table tr:last-child td { border-bottom: none; }

.delta { display: inline-block; padding: 2px 8px; border-radius: 10px;
  font-weight: 600; font-size: 11px; font-variant-numeric: tabular-nums; }
.delta-ruim { background: #fee2e2; color: #991b1b; }
.delta-ok   { background: #f1f5f9; color: #475569; }
.delta-bom  { background: #dcfce7; color: #166534; }

.qs-num { display: inline-block; width: 24px; height: 24px; line-height: 22px;
  border-radius: 50%; text-align: center; font-weight: 700; border: 1px solid; }
.qs-num-baixo { background: #fee2e2; color: #991b1b; border-color: #fca5a5; }

.chart-nota { margin: 10px 0 0; font-size: 12px; color: #475569;
  padding: 8px 10px; background: #f8fafc; border-radius: 6px; }

/* ─── Score de saúde (hero) ─── */
.score-hero { display: flex; gap: 16px; align-items: stretch; margin-bottom: 18px; flex-wrap: wrap; }
.score-card { flex: 0 0 auto; display: flex; align-items: center; gap: 20px;
  padding: 20px 28px; border-radius: 12px; min-width: 280px;
  box-shadow: 0 2px 8px rgba(15,23,42,.08); }
.score-numero { font-size: 56px; font-weight: 800; line-height: 1; font-variant-numeric: tabular-nums; }
.score-label strong { display: block; font-size: 17px; }
.score-label span { display: block; font-size: 12px; opacity: .8; margin-top: 4px; }
.score-ok      { background: linear-gradient(135deg, #15803d, #166534); color: #fff; }
.score-info    { background: linear-gradient(135deg, #0369a1, #075985); color: #fff; }
.score-atencao { background: linear-gradient(135deg, #d97706, #b45309); color: #fff; }
.score-alerta  { background: linear-gradient(135deg, #c0392b, #991b1b); color: #fff; }
.score-breakdown { flex: 1; background: #fff; border: 1px solid #e2e8f0;
  border-radius: 12px; padding: 14px 16px; min-width: 320px; }
.score-breakdown summary { cursor: pointer; font-size: 14px; font-weight: 600;
  color: #1a3a5c; padding: 4px 0; }
.score-breakdown[open] summary { margin-bottom: 10px; }
.score-breakdown table { font-size: 12px; }

/* ─── Δ% chips nos KPIs ─── */
.kpi-delta { display: inline-block; font-size: 10px; font-weight: 700;
  padding: 2px 6px; border-radius: 8px; vertical-align: middle; margin-left: 4px;
  font-variant-numeric: tabular-nums; }
.delta-ok    { background: #dcfce7; color: #166534; }
.delta-ruim  { background: #fee2e2; color: #991b1b; }
.delta-neutro{ background: #f1f5f9; color: #64748b; }
.kpi-destaque .kpi-delta { background: rgba(255,255,255,.2); color: #fff; }
.kpi-ga4 .kpi-delta { background: rgba(3,105,161,.15); color: #0369a1; }

/* ─── Anomalias ─── */
.anomalias { background: #fff; border: 1px solid #e2e8f0; border-radius: 12px;
  padding: 18px; margin-bottom: 22px; }
.anomalias h2 { margin-top: 0; }
.anom-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 10px; }
.anom { padding: 12px 14px; border-radius: 8px; border-left: 4px solid #cbd5e1;
  background: #f8fafc; }
.anom-titulo { font-weight: 700; font-size: 13px; margin-bottom: 4px; }
.anom-texto { font-size: 12px; color: #334155; }
.anom-alerta { border-left-color: #c0392b; background: #fef2f2; }
.anom-alerta .anom-titulo { color: #c0392b; }
.anom-atencao { border-left-color: #d97706; background: #fffbeb; }
.anom-atencao .anom-titulo { color: #b45309; }
.anom-ok { border-left-color: #15803d; background: #f0fdf4; }
.anom-ok .anom-titulo { color: #15803d; }
.anom-info { border-left-color: #0369a1; background: #f0f9ff; }
.anom-info .anom-titulo { color: #0369a1; }

/* ─── Negativações pra colar ─── */
.neg-card { background: #fff8f0; border-color: #fed7aa; }
.neg-actions { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.btn-copy { background: #1a3a5c; color: #fff; border: none; padding: 8px 16px;
  border-radius: 6px; font-size: 13px; cursor: pointer; }
.btn-copy:hover { background: #15314d; }
.copiado-msg { font-size: 13px; color: #15803d; font-weight: 600; }
.neg-bloco { width: 100%; min-height: 180px; padding: 12px; border: 1px solid #cbd5e1;
  border-radius: 8px; font-family: 'Consolas', 'Courier New', monospace; font-size: 12px;
  background: #fff; resize: vertical; }

/* ─── Diff entre uploads ─── */
.diff-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 12px; margin-top: 12px; }
.diff-bloco { background: #f8fafc; padding: 10px 12px; border-radius: 8px;
  border-left: 4px solid #cbd5e1; }
.diff-bloco h4 { font-size: 13px; margin: 0 0 8px; }
.diff-bloco ul { margin: 0; padding-left: 18px; font-size: 11px; color: #475569; line-height: 1.5; }
.diff-novos { color: #0369a1; }
.diff-sumidos { color: #64748b; }
.diff-melhoraram { color: #15803d; }
.diff-pioraram { color: #c0392b; }

/* ─── Anotações ─── */
.anot { background: #fff; border: 1px solid #e2e8f0; border-radius: 12px;
  padding: 18px; margin-bottom: 22px; }
.anot h2 { margin-top: 0; }
.anot-form { display: grid; grid-template-columns: 200px 1fr auto; gap: 8px;
  margin-bottom: 16px; align-items: start; }
.anot-form textarea { min-height: 60px; resize: vertical; padding: 8px 10px;
  border: 1px solid #cbd5e1; border-radius: 6px; font: inherit; }
.anot-form input { padding: 8px 10px; }
.anot-lista { list-style: none; padding: 0; margin: 0; }
.anot-lista li { background: #f8fafc; border-left: 3px solid #1a3a5c;
  padding: 10px 14px; margin-bottom: 8px; border-radius: 6px; }
.anot-cabec { display: flex; align-items: center; gap: 10px; margin-bottom: 4px; }
.anot-data { font-size: 11px; color: #64748b; }
.anot-autor { font-size: 12px; color: #1a3a5c; font-weight: 600; }
.anot-texto { font-size: 13px; color: #1f2933; white-space: pre-wrap; }
.anot-x { background: transparent; border: none; color: #94a3b8; cursor: pointer;
  font-size: 18px; margin-left: auto; padding: 0 4px; }
.anot-x:hover { color: #c0392b; }

/* ─── Cards multi-cliente (home) ─── */
.cards-multi { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 14px; }
.card-cliente { background: #fff; border: 1px solid #e2e8f0; border-radius: 12px;
  padding: 18px; border-top: 4px solid #94a3b8;
  transition: transform .12s, box-shadow .12s; }
.card-link:hover .card-cliente { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(15,23,42,.10); }
.card-cliente.card-ok      { border-top-color: #15803d; }
.card-cliente.card-info    { border-top-color: #0369a1; }
.card-cliente.card-atencao { border-top-color: #d97706; }
.card-cliente.card-alerta  { border-top-color: #c0392b; }
.card-cliente.card-neutro  { border-top-color: #cbd5e1; }
.card-cliente.inativo { opacity: .55; }
.card-cliente-head { display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 12px; gap: 8px; }
.card-cliente-head h3 { margin: 0; font-size: 16px; color: #1a3a5c; }
.badge-alerta { background: #fee2e2; color: #991b1b; font-size: 11px; font-weight: 700;
  padding: 3px 8px; border-radius: 10px; white-space: nowrap; }
.score-grande { text-align: center; padding: 14px 0; background: #f8fafc;
  border-radius: 8px; margin-bottom: 12px; }
.score-num { font-size: 42px; font-weight: 800; color: #1a3a5c; font-variant-numeric: tabular-nums; }
.score-tt  { font-size: 16px; color: #94a3b8; font-weight: 500; }
.score-classif { font-size: 12px; font-weight: 600; color: #475569;
  text-transform: uppercase; letter-spacing: .04em; margin-top: 4px; }
.score-vazio { font-size: 20px; color: #94a3b8; font-weight: 600; }
.card-cliente-stats { display: flex; gap: 16px; font-size: 12px; color: #475569;
  margin-bottom: 10px; }
.card-cliente-stats strong { color: #1a3a5c; font-size: 14px; }
.card-ok .score-num { color: #15803d; }
.card-info .score-num { color: #0369a1; }
.card-atencao .score-num { color: #b45309; }
.card-alerta .score-num { color: #991b1b; }

table { width: 100%; border-collapse: collapse; background: #fff; border: 1px solid #e2e8f0;
  border-radius: 10px; overflow: hidden; font-size: 12px; }
th, td { text-align: left; padding: 8px 10px; border-bottom: 1px solid #eef2f7; white-space: nowrap; }
th { background: #f0f4f8; font-size: 11px; text-transform: uppercase; letter-spacing: .03em; color: #475569; }
td { font-variant-numeric: tabular-nums; }

/* Login */
.login-body { display: flex; align-items: center; justify-content: center; min-height: 100vh; }
.login-box { background: #fff; border: 1px solid #e2e8f0; border-radius: 10px;
  padding: 32px; width: 320px; box-shadow: 0 4px 24px rgba(26,58,92,.12); }
.login-box h1 { margin: 0 0 20px; text-align: center; color: #1a3a5c; }
.login-box label { display: block; font-size: 14px; font-weight: 600; margin-bottom: 16px; }
.login-box input { width: 100%; margin-top: 6px; font-weight: 400; }
.login-box .btn { width: 100%; }
