﻿*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
[hidden] { display: none !important; }

:root {
  color-scheme: dark;

  --font-display: 'JetBrains Mono', 'SFMono-Regular', Consolas, monospace;
  --font-body:    'IBM Plex Sans', system-ui, -apple-system, sans-serif;

  --bg-base:    #0a0c10;
  --bg-alt:     #11151c;
  --bg-card:    #151a22;
  --bg-card-raised: #1b212b;
  --border:     #262e3b;
  --border-strong: #3a4456;

  --text-primary:   #eef1f6;
  --text-secondary: #9aa6bb;
  --text-muted:     #5d6779;

  --accent:         #c6ff4d;
  --accent-soft:    #9fdc2e;
  --accent-hover:   #ddff8a;
  --accent-ink:     #0a0c10;
  --accent-dim:     rgba(198, 255, 77, 0.12);
  --accent-glow:    rgba(198, 255, 77, 0.18);

  --good:    #6ee7a0;
  --good-dim: rgba(110, 231, 160, 0.14);
  --warn:    #ffb454;
  --warn-dim: rgba(255, 180, 84, 0.14);
  --danger:  #ff6b6b;
  --danger-dim: rgba(255, 107, 107, 0.14);
  --info:    #6fc7ff;
  --info-dim: rgba(111, 199, 255, 0.14);

  --slider-track:   linear-gradient(90deg, #c6ff4d 0%, #6ee7a0 45%, #6fc7ff 75%, #ffb454 100%);
  --slider-thumb:   linear-gradient(135deg, #ffffff 0%, #c6ff4d 100%);
  --scrollbar-track: rgba(17, 21, 28, 0.9);
  --scrollbar-thumb: linear-gradient(180deg, #c6ff4d 0%, #9fdc2e 100%);
  --scrollbar-thumb-hover: linear-gradient(180deg, #ddff8a 0%, #c6ff4d 100%);
  --navbar-bg:      rgba(10, 12, 16, 0.88);
  --shadow-soft:    rgba(0, 0, 0, 0.4);
  --grid-line:      rgba(198, 255, 77, 0.05);

  --radius:  0.25rem;
  --radius-lg: 0.4rem;
  --transition: 0.15s ease;
}

:root[data-theme="light"] {
  color-scheme: light;

  --bg-base:    #f5f4ee;
  --bg-alt:     #ece9df;
  --bg-card:    #fffffc;
  --bg-card-raised: #ffffff;
  --border:     #ddd8c8;
  --border-strong: #c4bda6;

  --text-primary:   #181a14;
  --text-secondary: #5b6151;
  --text-muted:     #8b8a76;

  --accent:         #5a8f00;
  --accent-soft:    #4a7700;
  --accent-hover:   #3f6600;
  --accent-ink:     #ffffff;
  --accent-dim:     rgba(90, 143, 0, 0.10);
  --accent-glow:    rgba(90, 143, 0, 0.14);

  --good:    #2f8f5b;
  --good-dim: rgba(47, 143, 91, 0.12);
  --warn:    #b8730a;
  --warn-dim: rgba(184, 115, 10, 0.12);
  --danger:  #c0392b;
  --danger-dim: rgba(192, 57, 43, 0.12);
  --info:    #2563a8;
  --info-dim: rgba(37, 99, 168, 0.12);

  --slider-track:   linear-gradient(90deg, #5a8f00 0%, #2f8f5b 45%, #2563a8 75%, #b8730a 100%);
  --slider-thumb:   linear-gradient(135deg, #ffffff 0%, #5a8f00 100%);
  --scrollbar-track: rgba(221, 216, 200, 0.9);
  --scrollbar-thumb: linear-gradient(180deg, #5a8f00 0%, #4a7700 100%);
  --scrollbar-thumb-hover: linear-gradient(180deg, #76b300 0%, #5a8f00 100%);
  --navbar-bg:      rgba(245, 244, 238, 0.92);
  --shadow-soft:    rgba(40, 38, 20, 0.12);
  --grid-line:      rgba(90, 143, 0, 0.07);
}

html { scroll-behavior: smooth; }

html {
  scrollbar-width: auto;
  scrollbar-color: var(--accent) var(--scrollbar-track);
}

body {
  font-family: var(--font-body);
  background:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px),
    var(--bg-base);
  background-size: 48px 48px, 48px 48px, 100% 100%;
  background-attachment: fixed;
  color: var(--text-primary);
  line-height: 1.65;
  font-size: 1rem;
  transition: background-color var(--transition), color var(--transition);
}

h1, h2, h3, h4, h5, h6,
.navbar__logo, .navbar__title,
.btn,
.page-tabs__label, .page-tabs__count,
.dashboard-hero__eyebrow, .dashboard-card__title, .dashboard-metric__value, .dashboard-metric__label,
.dashboard-attention__title, .dashboard-status-strip__label, .dashboard-status-strip__value,
.section__title, .gate__title,
.analytics-hero__eyebrow, .analytics-feature__eyebrow, .analytics-card__value, .analytics-card__label,
.analytics-section__title, .analytics-kpi__value, .analytics-kpi__label, .analytics-svg-chart__metric,
.status-chip, .analytics-badge, .row-detail__label, .row-detail__title, .ops-group__title,
th, .table-summary-chip, .form__label, .admin-panel__title, .admin-add-form__title,
.payment-window__title, .payment-window__tab, .theme-toggle, .dashboard-health-pill {
  font-family: var(--font-display);
}

* {
  scrollbar-width: thin;
  scrollbar-color: var(--accent) var(--scrollbar-track);
}

*::-webkit-scrollbar {
  width: 11px;
  height: 11px;
}

*::-webkit-scrollbar-track {
  background: var(--scrollbar-track);
  border-radius: 0;
}

*::-webkit-scrollbar-thumb {
  background: var(--scrollbar-thumb);
  border-radius: var(--radius);
  border: 2px solid var(--scrollbar-track);
}

*::-webkit-scrollbar-thumb:hover {
  background: var(--scrollbar-thumb-hover);
}

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

.container {
  width: 100%;
  max-width: 1600px;
  margin: 0 auto;
  padding: 0 2rem;
}

.btn {
  display: inline-block;
  padding: 0.65rem 1.5rem;
  border-radius: var(--radius);
  font-weight: 600;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  cursor: pointer;
  border: 1px solid transparent;
  transition: background var(--transition), color var(--transition), border-color var(--transition), transform var(--transition);
}
.btn:active { transform: translateY(1px); }

.btn--primary {
  background: var(--accent);
  color: var(--accent-ink);
  border-color: var(--accent);
}
.btn--primary:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
  color: var(--accent-ink);
}

.btn--ghost {
  background: transparent;
  color: var(--text-secondary);
  border-color: var(--border);
}
.btn--ghost:hover {
  border-color: var(--accent);
  color: var(--accent);
}

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

.gate {
  position: fixed;
  inset: 0;
  z-index: 999;
  background: var(--bg-base);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.4s ease;
}
.gate.hidden {
  opacity: 0;
  pointer-events: none;
}

.gate__card {
  position: relative;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-top: 2px solid var(--accent);
  border-radius: var(--radius-lg);
  padding: 2.5rem 2rem;
  width: 100%;
  max-width: 360px;
  text-align: center;
  box-shadow: 0 24px 60px var(--shadow-soft);
}

.gate__title {
  font-size: 1.2rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-primary);
  margin-bottom: 0.5rem;
}

.gate__sub {
  font-size: 0.9rem;
  color: var(--text-muted);
  margin-bottom: 1.5rem;
}

.gate__form {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.gate__input { text-align: center; }
.gate__input[type="password"] { letter-spacing: 0.1em; }

.gate__btn { width: 100%; }

.gate__error {
  font-size: 0.875rem;
  color: var(--danger);
  min-height: 1.2em;
}

.gate__card.shake {
  animation: shake 0.35s ease;
}

@keyframes shake {
  0%, 100% { transform: translateX(0); }
  20%       { transform: translateX(-8px); }
  40%       { transform: translateX(8px); }
  60%       { transform: translateX(-5px); }
  80%       { transform: translateX(5px); }
}

.navbar {
  background: var(--navbar-bg);
  border-bottom: 1px solid var(--border);
  border-top: 2px solid var(--accent);
  backdrop-filter: blur(10px);
  position: sticky;
  top: 0;
  z-index: 50;
}

.navbar__inner {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 4rem;
}

.navbar__logo {
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--text-primary);
  letter-spacing: 0.02em;
}
.navbar__logo::before {
  content: '> ';
  color: var(--accent);
}
.navbar__logo:hover { color: var(--accent); }

.navbar__title {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  color: var(--text-muted);
  font-family: var(--font-display);
  font-size: 0.78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  pointer-events: none;
}

.navbar__links {
  display: flex;
  align-items: center;
  gap: 2rem;
}
.navbar__logout {
  appearance: none;
  border: 0;
  background: transparent;
  color: var(--text-secondary);
  font: inherit;
  font-size: 0.95rem;
  font-weight: 500;
  cursor: pointer;
  padding: 0;
}
.navbar__links a {
  color: var(--text-secondary);
  font-size: 0.95rem;
  font-weight: 500;
}
.navbar__links a:hover,
.navbar__logout:hover { color: var(--text-primary); }

.section { padding: 5rem 0; }
.section--alt { background: var(--bg-alt); }

.section__title {
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 700;
  letter-spacing: -0.01em;
  margin-bottom: 1rem;
  color: var(--text-primary);
}

.section__subtext {
  margin-top: -0.55rem;
  color: var(--text-muted);
  font-size: 0.92rem;
}

.section__body {
  color: var(--text-secondary);
  max-width: 620px;
  font-size: 1.05rem;
}

.form { max-width: 560px; margin-top: 2rem; }

.form__group { display: flex; flex-direction: column; gap: 0.4rem; margin-bottom: 1.25rem; }

.form__label {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-family: var(--font-display);
}

.form__input {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text-primary);
  font-size: 1rem;
  font-family: inherit;
  padding: 0.65rem 0.9rem;
  transition: border-color var(--transition), box-shadow var(--transition);
  outline: none;
}
.form__input::placeholder { color: var(--text-muted); }
.form__input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-dim);
}

input[type="range"] {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 0.8rem;
  border-radius: var(--radius);
  background: var(--slider-track);
  background-size: 100% 100%;
  border: 1px solid var(--border);
  box-shadow: inset 0 1px 2px var(--shadow-soft);
  cursor: pointer;
}

input[type="range"]:focus {
  outline: none;
  box-shadow: 0 0 0 3px var(--accent-dim), inset 0 1px 2px var(--shadow-soft);
}

input[type="range"]::-webkit-slider-runnable-track {
  height: 0.8rem;
  border-radius: var(--radius);
  background: transparent;
}

input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 1.15rem;
  height: 1.15rem;
  margin-top: -0.2rem;
  border-radius: 50%;
  background: var(--slider-thumb);
  border: 2px solid var(--bg-card-raised);
  box-shadow: 0 4px 12px var(--shadow-soft), 0 0 0 2px var(--accent-glow);
}

input[type="range"]::-moz-range-track {
  height: 0.8rem;
  border-radius: var(--radius);
  background: var(--slider-track);
  border: 1px solid var(--border);
  box-shadow: inset 0 1px 2px var(--shadow-soft);
}

input[type="range"]::-moz-range-thumb {
  width: 1.15rem;
  height: 1.15rem;
  border-radius: 50%;
  background: var(--slider-thumb);
  border: 2px solid var(--bg-card-raised);
  box-shadow: 0 4px 12px var(--shadow-soft), 0 0 0 2px var(--accent-glow);
}

.form__textarea { resize: vertical; min-height: 120px; }

.form__feedback {
  margin-top: 1rem;
  font-size: 0.9rem;
  color: var(--text-secondary);
}
.form__feedback.success { color: var(--good); }
.form__feedback.error   { color: var(--danger); }

.admin-panel {
  background: var(--bg-alt);
  border-bottom: 1px solid var(--border);
  padding: 1.25rem 0;
}

.admin-panel__header {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
}

.admin-panel__title {
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--text-primary);
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

.admin-panel__title::before {
  content: '# ';
  color: var(--accent);
}

.admin-account-row {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.5rem 0.75rem;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  margin-bottom: 0.4rem;
}

.admin-account-row__name {
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--text-primary);
  flex: 0 0 100px;
}

