/* EMA Watch — Clean UX Redesign */

:root {
  --bg-base: #0a0a0b;
  --bg-surface: #111114;
  --bg-elevated: #1a1a1f;
  --bg-border: #1e1e24;

  --text-primary: #e8e8ed;
  --text-secondary: #8a8a9a;
  --text-muted: #4a4a5a;

  --accent: #6366f1;
  --accent-hover: #818cf8;

  /* 8-zone directional EMA colors */
  --ema-far-above-bg: #0f1f14; --ema-far-above: #4a7c59;
  --ema-above-bg: #122b1a; --ema-above: #4ade80;
  --ema-approaching-bg: #2d2410; --ema-approaching: #fbbf24;
  --ema-at-above-bg: #3a2010; --ema-at-above: #fb923c;
  --ema-at-below-bg: #3a1810; --ema-at-below: #f97316;
  --ema-below-bg: #3a1010; --ema-below: #ef4444;
  --ema-deep-below-bg: #440a0a; --ema-deep-below: #f87171;
  --ema-very-deep-bg: #5a0505; --ema-very-deep: #fca5a5;

  --font-mono: 'JetBrains Mono', 'Fira Code', monospace;
  --font-sans: 'IBM Plex Sans', 'Inter', system-ui, sans-serif;

  --space-1: 4px; --space-2: 8px; --space-3: 12px; --space-4: 16px;
  --space-5: 24px; --space-6: 32px; --space-7: 48px;

  --radius-sm: 4px; --radius-md: 8px; --radius-lg: 12px;
}

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

body {
  font-family: var(--font-sans);
  background: var(--bg-base);
  color: var(--text-primary);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

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

/* ─── Animations ─────────────────────────────────────────────────────── */
@keyframes pulse-dot { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.8)} }
@keyframes shake { 0%,100%{transform:translateX(0)} 20%{transform:translateX(-8px)} 40%{transform:translateX(8px)} 60%{transform:translateX(-4px)} 80%{transform:translateX(4px)} }
@keyframes row-flash { 0%{background:rgba(99,102,241,.12)} 100%{background:transparent} }
@keyframes fade-in { from{opacity:0;transform:translateY(-4px)} to{opacity:1;transform:translateY(0)} }
@keyframes spin { from{transform:rotate(0)} to{transform:rotate(360deg)} }
@keyframes signal-pulse { 0%,100%{box-shadow:0 0 0 0 rgba(255,215,0,0)} 50%{box-shadow:0 0 8px 2px rgba(255,215,0,.2)} }
@keyframes signal-pulse-red { 0%,100%{box-shadow:0 0 0 0 rgba(255,107,107,0)} 50%{box-shadow:0 0 8px 2px rgba(255,107,107,.15)} }

