/* ============================================================
   RTR Pilates — Studio Metrics Dashboard
   Brand: red #E11D2A, ink #0B0B0F, paper #F7F7F8
   ============================================================ */

:root {
  --rtr-red: #E11D2A;
  --rtr-red-dark: #B5121E;
  --rtr-red-soft: #FDECEE;
  --ink: #0B0B0F;
  --ink-2: #1E1E24;
  --muted: #6B6B73;
  --muted-2: #A1A1A9;
  --line: #ECECEF;
  --line-2: #DDDDE2;
  --paper: #F7F7F8;
  --white: #FFFFFF;
  --good: #16A34A;
  --good-soft: #DCFCE7;
  --bad: #DC2626;
  --bad-soft: #FEE2E2;
  --warn: #D97706;
  --warn-soft: #FEF3C7;
  --info: #2563EB;
  --info-soft: #DBEAFE;
  --shadow-sm: 0 1px 2px rgba(15, 15, 20, .04), 0 1px 1px rgba(15, 15, 20, .03);
  --shadow-md: 0 4px 12px rgba(15, 15, 20, .06), 0 2px 4px rgba(15, 15, 20, .04);
  --shadow-lg: 0 20px 40px -12px rgba(15, 15, 20, .12), 0 8px 16px -8px rgba(15, 15, 20, .08);
  --radius: 14px;
  --radius-sm: 10px;
  --radius-lg: 18px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; height: 100%; }

/* The HTML `hidden` attribute must always win over any author display rules
   (e.g. `display: grid` on .deploy-overlay). Without this, setting el.hidden
   = true has no visual effect on elements that declare a custom `display`. */
[hidden] { display: none !important; }

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background: var(--paper);
  color: var(--ink);
  font-size: 14px;
  line-height: 1.45;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

button { font-family: inherit; cursor: pointer; }

#app {
  display: grid;
  grid-template-columns: 260px 1fr;
  min-height: 100vh;
}