.admin-account-row__hash {
  font-family: monospace;
  font-size: 0.78rem;
  color: var(--text-muted);
  flex: 1;
}

.admin-account-row__fee-wrap {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  flex: 0 0 auto;
  margin-left: auto;
}

.admin-account-row__fee-label {
  font-size: 0.82rem;
  color: var(--text-muted);
}

.admin-account-row__fee-input {
  width: 80px;
  padding: 0.2rem 0.4rem;
  font-size: 0.82rem;
  background: var(--bg-base);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text-primary);
}

.admin-account-row__email-input {
  flex: 1 1 auto;
  min-width: 260px;
  max-width: none;
}
.admin-account-row__fee-input:focus {
  outline: none;
  border-color: var(--accent);
}
.admin-account-row__fee-input:disabled { opacity: 0.35; }

.admin-account-row__fee-btn {
  padding: 0.2rem 0.55rem;
  font-size: 0.78rem;
  font-weight: 600;
  background: transparent;
  color: var(--accent);
  border: 1px solid var(--accent);
  border-radius: var(--radius);
  cursor: pointer;
  transition: background var(--transition);
}
.admin-account-row__fee-btn:hover:not(:disabled) { background: var(--accent-dim); }
.admin-account-row__fee-btn:disabled { opacity: 0.35; cursor: not-allowed; }

.admin-account-row__remove {
  padding: 0.25rem 0.65rem;
  font-size: 0.78rem;
  font-weight: 600;
  background: transparent;
  color: var(--danger);
  border: 1px solid var(--danger);
  border-radius: var(--radius);
  cursor: pointer;
  transition: background var(--transition);
  flex: 0 0 auto;
}
.admin-account-row__remove:hover:not(:disabled) { background: var(--danger-dim); }
.admin-account-row__remove:disabled { opacity: 0.35; cursor: not-allowed; }

