/* Atlantic Fox Dashboard */

:root {
  --navy: #1B2A4A;
  --navy-dark: #111D33;
  --navy-light: #2A3D66;
  --amber: #C4842D;
  --amber-light: #D4973F;
  --amber-glow: #E8AD5A;
  --cream: #F8F6F2;
  --slate: #B2BEC3;
  --charcoal: #2D3436;
  --teal: #5eb7ad;
  --teal-dark: #1b7c9a;
  --red: #ef4444;
  --green: #22c55e;
  --font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --mono: 'SF Mono', 'Fira Code', Consolas, monospace;
  /* TDG compatibility aliases */
  --text-primary: var(--cream);
  --text-secondary: var(--slate);
  --text-muted: #7f8c8d;
  --accent-green: var(--teal);
  --accent-blue: #3b82f6;
  --accent-purple: #8b5cf6;
  --accent-amber: var(--amber-glow);
  --accent-cyan: #06b6d4;
  --accent-rose: #f43f5e;
  --bg-card: var(--card-bg);
  --font-mono: var(--mono);
  --radius: 10px;
  --card-bg: rgba(27, 42, 74, 0.6);
  --border: rgba(42, 61, 102, 0.4);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: var(--font);
  background: var(--navy-dark);
  color: var(--cream);
  line-height: 1.5;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

a { color: inherit; text-decoration: none; }
button { cursor: pointer; font-family: inherit; border: none; background: none; }
img { max-width: 100%; display: block; }

.hidden { display: none !important; }

/* ── Navbar ── */
.navbar {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(17, 29, 51, 0.92);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
}

.navbar-inner {
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 0 24px;
  height: 56px;
}

.navbar-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
}

.navbar-logo { height: 32px; width: auto; }

.navbar-title {
  font-weight: 700;
  font-size: 15px;
  color: var(--cream);
  letter-spacing: -0.01em;
}

.navbar-links {
  display: flex;
  gap: 2px;
  flex: 1;
}

.nav-link {
  padding: 7px 14px;
  font-size: 13px;
  font-weight: 500;
  color: var(--slate);
  border-radius: 6px;
  transition: color 0.15s, background 0.15s;
}

.nav-link:hover { color: var(--cream); background: rgba(255,255,255,0.06); }
.nav-link.active { color: var(--amber-glow); background: rgba(196,132,45,0.1); }

.navbar-right {
  display: flex;
  align-items: center;
  gap: 16px;
}

.navbar-status {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  color: var(--slate);
  opacity: 0.7;
}

.status-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--teal);
  animation: pulse 2.5s ease-in-out infinite;
}

.btn-ghost {
  padding: 5px 12px;
  font-size: 12px;
  font-weight: 500;
  color: var(--slate);
  border: 1px solid var(--border);
  border-radius: 6px;
  transition: all 0.15s;
}

.btn-ghost:hover { color: var(--cream); border-color: var(--slate); }

/* ── Page Container ── */
#app {
  max-width: 1400px;
  margin: 0 auto;
  padding: 28px 24px;
  min-height: calc(100vh - 56px);
}

/* ── Login ── */
.login-page {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  padding: 24px;
  background: var(--navy-dark);
}

.login-box {
  width: 100%;
  max-width: 360px;
  background: var(--navy);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 40px 32px;
}

.login-header {
  text-align: center;
  margin-bottom: 28px;
}

.login-header img {
  width: 52px; height: 52px;
  margin: 0 auto 14px;
}

.login-header h1 {
  font-size: 20px;
  font-weight: 700;
  color: var(--cream);
  margin: 0;
}

.login-header p {
  font-size: 13px;
  color: var(--slate);
  margin: 4px 0 0;
}

.form-group { margin-bottom: 16px; }

.form-group label {
  display: block;
  font-size: 12px;
  font-weight: 500;
  color: var(--slate);
  margin-bottom: 5px;
}

.form-input {
  width: 100%;
  padding: 9px 12px;
  font-size: 14px;
  font-family: var(--font);
  color: var(--cream);
  background: var(--navy-dark);
  border: 1px solid var(--border);
  border-radius: 7px;
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}

.form-input:focus {
  border-color: var(--amber);
  box-shadow: 0 0 0 3px rgba(196,132,45,0.15);
}

