/* Edge Engine UI: production server-rendered site.
   Dark navy/blue foundation, blue + orange accents, premium sports-tech aesthetic. */

:root {
  /* Core palette */
  --ee-surface: #0B1220;
  --ee-surface-alt: #0F1A2E;
  --ee-card: #111827;
  --ee-border: #1F2937;
  --ee-text: #E5E7EB;
  --ee-muted: #9CA3AF;
  --ee-blue: #3B82F6;
  --ee-blue-hover: #2563eb;
  --ee-orange: #F97316;
  --ee-orange-dark: #EA580C;
  --ee-success: #22C55E;
  --ee-warning: #F59E0B;
  --ee-danger: #EF4444;
  /* Legacy / compatibility */
  --color-edge-positive: var(--ee-success);
  --color-edge-neutral: var(--ee-muted);
  --color-edge-negative: var(--ee-danger);
  --primary: #1e3a5f;
  --primary-dark: #172554;
  --primary-hover: var(--ee-blue);
  --accent: var(--ee-orange);
  --bg-soft: var(--ee-surface-alt);
  --bg-dark: var(--ee-surface);
  --surface: var(--ee-card);
  --border: var(--ee-border);
  --text: var(--ee-text);
  --text-muted: var(--ee-muted);
  --panel: var(--ee-card);
  --primary-600: var(--ee-blue);
  --primary-700: var(--ee-blue-hover);
  --link: var(--ee-blue);
  --link-hover: var(--ee-orange);
  --radius-card: 0.75rem;
  --radius-badge: 9999px;
  --shadow-card: 0 1px 3px 0 rgb(0 0 0 / 0.25), 0 1px 2px -1px rgb(0 0 0 / 0.2);
  --shadow-card-hover: 0 6px 16px -4px rgb(0 0 0 / 0.35);
  --shadow-subtle: 0 2px 8px -2px rgb(0 0 0 / 0.2);
  --card-radius: 14px;
}

body {
  background: var(--ee-surface);
  color: var(--ee-text);
}

/* App layout (dashboard, account, accuracy, etc.): dark background */
.edge-app-bg {
  background: var(--ee-surface);
  color: var(--ee-text);
}

/* Scoped overrides: make Tailwind-style classes use dark theme inside app main */
.edge-app-main .bg-white,
.edge-app-main .bg-slate-50 { background: var(--ee-card) !important; }
.edge-app-main .bg-slate-100 { background: var(--ee-surface-alt) !important; }
.edge-app-main .text-slate-900,
.edge-app-main .text-gray-900 { color: var(--ee-text) !important; }
.edge-app-main .text-slate-700,
.edge-app-main .text-slate-600,
.edge-app-main .text-gray-600,
.edge-app-main .text-gray-700 { color: var(--ee-muted) !important; }
.edge-app-main .text-slate-500,
.edge-app-main .text-gray-500 { color: var(--ee-muted) !important; }
.edge-app-main .text-slate-400,
.edge-app-main .text-gray-400 { color: var(--ee-muted) !important; }
.edge-app-main .border-slate-200,
.edge-app-main .border-slate-300,
.edge-app-main .border-gray-200,
.edge-app-main .border-gray-300 { border-color: var(--ee-border) !important; }
.edge-app-main .divide-slate-200 > * + * { border-color: var(--ee-border) !important; }
.edge-app-main .divide-y.divide-slate-200 > * + * { border-top-color: var(--ee-border) !important; }

/* Landing: full dark theme */
.edge-theme { background: var(--ee-surface); color: var(--ee-text); }

/* Header: solid dark with subtle fade + border (landing and app) */
.edge-header,
.edge-app-header {
  background: linear-gradient(to bottom, #0B1220, #0B1220ee);
  border-bottom: 1px solid var(--ee-border);
  backdrop-filter: blur(6px);
}
.edge-text { color: var(--ee-text); }
.edge-muted { color: var(--ee-muted); }
.edge-section { background: var(--ee-card); border: 1px solid var(--ee-border); }
.edge-section-alt { background: var(--ee-surface-alt); border-top: 1px solid var(--ee-border); }
.edge-footer-cta { background: var(--ee-surface); border-top: 1px solid var(--ee-border); }

/* Buttons */
.edge-btn-secondary {
  border: 1px solid var(--ee-border);
  color: var(--ee-text);
  background: var(--ee-card);
  border-radius: 10px;
  transition: all 0.15s ease;
}
.edge-btn-secondary:hover {
  background: var(--ee-surface-alt);
  border-color: var(--ee-muted);
  color: var(--ee-text);
}
.edge-btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--ee-orange) 0%, var(--ee-orange-dark) 100%);
  color: #fff !important;
  border: none;
  border-radius: 10px;
  padding: 12px 24px;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.15s ease;
  box-shadow: var(--shadow-card);
}
.edge-btn-primary:hover {
  background: linear-gradient(135deg, var(--ee-orange-dark) 0%, var(--ee-orange) 100%);
  color: #fff !important;
  transform: translateY(-1px);
  box-shadow: var(--shadow-card-hover);
}