.admin-add-form { margin-top: 1rem; }

.admin-add-form__title {
  font-size: 0.82rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  margin-bottom: 0.6rem;
}

.admin-add-form__row {
  display: flex;
  gap: 0.6rem;
  align-items: center;
  flex-wrap: wrap;
}

.admin-add-form__row .form__input {
  flex: 1;
  min-width: 140px;
  margin-bottom: 0;
}

.admin-add-form__error {
  font-size: 0.85rem;
  color: var(--danger);
  min-height: 1.2em;
  margin-top: 0.4rem;
}

.admin-loading { font-size: 0.85rem; color: var(--text-muted); padding: 0.25rem 0; }
.admin-error   { font-size: 0.85rem; color: var(--danger); padding: 0.25rem 0; }

.analytics-shell {
  --analytics-surface: var(--bg-card);
  --analytics-surface-soft: var(--bg-card);
  --analytics-border: var(--border);
  --analytics-shadow: 0 18px 40px var(--shadow-soft);
  --analytics-accent: var(--accent);
  --analytics-accent-2: var(--info);
  --analytics-accent-3: var(--warn);
  --analytics-accent-4: var(--danger);
  --analytics-track: var(--bg-alt);
  --analytics-gridline: var(--border);
  display: grid;
  gap: 1.1rem;
}

.analytics-hero {
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent);
  background:
    repeating-linear-gradient(135deg, var(--grid-line) 0 1px, transparent 1px 28px),
    var(--bg-card);
  border-radius: var(--radius-lg);
  box-shadow: var(--analytics-shadow);
  padding: 1.25rem 1.35rem;
}

.analytics-hero__intro {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(260px, 0.85fr);
  gap: 1rem;
  align-items: start;
}

.analytics-hero__copy {
  display: grid;
  gap: 0.45rem;
}

.analytics-hero__eyebrow,
.analytics-feature__eyebrow {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--analytics-accent);
}

.analytics-hero__title {
  margin: 0;
  font-size: clamp(1.5rem, 3vw, 2.1rem);
  line-height: 1;
}

.analytics-hero__text {
  margin: 0;
  max-width: 58ch;
  color: var(--text-secondary);
  font-size: 0.94rem;
}

.analytics-hero__controls {
  display: grid;
  gap: 0.8rem;
  justify-items: end;
}

.analytics-hero__meta {
  display: flex;
  gap: 0.65rem;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.analytics-hero__range {
  color: var(--text-muted);
  font-size: 0.82rem;
}

.analytics-hero__footer {
  margin-top: 0.85rem;
  padding-top: 0.85rem;
  border-top: 1px solid var(--border);
}

.analytics-range {
  display: inline-flex;
  gap: 0.4rem;
  flex-wrap: wrap;
  padding: 0.35rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg-alt);
}

.analytics-range__btn {
  border: 1px solid transparent;
  background: transparent;
  color: var(--text-secondary);
  border-radius: var(--radius);
  padding: 0.42rem 0.85rem;
  font: inherit;
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 0.78rem;
  cursor: pointer;
  transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}

.analytics-range__btn:hover {
  transform: translateY(-1px);
  color: var(--text-primary);
}

.analytics-range__btn.is-active {
  background: var(--accent-dim);
  border-color: var(--accent);
  color: var(--accent);
}

.analytics-layout {
  display: grid;
  gap: 1.1rem;
}

.analytics-band {
  display: grid;
  gap: 0.85rem;
}

.analytics-band--primary {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.analytics-band--secondary {
  grid-template-columns: 1.05fr 1.05fr 0.9fr;
  gap: 1rem;
}

.analytics-band--people {
  grid-template-columns: minmax(0, 1.5fr) minmax(320px, 0.9fr);
  gap: 1rem;
}

.analytics-warning {
  margin: 0.2rem 0 0;
  color: var(--warn);
  font-size: 0.82rem;
}

.analytics-band__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.75rem;
}

.analytics-section__head {
  display: flex;
  justify-content: space-between;
  gap: 0.6rem;
  align-items: baseline;
  flex-wrap: wrap;
}

.analytics-section__title {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 700;
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.analytics-section__meta {
  font-size: 0.82rem;
  color: var(--text-muted);
}

.analytics-grid--hero {
  margin-top: 0;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.analytics-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.95rem;
}

.analytics-card {
  position: relative;
  overflow: hidden;
  padding: 1.05rem 1.05rem 1rem;
  border: 1px solid var(--analytics-border);
  border-radius: var(--radius-lg);
  background: var(--analytics-surface-soft);
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  min-width: 0;
}

.analytics-card::after {
  content: '';
  position: absolute;
  inset: auto 0 0;
  height: 2px;
  background: linear-gradient(90deg, var(--accent), transparent);
  opacity: 0.9;
}

.analytics-card__label {
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.analytics-card__value {
  font-size: clamp(1.8rem, 2.8vw, 2.5rem);
  font-weight: 700;
  color: var(--text-primary);
  line-height: 0.98;
  letter-spacing: -0.03em;
}

.analytics-card__hint {
  font-size: 0.8rem;
  color: var(--text-muted);
}

.analytics-card--interactive {
  cursor: pointer;
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.analytics-card--interactive:hover {
  transform: translateY(-2px);
  border-color: var(--accent);
  box-shadow: 0 18px 32px var(--shadow-soft);
}

.analytics-card__subvalue {
  font-size: 0.82rem;
  color: var(--analytics-accent-2);
  font-weight: 600;
}

.analytics-card__sparkline {
  width: 100%;
  height: 38px;
  display: block;
  margin-top: auto;
}

.analytics-panel {
  border: 1px solid var(--analytics-border);
  border-radius: var(--radius-lg);
  background: var(--analytics-surface);
  padding: 1rem 1rem 1.05rem;
  min-width: 0;
  box-shadow: var(--analytics-shadow);
}

.analytics-feature {
  display: grid;
  gap: 0.85rem;
  border: 1px solid var(--analytics-border);
  border-radius: var(--radius-lg);
  background: var(--bg-card);
  padding: 1rem;
  box-shadow: var(--analytics-shadow);
}

.analytics-feature--review {
  border-left: 3px solid var(--info);
}

.analytics-feature--update {
  border-left: 3px solid var(--good);
}

.analytics-feature__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.analytics-feature__body {
  display: grid;
  grid-template-columns: 0.92fr 1.08fr;
  gap: 0.9rem;
}

.analytics-dual {
  display: grid;
  grid-template-columns: 1fr;
}

.analytics-panel__title {
  margin: 0 0 0.8rem;
  font-size: 0.85rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
}

.analytics-list,
.analytics-focus-list {
  display: grid;
  gap: 0.65rem;
}

.analytics-list__row {
  padding: 0.15rem 0 0.8rem;
}

.analytics-list__row,
.analytics-focus-item,
.analytics-details__item {
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
  align-items: center;
  padding-bottom: 0.65rem;
  border-bottom: 1px solid var(--border);
}

.analytics-list__row:last-child,
.analytics-focus-item:last-child,
.analytics-details__item:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

.analytics-list__label {
  font-weight: 600;
  color: var(--text-primary);
}

.analytics-list__meta,
.analytics-focus-item__detail,
.analytics-details__meta {
  font-size: 0.8rem;
  color: var(--text-muted);
}

.analytics-list__value {
  font-weight: 700;
  color: var(--text-primary);
  text-align: right;
}

.analytics-list__value--soft {
  color: var(--text-secondary);
}

.analytics-badge {
  display: inline-flex;
  align-items: center;
  border-radius: var(--radius);
  padding: 0.3rem 0.62rem;
  font-size: 0.75rem;
  font-weight: 700;
  background: var(--bg-alt);
  color: var(--text-secondary);
}

.analytics-badge--critical {
  background: var(--danger-dim);
  color: var(--danger);
}

.analytics-badge--warning {
  background: var(--warn-dim);
  color: var(--warn);
}

.analytics-badge--info {
  background: var(--info-dim);
  color: var(--info);
}

.analytics-svg-chart {
  display: grid;
  gap: 0.85rem;
}

.analytics-svg-chart__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.analytics-svg-chart__metric {
  font-size: 1.2rem;
  font-weight: 700;
}

.analytics-svg-chart__submetric {
  color: var(--text-muted);
  font-size: 0.8rem;
}

.analytics-svg-chart__legend {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  flex-wrap: wrap;
}

.analytics-svg-chart__legend-item {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.78rem;
  color: var(--text-secondary);
}

.analytics-svg-chart__swatch {
  width: 10px;
  height: 10px;
  border-radius: var(--radius);
  display: inline-block;
}

.analytics-svg-chart__frame {
  width: 100%;
  border-radius: var(--radius);
  background: var(--bg-alt);
  border: 1px solid var(--border);
  padding: 0.65rem;
}

.analytics-svg-chart__svg {
  width: 100%;
  height: auto;
  display: block;
}

.analytics-svg-chart__empty {
  color: var(--text-muted);
  font-size: 0.85rem;
}

.analytics-metric-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0.75rem;
  margin-bottom: 0.95rem;
}

.analytics-kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(125px, 1fr));
  gap: 0.75rem;
  margin-bottom: 0.9rem;
}