/* ----------------------------- Sidebar ----------------------------- */
.sidebar {
  background: var(--ink);
  color: #EDEDF0;
  padding: 22px 16px;
  display: flex;
  flex-direction: column;
  position: sticky;
  top: 0;
  height: 100vh;
}
.brand {
  display: flex; align-items: center; gap: 12px;
  padding: 4px 6px 18px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  margin-bottom: 14px;
}
.logo-mark {
  width: 42px; height: 42px;
  border-radius: 50%;
  background: var(--rtr-red);
  color: #fff;
  display: grid; place-items: center;
  font-family: 'Manrope', sans-serif;
  font-weight: 800;
  font-size: 13px;
  letter-spacing: .5px;
  box-shadow: 0 6px 14px rgba(225, 29, 42, .35);
}
.brand-title {
  font-family: 'Manrope', sans-serif;
  font-weight: 800;
  font-size: 16px;
  letter-spacing: .2px;
  color: #fff;
}
.brand-sub {
  font-size: 11px;
  color: #9A9AA3;
  letter-spacing: .8px;
  text-transform: uppercase;
  margin-top: 2px;
}
.nav { display: flex; flex-direction: column; gap: 2px; flex: 1; overflow-y: auto; padding-right: 2px; }
.nav-group {
  font-size: 10px;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: #6E6E78;
  margin: 14px 12px 6px;
}
.nav button {
  text-align: left;
  background: transparent;
  border: 0;
  color: #C8C8CE;
  padding: 9px 12px;
  border-radius: 9px;
  font-size: 13.5px;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 10px;
  transition: background .15s ease, color .15s ease;
}
.nav button:hover { background: rgba(255,255,255,.05); color: #fff; }
.nav button.active {
  background: var(--rtr-red);
  color: #fff;
  box-shadow: 0 6px 14px rgba(225,29,42,.35);
}
.nav button .dot-pin {
  width: 6px; height: 6px; border-radius: 50%;
  background: #4A4A52;
  flex-shrink: 0;
}
.nav button.active .dot-pin { background: #fff; }

.sidebar-foot {
  border-top: 1px solid rgba(255,255,255,.08);
  padding-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.btn-ghost {
  background: transparent;
  border: 1px solid rgba(255,255,255,.12);
  color: #D4D4DA;
  padding: 7px 10px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 500;
  transition: background .15s ease;
}
.btn-ghost:hover { background: rgba(255,255,255,.07); color: #fff; }
.sidebar-meta { font-size: 10.5px; color: #5C5C66; margin-top: 8px; padding: 0 4px; }

/* Dev-only tools panel (only shown on localhost) */
.dev-tools { display: flex; flex-direction: column; gap: 6px; margin-top: 10px; }
.dev-tools-divider {
  display: flex; align-items: center; gap: 8px;
  margin: 6px 0 2px;
  color: #6E6E78;
  font-size: 10px;
  letter-spacing: 1.4px;
  text-transform: uppercase;
}
.dev-tools-divider::before,
.dev-tools-divider::after {
  content: ''; flex: 1; height: 1px; background: rgba(255,255,255,.08);
}
.dev-tools-meta {
  font-size: 10px;
  color: #5C5C66;
  letter-spacing: .3px;
  padding: 0 4px;
}
.btn-deploy {
  background: linear-gradient(180deg, #16A34A, #0F8038);
  color: #fff;
  border: 0;
  border-radius: 8px;
  padding: 9px 12px;
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: .3px;
  display: flex; align-items: center; gap: 8px;
  justify-content: center;
  box-shadow: 0 4px 12px rgba(15, 128, 56, .35);
  cursor: pointer;
  transition: transform .12s ease, box-shadow .15s ease;
}
.btn-deploy:hover { transform: translateY(-1px); box-shadow: 0 6px 16px rgba(15, 128, 56, .45); }
.btn-deploy .rocket { transform: rotate(45deg); font-size: 13px; }

/* Deploy modal */
.deploy-overlay {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(11, 11, 15, .55);
  backdrop-filter: blur(4px);
  display: grid; place-items: center;
  padding: 24px;
}
.deploy-modal {
  background: #fff;
  border-radius: 14px;
  max-width: 620px; width: 100%;
  box-shadow: 0 30px 60px -10px rgba(0,0,0,.35);
  overflow: hidden;
}
.deploy-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 20px 24px 16px;
  border-bottom: 1px solid var(--line);
}
.deploy-head h3 {
  margin: 0;
  font-family: 'Manrope', sans-serif;
  font-size: 18px; font-weight: 800; letter-spacing: -.2px;
}
.deploy-sub {
  margin: 6px 0 0; color: var(--muted); font-size: 12.5px; line-height: 1.4;
}
.deploy-sub b { color: var(--ink); font-weight: 600; }
.deploy-close {
  border: 0; background: transparent;
  font-size: 22px; line-height: 1;
  color: var(--muted-2);
  padding: 2px 8px;
  border-radius: 8px;
  cursor: pointer;
}
.deploy-close:hover { background: var(--line); color: var(--ink); }
.deploy-stage { padding: 18px 24px 22px; }
.deploy-confirm p {
  margin: 0 0 18px;
  color: var(--ink-2);
  font-size: 13px;
  line-height: 1.55;
}
.deploy-confirm code {
  background: var(--line);
  padding: 1px 6px;
  border-radius: 4px;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 11.5px;
}
.deploy-actions {
  display: flex; gap: 10px; justify-content: flex-end;
}
.btn-primary {
  background: linear-gradient(180deg, #16A34A, #0F8038);
  color: #fff;
  border: 0;
  border-radius: 8px;
  padding: 9px 16px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .2px;
  text-decoration: none;
  display: inline-flex; align-items: center; gap: 6px;
  cursor: pointer;
  box-shadow: 0 3px 8px rgba(15, 128, 56, .3);
}
.btn-primary:hover { box-shadow: 0 5px 12px rgba(15, 128, 56, .4); }
.btn-ghost-dark {
  background: transparent;
  color: var(--muted);
  border: 1px solid var(--line-2);
  border-radius: 8px;
  padding: 9px 16px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
}
.btn-ghost-dark:hover { background: var(--line); color: var(--ink); }

.deploy-running { text-align: center; padding: 6px 0 4px; }
.deploy-spinner {
  width: 28px; height: 28px;
  border: 3px solid var(--line);
  border-top-color: var(--rtr-red);
  border-radius: 50%;
  margin: 0 auto 12px;
  animation: spin .9s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.deploy-status {
  font-size: 13.5px;
  font-weight: 600;
  margin-bottom: 10px;
  color: var(--ink);
}
.deploy-log {
  text-align: left;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 11px;
  line-height: 1.45;
  background: #0B0B0F;
  color: #C8C8CE;
  padding: 12px 14px;
  border-radius: 8px;
  max-height: 260px;
  overflow: auto;
  white-space: pre-wrap;
  word-break: break-word;
  margin: 0;
}

.deploy-done, .deploy-failed { text-align: center; padding: 8px 0; }
.deploy-result-icon {
  width: 48px; height: 48px;
  border-radius: 50%;
  display: grid; place-items: center;
  font-size: 24px; font-weight: 800;
  margin: 0 auto 12px;
}
.deploy-result-icon.ok { background: #DCFCE7; color: #15803D; }
.deploy-result-icon.err { background: #FEE2E2; color: #B91C1C; }
.deploy-result-msg {
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 14px;
  color: var(--ink);
}
.deploy-failed .deploy-log { text-align: left; margin-bottom: 14px; }

/* ----------------------------- Main ----------------------------- */
.main { display: flex; flex-direction: column; min-width: 0; }

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px 32px 18px;
  border-bottom: 1px solid var(--line);
  background: rgba(247,247,248,.85);
  backdrop-filter: blur(8px);
  position: sticky; top: 0; z-index: 5;
}
.topbar-left { min-width: 0; }
.page-title {
  font-family: 'Manrope', sans-serif;
  font-size: 26px;
  font-weight: 800;
  letter-spacing: -.4px;
  margin: 0;
  color: var(--ink);
}
.page-sub { margin: 4px 0 0; color: var(--muted); font-size: 13.5px; }
.topbar-right { display: flex; align-items: center; gap: 12px; }

.year-toggle {
  display: inline-flex;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 3px;
  box-shadow: var(--shadow-sm);
}
.year-toggle button {
  border: 0;
  background: transparent;
  padding: 6px 14px;
  font-size: 12.5px;
  font-weight: 600;
  border-radius: 999px;
  color: var(--muted);
  transition: all .15s ease;
}
.year-toggle button.active {
  background: var(--ink);
  color: #fff;
}
.year-badge {
  display: inline-flex; align-items: center; gap: 4px;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 7px 14px;
  font-size: 12px;
  color: var(--muted);
  letter-spacing: .2px;
  box-shadow: var(--shadow-sm);
}
.year-badge b { color: var(--ink); font-weight: 700; letter-spacing: .3px; }

.saved-pill {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11.5px;
  color: var(--muted);
  background: var(--white);
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--line);
}
.saved-pill .dot { width: 7px; height: 7px; background: var(--good); border-radius: 50%; box-shadow: 0 0 0 3px rgba(22,163,74,.18); }

/* Live-sync status indicator */
.sync-status {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 11.5px;
  font-weight: 600;
  color: var(--ink);
  background: var(--white);
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
  transition: background .25s ease, border-color .25s ease;
}
.sync-status .indicator {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--muted-2);
  box-shadow: 0 0 0 3px rgba(161,161,169,.18);
}
.sync-status[data-status="live"] .indicator { background: #16A34A; box-shadow: 0 0 0 3px rgba(22,163,74,.18); animation: sync-pulse 2.2s ease-in-out infinite; }
.sync-status[data-status="saving"] .indicator { background: #D97706; box-shadow: 0 0 0 3px rgba(217,119,6,.18); }
.sync-status[data-status="connecting"] .indicator { background: #2563EB; box-shadow: 0 0 0 3px rgba(37,99,235,.18); animation: sync-pulse 1.4s ease-in-out infinite; }
.sync-status[data-status="error"] .indicator { background: var(--bad); box-shadow: 0 0 0 3px rgba(220,38,38,.18); }
.sync-status[data-status="offline"] .indicator { background: var(--muted-2); box-shadow: 0 0 0 3px rgba(161,161,169,.18); }
.sync-status[data-status="offline"] { color: var(--muted); }
.sync-status.local-flash { border-color: #86EFAC; background: #F0FDF4; }
.sync-status.remote-flash { border-color: #93C5FD; background: #EFF6FF; }
@keyframes sync-pulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.25); opacity: .7; }
}

.view { padding: 24px 32px 32px; }

.footer {
  padding: 14px 32px 22px;
  color: var(--muted-2);
  font-size: 11.5px;
}

/* ----------------------------- Generic ----------------------------- */
.card {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.card-pad { padding: 18px 20px; }
.card-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--line);
}
.card-head h3 {
  margin: 0;
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .1px;
  color: var(--ink);
}
.card-head .sub { color: var(--muted); font-size: 12px; }

.section-title {
  display: flex; align-items: baseline; justify-content: space-between;
  margin: 26px 0 12px;
}
.section-title h2 {
  font-family: 'Manrope', sans-serif;
  margin: 0; font-size: 16px; font-weight: 700; letter-spacing: -.2px;
}
.section-title .hint { color: var(--muted); font-size: 12px; }

/* KPI cards */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
}
.kpi {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 16px 18px;
  position: relative;
  overflow: hidden;
  transition: transform .12s ease, box-shadow .15s ease;
}
.kpi:hover { transform: translateY(-1px); box-shadow: var(--shadow-md); }
.kpi-accent {
  position: absolute;
  top: 0; right: 0; bottom: 0;
  width: 4px;
  background: linear-gradient(180deg, var(--rtr-red) 0%, var(--rtr-red-dark) 100%);
  opacity: .9;
}
.kpi-label {
  font-size: 11.5px;
  text-transform: uppercase;
  letter-spacing: 1.1px;
  color: var(--muted);
  font-weight: 600;
}
.kpi-value {
  font-family: 'Manrope', sans-serif;
  font-size: 28px;
  font-weight: 800;
  letter-spacing: -.6px;
  margin-top: 8px;
  color: var(--ink);
}
.kpi-row {
  display: flex; align-items: center; gap: 8px;
  margin-top: 8px;
  font-size: 12px;
}
.delta {
  display: inline-flex; align-items: center; gap: 3px;
  font-weight: 600;
  padding: 2px 7px;
  border-radius: 999px;
  font-size: 11.5px;
}
.delta.up   { color: var(--good); background: var(--good-soft); }
.delta.down { color: var(--bad);  background: var(--bad-soft); }
.delta.flat { color: var(--muted); background: var(--line); }
.kpi-foot { color: var(--muted); font-size: 11.5px; margin-top: 10px; display: flex; gap: 10px; flex-wrap: wrap; }
.kpi-foot b { color: var(--ink); font-weight: 600; }

/* Tabs/segmented */
.segmented {
  display: inline-flex;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 3px;
  box-shadow: var(--shadow-sm);
}
.segmented button {
  border: 0; background: transparent;
  padding: 6px 12px;
  font-size: 12.5px; font-weight: 600;
  border-radius: 7px;
  color: var(--muted);
}
.segmented button.active { background: var(--ink); color: #fff; }

/* Tables */
.table-wrap {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
}
.table-scroll { overflow-x: auto; }
table.metrics {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  min-width: 1100px;
}
table.metrics th, table.metrics td {
  padding: 10px 12px;
  text-align: right;
  font-size: 12.5px;
  border-bottom: 1px solid var(--line);
  white-space: nowrap;
}
table.metrics th {
  background: #FAFAFB;
  color: var(--muted);
  font-weight: 600;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .6px;
  position: sticky; top: 0;
}
table.metrics th.left, table.metrics td.left { text-align: left; }
table.metrics td.metric-name { font-weight: 600; color: var(--ink); }
table.metrics tbody tr:hover { background: #FBFBFC; }
table.metrics input.cell {
  width: 100%;
  min-width: 64px;
  padding: 6px 8px;
  border: 1px solid transparent;
  border-radius: 6px;
  background: #EEF5FF;
  color: var(--ink);
  font-family: inherit;
  font-size: 12.5px;
  text-align: right;
  transition: border-color .15s ease, background .15s ease;
}
table.metrics input.cell:hover { border-color: #BCD0F0; }
table.metrics input.cell:focus { outline: 0; border-color: var(--info); background: #fff; }
table.metrics input.cell.empty { background: #F2F4F8; }
table.metrics td.calc { color: var(--ink-2); }
table.metrics td.calc-muted { color: var(--muted); }
table.metrics td.divider { background: #FAFAFB; border-left: 1px solid var(--line-2); border-right: 1px solid var(--line-2); }
table.metrics th.divider { background: #F2F2F4; border-left: 1px solid var(--line-2); border-right: 1px solid var(--line-2); }
table.metrics tr.subtotal td { background: #FAFAFB; font-weight: 700; color: var(--ink); border-top: 2px solid var(--line-2); }
.cell-pct { color: var(--muted); font-size: 10.5px; margin-left: 4px; }

/* Studio snapshot table — consistent dark headers matching studio detail grids */
.snapshot {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}
.snapshot th, .snapshot td {
  padding: 10px 8px;
  font-size: 12.5px;
  text-align: center;
  border-bottom: 1px solid var(--line);
  white-space: nowrap;
}
.snapshot th {
  background: var(--ink);
  color: #fff;
  font-weight: 700;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: .7px;
  padding: 11px 8px;
  border-bottom: 1px solid var(--ink);
}
.snapshot th.left, .snapshot td.left { text-align: left; padding-left: 14px; }
.snapshot td.studio-name { font-weight: 600; }
.snapshot tr.total td {
  background: #F0FDF4;
  font-weight: 700;
  color: var(--ink);
  border-top: 2px solid #15803D;
  border-bottom: 2px solid #15803D;
}
.snapshot tr.total td.studio-name { color: #15803D; }
.snapshot tbody tr:hover { background: #FAFAFB; }
.snapshot tbody tr.total:hover { background: #F0FDF4; }

/* Grid layouts */
.grid-2 { display: grid; grid-template-columns: 2fr 1fr; gap: 18px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.grid-12 { display: grid; grid-template-columns: repeat(12, 1fr); gap: 14px; }

@media (max-width: 1100px) {
  .grid-2 { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  #app { grid-template-columns: 1fr; }
  .sidebar { position: relative; height: auto; }
  .view { padding: 16px; }
  .topbar { padding: 16px; }
}

/* Charts */
.chart-wrap { position: relative; height: 260px; padding: 14px 16px 6px; }
.chart-wrap.tall { height: 320px; }
.chart-legend { display: flex; gap: 14px; padding: 0 16px 12px; font-size: 11.5px; color: var(--muted); flex-wrap: wrap; }
.chart-legend .swatch { display: inline-flex; align-items: center; gap: 6px; }
.chart-legend .swatch i { width: 10px; height: 10px; border-radius: 3px; display: inline-block; }

/* Progress bar */
.progress {
  height: 8px;
  background: var(--line);
  border-radius: 999px;
  overflow: hidden;
  position: relative;
}
.progress > span {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, var(--rtr-red), var(--rtr-red-dark));
  border-radius: 999px;
}
.progress.danger > span { background: linear-gradient(90deg, #F87171, #DC2626); }
.progress.warn > span { background: linear-gradient(90deg, #FBBF24, #D97706); }
.progress.good > span { background: linear-gradient(90deg, #34D399, #16A34A); }
.progress.cap {
  position: relative;
}
.progress.cap::after {
  content: '';
  position: absolute;
  top: -2px; bottom: -2px;
  width: 2px;
  background: var(--ink);
  opacity: .55;
  border-radius: 2px;
}
.progress.cap[data-pace="0"]::after { left: 0; }

/* Pill / badge */
.pill {
  display: inline-flex; align-items: center;
  font-size: 11px;
  font-weight: 600;
  padding: 3px 8px;
  border-radius: 999px;
  background: var(--line);
  color: var(--ink-2);
  letter-spacing: .2px;
}
.pill.good { background: var(--good-soft); color: var(--good); }
.pill.bad  { background: var(--bad-soft);  color: var(--bad); }
.pill.warn { background: var(--warn-soft); color: var(--warn); }
.pill.info { background: var(--info-soft); color: var(--info); }
.pill.red  { background: var(--rtr-red-soft); color: var(--rtr-red); }

/* Inputs (goal, etc.) */
.goal-input {
  width: 100%;
  padding: 6px 8px;
  border: 1px solid transparent;
  border-radius: 6px;
  background: #EEF5FF;
  color: var(--ink);
  font-family: inherit;
  font-size: 12.5px;
  text-align: right;
}
.goal-input:hover { border-color: #BCD0F0; }
.goal-input:focus { outline: 0; border-color: var(--info); background: #fff; }

/* Notes */
.notes {
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  font-family: inherit;
  font-size: 12.5px;
  background: #fff;
  color: var(--ink);
  resize: vertical;
  min-height: 36px;
  max-height: 80px;
  text-align: left;
}
.notes:focus { outline: 0; border-color: var(--info); }

/* Hero banner */
.hero {
  background: linear-gradient(115deg, #0B0B0F 0%, #1A1A22 55%, #4A0B11 100%);
  color: #fff;
  border-radius: var(--radius-lg);
  padding: 22px 24px;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 20px;
  box-shadow: var(--shadow-lg);
  position: relative;
  overflow: hidden;
}
.hero::before {
  content: '';
  position: absolute;
  top: -40%; right: -10%;
  width: 360px; height: 360px;
  background: radial-gradient(closest-side, rgba(225,29,42,.55), transparent 70%);
  pointer-events: none;
}
.hero h2 {
  font-family: 'Manrope', sans-serif;
  margin: 0; font-size: 22px; font-weight: 800; letter-spacing: -.4px;
}
.hero p { margin: 6px 0 0; color: #C8C8CE; font-size: 13.5px; max-width: 56ch; }
.hero-stats { display: flex; gap: 26px; position: relative; z-index: 1; }
.hero-stat { text-align: right; }
.hero-stat .v {
  font-family: 'Manrope', sans-serif;
  font-size: 26px; font-weight: 800; letter-spacing: -.5px;
}
.hero-stat .l { color: #B5B5BD; font-size: 11px; text-transform: uppercase; letter-spacing: 1.1px; }

/* Toast */
.toast {
  position: fixed;
  bottom: 22px; right: 22px;
  background: var(--ink);
  color: #fff;
  padding: 10px 14px;
  border-radius: 10px;
  box-shadow: var(--shadow-lg);
  font-size: 12.5px;
  opacity: 0;
  transform: translateY(8px);
  pointer-events: none;
  transition: opacity .2s ease, transform .2s ease;
  z-index: 100;
}
.toast.show { opacity: 1; transform: translateY(0); }

/* Scrollbar polish */
.nav::-webkit-scrollbar, .table-scroll::-webkit-scrollbar { height: 8px; width: 8px; }
.nav::-webkit-scrollbar-thumb { background: rgba(255,255,255,.15); border-radius: 4px; }
.table-scroll::-webkit-scrollbar-thumb { background: rgba(0,0,0,.15); border-radius: 4px; }

/* Studio header row */
.studio-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}
.studio-head .meta {
  display: flex; gap: 16px; flex-wrap: wrap;
}
.studio-head .meta div { color: var(--muted); font-size: 12px; }
.studio-head .meta b { color: var(--ink); font-weight: 600; }

/* Marketing pace dots */
.dot-track {
  display: flex; gap: 3px;
}
.dot-track i {
  width: 8px; height: 8px; border-radius: 2px; background: var(--line);
}
.dot-track i.on { background: var(--rtr-red); }
.dot-track i.future { background: var(--line); }

/* Help text */
.help {
  color: var(--muted);
  font-size: 11.5px;
  background: #FAFAFB;
  border: 1px dashed var(--line-2);
  padding: 8px 12px;
  border-radius: 10px;
  margin-bottom: 14px;
}
.help b { color: var(--ink); }

/* Empty state */
.empty {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 40px 16px;
  color: var(--muted); text-align: center;
}
.empty .em-title { font-weight: 700; color: var(--ink); margin-bottom: 4px; }

/* Variance text colors */
.v-pos { color: var(--good); font-weight: 600; }
.v-neg { color: var(--bad);  font-weight: 600; }
.v-zero { color: var(--muted); }

/* Year pill on section titles (e.g. "Spend by category 2026") */
.year-pill {
  display: inline-block;
  vertical-align: middle;
  margin-left: 10px;
  background: var(--rtr-red);
  color: #fff;
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .6px;
  padding: 3px 9px;
  border-radius: 999px;
  position: relative;
  top: -2px;
}

/* Compact marketing-budget tables: dark centered headers, fits without scroll */
table.metrics.mkt {
  min-width: 0;
  width: 100%;
  table-layout: auto;
}
table.metrics.mkt.fixed {
  table-layout: fixed;
}
table.metrics.mkt th {
  background: var(--ink);
  color: #fff;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: .7px;
  text-transform: uppercase;
  padding: 10px 6px;
  text-align: center;
  border-bottom: 1px solid var(--ink);
  white-space: nowrap;
}
table.metrics.mkt th.left { text-align: left; padding-left: 14px; }
table.metrics.mkt td {
  text-align: center;
  padding: 7px 4px;
  font-size: 11.5px;
  white-space: nowrap;
}
table.metrics.mkt td.left { text-align: left; padding-left: 14px; }
table.metrics.mkt td.metric-name {
  font-size: 12px;
  font-weight: 600;
  white-space: normal;
  line-height: 1.25;
  max-width: 180px;
}
table.metrics.mkt input.cell,
table.metrics.mkt input.goal-input {
  min-width: 0;
  width: 100%;
  padding: 5px 3px;
  font-size: 11px;
  text-align: center;
}
table.metrics.mkt td.input-cell { padding: 4px 2px; }
table.metrics.mkt .pill { font-size: 10.5px; padding: 2px 7px; }
table.metrics.mkt tr.subtotal td {
  background: #FFF5F6;
  color: var(--ink);
  font-weight: 700;
  border-top: 2px solid var(--rtr-red);
  border-bottom: 2px solid var(--rtr-red);
}
table.metrics.mkt tr.subtotal td.left { color: var(--rtr-red); }

/* Year banner inside the studio grid card */
.grid-year-banner {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 18px;
  border-bottom: 1px solid var(--line);
  background: #FFF8F9;
}
.grid-year-banner.prior {
  background: #FAFAFB;
}
.grid-year-banner .grid-year-text {
  color: var(--muted);
  font-size: 12.5px;
  line-height: 1.5;
}
.grid-year-banner .grid-year-text b { color: var(--ink); font-weight: 600; }

/* =============== Studio metric grid (location pages) =============== */
table.metrics.studio { width: 100%; min-width: 0; }
table.metrics.studio.fixed { table-layout: fixed; }

table.metrics.studio th {
  background: var(--ink);
  color: #fff;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: .7px;
  text-transform: uppercase;
  padding: 10px 6px;
  text-align: center;
  vertical-align: middle;
  border-bottom: 1px solid var(--ink);
  white-space: nowrap;
  line-height: 1.25;
}
table.metrics.studio th.left { text-align: left; padding-left: 14px; }

/* Year band header — soft green for Current, muted slate for Prior */
table.metrics.studio th.year-band-current {
  background: #15803D;
  color: #fff;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  font-size: 11.5px;
  border-bottom: 1px solid #0F6A33;
}
table.metrics.studio th.year-band-prior {
  background: #475569;
  color: #fff;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  font-size: 11.5px;
  border-bottom: 1px solid #334155;
}

table.metrics.studio td {
  padding: 8px 4px;
  font-size: 11.5px;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
}
table.metrics.studio td.left { text-align: left; padding-left: 14px; }
table.metrics.studio td.metric-name {
  font-size: 12px;
  font-weight: 600;
  white-space: normal;
  line-height: 1.25;
}
table.metrics.studio td.calc {
  font-weight: 600;
}
table.metrics.studio td.calc b { font-weight: 700; }

table.metrics.studio td.input-cell { padding: 5px 2px; }
table.metrics.studio input.cell,
table.metrics.studio input.goal-input {
  min-width: 0;
  width: 100%;
  padding: 6px 4px;
  font-size: 11px;
  text-align: center;
}

/* Highlight the active current-month editable cell in soft green */
table.metrics.studio input.cell.current-month {
  background: #DCFCE7;
  border-color: #86EFAC;
  box-shadow: inset 0 0 0 1px rgba(22,163,74,.18);
  font-weight: 700;
  color: #0F6A33;
}
table.metrics.studio input.cell.current-month:focus {
  background: #fff;
  color: var(--ink);
  border-color: #16A34A;
  box-shadow: inset 0 0 0 1px #16A34A;
}

/* Legend below the studio table explaining what feeds the calc columns */
.calc-key {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 22px;
  padding: 12px 18px 14px;
  font-size: 11.5px;
  color: var(--muted);
  border-top: 1px solid var(--line);
  background: #FAFAFB;
}
.calc-key b { color: var(--ink); font-weight: 600; }