/* App header (layout.html): uses .edge-header, .edge-app-header block above */
.edge-app-nav-brand { color: var(--ee-text); }
.edge-app-nav-brand:hover { color: #fff; }
.edge-app-header .nav-link { color: var(--ee-muted); }
.edge-app-header .nav-link:hover { color: var(--ee-text); background: rgba(255,255,255,0.06); }
.edge-app-header .edge-muted { color: var(--ee-muted); }
.edge-app-header a[href="/logout"]:hover { color: #fca5a5; }
.edge-panel-border { border-color: var(--ee-border) !important; }

/* Hero (landing) */
.hero-section { background: linear-gradient(160deg, var(--ee-surface) 0%, var(--ee-surface-alt) 50%, #1e3a5f 100%); }
.hero-bg { position: absolute; inset: 0; background: radial-gradient(ellipse 80% 50% at 50% -20%, rgba(59, 130, 246, 0.12) 0%, transparent 50%); pointer-events: none; }
.hero-grid { position: absolute; inset: 0; background-image: repeating-linear-gradient(0deg, transparent, transparent 31px, rgba(255,255,255,0.03) 31px, rgba(255,255,255,0.03) 32px), repeating-linear-gradient(90deg, transparent, transparent 31px, rgba(255,255,255,0.03) 31px, rgba(255,255,255,0.03) 32px); pointer-events: none; }
.hero-glow { position: absolute; inset: 0; background: radial-gradient(circle at 70% 30%, rgba(249, 115, 22, 0.06) 0%, transparent 40%); pointer-events: none; }

/* Landing: override light sections to dark */
body.edge-theme .bg-white { background: var(--ee-card) !important; }
body.edge-theme .bg-slate-50 { background: var(--ee-surface-alt) !important; }
body.edge-theme .text-slate-900 { color: var(--ee-text) !important; }
body.edge-theme .text-slate-800 { color: var(--ee-text) !important; }
body.edge-theme .text-slate-600,
body.edge-theme .text-slate-500 { color: var(--ee-muted) !important; }
body.edge-theme .text-slate-400 { color: var(--ee-muted) !important; }
body.edge-theme .border-slate-200,
body.edge-theme .border-slate-100 { border-color: var(--ee-border) !important; }
body.edge-theme .border-white\/20 { border-color: rgba(255,255,255,0.15) !important; }
body.edge-theme .border-slate-700\/30,
body.edge-theme .border-slate-700\/50 { border-color: var(--ee-border) !important; }
body.edge-theme .bg-slate-800\/30 { background: rgba(15, 26, 46, 0.6) !important; }

/* Cards */
.card,
.pricing-card {
  background: var(--ee-card);
  border-radius: var(--card-radius);
  box-shadow: var(--shadow-card);
  border: 1px solid var(--ee-border);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.card:hover,
.pricing-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-card-hover); }
.card-hover:hover { box-shadow: var(--shadow-card-hover); transition: box-shadow 0.2s ease, border-color 0.2s ease; border-color: var(--ee-border); }

/* Stat cards */
.stat-card { min-height: 7.5rem; padding: 1.375rem 1.5rem; display: flex; flex-direction: column; justify-content: flex-start; gap: 0; }
.stat-card .stat-card-label { margin-bottom: 0.375rem; }
.stat-card .stat-card-metric { margin-bottom: 0.25rem; }
.stat-card .stat-card-subtext { margin-top: auto; padding-top: 0.25rem; }
.stat-card.card:hover { transform: none; box-shadow: var(--shadow-card-hover); }
.stat-card-label { font-size: 0.6875rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ee-muted); line-height: 1.35; flex-shrink: 0; }
.stat-card-metric { font-size: 1.75rem; font-weight: 700; letter-spacing: -0.02em; color: var(--ee-text); line-height: 1.25; font-variant-numeric: tabular-nums; word-break: break-word; }
.stat-card-subtext { font-size: 0.8125rem; color: var(--ee-muted); line-height: 1.45; }
.stat-card-metric-row { display: flex; flex-wrap: wrap; gap: 0.75rem 1rem; font-size: 1rem; font-weight: 600; color: var(--ee-text); line-height: 1.5; font-variant-numeric: tabular-nums; }
.stat-card-metric-row span { white-space: nowrap; }
.stat-cards-grid { display: grid; grid-template-columns: repeat(1, minmax(0, 1fr)); gap: 1rem; }
@media (min-width: 640px) { .stat-cards-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (min-width: 1024px) { .stat-cards-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); } }
.stat-card-advanced { min-height: auto; padding: 1.375rem 1.5rem; margin-top: 1rem; border-radius: var(--card-radius); border: 1px solid var(--ee-border); background: var(--ee-card); box-shadow: var(--shadow-subtle); }
.stat-card-advanced.card:hover { transform: none; box-shadow: var(--shadow-card-hover); }
.stat-card-advanced summary { font-size: 0.6875rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ee-muted); line-height: 1.35; cursor: pointer; }
.stat-card-advanced[open] summary { margin-bottom: 1rem; }
.stat-card-advanced .stat-card-label { margin-bottom: 0.375rem; }
.stat-card-advanced .stat-card-metric { font-size: 1.125rem; margin-bottom: 0.25rem; }
.stat-card-advanced .stat-card-subtext { margin-top: 0; padding-top: 0; }
.stat-card-advanced .stat-card-advanced-body { margin-top: 0; border-top: 1px solid var(--ee-border); padding-top: 1rem; }
main .card .bg-slate-50 { background: var(--ee-surface-alt) !important; }
main .card .border-slate-200 { border-color: var(--ee-border) !important; }
main .card .border-b { border-bottom-color: var(--ee-border) !important; }