.analytics-kpi {
  padding: 0.85rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg-alt);
}

.analytics-kpi__label {
  display: block;
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  margin-bottom: 0.35rem;
}

.analytics-kpi__value {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--text-primary);
}

.analytics-table-card__head {
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
  align-items: baseline;
  margin-bottom: 0.85rem;
}

.analytics-table-wrap {
  overflow-x: auto;
}

.analytics-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.87rem;
}

.analytics-table th,
.analytics-table td {
  padding: 0.55rem 0.65rem;
  border-bottom: 1px solid var(--border);
  text-align: left;
}

.analytics-table th {
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
}

.analytics-table td:last-child,
.analytics-table th:last-child {
  text-align: right;
}

.analytics-table tbody tr:hover {
  background: var(--bg-alt);
}

.analytics-table__name {
  font-weight: 600;
}

.analytics-meter {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.analytics-meter__track {
  width: 72px;
  height: 6px;
  border-radius: var(--radius);
  background: var(--analytics-track);
  overflow: hidden;
}

.analytics-meter__fill {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--analytics-accent), var(--analytics-accent-2));
}

.analytics-meter__value {
  font-size: 0.8rem;
  color: var(--text-secondary);
}

.analytics-action {
  border: 0;
  background: transparent;
  color: var(--analytics-accent);
  cursor: pointer;
  padding: 0;
  font: inherit;
  text-align: left;
}

.analytics-action:hover {
  color: var(--accent-hover);
}

.analytics-focus-list {
  gap: 0.8rem;
}

.analytics-focus-item {
  align-items: flex-start;
}

.analytics-panel--focus .analytics-list__label {
  font-size: 0.95rem;
}

.analytics-panel--quality .analytics-list__row {
  align-items: flex-start;
}

.analytics-details__empty {
  color: var(--text-muted);
  font-size: 0.85rem;
}

@media (max-width: 900px) {
  .analytics-hero__intro,
  .analytics-band--primary,
  .analytics-band--secondary,
  .analytics-band--people,
  .analytics-feature__body {
    grid-template-columns: 1fr;
  }

  .analytics-hero__controls {
    justify-items: stretch;
  }

  .analytics-hero__meta {
    justify-content: space-between;
  }

  .analytics-grid--hero {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .analytics-hero {
    padding: 1rem;
  }

  .analytics-grid--hero {
    grid-template-columns: 1fr;
  }
}

.payment-window {
  margin-top: 1.5rem;
  border-top: 1px solid var(--border);
  padding-top: 1.25rem;
}

.payment-window__header {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 0.75rem;
}

.payment-window__title {
  font-size: 0.82rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
}

.payment-window__tabs {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 0.85rem;
  border-bottom: 1px solid var(--border);
}

.payment-window__tab {
  border: 0;
  background: transparent;
  color: var(--text-muted);
  padding: 0.55rem 0.75rem;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  font-size: 0.78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.payment-window__tab.is-active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

.payment-window__panel {
  overflow-x: auto;
}

.payment-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.88rem;
}

.payment-table th,
.payment-table td {
  padding: 0.5rem 0.75rem;
  text-align: left;
  border-bottom: 1px solid var(--border);
}

.payment-table th {
  color: var(--text-muted);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 600;
}

.payment-table__name   { font-weight: 600; color: var(--text-primary); }
.payment-table__count  { color: var(--text-secondary); }
.payment-table__fee    { color: var(--text-secondary); }
.payment-table__earned { font-weight: 700; color: var(--accent); }
.payment-table__paid   { color: var(--text-secondary); font-size: 0.875rem; }
.payment-table__outstanding { font-weight: 600; }
.payment-table__outstanding--due { color: var(--accent); font-weight: 600; }
.payment-table__log-input { width: 80px; padding: 2px 6px; font-size: 0.85rem; }
.payment-table__sub { color: var(--text-muted); font-size: 0.78rem; margin-top: 0.2rem; }
.payment-table__items { display: grid; gap: 0.45rem; }
.payment-table__item { display: flex; align-items: flex-start; gap: 0.5rem; }
.payment-table__item small { display: block; color: var(--text-muted); margin-top: 0.15rem; }
.payment-table__action-wrap { white-space: nowrap; }

.payment-table tbody tr:hover { background: var(--bg-card); }

.session-ledger {
  display: grid;
  gap: 0.9rem;
}

.session-ledger__summary {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.session-ledger__toolbar {
  display: grid;
  grid-template-columns: minmax(220px, 1.4fr) minmax(160px, 0.8fr) minmax(160px, 0.8fr);
  gap: 0.6rem;
  align-items: center;
}

.session-ledger__table-wrap {
  max-height: 60vh;
  overflow: auto;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
}

.payment-table--sessions {
  min-width: 980px;
}

.payment-table--sessions thead th {
  position: sticky;
  top: 0;
  background: var(--bg-card-raised);
  z-index: 1;
}

.session-ledger__editor-cell {
  background: color-mix(in srgb, var(--bg-card) 75%, transparent);
}

.session-ledger__editor {
  display: grid;
  grid-template-columns: minmax(200px, 1fr) minmax(200px, 1fr) minmax(220px, 1fr) auto;
  gap: 0.75rem;
  align-items: end;
  padding: 0.85rem 0;
}

.session-ledger__field {
  display: grid;
  gap: 0.35rem;
  font-size: 0.82rem;
  color: var(--text-secondary);
}

.session-ledger__meta {
  display: grid;
  gap: 0.2rem;
  font-size: 0.8rem;
  color: var(--text-muted);
}

.session-ledger__actions {
  display: flex;
  gap: 0.5rem;
  justify-content: flex-end;
}

.change-request-manager {
  display: grid;
  gap: 1rem;
  margin-bottom: 1rem;
}

.change-request-form {
  display: grid;
  grid-template-columns: minmax(130px, 1fr) minmax(130px, 1fr) minmax(120px, 0.8fr) auto;
  gap: 0.6rem;
  align-items: start;
}

.change-request-form textarea {
  grid-column: 1 / -2;
  min-height: 4.5rem;
  resize: vertical;
}

.change-request-list {
  display: grid;
  gap: 0.5rem;
}

.request-source-editor {
  display: grid;
  grid-template-columns: minmax(240px, 320px) minmax(0, 1fr);
  gap: 1rem;
}

.request-source-editor__list {
  display: grid;
  gap: 0.55rem;
  max-height: 32rem;
  overflow: auto;
}

.request-source-editor__item {
  display: block;
  width: 100%;
  text-align: left;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg-card);
  padding: 0.8rem 0.9rem;
  color: inherit;
  font: inherit;
  cursor: pointer;
}

.request-source-editor__item.is-active {
  border-color: var(--accent);
  background: var(--accent-dim);
}

.request-source-editor__item span,
.request-source-editor__item small {
  display: block;
  margin-top: 0.18rem;
  color: var(--text-muted);
}

.request-source-editor__form {
  display: grid;
  gap: 0.85rem;
}

.request-source-editor__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.7rem;
}