.form-input::placeholder { color: rgba(178,190,195,0.4); }

.login-error {
  color: var(--red);
  font-size: 13px;
  min-height: 20px;
  margin-bottom: 6px;
}

.btn-primary {
  width: 100%;
  padding: 10px 20px;
  font-size: 14px;
  font-weight: 600;
  color: #fff;
  background: var(--amber);
  border: none;
  border-radius: 7px;
  cursor: pointer;
  transition: background 0.15s;
}

.btn-primary:hover { background: var(--amber-light); }
.btn-primary:disabled { opacity: 0.6; cursor: not-allowed; }

/* ── Cards ── */
.card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px;
}

/* ── Glass Card (TDG compat) ── */
.glass-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px;
}

.glass-card:hover { border-color: rgba(42,61,102,0.6); }

/* ── Stat Cards ── */
.stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 24px;
}

.stat-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px;
}

.stat-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--slate);
  margin-bottom: 6px;
}

.stat-value {
  font-size: 28px;
  font-weight: 700;
  line-height: 1.1;
  color: var(--cream);
}

.stat-value.amber { color: var(--amber-glow); }

/* ── Section Headers ── */
.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}

.section-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--cream);
}

/* ── Grid ── */
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }

.error-card {
  background: var(--card-bg);
  border: 1px solid rgba(239,68,68,0.4);
  border-radius: var(--radius);
  padding: 24px;
  color: var(--red);
}

.loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 80px 0;
  gap: 14px;
  color: var(--slate);
  font-size: 14px;
}

.btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  font-size: 13px;
  font-weight: 500;
  color: var(--cream);
  background: rgba(42,61,102,0.5);
  border: 1px solid var(--border);
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.15s;
}

.btn:hover { background: rgba(42,61,102,0.8); border-color: var(--slate); }

.text-sm { font-size: 13px; }
.text-xs { font-size: 11px; }
.text-muted { color: var(--slate); }
.animate-in { animation: fadeIn 0.3s ease-out both; }
.session-card:hover { border-color: var(--amber) !important; }

/* ── Tables ── */
.table-wrap {
  overflow-x: auto;
}

table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}

thead th {
  text-align: left;
  padding: 10px 14px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--slate);
  border-bottom: 1px solid var(--border);
}

tbody td {
  padding: 10px 14px;
  border-bottom: 1px solid rgba(42,61,102,0.2);
  color: var(--slate);
}

tbody tr { transition: background 0.1s; }
tbody tr:hover { background: rgba(255,255,255,0.03); }

/* ── Bar Charts (CSS) ── */
.bar-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
}

.bar-label {
  width: 130px;
  font-size: 12px;
  color: var(--slate);
  text-align: right;
  flex-shrink: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.bar-track {
  flex: 1;
  height: 22px;
  background: rgba(42,61,102,0.3);
  border-radius: 4px;
  overflow: hidden;
}

.bar-fill {
  height: 100%;
  border-radius: 4px;
  transition: width 0.6s ease-out;
  min-width: 2px;
}

.bar-value {
  width: 70px;
  font-size: 12px;
  font-weight: 500;
  color: var(--cream);
  font-family: var(--mono);
}

.clickable-bar { cursor: pointer; padding: 2px 4px; border-radius: 4px; transition: background 0.15s; }
.clickable-bar:hover { background: rgba(255,255,255,0.05); }

/* ── Filters ── */
.filter-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}

.filter-select {
  padding: 7px 10px;
  font-size: 13px;
  font-family: var(--font);
  color: var(--cream);
  background: var(--navy);
  border: 1px solid var(--border);
  border-radius: 6px;
  outline: none;
  cursor: pointer;
}

.filter-select:focus { border-color: var(--amber); }

.filter-input {
  padding: 7px 10px;
  font-size: 13px;
  font-family: var(--font);
  color: var(--cream);
  background: var(--navy);
  border: 1px solid var(--border);
  border-radius: 6px;
  outline: none;
  min-width: 200px;
}

.filter-input:focus { border-color: var(--amber); }
.filter-input::placeholder { color: rgba(178,190,195,0.4); }

/* ── Loading / Empty ── */
.page-loading, .page-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 80px 0;
  gap: 14px;
  color: var(--slate);
  font-size: 14px;
}