.num { text-align: right; font-variant-numeric: tabular-nums; }
.num-emphasis { font-variant-numeric: tabular-nums; font-weight: 700; }
.font-mono-ticker { font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace; font-size: 0.8125rem; }

.edge-positive { color: var(--ee-success); }
.edge-neutral { color: var(--ee-muted); }
.edge-negative { color: var(--ee-danger); }

/* Badges */
.badge { display: inline-flex; align-items: center; gap: 0.375rem; padding: 0.25rem 0.625rem; font-size: 0.75rem; font-weight: 600; border-radius: var(--radius-badge); white-space: nowrap; border: 1px solid transparent; }
.badge-open { background: rgba(34, 197, 94, 0.2); color: var(--ee-success); border-color: rgba(34, 197, 94, 0.4); }
.badge-closed { background: var(--ee-surface-alt); color: var(--ee-muted); border-color: var(--ee-border); }
.badge-bet { background: rgba(249, 115, 22, 0.2); color: var(--ee-orange); border-color: rgba(249, 115, 22, 0.5); }
.badge-watch { background: rgba(245, 158, 11, 0.2); color: var(--ee-warning); border-color: rgba(245, 158, 11, 0.4); }
.badge-pass { background: var(--ee-surface-alt); color: var(--ee-muted); border-color: var(--ee-border); }
.badge-sport { background: rgba(59, 130, 246, 0.2); color: #93c5fd; border-color: rgba(59, 130, 246, 0.4); }
.badge-premium { background: rgba(249, 115, 22, 0.15); color: var(--ee-orange); border-color: rgba(249, 115, 22, 0.4); }
.badge-locked { background: var(--ee-surface-alt); color: var(--ee-muted); border: 1px dashed var(--ee-border); }
.risk-green { background: rgba(34, 197, 94, 0.2); color: var(--ee-success); border: 1px solid rgba(34, 197, 94, 0.4); }
.risk-yellow { background: rgba(245, 158, 11, 0.2); color: var(--ee-warning); border: 1px solid rgba(245, 158, 11, 0.4); }
.risk-red { background: rgba(239, 68, 68, 0.2); color: #fca5a5; border: 1px solid rgba(239, 68, 68, 0.4); }
.risk-speculative { background: var(--ee-surface-alt); color: var(--ee-muted); border: 1px solid var(--ee-border); }
.edge-app-main .badge.bg-emerald-50,
.edge-app-main .badge.bg-amber-50,
.edge-app-main .badge.bg-slate-50,
.edge-app-main .badge.bg-rose-50 { background: var(--ee-surface-alt) !important; border-color: var(--ee-border) !important; }
.edge-app-main .badge.text-emerald-700 { color: var(--ee-success) !important; }
.edge-app-main .badge.text-amber-700 { color: var(--ee-warning) !important; }
.edge-app-main .badge.text-slate-700 { color: var(--ee-muted) !important; }
.edge-app-main .badge.text-rose-700 { color: #fca5a5 !important; }
.edge-app-main .badge.border-emerald-200,
.edge-app-main .badge.border-amber-200,
.edge-app-main .badge.border-slate-200,
.edge-app-main .badge.ring-emerald-200,
.edge-app-main .badge.ring-amber-200,
.edge-app-main .badge.ring-rose-200 { border-color: var(--ee-border) !important; }

/* Nav links */
.nav-link {
  display: inline-flex;
  align-items: center;
  height: 2.25rem;
  padding: 0 0.75rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--ee-muted);
  border-radius: 0.5rem;
  transition: background-color 0.15s ease, color 0.15s ease;
}
.nav-link:hover { background: rgba(255,255,255,0.06); color: var(--ee-text); }

/* Section titles */
.section-title { font-size: 1.6rem; font-weight: 700; letter-spacing: -0.01em; color: var(--ee-text); }
.section-subtitle { font-size: 0.875rem; color: var(--ee-muted); }

/* Links */
a.text-blue-600 { color: var(--ee-blue) !important; }
a.text-blue-600:hover { color: var(--ee-orange) !important; }
a[href].edge-link { color: var(--ee-blue); }
a[href].edge-link:hover { color: var(--ee-orange); }
.edge-app-main a.text-blue-600,
.edge-app-main a[href].text-slate-700 { color: var(--ee-blue) !important; }
.edge-app-main a.text-blue-600:hover,
.edge-app-main a[href]:hover { color: var(--ee-orange) !important; }

/* Tables */
.min-w-full thead th { padding: 0.75rem 1rem; font-size: 0.6875rem; font-weight: 700; letter-spacing: 0.05em; color: var(--ee-muted); border-bottom: 2px solid var(--ee-border); background: var(--ee-surface-alt); }
.min-w-full tbody td { padding: 0.75rem 1rem; vertical-align: middle; color: var(--ee-text); }
.min-w-full thead { background: var(--ee-surface-alt); }
.dashboard-table-mobile-cards thead { background: var(--ee-surface-alt); }
.min-w-full tbody tr:hover { background: rgba(255,255,255,0.03); }
.table-picks { border-collapse: collapse; font-size: 0.875rem; background: var(--ee-card); }
.table-picks thead th { position: sticky; top: 0; z-index: 10; background: var(--ee-surface-alt); padding: 0.75rem 1rem; font-size: 0.6875rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--ee-muted); border-bottom: 2px solid var(--ee-border); white-space: nowrap; }
.table-picks tbody td { padding: 0.75rem 1rem; vertical-align: middle; border-bottom: 1px solid var(--ee-border); color: var(--ee-text); }
.table-picks tbody tr:nth-child(even) { background: rgba(0,0,0,0.06); }
.table-picks tbody tr:hover { background: rgba(255,255,255,0.04); }

/* Watchlist star button */
.watchlist-star-btn { display: inline-flex; align-items: center; gap: 0.25rem; padding: 0.25rem 0.5rem; font-size: 0.75rem; font-weight: 500; border-radius: 0.5rem; border: 1px solid transparent; cursor: pointer; transition: background 0.15s, color 0.15s; background: transparent; color: var(--ee-muted); }
.watchlist-star-btn:hover { background: var(--ee-surface-alt); color: var(--ee-text); }
.watchlist-star-btn.saved { color: var(--ee-orange); }
.watchlist-star-btn.saved:hover { background: rgba(249, 115, 22, 0.15); color: var(--ee-orange); }

/* Refresh banner */
.dashboard-refresh-banner { position: sticky; top: 3.5rem; z-index: 30; display: none; align-items: center; justify-content: center; gap: 0.5rem; padding: 0.5rem 1rem; background: var(--ee-surface-alt); color: var(--ee-text); font-size: 0.875rem; font-weight: 500; box-shadow: var(--shadow-subtle); border: 1px solid var(--ee-border); }
.dashboard-refresh-banner.visible { display: flex; }
.dashboard-refresh-banner a, .dashboard-refresh-banner button { color: #93c5fd; text-decoration: underline; font-weight: 600; background: none; border: none; cursor: pointer; padding: 0; }

/* Skeleton */
.skeleton { background: linear-gradient(90deg, var(--ee-surface-alt) 25%, var(--ee-border) 50%, var(--ee-surface-alt) 75%); background-size: 200% 100%; animation: skeleton 1s ease-in-out infinite; border-radius: 0.5rem; }
@keyframes skeleton { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
.skeleton-text { height: 1rem; }
.skeleton-row { height: 2.5rem; }

/* Mobile table cards */
@media (max-width: 640px) {
  .dashboard-table-mobile-cards thead { display: none; }
  .dashboard-table-mobile-cards tbody tr { display: block; border: 1px solid var(--ee-border); border-radius: 0.5rem; margin-bottom: 0.75rem; padding: 0.75rem; background: var(--ee-card); box-shadow: var(--shadow-card); }
  .dashboard-table-mobile-cards tbody td { display: block; padding: 0.25rem 0; border: none; }
  .dashboard-table-mobile-cards tbody td:empty { display: none; }
  .dashboard-table-mobile-cards tbody td::before { content: attr(data-label); font-size: 0.6875rem; font-weight: 600; text-transform: uppercase; color: var(--ee-muted); display: block; margin-bottom: 0.125rem; }
  .dashboard-table-mobile-cards tbody td.table-message-cell::before { display: none; content: none; }
  .dashboard-table-mobile-cards .mobile-primary-actions { margin-top: 0.5rem; padding-top: 0.5rem; border-top: 1px solid var(--ee-border); }
  .stat-card { min-height: auto; padding: 1rem 1rem; }
  .stat-card-metric { font-size: 1.5rem; }
  .dashboard-filters-panel.filters-collapsed { max-height: 0; opacity: 0; overflow: hidden; pointer-events: none; }
  .dashboard-filters-panel.filters-expanded { max-height: 1000px; opacity: 1; pointer-events: auto; }
  .watchlist-star-btn { min-height: 44px; min-width: 44px; padding: 0.45rem 0.65rem; touch-action: manipulation; }
  .dash-tier-chip { min-height: 44px; display: inline-flex; align-items: center; touch-action: manipulation; }
  .filters-toggle-btn { min-height: 44px; min-width: 44px; touch-action: manipulation; }
  #top-picks-container { overflow-x: hidden; }
  /* Long matchup / driver / ticker text: avoid horizontal page scroll */
  .dashboard-table-mobile-cards tbody td[data-label="Drivers"],
  .dashboard-table-mobile-cards tbody td[data-label="Matchup"],
  .dashboard-table-mobile-cards tbody td[data-label="Side"],
  .dashboard-table-mobile-cards tbody td[data-label="Ticker"],
  .dashboard-table-mobile-cards tbody td[data-label="Sport"] {
    word-break: break-word;
    overflow-wrap: anywhere;
  }
  /* Accuracy uses same card pattern on small screens */
  .edge-app-main .card .dashboard-table-mobile-cards tbody td[data-label="Time"],
  .edge-app-main .card .dashboard-table-mobile-cards tbody td[data-label="Sport"] {
    word-break: break-word;
    overflow-wrap: anywhere;
  }
  main.edge-app-main {
    padding-bottom: max(2rem, env(safe-area-inset-bottom));
  }
}

/* Mobile nav */
.nav-mobile-menu { display: none; }
.nav-mobile-backdrop { position: fixed; inset: 0; z-index: 80; background: rgba(0, 0, 0, 0.5); cursor: pointer; visibility: hidden; pointer-events: none; }
.nav-mobile-panel {
  position: fixed;
  inset: 0;
  z-index: 90;
  overflow-y: auto;
  padding-top: 3.5rem;
  background: var(--ee-card);
  border-left: 1px solid var(--ee-border);
  box-shadow: 0 10px 30px rgba(0,0,0,0.3);
  visibility: hidden;
  pointer-events: none;
}
body.nav-open .nav-mobile-backdrop { visibility: visible; pointer-events: auto; }
body.nav-open .nav-mobile-panel { visibility: visible; pointer-events: auto; }
.nav-mobile-link {
  display: block;
  width: 100%;
  padding: 0.875rem 1rem;
  border-top: 1px solid var(--ee-border);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--ee-text);
  text-decoration: none;
  transition: background 0.15s ease, color 0.15s ease;
  -webkit-tap-highlight-color: transparent;
}
.nav-mobile-link:hover,
.nav-mobile-link:active { background: var(--ee-surface-alt); color: var(--ee-orange); }

@media (max-width: 640px) {
  .nav-desktop { display: none; }
  .nav-mobile-menu { display: block; }
  .nav-mobile-toggle-btn { min-width: 44px; min-height: 44px; touch-action: manipulation; cursor: pointer; -webkit-tap-highlight-color: transparent; }
}

/* Hamburger button in header: light icon on dark */
.edge-app-header .nav-mobile-toggle-btn { color: var(--ee-muted); }
.edge-app-header .nav-mobile-toggle-btn:hover { background: rgba(255,255,255,0.08); color: var(--ee-text); }

/* HTMX */
.htmx-indicator { display: none !important; }
#top-picks-container.htmx-request ~ #top-picks-spinner { display: flex !important; }
.spinner { width: 1.25rem; height: 1.25rem; border: 2px solid var(--ee-border); border-top-color: var(--ee-blue); border-radius: 50%; animation: spin 0.6s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* Copy button */
.copy-btn { cursor: pointer; padding: 0.25rem 0.375rem; border-radius: 0.375rem; color: var(--ee-muted); transition: background-color 0.15s ease, color 0.15s ease; }
.copy-btn:hover { background: var(--ee-surface-alt); color: var(--ee-text); }
.copy-btn:disabled { opacity: 0.45; cursor: not-allowed; }
.copy-btn.copied { color: var(--ee-success); }

/* Details */
details summary { list-style: none; cursor: pointer; }
details summary::-webkit-details-marker { display: none; }
.details-content { overflow: hidden; }
details[open] .details-content { animation: detailsSlide 0.22s ease-out; }
@keyframes detailsSlide { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: translateY(0); } }

/* Primary button (CTA) */
.btn-primary {
  display: inline-block;
  background: linear-gradient(135deg, var(--ee-blue) 0%, var(--ee-blue-hover) 100%);
  color: white;
  border-radius: 10px;
  padding: 12px 20px;
  font-weight: 600;
  text-align: center;
  text-decoration: none;
  transition: all 0.15s ease;
  border: none;
  cursor: pointer;
  box-shadow: var(--shadow-subtle);
}
.btn-primary:hover {
  background: linear-gradient(135deg, var(--ee-orange) 0%, var(--ee-orange-dark) 100%);
  transform: translateY(-1px);
  box-shadow: var(--shadow-card-hover);
  color: white;
}
.btn-primary:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.4);
}
.edge-app-main button.bg-blue-500 { background: var(--ee-blue) !important; color: #fff !important; }
.edge-app-main button.bg-blue-500:hover { background: var(--ee-blue-hover) !important; color: #fff !important; }
.edge-app-main input[type="email"],
.edge-app-main input[type="password"],
.edge-app-main input[type="text"] { background: var(--ee-surface-alt) !important; border-color: var(--ee-border) !important; color: var(--ee-text) !important; }
.edge-app-main input:focus { box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.25); }

/* Form controls: dark theme when inside app main */
.edge-app-main input:not([type=checkbox]):not([type=radio]),
.edge-app-main select,
.edge-app-main textarea {
  background: var(--ee-surface-alt) !important;
  border-color: var(--ee-border) !important;
  color: var(--ee-text) !important;
}
.edge-app-main input::placeholder,
.edge-app-main textarea::placeholder { color: var(--ee-muted) !important; }
.edge-app-main input:focus,
.edge-app-main select:focus,
.edge-app-main textarea:focus {
  outline: none;
  border-color: var(--ee-blue) !important;
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.25);
}
.edge-app-main .filters-toggle-btn { background: var(--ee-card) !important; border-color: var(--ee-border) !important; color: var(--ee-text) !important; }
.edge-app-main .filters-toggle-btn:hover { background: var(--ee-surface-alt) !important; }
.edge-app-main .dash-tier-chip { border-color: var(--ee-border) !important; }
.edge-app-main .dash-tier-chip.bg-white { background: var(--ee-card) !important; color: var(--ee-muted) !important; }
.edge-app-main .dash-tier-chip.bg-white:hover { background: var(--ee-surface-alt) !important; }
.edge-app-main .dash-tier-chip.bg-slate-200 { background: var(--ee-surface-alt) !important; color: var(--ee-text) !important; border-color: var(--ee-muted) !important; }
.edge-app-main .dash-tier-chip.bg-emerald-100 { background: rgba(34, 197, 94, 0.2) !important; color: var(--ee-success) !important; border-color: rgba(34, 197, 94, 0.4) !important; }
.edge-app-main .dash-tier-chip.bg-amber-100 { background: rgba(245, 158, 11, 0.2) !important; color: var(--ee-warning) !important; border-color: rgba(245, 158, 11, 0.4) !important; }
.edge-app-main .dash-tier-chip.bg-rose-100 { background: rgba(239, 68, 68, 0.2) !important; color: #fca5a5 !important; border-color: rgba(239, 68, 68, 0.4) !important; }
.edge-app-main .disabled\:bg-slate-100:disabled { background: var(--ee-card) !important; }
.edge-app-main .disabled\:text-slate-500:disabled { color: var(--ee-muted) !important; }
.edge-app-main button.bg-gray-800 { background: var(--ee-blue) !important; color: #fff !important; border: none; }
.edge-app-main button.bg-gray-800:hover { background: var(--ee-blue-hover) !important; }
.edge-app-main .stat-card.border-slate-200,
.edge-app-main .stat-card.border-slate-300 { border-left-color: var(--ee-border) !important; }
.edge-app-main .stat-card.border-blue-500 { border-left-color: var(--ee-blue) !important; }
.edge-app-main .bg-emerald-100 { background: rgba(34, 197, 94, 0.2) !important; }
.edge-app-main .text-emerald-800 { color: var(--ee-success) !important; }
.edge-app-main .border-emerald-200 { border-color: rgba(34, 197, 94, 0.4) !important; }
.edge-app-main button.bg-slate-100 { background: var(--ee-surface-alt) !important; color: var(--ee-text) !important; border: 1px solid var(--ee-border); }
.edge-app-main button.bg-slate-100:hover { background: var(--ee-border) !important; }
.edge-app-main .bg-stone-600 { background: var(--ee-card) !important; }
.edge-app-main .bg-stone-800 { background: var(--ee-blue) !important; color: #fff !important; }
.edge-app-main .hover\:bg-stone-700:hover { background: var(--ee-blue-hover) !important; color: #fff !important; }
.edge-app-main .bg-slate-200 { background: var(--ee-surface-alt) !important; color: var(--ee-muted) !important; }
.edge-app-main .bg-amber-500 { background: var(--ee-orange) !important; color: #fff !important; }
.edge-app-main .bg-slate-700 { background: var(--ee-blue) !important; color: #fff !important; }
.edge-app-main .hover\:bg-slate-600:hover { background: var(--ee-blue-hover) !important; color: #fff !important; }
.edge-app-main .border-emerald-300 { border-color: rgba(34, 197, 94, 0.5) !important; }
.edge-app-main .bg-emerald-50\/50 { background: rgba(34, 197, 94, 0.08) !important; }

/* Alerts / notices (keep semantic colors) */
.edge-app-main .bg-red-50,
.edge-app-main .bg-red-100 { background: rgba(239, 68, 68, 0.15) !important; }
.edge-app-main .border-red-200,
.edge-app-main .border-red-400 { border-color: rgba(239, 68, 68, 0.5) !important; }
.edge-app-main .text-red-700,
.edge-app-main .text-red-800 { color: #fca5a5 !important; }
.edge-app-main .bg-amber-50,
.edge-app-main .bg-amber-100 { background: rgba(245, 158, 11, 0.15) !important; }
.edge-app-main .border-amber-200,
.edge-app-main .border-amber-400 { border-color: rgba(245, 158, 11, 0.5) !important; }
.edge-app-main .text-amber-700,
.edge-app-main .text-amber-800 { color: var(--ee-warning) !important; }
.edge-app-main .bg-green-50,
.edge-app-main .bg-green-100 { background: rgba(34, 197, 94, 0.15) !important; }
.edge-app-main .border-green-200,
.edge-app-main .border-green-400 { border-color: rgba(34, 197, 94, 0.5) !important; }
.edge-app-main .text-green-700,
.edge-app-main .text-green-800 { color: var(--ee-success) !important; }

/* Modals (drilldown, support): dark */
.edge-app-main #drilldown-modal .card,
.edge-app-main #drilldown-modal .bg-white { background: var(--ee-card) !important; border-color: var(--ee-border); }
.edge-app-main #drilldown-modal .sticky.bg-white { background: var(--ee-card) !important; }
.edge-app-main #drilldown-modal .text-gray-900 { color: var(--ee-text) !important; }
.edge-app-main #drilldown-modal .text-gray-500 { color: var(--ee-muted) !important; }
.edge-app-main #drilldown-modal .text-gray-400:hover { color: var(--ee-text) !important; }
.edge-app-main #drilldown-modal .hover\:bg-gray-100:hover { background: var(--ee-surface-alt) !important; }
.edge-app-main #support-modal .bg-white,
.edge-app-main #support-modal .relative.bg-white { background: var(--ee-card) !important; border: 1px solid var(--ee-border); }
.edge-app-main #support-modal .text-slate-900 { color: var(--ee-text) !important; }
.edge-app-main #support-modal .text-slate-400:hover { color: var(--ee-text) !important; }
.edge-app-main #support-modal .text-slate-600:hover { color: var(--ee-text) !important; }
.edge-app-main #support-modal textarea { background: var(--ee-surface-alt) !important; border-color: var(--ee-border) !important; color: var(--ee-text) !important; }
.edge-app-main #support-modal .bg-slate-800 { background: var(--ee-blue) !important; }
.edge-app-main #support-modal .hover\:bg-slate-700:hover { background: var(--ee-blue-hover) !important; }
.edge-app-main #support-modal .bg-slate-100 { background: var(--ee-surface-alt) !important; }
.edge-app-main #support-modal .hover\:bg-slate-200:hover { background: var(--ee-border) !important; }
.edge-app-main #support-modal .text-slate-500 { color: var(--ee-muted) !important; }

/* Landing contact modal */
body.edge-theme #contactModal .bg-white { background: var(--ee-card) !important; border: 1px solid var(--ee-border); }
body.edge-theme #contactModal .text-slate-900 { color: var(--ee-text) !important; }
body.edge-theme #contactModal .text-gray-500 { color: var(--ee-muted) !important; }
body.edge-theme #contactModal input,
body.edge-theme #contactModal textarea { background: var(--ee-surface-alt) !important; border-color: var(--ee-border) !important; color: var(--ee-text) !important; }

/* Pricing card on landing: accent border */
body.edge-theme .pricing-card.premium { border-color: rgba(249, 115, 22, 0.4); }
body.edge-theme .text-emerald-600 { color: var(--ee-success) !important; }
body.edge-theme .text-emerald-700 { color: var(--ee-success) !important; }
body.edge-theme .bg-emerald-500 { background: var(--ee-success) !important; }
body.edge-theme .border-emerald-300 { border-color: var(--ee-success) !important; }
body.edge-theme .bg-emerald-50\/50 { background: rgba(34, 197, 94, 0.08) !important; }

/* Landing: proof row + section polish */
body.edge-theme .hero-proof-row { font-size: 0.8125rem; }
@media (min-width: 640px) { body.edge-theme .hero-proof-row { font-size: 0.875rem; } }
body.edge-theme .landing-picks-cta { margin-top: 1.25rem; padding-top: 1.25rem; }
body.edge-theme .landing-picks-bridge { margin-bottom: 1rem; }

/* Signup / account / login cards: use card background when inside app */
.edge-app-main .max-w-md .bg-white,
.edge-app-main .max-w-lg .bg-white,
.edge-app-main .max-w-2xl .bg-white { background: var(--ee-card) !important; border: 1px solid var(--ee-border); }
.edge-app-main .shadow-md { box-shadow: var(--shadow-card) !important; }
.edge-app-main .rounded-lg { border-radius: var(--radius-card); }

/* Strong blue for Playable tier */
.risk-blue-strong {
  background: rgba(59, 130, 246, 0.25);
  color: #93c5fd;
  border: 1px solid rgba(59, 130, 246, 0.5);
  font-weight: 600;
}