.request-source-editor__description {
  min-height: 9rem;
  grid-column: 1 / -1;
  resize: vertical;
}

.request-source-editor__checkbox {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  min-height: 42px;
  color: var(--text-secondary);
}

.request-source-editor__actions {
  display: flex;
  gap: 0.75rem;
  align-items: center;
  justify-content: space-between;
}

.change-request-row {
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
  align-items: center;
  padding: 0.65rem 0;
  border-bottom: 1px solid var(--border);
}

.change-request-row span,
.change-request-row small {
  display: block;
  color: var(--text-muted);
  margin-top: 0.15rem;
}


.main-content { min-height: calc(100vh - 4rem); }

.page-tabs {
  display: flex;
  gap: 0.15rem;
  padding-top: 1.5rem;
  border-bottom: 1px solid var(--border);
  overflow-x: auto;
  scrollbar-width: thin;
}

.page-tabs__tab {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  border: 1px solid transparent;
  border-bottom: none;
  border-radius: var(--radius) var(--radius) 0 0;
  background: transparent;
  color: var(--text-muted);
  padding: 0.68rem 1rem;
  font: inherit;
  font-size: 0.78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  cursor: pointer;
  transition:
    color var(--transition),
    border-color var(--transition),
    background var(--transition);
  white-space: nowrap;
}

.page-tabs__tab:hover {
  color: var(--text-primary);
  background: var(--bg-card);
}

.page-tabs__tab.is-active {
  color: var(--accent);
  border-color: var(--border);
  background: var(--bg-card);
}

.page-tabs__tab.is-active::after {
  content: '';
  position: absolute;
  left: -1px;
  right: -1px;
  bottom: -1px;
  height: 2px;
  background: var(--accent);
}

.page-tabs__label {
  line-height: 1;
}

.page-tabs__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.4rem;
  min-height: 1.4rem;
  padding: 0 0.4rem;
  border-radius: var(--radius);
  background: var(--bg-alt);
  color: var(--text-muted);
  font-size: 0.7rem;
  font-weight: 700;
}

.page-tabs__tab.is-active .page-tabs__count {
  background: var(--accent-dim);
  color: var(--accent);
}

.page-tab-panel {
  padding-top: 2rem;
}

.dashboard-hero {
  position: relative;
  display: grid;
  gap: 1rem;
  padding: 1.4rem 1.5rem;
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent);
  border-radius: var(--radius-lg);
  background:
    repeating-linear-gradient(135deg, var(--grid-line) 0 1px, transparent 1px 28px),
    var(--bg-card);
  box-shadow: 0 18px 40px var(--shadow-soft);
}

.dashboard-hero__intro {
  display: grid;
  gap: 0.45rem;
}

.dashboard-hero__eyebrow {
  font-size: 0.74rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--accent);
}

.dashboard-hero__eyebrow::before {
  content: '// ';
}

.dashboard-hero__title {
  font-size: 1.65rem;
  line-height: 1.1;
  color: var(--text-primary);
}

.dashboard-hero__text {
  color: var(--text-secondary);
  max-width: 56rem;
}

.dashboard-hero__warning {
  padding: 0.85rem 1rem;
  border: 1px solid var(--danger);
  border-radius: var(--radius);
  background: var(--danger-dim);
  color: var(--danger);
  font-weight: 600;
}

.dashboard-metrics {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 0.85rem;
  margin-top: 1rem;
}

.dashboard-metric {
  display: grid;
  gap: 0.3rem;
  padding: 0.9rem 1rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg-card);
}

.dashboard-metric__label {
  font-size: 0.74rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 700;
}

.dashboard-metric__value {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--accent);
}

.dashboard-metric__meta {
  color: var(--text-secondary);
  font-size: 0.84rem;
}

.dashboard-columns {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 1rem;
  margin-top: 1rem;
}

.dashboard-columns--primary {
  grid-template-columns: 1fr;
}

.dashboard-columns--secondary {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.dashboard-card {
  display: grid;
  gap: 1rem;
  padding: 1.25rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--bg-card);
}

.dashboard-card--stacked {
  margin-top: 1rem;
}

.dashboard-card--action-hero {
  margin-top: 1rem;
  padding: 1.4rem 1.45rem;
  border-color: var(--accent);
  background:
    repeating-linear-gradient(135deg, var(--grid-line) 0 1px, transparent 1px 28px),
    var(--bg-card);
  box-shadow: 0 0 0 1px var(--accent-dim), 0 18px 42px var(--shadow-soft);
}

.dashboard-card--muted {
  background: var(--bg-alt);
}

.dashboard-card__head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
}

.dashboard-card__head--stacked {
  display: grid;
  gap: 0.35rem;
}