/* ─── Navbar ─────────────────────────────────────────────────────────── */
.navbar {
  position: fixed; top: 0; left: 0; right: 0; height: 48px;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 var(--space-5); background: var(--bg-surface);
  border-bottom: 1px solid var(--bg-border); z-index: 100;
}
.nav-left { display: flex; align-items: center; gap: var(--space-2); }
.nav-dot { width: 8px; height: 8px; border-radius: 50%; background: #4ade80; animation: pulse-dot 2s ease-in-out infinite; }
.nav-brand { font-family: var(--font-mono); font-weight: 600; font-size: 14px; color: var(--accent); }
.nav-sub { font-size: 11px; color: var(--text-muted); margin-left: var(--space-2); }
.nav-center { display: flex; gap: var(--space-5); }
.nav-center a { color: var(--text-secondary); font-size: 13px; font-weight: 500; padding: 4px 0; transition: color 150ms; }
.nav-center a:hover { color: var(--text-primary); }
.nav-center a.active { color: var(--text-primary); border-bottom: 2px solid var(--accent); }
.nav-right { display: flex; align-items: center; gap: var(--space-4); font-size: 12px; }
.nav-time { font-family: var(--font-mono); color: var(--text-muted); }
.nav-countdown { font-family: var(--font-mono); padding: 2px 8px; border-radius: var(--radius-sm); background: var(--bg-elevated); color: #4ade80; font-weight: 500; }
.nav-countdown.soon { color: #fbbf24; }
.nav-logout { color: var(--text-muted) !important; font-size: 12px !important; }
.nav-logout:hover { color: #f87171 !important; }
.nav-hamburger { display: none; background: none; border: none; color: var(--text-secondary); font-size: 20px; cursor: pointer; }

/* ─── Page ───────────────────────────────────────────────────────────── */
.page { max-width: 1400px; margin: 0 auto; padding: 60px var(--space-5) var(--space-7); }

/* ─── Stat Bar ───────────────────────────────────────────────────────── */
.stat-bar { display: grid; grid-template-columns: repeat(4,1fr); gap: var(--space-3); margin-bottom: var(--space-4); }
.stat-card { background: var(--bg-surface); border-radius: var(--radius-md); padding: var(--space-3) var(--space-4); }
.stat-label { font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: .5px; color: var(--text-muted); margin-bottom: 2px; }
.stat-value { font-family: var(--font-mono); font-size: 20px; font-weight: 600; color: var(--text-primary); }
.stat-detail { font-size: 11px; color: var(--text-muted); }
.stat-card.active { border-left: 3px solid #fbbf24; }
.stat-card.active .stat-value { color: #fbbf24; }

/* ─── Legend Bar ──────────────────────────────────────────────────────── */
.legend-bar { text-align: center; font-size: 12px; color: var(--text-muted); padding: var(--space-2) 0 var(--space-4); }
.legend-bar span { margin: 0 var(--space-3); }
.legend-up { color: #4ade80; }
.legend-down { color: #f87171; }

/* ─── Alert Banner ───────────────────────────────────────────────────── */
.alert-banner {
  background: var(--ema-at-below-bg); border-left: 3px solid #fb923c;
  border-radius: var(--radius-md); padding: var(--space-3) var(--space-4);
  margin-bottom: var(--space-4); font-size: 13px; color: #fb923c; animation: fade-in 300ms;
}

/* ─── Section Headers ────────────────────────────────────────────────── */
.section-header {
  font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: .6px;
  padding: var(--space-3) 0 var(--space-2); margin-top: var(--space-4); color: var(--text-muted);
}
.section-zone { color: #fb923c; }
.section-zone .section-count { color: #fbbf24; font-family: var(--font-mono); }
.section-clear { color: var(--text-muted); }
.section-count { margin-left: var(--space-2); font-weight: 400; }

/* ─── Watchlist Table ────────────────────────────────────────────────── */
.table-wrap { overflow-x: auto; }
.watch-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.watch-table th {
  text-align: left; padding: var(--space-2) var(--space-3); font-size: 10px;
  font-weight: 600; text-transform: uppercase; letter-spacing: .5px; color: var(--text-muted);
  border-bottom: 1px solid var(--bg-border); position: sticky; top: 48px;
  background: var(--bg-base); z-index: 10; white-space: nowrap;
}
.watch-table td { padding: var(--space-2) var(--space-3); border-bottom: 1px solid var(--bg-border); white-space: nowrap; vertical-align: middle; }
.watch-table tbody tr { transition: background 150ms; }
.watch-table tbody tr:hover { background: var(--bg-elevated); }
.watch-table tbody tr.flashed { animation: row-flash 1.5s ease-out; }

/* Muted monitoring rows */
.table-muted tbody tr { opacity: .82; }
.table-muted tbody tr:hover { opacity: 1; }
.table-muted td { padding: 6px var(--space-3); }

/* Cell types */
.cell-ticker { font-family: var(--font-mono); font-weight: 600; font-size: 14px; color: var(--text-primary); line-height: 1.2; }
.cell-ticker-name { font-family: var(--font-sans); font-size: 11px; color: var(--text-muted); font-weight: 400; }
.cell-price { font-family: var(--font-mono); color: var(--text-primary); }

/* Timeframe column accents */
.th-weekly { border-left: 2px solid rgba(129,140,248,.25); }
.th-monthly { border-left: 2px solid rgba(251,146,60,.3); }
.td-weekly { border-left: 2px solid rgba(129,140,248,.1); }
.td-monthly { border-left: 2px solid rgba(251,146,60,.15); }

/* Timeframe weight badges in headers */
.tf-badge { font-size: 9px; padding: 1px 4px; border-radius: 3px; margin-left: 4px; font-weight: 700; vertical-align: middle; }
.tf-1x { background: #1a2a1a; color: #4ade80; }
.tf-10x { background: #1a1a3a; color: #818cf8; }
.tf-100x { background: #3a1a05; color: #fb923c; }
.tf-desc { display: block; font-size: 9px; color: var(--text-muted); font-weight: 400; margin-top: 1px; }

/* 8-zone EMA cells */
.cell-pct {
  font-family: var(--font-mono); font-weight: 500; font-size: 13px;
  text-align: center; padding: 3px 8px; border-radius: var(--radius-sm);
  cursor: help; position: relative; display: inline-block; min-width: 70px;
}
.cell-pct.ema-far-above   { background: var(--ema-far-above-bg); color: var(--ema-far-above); }
.cell-pct.ema-above        { background: var(--ema-above-bg); color: var(--ema-above); }
.cell-pct.ema-approaching  { background: var(--ema-approaching-bg); color: var(--ema-approaching); }
.cell-pct.ema-at-above     { background: var(--ema-at-above-bg); color: var(--ema-at-above); }
.cell-pct.ema-at-below     { background: var(--ema-at-below-bg); color: var(--ema-at-below); }
.cell-pct.ema-below        { background: var(--ema-below-bg); color: var(--ema-below); }
.cell-pct.ema-deep-below   { background: var(--ema-deep-below-bg); color: var(--ema-deep-below); }
.cell-pct.ema-very-deep    { background: var(--ema-very-deep-bg); color: var(--ema-very-deep); }
.cell-pct.no-data          { color: var(--text-muted); }
.pct-note { font-size: 9px; color: #fbbf24; vertical-align: super; margin-left: 1px; }

/* Signal badges */
.signal-generational { background: linear-gradient(135deg,#7c3a00,#c45c00); color: #ffd700; border: 1px solid #ffd700; font-weight: 700; animation: signal-pulse 2s ease-in-out infinite; padding: 3px 10px; border-radius: var(--radius-sm); font-size: 11px; text-transform: uppercase; letter-spacing: .05em; white-space: nowrap; }
.signal-major { background: #3a0808; color: #ff6b6b; border: 1px solid rgba(255,107,107,.4); font-weight: 700; animation: signal-pulse-red 3s ease-in-out infinite; padding: 3px 10px; border-radius: var(--radius-sm); font-size: 11px; text-transform: uppercase; letter-spacing: .05em; white-space: nowrap; }
.signal-watch { background: #2a2000; color: #fbbf24; padding: 3px 10px; border-radius: var(--radius-sm); font-size: 11px; text-transform: uppercase; font-weight: 600; white-space: nowrap; }
.signal-buyzone { background: #1a2a0a; color: #86efac; border: 1px solid rgba(134,239,172,.2); padding: 3px 10px; border-radius: var(--radius-sm); font-size: 11px; text-transform: uppercase; font-weight: 600; white-space: nowrap; }
.signal-near { background: #1a2a14; color: #4ade80; padding: 3px 10px; border-radius: var(--radius-sm); font-size: 11px; text-transform: uppercase; white-space: nowrap; }
.signal-clear { color: var(--text-muted); padding: 3px 10px; font-size: 11px; text-transform: uppercase; white-space: nowrap; }

/* ─── Tooltip ────────────────────────────────────────────────────────── */
.tooltip {
  position: absolute; bottom: calc(100% + 8px); left: 50%; transform: translateX(-50%);
  background: var(--bg-elevated); border: 1px solid var(--bg-border); border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4); font-family: var(--font-mono); font-size: 12px;
  line-height: 1.7; white-space: nowrap; z-index: 50; pointer-events: none;
  animation: fade-in 150ms; box-shadow: 0 4px 16px rgba(0,0,0,.5);
}
.tooltip::after { content:''; position:absolute; top:100%; left:50%; transform:translateX(-50%); border:5px solid transparent; border-top-color:var(--bg-border); }
.tooltip-label { color: var(--text-muted); }
.tooltip-warn { color: #fbbf24; font-size: 11px; }

/* ─── Badges ─────────────────────────────────────────────────────────── */
.badge { display: inline-flex; align-items: center; padding: 2px 8px; border-radius: 10px; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .02em; }
.badge-approaching { background: var(--ema-approaching-bg); color: var(--ema-approaching); }
.badge-at-ema { background: var(--ema-at-below-bg); color: var(--ema-at-below); }
.badge-stock { background: var(--bg-elevated); color: var(--text-secondary); }
.badge-etf { background: rgba(99,102,241,.12); color: var(--accent); }
.badge-crypto { background: var(--ema-approaching-bg); color: var(--ema-approaching); }
.badge-active { background: rgba(74,222,128,.1); color: #4ade80; }
.badge-revoked { background: rgba(248,113,113,.1); color: #f87171; }

/* History timeframe badges */
.badge-daily { background: #1a2a1a; color: #4ade80; border: 1px solid rgba(74,222,128,.15); }
.badge-weekly { background: #1a1a3a; color: #818cf8; border: 1px solid rgba(129,140,248,.25); font-weight: 600; }
.badge-monthly { background: #3a2000; color: #fbbf24; border: 1px solid rgba(251,191,36,.3); font-weight: 700; }
.badge-rare { display: block; font-size: 8px; color: rgba(251,191,36,.5); letter-spacing: .08em; margin-top: 1px; }

/* ─── Login ──────────────────────────────────────────────────────────── */
.login-wrap { display: flex; justify-content: center; align-items: center; min-height: 100vh; padding: var(--space-5); }
.login-card { background: var(--bg-surface); border-radius: var(--radius-lg); padding: var(--space-6) var(--space-6); width: 100%; max-width: 380px; animation: fade-in 300ms; }
.login-card.shake { animation: shake 400ms; }
.login-brand { display: flex; align-items: center; justify-content: center; gap: var(--space-2); margin-bottom: var(--space-1); }
.login-brand-text { font-family: var(--font-mono); font-weight: 600; font-size: 18px; color: var(--accent); }
.login-tagline { text-align: center; font-size: 12px; color: var(--text-muted); margin-bottom: var(--space-5); }
.login-help { text-align: center; font-size: 12px; color: var(--text-muted); margin-top: var(--space-4); }

/* ─── Forms ──────────────────────────────────────────────────────────── */
.form-group { margin-bottom: var(--space-4); }
.form-group label { display: block; font-size: 11px; font-weight: 600; color: var(--text-secondary); margin-bottom: var(--space-1); text-transform: uppercase; letter-spacing: .3px; }
.form-input { width: 100%; padding: var(--space-3) var(--space-4); background: var(--bg-base); border: 1px solid var(--bg-border); border-radius: var(--radius-md); color: var(--text-primary); font-family: var(--font-mono); font-size: 14px; transition: border-color 150ms,box-shadow 150ms; }
.form-input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(99,102,241,.12); }
.form-input.error { border-color: #f87171; }
.form-input::placeholder { color: var(--text-muted); }
.form-input-code { text-transform: uppercase; text-align: center; letter-spacing: 3px; font-size: 18px; }

/* Buttons */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 6px; padding: var(--space-3) var(--space-5); border: none; border-radius: var(--radius-md); font-family: var(--font-sans); font-size: 14px; font-weight: 600; cursor: pointer; transition: opacity 150ms,transform 100ms; }
.btn:hover { opacity: .88; }
.btn:active { transform: scale(.98); }
.btn:disabled { opacity: .5; cursor: not-allowed; }
.btn-primary { background: var(--accent); color: #fff; width: 100%; }
.btn-ghost { background: var(--bg-elevated); color: var(--text-primary); border: 1px solid var(--bg-border); }
.btn-sm { padding: var(--space-1) var(--space-3); font-size: 12px; }
.btn-muted { background: none; color: var(--text-muted); border: 1px solid var(--bg-border); font-weight: 500; }
.btn-muted:hover { color: #f87171; border-color: rgba(248,113,113,.3); }
.btn .spinner { width: 14px; height: 14px; border: 2px solid rgba(255,255,255,.3); border-top-color: #fff; border-radius: 50%; animation: spin 600ms linear infinite; }

/* ─── Messages ───────────────────────────────────────────────────────── */
.msg { padding: var(--space-3) var(--space-4); border-radius: var(--radius-md); margin-bottom: var(--space-4); font-size: 13px; animation: fade-in 300ms; }
.msg-error { background: rgba(248,113,113,.08); border: 1px solid rgba(248,113,113,.25); color: #f87171; }
.msg-success { background: rgba(74,222,128,.08); border: 1px solid rgba(74,222,128,.2); color: #4ade80; }

/* ─── Empty State ────────────────────────────────────────────────────── */
.empty-state { text-align: center; padding: var(--space-7) var(--space-5); color: var(--text-muted); }
.empty-state-icon { font-size: 28px; margin-bottom: var(--space-3); }
.empty-state-text { font-size: 14px; line-height: 1.7; }

/* ─── Cards (admin) ──────────────────────────────────────────────────── */
.card { background: var(--bg-surface); border-radius: var(--radius-md); padding: var(--space-5); margin-bottom: var(--space-4); }
.card-title { font-size: 14px; font-weight: 600; margin-bottom: var(--space-4); }
.card-desc { font-size: 13px; color: var(--text-secondary); margin-bottom: var(--space-4); line-height: 1.6; }

.code-display { font-family: var(--font-mono); font-size: 24px; font-weight: 600; letter-spacing: 3px; text-align: center; padding: var(--space-4); background: var(--bg-base); border-radius: var(--radius-md); color: var(--accent); margin-bottom: var(--space-2); position: relative; }
.copy-btn { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); background: none; border: none; color: var(--text-muted); cursor: pointer; font-size: 16px; transition: color 150ms; }
.copy-btn:hover { color: var(--accent); }
.copy-btn.copied { color: #4ade80; }
.code-help { text-align: center; font-size: 12px; color: var(--text-muted); margin-bottom: var(--space-4); }

.radio-group { margin-bottom: var(--space-4); }
.radio-group label { display: block; padding: var(--space-2) 0; font-size: 13px; color: var(--text-secondary); cursor: pointer; }
.radio-group input[type="radio"] { margin-right: var(--space-2); }

.admin-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.admin-table th { text-align: left; padding: var(--space-2) var(--space-3); font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: .3px; color: var(--text-muted); border-bottom: 1px solid var(--bg-border); }
.admin-table td { padding: var(--space-2) var(--space-3); border-bottom: 1px solid var(--bg-border); color: var(--text-secondary); }
.admin-table tbody tr:hover { background: var(--bg-elevated); }
.you-tag { font-size: 10px; color: var(--accent); margin-left: 4px; }

.trigger-result { margin-top: var(--space-3); padding: var(--space-3) var(--space-4); border-radius: var(--radius-md); font-family: var(--font-mono); font-size: 13px; }

/* ─── History ────────────────────────────────────────────────────────── */
.page-header { margin-bottom: var(--space-4); }
.page-header h1 { font-size: 18px; font-weight: 600; }
.page-header-sub { font-size: 12px; color: var(--text-secondary); margin-top: 2px; }

.filter-bar { display: flex; gap: var(--space-3); margin-bottom: var(--space-4); align-items: center; flex-wrap: wrap; }
.filter-select { padding: 6px var(--space-3); background: var(--bg-surface); border: 1px solid var(--bg-border); border-radius: var(--radius-md); color: var(--text-primary); font-family: var(--font-sans); font-size: 12px; cursor: pointer; }
.filter-select:focus { outline: none; border-color: var(--accent); }
.filter-clear { font-size: 12px; color: var(--text-muted); cursor: pointer; display: none; }
.filter-clear:hover { color: var(--accent); }
.filter-clear.visible { display: inline; }

.history-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.history-table th { text-align: left; padding: var(--space-2) var(--space-3); font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: .3px; color: var(--text-muted); border-bottom: 1px solid var(--bg-border); }
.history-table td { padding: var(--space-2) var(--space-3); border-bottom: 1px solid var(--bg-border); }
.history-table tbody tr:hover { background: var(--bg-elevated); }
.cell-time { font-family: var(--font-mono); font-size: 12px; color: var(--text-secondary); }

/* ─── Data Notes ─────────────────────────────────────────────────────── */
.data-note { margin-top: var(--space-5); padding: var(--space-4); background: var(--bg-surface); border-radius: var(--radius-md); font-size: 12px; color: var(--text-secondary); line-height: 1.7; }
.data-note-title { font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: .5px; color: var(--text-muted); margin-bottom: var(--space-2); }
.data-note-row { display: flex; align-items: baseline; gap: var(--space-2); margin-bottom: var(--space-1); }
.data-note-row:last-child { margin-bottom: 0; }
.data-note-row strong { color: var(--text-primary); }
.data-note-dash { font-family: var(--font-mono); font-size: 12px; color: var(--text-muted); }

/* ─── Refresh indicator ──────────────────────────────────────────────── */
.refresh-indicator { position: fixed; top: 56px; right: 24px; font-size: 12px; font-family: var(--font-mono); padding: 3px 10px; border-radius: var(--radius-sm); z-index: 90; opacity: 0; transition: opacity 300ms; }
.refresh-indicator.visible { opacity: 1; }
.refresh-indicator.updating { background: var(--bg-elevated); color: var(--text-muted); }
.refresh-indicator.success { background: rgba(74,222,128,.1); color: #4ade80; }
.refresh-indicator.stale { background: rgba(251,191,36,.1); color: #fbbf24; }

/* ─── Responsive ─────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .navbar { padding: 0 var(--space-4); }
  .nav-center { display: none; }
  .nav-center.open { display: flex; flex-direction: column; position: absolute; top: 48px; left: 0; right: 0; background: var(--bg-surface); border-bottom: 1px solid var(--bg-border); padding: var(--space-3) var(--space-4); gap: var(--space-3); }
  .nav-right { display: none; }
  .nav-hamburger { display: block; }
  .page { padding: 56px var(--space-4) var(--space-6); }
  .stat-bar { grid-template-columns: 1fr 1fr; }
  .col-weekly, .col-monthly, .th-weekly, .th-monthly, .td-weekly, .td-monthly { display: none; }
  .filter-bar { flex-direction: column; }
}