.spinner {
  width: 28px; height: 28px;
  border: 3px solid var(--border);
  border-top-color: var(--amber);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
}

/* ── Badges ── */
.badge {
  display: inline-block;
  padding: 2px 8px;
  font-size: 11px;
  font-weight: 600;
  border-radius: 9999px;
}

.badge-amber { color: var(--amber-glow); background: rgba(196,132,45,0.12); }
.badge-teal  { color: var(--teal); background: rgba(94,183,173,0.12); }
.badge-red   { color: var(--red); background: rgba(239,68,68,0.12); }

/* ── Partner Cards ── */
.partner-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  transition: border-color 0.15s;
}

.partner-card:hover { border-color: var(--amber); }

.partner-name { font-size: 15px; font-weight: 600; color: var(--cream); }
.partner-slug {
  font-size: 11px;
  color: var(--slate);
  font-family: var(--mono);
  margin-top: 4px;
}
.partner-share {
  font-size: 22px;
  font-weight: 700;
  color: var(--amber-glow);
}
.partner-share-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--slate);
  text-align: right;
}

/* ── Revenue Breakdown ── */
.revenue-line {
  display: flex;
  justify-content: space-between;
  font-size: 13px;
  padding: 6px 0;
}

.revenue-line + .revenue-line { border-top: 1px solid rgba(42,61,102,0.2); }

.revenue-label { color: var(--slate); }
.revenue-value { color: var(--cream); font-weight: 500; font-family: var(--mono); }
.revenue-value.amber { color: var(--amber-glow); font-weight: 700; font-size: 16px; }

/* ── Skeleton Loading ── */
.skeleton {
  background: linear-gradient(90deg, var(--card-bg) 25%, rgba(42,61,102,0.5) 50%, var(--card-bg) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s ease-in-out infinite;
  border-radius: var(--radius);
}

.skeleton-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 24px; }
.skeleton-card { height: 100px; border: 1px solid var(--border); }
.skeleton-block { height: 200px; border: 1px solid var(--border); margin-bottom: 16px; }
.skeleton-bar { height: 300px; border: 1px solid var(--border); }

/* ── Animations ── */
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes shimmer { 0% { background-position: -200% 0; } 100% { background-position: 200% 0; } }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.3; } }
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

.fade-in { animation: fadeIn 0.3s ease-out both; }

/* ── Scrollbar ── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.08); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,0.15); }

/* ── Light Mode ── */
body.light {
  --navy: #ffffff;
  --navy-dark: #f5f5f5;
  --navy-light: #e8ecf0;
  --cream: #1a1a2e;
  --slate: #4a5568;
  --charcoal: #2d3748;
  --card-bg: rgba(255,255,255,0.9);
  --border: rgba(0,0,0,0.08);
}

body.light .navbar { background: rgba(255,255,255,0.92); }
body.light .form-input { background: #f5f5f5; color: #1a1a2e; border-color: rgba(0,0,0,0.12); }
body.light .filter-select { background: #fff; color: #1a1a2e; border-color: rgba(0,0,0,0.12); }
body.light .filter-input { background: #fff; color: #1a1a2e; border-color: rgba(0,0,0,0.12); }
body.light .btn-ghost { color: #4a5568; border-color: rgba(0,0,0,0.12); }
body.light .btn-ghost:hover { color: #1a1a2e; border-color: rgba(0,0,0,0.25); }
body.light .bar-track { background: rgba(0,0,0,0.06); }
body.light tbody td { border-bottom-color: rgba(0,0,0,0.06); }
body.light thead th { border-bottom-color: rgba(0,0,0,0.1); }
body.light tbody tr:hover { background: rgba(0,0,0,0.02); }
body.light .login-box { background: #fff; }
body.light .skeleton { background: linear-gradient(90deg, #e8ecf0 25%, #f5f5f5 50%, #e8ecf0 75%); background-size: 200% 100%; }

/* ── Responsive ── */
@media (max-width: 1024px) {
  .stats-row { grid-template-columns: repeat(2, 1fr); }
  .grid-3 { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 768px) {
  .stats-row, .grid-2, .grid-3 { grid-template-columns: 1fr; }
  .navbar-status { display: none; }
  .navbar-links { display: none; }
  #app { padding: 16px; }
  .bar-label { width: 80px; }
}