.dashboard-card__title {
  color: var(--text-primary);
  font-size: 0.92rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.dashboard-card__meta {
  color: var(--text-muted);
  font-size: 0.83rem;
}

.ops-list {
  display: grid;
  gap: 0.75rem;
}

.ops-group {
  display: grid;
  gap: 0.55rem;
}

.ops-group + .ops-group {
  margin-top: 0.85rem;
}

.ops-group__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.ops-group__title {
  color: var(--text-primary);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.ops-item {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
  padding: 0.85rem 0;
  border-bottom: 1px solid var(--border);
}

.ops-item:first-child {
  padding-top: 0;
}

.ops-item:last-child {
  padding-bottom: 0;
  border-bottom: none;
}

.ops-item__main {
  display: grid;
  gap: 0.25rem;
  min-width: 0;
}

.ops-item__title {
  color: var(--text-primary);
  font-weight: 600;
}

.ops-item__meta {
  color: var(--text-muted);
  font-size: 0.84rem;
}

.ops-item__value {
  color: var(--text-secondary);
  font-size: 0.84rem;
  font-weight: 600;
  text-align: right;
}

.ops-item__link {
  border: 0;
  background: transparent;
  color: var(--accent);
  font: inherit;
  font-weight: 600;
  padding: 0;
  cursor: pointer;
  text-align: left;
}

.ops-item__link:hover {
  color: var(--text-primary);
}

.dashboard-attention {
  margin-top: 1rem;
  padding: 1rem 1.1rem;
  border: 1px solid var(--border);
  border-left: 3px solid var(--danger);
  border-radius: var(--radius-lg);
  background: var(--danger-dim);
}

.dashboard-attention__head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: baseline;
  flex-wrap: wrap;
}

.dashboard-attention__list {
  display: grid;
  gap: 0.65rem;
  margin-top: 0.85rem;
}

.dashboard-attention__item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding-top: 0.65rem;
  border-top: 1px solid var(--danger-dim);
}

.dashboard-attention__item:first-child {
  border-top: 0;
  padding-top: 0;
}

.dashboard-attention__main {
  display: grid;
  gap: 0.2rem;
}

.dashboard-attention__title {
  color: var(--text-primary);
  font-weight: 700;
}

.dashboard-attention__meta {
  color: var(--text-secondary);
  font-size: 0.84rem;
}

.dashboard-attention__link {
  border: 0;
  padding: 0;
  background: transparent;
  color: var(--text-primary);
  font: inherit;
  font-weight: 700;
  cursor: pointer;
}

.dashboard-attention__link:hover {
  color: var(--accent-hover);
}

.ops-empty {
  color: var(--text-muted);
  font-size: 0.92rem;
}

.status-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  width: fit-content;
  padding: 0.22rem 0.5rem;
  border: 1px solid currentColor;
  border-radius: var(--radius);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.status-chip--blue {
  color: var(--info);
  background: var(--info-dim);
}

.status-chip--amber {
  color: var(--warn);
  background: var(--warn-dim);
}

.status-chip--red {
  color: var(--danger);
  background: var(--danger-dim);
}

.status-chip--green {
  color: var(--good);
  background: var(--good-dim);
}

.status-chip--gray {
  color: var(--text-secondary);
  background: var(--bg-alt);
}

.placeholder-panel {
  min-height: 320px;
  display: grid;
  place-items: center;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--bg-card);
}

.placeholder-panel__text {
  font-size: 1.05rem;
  color: var(--text-secondary);
}

.db-header {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.25rem;
}

.table-toolbar {
  display: flex;
  gap: 0.75rem;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 0.75rem;
}

.table-summary-bar {
  display: flex;
  gap: 0.55rem;
  flex-wrap: wrap;
  margin-bottom: 0.75rem;
}

.table-summary-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  min-height: 2.2rem;
  padding: 0.38rem 0.8rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg-card);
  color: var(--text-secondary);
  font-family: var(--font-display);
  font-size: 0.78rem;
  font-weight: 600;
  cursor: pointer;
  transition: border-color var(--transition), color var(--transition), background var(--transition);
}

.table-summary-chip:hover {
  color: var(--text-primary);
  border-color: var(--accent);
}

.table-summary-chip.is-active {
  border-color: var(--accent);
  background: var(--accent-dim);
  color: var(--text-primary);
}

.table-summary-chip__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.4rem;
  height: 1.4rem;
  padding: 0 0.35rem;
  border-radius: var(--radius);
  background: var(--bg-alt);
  color: var(--text-primary);
  font-size: 0.72rem;
  font-weight: 700;
}

.table-view-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 0.75rem;
}

.table-view-meta__text {
  color: var(--text-muted);
  font-size: 0.84rem;
}

.table-toolbar__search {
  flex: 1 1 320px;
  min-width: 220px;
}

.table-toolbar__filter {
  flex: 0 0 180px;
}

.btn--sm {
  padding: 0.4rem 0.9rem;
  font-size: 0.85rem;
}

.table-status {
  font-size: 0.85rem;
  color: var(--text-muted);
  margin-bottom: 0.75rem;
  min-height: 1.2em;
}
.table-status--error { color: var(--danger); }

.dashboard-status-strip {
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background:
    linear-gradient(180deg, var(--accent-dim), transparent 120%),
    var(--bg-alt);
}

.dashboard-status-strip__inner {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.9rem 0;
  flex-wrap: wrap;
}

.dashboard-status-strip__identity,
.dashboard-status-strip__meta {
  display: grid;
  gap: 0.15rem;
  min-width: 140px;
}

.dashboard-status-strip__label {
  color: var(--text-muted);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-family: var(--font-display);
}

.dashboard-status-strip__value {
  color: var(--text-primary);
  font-size: 0.95rem;
}

.notifications-panel {
  margin-top: 1rem;
  padding: 1rem 1.1rem;
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent);
  border-radius: var(--radius-lg);
  background: var(--bg-card);
}

.notifications-panel__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.85rem;
}

.notifications-panel__title {
  margin: 0;
  font-size: 1rem;
  color: var(--text-primary);
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.notifications-panel__title::before {
  content: '# ';
  color: var(--accent);
}

.notification-item,
.triage-item,
.timeline-item,
.comment-item,
.blocker-item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.8rem 0;
  border-top: 1px solid var(--border);
}

.notification-item:first-child,
.triage-item:first-child,
.timeline-item:first-child,
.comment-item:first-child,
.blocker-item:first-child {
  border-top: 0;
  padding-top: 0;
}

.notification-item__title,
.triage-item__title,
.timeline-item__title,
.comment-item__title,
.blocker-item__title {
  font-weight: 700;
  color: var(--text-primary);
}

.notification-item__meta,
.triage-item__meta,
.timeline-item__meta,
.comment-item__meta,
.blocker-item__meta {
  margin-top: 0.25rem;
  color: var(--text-secondary);
  font-size: 0.9rem;
  white-space: pre-wrap;
}

.dashboard-health-list {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
  margin-left: auto;
}

.dashboard-health-pill {
  display: inline-flex;
  align-items: center;
  min-height: 2rem;
  padding: 0.3rem 0.7rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg-card);
  color: var(--text-secondary);
  font-size: 0.82rem;
  font-weight: 600;
  font-family: var(--font-display);
}

.dashboard-health-pill.is-loading {
  border-color: var(--info);
  color: var(--info);
}

.dashboard-health-pill.is-ok {
  border-color: var(--good);
  color: var(--good);
}

.dashboard-health-pill.is-error {
  border-color: var(--danger);
  color: var(--danger);
}

.dashboard-health-pill.is-stale {
  border-color: var(--warn);
  color: var(--warn);
}

#notificationsToggleBtn.is-unread {
  border-color: var(--danger);
  color: var(--danger);
}

.table-expand-controls {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.75rem;
}

.table-wrap {
  overflow-x: auto;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  scrollbar-width: auto;
  scrollbar-color: var(--accent) var(--scrollbar-track);
}

.table-wrap::-webkit-scrollbar { height: 10px; }
.table-wrap::-webkit-scrollbar-track { background: var(--scrollbar-track); border-radius: 0; }
.table-wrap::-webkit-scrollbar-thumb { background: var(--scrollbar-thumb); border-radius: var(--radius); border: 2px solid var(--scrollbar-track); }
.table-wrap::-webkit-scrollbar-thumb:hover { background: var(--scrollbar-thumb-hover); }

.db-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.88rem;
}

.db-table thead {
  background: var(--bg-alt);
  position: sticky;
  top: 0;
  z-index: 1;
}

.db-table th {
  padding: 0.7rem 1rem;
  text-align: left;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--accent);
  white-space: nowrap;
  border-bottom: 1px solid var(--border);
}

.db-table td {
  padding: 0.65rem 1rem;
  color: var(--text-secondary);
  border-bottom: 1px solid var(--border);
  max-width: 220px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.db-table tbody tr:last-child td { border-bottom: none; }

.db-table tbody tr:hover td {
  background: var(--bg-alt);
  color: var(--text-primary);
}

.table-loading {
  text-align: center;
  color: var(--text-muted);
  padding: 2rem !important;
  font-family: var(--font-display);
}

.db-table tbody tr { cursor: pointer; transition: background var(--transition); }
.db-table tbody tr.selected td {
  background: var(--accent-dim);
  color: var(--text-primary);
  border-bottom-color: var(--accent);
}

.row-detail {
  margin-top: 1.5rem;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-top: 2px solid var(--accent);
  border-radius: var(--radius-lg);
  padding: 1.75rem;
}

.row-detail__header {
  display: grid;
  gap: 0.9rem;
}

.row-detail__title {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0;
}

.row-detail__summary {
  display: flex;
  gap: 0.55rem;
  flex-wrap: wrap;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--border);
}

.row-detail__summary-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.3rem 0.7rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg-alt);
  color: var(--text-secondary);
  font-family: var(--font-display);
  font-size: 0.78rem;
  font-weight: 600;
}

.row-detail__next-step {
  display: grid;
  gap: 0.5rem;
  margin-top: 1rem;
  padding: 1rem 1.05rem;
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent);
  border-radius: var(--radius);
  background: var(--bg-alt);
}

.row-detail__next-copy {
  color: var(--text-primary);
  font-size: 0.96rem;
  line-height: 1.55;
}

.row-detail__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem 2rem;
  margin-top: 1rem;
}

.row-detail__field {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}

.row-detail__label {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
}

.row-detail__value {
  font-size: 0.95rem;
  color: var(--text-secondary);
  word-break: break-word;
  white-space: pre-wrap;
}

.row-detail__badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 0.2rem 0.55rem;
  border-radius: var(--radius);
  font-family: var(--font-display);
  font-size: 0.78rem;
  font-weight: 700;
}

.row-detail__badge--billable {
  color: var(--good);
  background: var(--good-dim);
}

.row-detail__badge--free {
  color: var(--warn);
  background: var(--warn-dim);
}

.row-detail__field--full {
  grid-column: 1 / -1;
}

.row-detail__input {
  width: 100%;
}

.row-detail__textarea {
  min-height: 120px;
  resize: vertical;
}

.row-detail__actions {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.9rem;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--border);
}

.row-detail__actions-group {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  flex-wrap: wrap;
}

.row-detail__actions-group--primary .btn {
  min-width: 8.75rem;
}

.row-detail__workflow {
  display: grid;
  gap: 1rem;
  margin-top: 1.25rem;
}

.row-detail__section {
  padding-top: 1rem;
  border-top: 1px solid var(--border);
}

.row-detail__section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.8rem;
}

.row-detail__section-title {
  margin: 0;
  font-size: 0.95rem;
  color: var(--text-primary);
}

.row-detail__inline-form {
  display: grid;
  gap: 0.75rem;
  margin-bottom: 0.9rem;
}

.row-detail__inline-form--split {
  grid-template-columns: minmax(200px, 240px) minmax(0, 1fr) auto;
  align-items: start;
}

.row-detail__note {
  color: var(--text-muted);
  font-size: 0.9rem;
}

.row-detail__status {
  font-size: 0.9rem;
  color: var(--text-secondary);
  min-height: 1.2em;
}

.row-detail__status--success { color: var(--good); }
.row-detail__status--error { color: var(--danger); }

.row-detail__future {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--border);
}

.row-detail__rename {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin: 0.6rem 0 0.85rem;
}

.session-notice {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(8px);
  z-index: 9500;
  cursor: pointer;
}
.session-notice[hidden] {
  display: none;
}
.session-notice__card {
  width: min(100%, 420px);
  padding: 1.4rem 1.3rem;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-strong);
  border-top: 3px solid var(--accent);
  background: var(--bg-card);
  box-shadow: 0 28px 80px var(--shadow-soft);
  text-align: center;
}
.session-notice__title {
  margin: 0 0 0.45rem;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--text-primary);
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.session-notice__message {
  margin: 0;
  color: var(--text-secondary);
  line-height: 1.5;
}
.session-notice__hint {
  margin: 0.85rem 0 0;
  color: var(--text-muted);
  font-size: 0.88rem;
  letter-spacing: 0.02em;
}

.confetti-canvas {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9001;
  width: 100%;
  height: 100%;
}

.btn--deny.btn-pulse,
.btn--accept.btn-pulse {
  animation: btn-pulse 0.28s ease;
}
@keyframes btn-pulse {
  0%   { transform: scale(1); }
  40%  { transform: scale(0.91); }
  100% { transform: scale(1); }
}

.theme-toggle-section {
  padding-top: 0.25rem;
}

.action-bar {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 1rem;
  padding: 0.35rem 0 1.25rem;
}

.action-bar--simple {
  justify-content: flex-start;
}

.theme-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.65rem;
  min-width: 9.25rem;
  padding: 0.55rem 0.85rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--bg-card);
  color: var(--text-primary);
  font: inherit;
  font-family: var(--font-display);
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  cursor: pointer;
  box-shadow: 0 8px 24px var(--shadow-soft);
  transition: border-color var(--transition), color var(--transition), background var(--transition);
}

.theme-toggle:hover {
  border-color: var(--accent);
  color: var(--accent);
}

.theme-toggle:focus-visible {
  outline: 3px solid var(--accent-dim);
  outline-offset: 3px;
}

.theme-toggle__track {
  position: relative;
  width: 2.45rem;
  height: 1.25rem;
  border-radius: 999px;
  background: var(--bg-alt);
  border: 1px solid var(--border);
  flex: 0 0 auto;
}

.theme-toggle__knob {
  position: absolute;
  top: 50%;
  left: 0.18rem;
  width: 0.82rem;
  height: 0.82rem;
  border-radius: 50%;
  background: var(--text-secondary);
  transform: translateY(-50%);
  transition: transform var(--transition), background var(--transition);
}

:root[data-theme="light"] .theme-toggle__knob {
  background: var(--accent);
  transform: translate(1.15rem, -50%);
}

.btn--deny {
  background: var(--danger);
  color: #fff;
  border-color: var(--danger);
}
.btn--deny:hover {
  filter: brightness(1.15);
  color: #fff;
}

.btn--accept {
  background: var(--good);
  color: var(--accent-ink);
  border-color: var(--good);
}
.btn--accept:hover {
  filter: brightness(1.1);
  color: var(--accent-ink);
}

@media (max-width: 1280px) {
  .container {
    padding: 0 1.5rem;
  }

  .admin-account-row {
    flex-wrap: wrap;
    align-items: flex-start;
  }

  .admin-account-row__name {
    flex: 0 0 120px;
  }

  .admin-account-row__email-input {
    min-width: 220px;
  }

  .admin-account-row__fee-wrap {
    margin-left: 0;
    width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .change-request-form {
    grid-template-columns: minmax(180px, 1fr) minmax(180px, 1fr) minmax(140px, 1fr);
  }

  .request-source-editor {
    grid-template-columns: 1fr;
  }

  .change-request-form textarea {
    grid-column: 1 / -1;
  }

  .change-request-row {
    align-items: flex-start;
  }

  .action-bar {
    padding: 0.35rem 0 1rem;
    gap: 0.8rem;
  }

  .theme-toggle {
    min-width: auto;
  }
}

@media (max-width: 820px) {
  .container {
    padding: 0 1rem;
  }

  .dashboard-columns,
  .dashboard-columns--secondary {
    grid-template-columns: 1fr;
  }

  .row-detail__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .row-detail__actions-group {
    width: 100%;
  }

  .admin-account-row {
    gap: 0.75rem;
  }

  .admin-account-row__name,
  .admin-account-row__email-input,
  .admin-account-row__fee-wrap,
  .admin-account-row__remove {
    width: 100%;
    flex: 1 1 100%;
  }

  .admin-account-row__fee-wrap {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 0.5rem;
    align-items: center;
  }

  .admin-account-row__fee-input {
    width: 100%;
    min-width: 0;
  }

  .admin-account-row__fee-btn,
  .admin-account-row__remove {
    width: 100%;
    text-align: center;
  }

  .admin-add-form__row {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  .admin-add-form__row .form__input,
  .admin-add-form__row .btn {
    min-width: 0;
    width: 100%;
  }

  .payment-window__tabs {
    overflow-x: auto;
    padding-bottom: 0.15rem;
  }

  .payment-table {
    min-width: 760px;
  }

  .session-ledger__toolbar,
  .session-ledger__editor {
    grid-template-columns: 1fr;
  }

  .session-ledger__actions {
    justify-content: flex-start;
  }

  .change-request-form {
    grid-template-columns: 1fr 1fr;
  }

  .request-source-editor__grid {
    grid-template-columns: 1fr;
  }

  .request-source-editor__actions {
    flex-direction: column;
    align-items: flex-start;
  }

  .change-request-form textarea {
    grid-column: 1 / -1;
  }

  .change-request-row {
    flex-direction: column;
  }

  .row-detail__grid {
    grid-template-columns: 1fr;
  }

  .row-detail__actions .btn,
  .row-detail__rename .btn,
  .row-detail__rename .row-detail__input {
    width: 100%;
  }

  .theme-toggle {
    width: auto;
  }
}

@media (max-width: 640px) {
  .page-tabs {
    gap: 0.5rem;
    padding-top: 1rem;
  }

  .page-tabs__tab {
    padding-inline: 0.85rem;
    padding-block: 0.72rem;
  }

  .navbar__title { font-size: 0.9rem; }
  .navbar__links {
    display: flex;
    gap: 1rem;
  }

  .section { padding: 3rem 0; }

  .admin-panel {
    padding: 1rem 0;
  }

  .admin-panel__header {
    gap: 0.75rem;
  }

  .admin-account-row {
    padding: 0.85rem;
  }

  .admin-account-row__fee-wrap {
    grid-template-columns: 1fr;
  }

  .admin-account-row__fee-label {
    display: none;
  }

  .admin-add-form__row,
  .change-request-form {
    grid-template-columns: 1fr;
  }

  .table-expand-controls {
    flex-wrap: wrap;
  }

  .table-expand-controls .btn {
    width: 100%;
  }

  .table-summary-bar,
  .table-view-meta,
  .dashboard-attention__item {
    flex-direction: column;
    align-items: stretch;
  }

  .table-wrap {
    overflow: visible;
    border: none;
    background: transparent;
  }

  .db-table,
  .db-table thead,
  .db-table tbody,
  .db-table tr,
  .db-table th,
  .db-table td {
    display: block;
    width: 100%;
  }

  .db-table thead {
    display: none;
  }

  .db-table tbody {
    display: grid;
    gap: 0.85rem;
  }

  .db-table tbody tr {
    cursor: pointer;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background: var(--bg-card);
    padding: 0.9rem 1rem;
  }

  .db-table tbody tr.selected {
    border-color: var(--accent);
    background: var(--accent-dim);
  }

  .db-table td {
    display: grid;
    grid-template-columns: minmax(88px, 108px) 1fr;
    gap: 0.65rem;
    align-items: start;
    max-width: none;
    white-space: normal;
    overflow: visible;
    text-overflow: initial;
    border: none;
    padding: 0.35rem 0;
    color: var(--text-primary);
    background: transparent !important;
  }

  .db-table td::before {
    content: '';
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--text-muted);
  }

  .db-table .table-loading,
  .db-table td[colspan] {
    display: block;
    text-align: center;
    padding: 1.25rem 0;
  }

  .db-table td[colspan]::before,
  .db-table .table-loading::before {
    content: none;
  }

  #contactsTable td:nth-child(1)::before { content: 'Place'; }
  #contactsTable td:nth-child(2)::before { content: 'Age'; }
  #contactsTable td:nth-child(3)::before { content: 'Attention'; }
  #contactsTable td:nth-child(4)::before { content: 'Next'; }
  #contactsTable td:nth-child(5)::before { content: 'Site'; }
  #contactsTable td:nth-child(6)::before { content: 'Maps'; }

  #updateRequestsTable td:nth-child(1)::before { content: 'Website'; }
  #updateRequestsTable td:nth-child(2)::before { content: 'Request'; }
  #updateRequestsTable td:nth-child(3)::before { content: 'Assigned'; }
  #updateRequestsTable td:nth-child(4)::before { content: 'Status'; }
  #updateRequestsTable td:nth-child(5)::before { content: 'Due'; }
  #updateRequestsTable td:nth-child(6)::before { content: 'Blockers'; }
  #updateRequestsTable td:nth-child(7)::before { content: 'Next'; }

  .row-detail {
    margin-top: 1rem;
    padding: 1rem;
  }

  .row-detail__title {
    font-size: 1rem;
    margin-bottom: 1rem;
  }

  .action-bar {
    padding: 0.9rem 0;
  }

  .theme-toggle #themeToggleLabel { display: none; }
}

