@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Space+Grotesk:wght@400;500;600;700&display=swap');

/* ═══════════════════════════════════════════
   INVESTAI PRO v2 — PREMIUM FINTECH DESIGN
   ═══════════════════════════════════════════ */

:root {
  --bg-primary:     #070B14;
  --bg-secondary:   #0D1421;
  --bg-card:        #111927;
  --bg-card-hover:  #162035;
  --bg-input:       #1A2540;
  --bg-overlay:     rgba(7,11,20,0.92);
  --border:         #1C2D45;
  --border-light:   rgba(255,255,255,0.06);
  --accent-green:   #00E5B8;
  --accent-green2:  #00D4AA;
  --accent-blue:    #4F8EF7;
  --accent-blue2:   #6EA8FF;
  --accent-red:     #FF4757;
  --accent-yellow:  #FFB830;
  --accent-purple:  #9B5CF6;
  --accent-orange:  #FF7043;
  --text-primary:   #EEF4FF;
  --text-secondary: #7B93B8;
  --text-muted:     #3D526B;
  --glow-green:     0 0 30px rgba(0,229,184,0.25);
  --glow-blue:      0 0 30px rgba(79,142,247,0.25);
  --glow-red:       0 0 30px rgba(255,71,87,0.25);
  --font:           'Inter', -apple-system, sans-serif;
  --font-display:   'Space Grotesk', sans-serif;
  --r:   10px;
  --r-lg:16px;
  --r-xl:20px;
  --t:   all 0.22s cubic-bezier(0.4,0,0.2,1);
}

/* ─── RESET ─── */
.investai-wrap *, .investai-wrap *::before, .investai-wrap *::after { box-sizing: border-box; margin: 0; padding: 0; }
.investai-wrap { font-family: var(--font); background: var(--bg-primary); color: var(--text-primary); min-height: 100vh; -webkit-font-smoothing: antialiased; }
.investai-wrap a { color: var(--accent-blue); text-decoration: none; }
.investai-wrap button { font-family: var(--font); }

/* ─── SCROLLBAR ─── */
.investai-wrap ::-webkit-scrollbar { width: 5px; height: 5px; }
.investai-wrap ::-webkit-scrollbar-track { background: transparent; }
.investai-wrap ::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
.investai-wrap ::-webkit-scrollbar-thumb:hover { background: #2A3F5F; }

/* ═══ LAYOUT ═══ */
.investai-dashboard { display: grid; grid-template-columns: 260px 1fr; min-height: 100vh; }

/* ═══ SIDEBAR ═══ */
.investai-sidebar {
  grid-row: 1/-1;
  background: var(--bg-secondary);
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  position: sticky; top: 0; height: 100vh; overflow-y: auto;
  overflow-x: hidden;
}

.sidebar-brand {
  padding: 22px 20px 16px;
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 10px;
}
.brand-logo-icon { font-size: 28px; }
.brand-name {
  font-family: var(--font-display);
  font-size: 17px; font-weight: 700;
  background: linear-gradient(135deg, var(--accent-green), var(--accent-blue));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.brand-version { font-size: 10px; color: var(--text-muted); }

/* ─── User card in sidebar ─── */
.sidebar-user {
  padding: 16px 16px 14px;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: var(--t);
}
.sidebar-user:hover { background: var(--bg-card); }

.user-row { display: flex; align-items: center; gap: 10px; }
.user-avatar {
  width: 38px; height: 38px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 15px; color: #000;
  background: linear-gradient(135deg, var(--accent-green), var(--accent-blue));
  border: 2px solid transparent;
  position: relative; overflow: hidden;
}
.user-avatar.level-2 { border-color: var(--accent-blue); }
.user-avatar.level-3 { border-color: var(--accent-green); }
.user-avatar.level-4 { border-color: var(--accent-yellow); }
.user-avatar.level-5 { border-color: var(--accent-red); }
.user-avatar.level-6 { border-color: var(--accent-purple); }
.user-avatar.level-7 { border-color: #F59E0B; box-shadow: 0 0 12px rgba(245,158,11,0.5); animation: crown-glow 2s ease-in-out infinite; }

@keyframes crown-glow { 0%,100%{box-shadow:0 0 12px rgba(245,158,11,0.5)} 50%{box-shadow:0 0 24px rgba(245,158,11,0.9)} }

.user-info { flex: 1; min-width: 0; }
.user-name  { font-size: 13px; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.user-meta  { display: flex; align-items: center; gap: 6px; margin-top: 3px; }

.plan-chip {
  font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.6px;
  padding: 2px 7px; border-radius: 20px; display: inline-block;
}
.plan-demo   { background: rgba(255,184,48,0.12);  color: var(--accent-yellow); }
.plan-basic  { background: rgba(79,142,247,0.12);  color: var(--accent-blue); }
.plan-pro    { background: rgba(0,229,184,0.12);   color: var(--accent-green); }
.plan-elite  { background: rgba(155,92,246,0.12);  color: var(--accent-purple); }

/* Level bar in sidebar */
.level-bar-wrap { padding: 10px 16px 0; }
.level-row { display: flex; justify-content: space-between; font-size: 11px; color: var(--text-muted); margin-bottom: 5px; }
.level-row span { color: var(--text-secondary); font-weight: 600; }
.level-bar { height: 4px; background: var(--bg-input); border-radius: 4px; overflow: hidden; }
.level-bar-fill { height: 100%; border-radius: 4px; background: linear-gradient(90deg, var(--accent-green), var(--accent-blue)); transition: width 1s ease; }

/* Streak in sidebar */
.streak-badge {
  margin: 10px 16px 0;
  background: rgba(255,71,87,0.08);
  border: 1px solid rgba(255,71,87,0.2);
  border-radius: var(--r); padding: 8px 12px;
  display: flex; align-items: center; gap: 10px;
  cursor: pointer; transition: var(--t);
}
.streak-badge:hover { background: rgba(255,71,87,0.14); }
.streak-fire { font-size: 20px; animation: fire-shake 1.5s ease-in-out infinite; }
@keyframes fire-shake { 0%,100%{transform:rotate(-5deg)} 50%{transform:rotate(5deg)} }
.streak-days { font-size: 20px; font-weight: 900; font-family: var(--font-display); color: var(--accent-red); line-height: 1; }
.streak-label { font-size: 10px; color: var(--text-muted); }

/* Demo timer */
.demo-strip {
  margin: 10px 16px 0;
  background: linear-gradient(135deg,rgba(255,184,48,0.08),rgba(255,184,48,0.03));
  border: 1px solid rgba(255,184,48,0.25); border-radius: var(--r); padding: 10px 12px;
  display: flex; flex-direction: column; align-items: center; text-align: center;
}
.demo-strip-label { font-size: 10px; color: var(--accent-yellow); font-weight: 700; text-transform: uppercase; letter-spacing: 0.7px; margin-bottom: 4px; }
.demo-countdown { font-size: 22px; font-weight: 900; font-family: var(--font-display); font-variant-numeric: tabular-nums; color: var(--accent-yellow); }
.demo-strip .btn-upgrade { margin-top: 8px; font-size: 11px; padding: 5px 10px; width: 100%; justify-content: center; border-radius: 8px; display: flex; }

/* NAV */
.sidebar-nav { padding: 10px 0; flex: 1; }
.nav-section-label {
  padding: 8px 18px 4px;
  font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.2px; color: var(--text-muted);
}
.nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 18px; cursor: pointer;
  font-size: 13px; font-weight: 500; color: var(--text-secondary);
  border-left: 3px solid transparent; transition: var(--t); user-select: none;
  position: relative;
}
.nav-item:hover  { background: rgba(255,255,255,0.03); color: var(--text-primary); }
.nav-item.active { background: rgba(0,229,184,0.06); color: var(--accent-green); border-left-color: var(--accent-green); }
.nav-item i      { width: 17px; text-align: center; font-size: 14px; }
.nav-badge {
  margin-left: auto; background: var(--accent-red); color: #fff;
  font-size: 10px; font-weight: 800; min-width: 18px; height: 18px;
  border-radius: 9px; display: flex; align-items: center; justify-content: center; padding: 0 4px;
  animation: badge-pulse 2s ease infinite;
}
@keyframes badge-pulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.15)} }

.sidebar-bottom { padding: 14px 16px; border-top: 1px solid var(--border); }

/* ═══ TOPBAR ═══ */
.investai-topbar {
  background: rgba(13,20,33,0.9); backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border);
  padding: 0 24px; height: 58px;
  display: flex; align-items: center; justify-content: space-between;
  position: sticky; top: 0; z-index: 100;
}
.topbar-left { display: flex; align-items: center; gap: 14px; }
.topbar-title { font-size: 16px; font-weight: 700; font-family: var(--font-display); }
.live-pill {
  display: flex; align-items: center; gap: 5px;
  background: rgba(0,229,184,0.08); border: 1px solid rgba(0,229,184,0.2);
  border-radius: 20px; padding: 3px 10px;
  font-size: 10px; font-weight: 700; color: var(--accent-green); text-transform: uppercase; letter-spacing: 0.8px;
}
.live-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent-green); animation: blink-dot 1.4s ease-in-out infinite; }
@keyframes blink-dot { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.4;transform:scale(0.7)} }

.topbar-right { display: flex; align-items: center; gap: 10px; }
.sound-btn {
  width: 34px; height: 34px; border-radius: 8px; background: var(--bg-input); border: 1px solid var(--border);
  color: var(--text-secondary); cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 14px; transition: var(--t);
}
.sound-btn:hover { color: var(--text-primary); }

/* ═══ CONTENT ═══ */
.investai-content { padding: 20px 24px; overflow-y: auto; }
.investai-view { display: none; }
.investai-view.active { display: block; animation: view-in 0.25s ease-out; }
@keyframes view-in { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }

/* ═══ BUTTONS ═══ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 7px;
  padding: 10px 20px; border-radius: var(--r); font-family: var(--font);
  font-size: 13px; font-weight: 600; border: none; cursor: pointer; transition: var(--t);
  text-decoration: none; white-space: nowrap; position: relative; overflow: hidden;
}
.btn::after { content:''; position:absolute; inset:0; opacity:0; background:rgba(255,255,255,0.1); transition:opacity 0.15s; }
.btn:hover::after { opacity:1; }
.btn:active { transform: scale(0.97); }
.btn-primary { background: linear-gradient(135deg,var(--accent-green),var(--accent-blue)); color:#000; font-weight:700; }
.btn-primary:hover { box-shadow: var(--glow-green); }
.btn-secondary { background:var(--bg-input); color:var(--text-primary); border:1px solid var(--border); }
.btn-secondary:hover { border-color: var(--accent-blue); }
.btn-danger { background:rgba(255,71,87,0.1); color:var(--accent-red); border:1px solid rgba(255,71,87,0.25); }
.btn-danger:hover { background:rgba(255,71,87,0.2); }
.btn-ghost { background:transparent; color:var(--text-secondary); border:1px solid var(--border); }
.btn-ghost:hover { color:var(--text-primary); border-color:rgba(255,255,255,0.15); }
.btn-sm { padding:6px 13px; font-size:12px; border-radius:8px; }
.btn-xs { padding:4px 9px; font-size:11px; border-radius:7px; }
.btn-icon { padding:8px; border-radius:8px; }
.btn:disabled { opacity:0.45; cursor:not-allowed; transform:none !important; }

/* ═══ FORMS ═══ */
.form-group { margin-bottom: 16px; }
.form-group label { display:block; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.8px; color:var(--text-secondary); margin-bottom:7px; }
.form-group input, .form-group select, .form-group textarea {
  width:100%; background:var(--bg-input); border:1px solid var(--border);
  border-radius:var(--r); padding:11px 14px; color:var(--text-primary);
  font-family:var(--font); font-size:13px; outline:none; transition:var(--t);
}
.form-group input:focus, .form-group select:focus { border-color:var(--accent-blue); box-shadow:0 0 0 3px rgba(79,142,247,0.12); }

/* ═══ CARDS ═══ */
.card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-lg); overflow: hidden;
}
.card-header {
  padding: 14px 18px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
}
.card-title { font-size: 13px; font-weight: 700; display:flex; align-items:center; gap:8px; }
.card-body { padding: 18px; }

/* ═══ STAT CARDS ═══ */
.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px,1fr)); gap: 14px; margin-bottom: 20px; }

.stat-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: 18px; position: relative; overflow: hidden;
  cursor: default; transition: var(--t);
}
.stat-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background: var(--stat-color, var(--accent-green));
}
.stat-card::after {
  content:''; position:absolute; bottom:0; right:0;
  width:80px; height:80px; border-radius:50%;
  background: radial-gradient(circle, var(--stat-color, var(--accent-green)) 0%, transparent 70%);
  opacity:0.07; transform:translate(20px,20px);
}
.stat-card:hover { border-color:rgba(255,255,255,0.1); transform:translateY(-2px); }
.stat-label { font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:0.8px; color:var(--text-muted); margin-bottom:8px; }
.stat-value { font-size:24px; font-weight:900; font-family:var(--font-display); font-variant-numeric:tabular-nums; line-height:1; }
.stat-change { font-size:12px; font-weight:600; margin-top:5px; }
.stat-icon { position:absolute; right:14px; top:14px; font-size:22px; opacity:0.2; }
.stat-change.pos { color:var(--accent-green); }
.stat-change.neg { color:var(--accent-red); }

/* ═══ PORTFOLIO CARDS ═══ */
.portfolios-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:16px; margin-bottom:22px; }

.portfolio-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-xl); padding: 20px; cursor: pointer; transition: var(--t);
  position: relative; overflow: hidden;
}
.portfolio-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background: var(--pcolor, var(--accent-green));
}
.portfolio-card::after {
  content:''; position:absolute; top:0; right:0;
  width:120px; height:120px; border-radius:50%;
  background: radial-gradient(circle, var(--pcolor, var(--accent-green)) 0%, transparent 70%);
  opacity:0.05; transform:translate(30px,-30px);
}
.portfolio-card:hover { border-color:rgba(255,255,255,0.12); transform:translateY(-4px); box-shadow:0 16px 40px rgba(0,0,0,0.35); }
.portfolio-card.selected { border-color:var(--accent-blue); box-shadow:0 0 0 2px rgba(79,142,247,0.2); }

.portfolio-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:12px; }
.portfolio-name { font-size:14px; font-weight:700; }
.portfolio-actions { display:flex; gap:5px; opacity:0; pointer-events:none; transition:var(--t); }
.portfolio-card:hover .portfolio-actions { opacity:1; pointer-events:auto; }

.portfolio-value { font-size:28px; font-weight:900; font-family:var(--font-display); font-variant-numeric:tabular-nums; margin-bottom:4px; }

/* ─── P&L DISPLAY — KEY FEATURE ─── */
.pnl-display {
  display:flex; align-items:center; gap:8px;
  padding:8px 12px; border-radius:var(--r);
  margin:10px 0;
}
.pnl-display.pos { background:rgba(0,229,184,0.08); border:1px solid rgba(0,229,184,0.2); }
.pnl-display.neg { background:rgba(255,71,87,0.08);  border:1px solid rgba(255,71,87,0.2); }

.pnl-arrow { font-size:20px; animation: pnl-bounce 1s ease-in-out infinite; }
.pnl-display.pos .pnl-arrow { animation: pnl-up 1s ease-in-out infinite; }
.pnl-display.neg .pnl-arrow { animation: pnl-down 1s ease-in-out infinite; }
@keyframes pnl-up   { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-3px)} }
@keyframes pnl-down { 0%,100%{transform:translateY(0)} 50%{transform:translateY(3px)} }

.pnl-abs { font-size:16px; font-weight:900; font-family:var(--font-display); font-variant-numeric:tabular-nums; }
.pnl-pct { font-size:12px; font-weight:700; }
.pnl-display.pos .pnl-abs, .pnl-display.pos .pnl-pct { color:var(--accent-green); }
.pnl-display.neg .pnl-abs, .pnl-display.neg .pnl-pct { color:var(--accent-red); }

/* SPARKLINE in card */
.portfolio-sparkline { display:none; }
.sparkline-canvas { width:100%; height:100%; }

.portfolio-footer { display:flex; justify-content:space-between; align-items:center; font-size:11px; color:var(--text-muted); }

/* ═══ POSITIONS TABLE ═══ */
.table-wrap { overflow-x:auto; }
.pos-table { width:100%; border-collapse:collapse; font-size:12px; }
.pos-table th {
  padding:9px 14px; text-align:left; font-size:10px; font-weight:700;
  text-transform:uppercase; letter-spacing:0.8px; color:var(--text-muted);
  border-bottom:1px solid var(--border); white-space:nowrap;
}
.pos-table td { padding:13px 14px; border-bottom:1px solid rgba(255,255,255,0.025); vertical-align:middle; }
.pos-table tr:hover td { background:rgba(255,255,255,0.018); }

.symbol-cell { display:flex; align-items:center; gap:8px; }
.asset-icon {
  width:34px; height:34px; border-radius:9px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:15px;
  background: linear-gradient(135deg, var(--bg-input), var(--border));
}

.dir-badge { padding:3px 8px; border-radius:6px; font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:0.5px; }
.dir-long  { background:rgba(0,229,184,0.1);  color:var(--accent-green); }
.dir-short { background:rgba(255,71,87,0.1);  color:var(--accent-red); }

.price-live { font-variant-numeric:tabular-nums; font-weight:700; transition:color 0.4s ease; }
.price-live.fl-up   { color:var(--accent-green) !important; }
.price-live.fl-down { color:var(--accent-red) !important; }

.pnl-cell { font-variant-numeric:tabular-nums; font-weight:800; font-family:var(--font-display); }
.pnl-cell.pos { color:var(--accent-green); }
.pnl-cell.neg { color:var(--accent-red); }

/* Sparkline in position row */
.mini-spark { width:60px; height:24px; }

/* ═══ MARKET TICKER ═══ */
.market-ticker-wrap {
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: var(--r-lg); overflow: hidden; margin-bottom: 20px;
  padding: 10px 0; position: relative;
}
.market-ticker-wrap::before,
.market-ticker-wrap::after {
  content:''; position:absolute; top:0; bottom:0; width:60px; z-index:2;
}
.market-ticker-wrap::before { left:0; background:linear-gradient(90deg,var(--bg-secondary),transparent); }
.market-ticker-wrap::after  { right:0; background:linear-gradient(-90deg,var(--bg-secondary),transparent); }

.ticker-track { display:flex; gap:0; animation:ticker-run 50s linear infinite; width:max-content; }
.ticker-track:hover { animation-play-state:paused; }

@keyframes ticker-run { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

.ticker-item {
  display:inline-flex; align-items:center; gap:7px; padding:2px 24px;
  border-right:1px solid var(--border); font-size:12px; flex-shrink:0;
}
.ticker-sym  { font-weight:700; color:var(--text-primary); }
.ticker-price { font-variant-numeric:tabular-nums; color:var(--text-secondary); }
.ticker-spark { display:inline-block; width:40px; height:18px; }
.ticker-chg  { font-weight:700; font-size:11px; }
.ticker-chg.up   { color:var(--accent-green); }
.ticker-chg.down { color:var(--accent-red); }

/* ═══ GAUGE (velocímetro) ═══ */
.gauge-wrap {
  display:flex; flex-direction:column; align-items:center;
  padding:16px; position:relative;
}
.gauge-label { font-size:11px; color:var(--text-muted); text-transform:uppercase; letter-spacing:0.8px; margin-top:8px; }
.gauge-value { font-size:22px; font-weight:900; font-family:var(--font-display); font-variant-numeric:tabular-nums; }
.gauge-value.pos { color:var(--accent-green); }
.gauge-value.neg { color:var(--accent-red); }

/* ═══ HEATMAP ═══ */
.heatmap-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(80px,1fr)); gap:4px; padding:4px; }
.heat-cell {
  border-radius:8px; padding:8px 6px; text-align:center; cursor:pointer; transition:var(--t);
  aspect-ratio:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:2px;
  position:relative; overflow:hidden;
}
.heat-cell:hover { transform:scale(1.08); z-index:2; box-shadow:0 4px 20px rgba(0,0,0,0.4); }
.heat-cell .heat-sym  { font-size:10px; font-weight:800; }
.heat-cell .heat-pct  { font-size:12px; font-weight:900; }
.heat-cell .heat-price{ font-size:9px; opacity:0.8; }

/* Heat colors */
.heat-vpos { background:rgba(0,229,184,0.5);  color:#fff; }
.heat-pos  { background:rgba(0,229,184,0.28); color:var(--accent-green); }
.heat-neu  { background:rgba(255,255,255,0.05); color:var(--text-secondary); }
.heat-neg  { background:rgba(255,71,87,0.28);  color:var(--accent-red); }
.heat-vneg { background:rgba(255,71,87,0.5);   color:#fff; }

/* ═══ CHATBOT ═══ */
.chatbot-wrap { display:flex; flex-direction:column; height:calc(100vh - 130px); max-height:750px; }
.chat-messages { flex:1; overflow-y:auto; padding:16px; display:flex; flex-direction:column; gap:14px; }
.chat-msg { display:flex; gap:10px; animation:msg-in 0.3s ease; }
@keyframes msg-in { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }
.chat-msg.user { flex-direction:row-reverse; }
.chat-av {
  width:34px; height:34px; border-radius:50%; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:14px; font-weight:800;
}
.chat-av.ai   { background:linear-gradient(135deg,var(--accent-green),var(--accent-blue)); color:#000; }
.chat-av.user { background:var(--bg-input); border:1px solid var(--border); color:var(--text-primary); }
.chat-bubble {
  max-width:78%; padding:12px 15px; border-radius:14px; font-size:13px; line-height:1.65; word-break:break-word;
}
.chat-msg.assistant .chat-bubble { background:var(--bg-secondary); border:1px solid var(--border); border-bottom-left-radius:4px; }
.chat-msg.user .chat-bubble { background:linear-gradient(135deg,rgba(0,229,184,0.12),rgba(79,142,247,0.12)); border:1px solid rgba(0,229,184,0.18); border-bottom-right-radius:4px; }
.chat-bubble strong { color:var(--accent-green); }
.chat-bubble code { background:rgba(0,0,0,0.3); padding:2px 6px; border-radius:5px; font-size:11px; }
.chat-bubble ul { padding-left:16px; margin-top:6px; }
.chat-time { font-size:10px; color:var(--text-muted); margin-top:4px; text-align:right; }
.typing-dots { display:flex; gap:4px; padding:4px 0; }
.typing-dot { width:7px; height:7px; background:var(--text-muted); border-radius:50%; animation:bounce-dot 1.2s ease infinite; }
.typing-dot:nth-child(2){animation-delay:.2s} .typing-dot:nth-child(3){animation-delay:.4s}
@keyframes bounce-dot { 0%,60%,100%{transform:translateY(0)} 30%{transform:translateY(-7px)} }
.chat-input-area { padding:14px 16px; border-top:1px solid var(--border); background:var(--bg-secondary); }
.chat-suggestions { display:flex; flex-wrap:wrap; gap:7px; margin-bottom:10px; }
.chat-sugg {
  background:var(--bg-input); border:1px solid var(--border); border-radius:20px;
  padding:5px 12px; font-size:11px; cursor:pointer; transition:var(--t); color:var(--text-secondary);
}
.chat-sugg:hover { border-color:var(--accent-green); color:var(--accent-green); }
.chat-row { display:flex; gap:8px; align-items:flex-end; }
.chat-row textarea {
  flex:1; background:var(--bg-input); border:1px solid var(--border); border-radius:var(--r);
  padding:11px 14px; color:var(--text-primary); font-family:var(--font); font-size:13px;
  resize:none; min-height:44px; max-height:120px; outline:none; transition:var(--t); line-height:1.5;
}
.chat-row textarea:focus { border-color:var(--accent-blue); }
.chat-send { width:44px; height:44px; border-radius:10px; background:linear-gradient(135deg,var(--accent-green),var(--accent-blue)); border:none; color:#000; cursor:pointer; font-size:16px; display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:var(--t); }
.chat-send:hover { transform:scale(1.08); box-shadow:var(--glow-green); }

/* ═══ SIGNAL CARDS ═══ */
.signals-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:14px; }
.signal-card {
  background:var(--bg-card); border:1px solid var(--border); border-radius:var(--r-lg); padding:18px;
  transition:var(--t); position:relative; overflow:hidden;
}
.signal-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--signal-color,var(--accent-green)); }
.signal-card:hover { border-color:rgba(255,255,255,0.1); transform:translateY(-2px); }
.signal-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:12px; }
.signal-sym { font-size:15px; font-weight:800; }
.signal-dir {
  padding:4px 12px; border-radius:20px; font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:0.5px;
}
.signal-dir.buy  { background:rgba(0,229,184,0.15); color:var(--accent-green); }
.signal-dir.sell { background:rgba(255,71,87,0.15);  color:var(--accent-red); }
.signal-confidence { margin-bottom:10px; }
.conf-row { display:flex; justify-content:space-between; font-size:11px; color:var(--text-muted); margin-bottom:5px; }
.conf-row span { color:var(--text-primary); font-weight:700; }
.conf-bar { height:6px; background:var(--bg-input); border-radius:6px; overflow:hidden; }
.conf-fill { height:100%; border-radius:6px; background:linear-gradient(90deg,var(--accent-blue),var(--accent-green)); }
.signal-reason { font-size:11px; color:var(--text-secondary); font-style:italic; margin-bottom:12px; line-height:1.5; }
.signal-levels { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.signal-level { background:var(--bg-input); border-radius:8px; padding:8px; text-align:center; }
.signal-level-label { font-size:10px; color:var(--text-muted); margin-bottom:3px; }
.signal-level-val { font-size:13px; font-weight:800; font-variant-numeric:tabular-nums; }

/* ═══ BADGES ═══ */
.badges-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(130px,1fr)); gap:12px; }
.badge-card {
  background:var(--bg-card); border:1px solid var(--border); border-radius:var(--r-lg);
  padding:16px 12px; text-align:center; transition:var(--t); position:relative;
}
.badge-card.earned { border-color:var(--badge-color,var(--accent-green)); background:rgba(0,229,184,0.03); }
.badge-card:not(.earned) { opacity:0.4; filter:grayscale(0.8); }
.badge-card:hover { transform:translateY(-3px); }
.badge-icon { font-size:32px; margin-bottom:8px; display:block; }
.badge-name { font-size:11px; font-weight:700; margin-bottom:4px; }
.badge-desc { font-size:10px; color:var(--text-muted); line-height:1.4; }
.badge-earned-date { font-size:10px; color:var(--accent-green); margin-top:4px; }
.badge-card.earned .badge-icon { filter:drop-shadow(0 0 8px var(--badge-color,var(--accent-green))); }

/* ═══ COURSES ═══ */
.courses-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:16px; }
.course-card {
  background:var(--bg-card); border:1px solid var(--border); border-radius:var(--r-xl);
  padding:20px; transition:var(--t); cursor:pointer; position:relative; overflow:hidden;
}
.course-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--course-color,var(--accent-blue)); }
.course-card:hover { border-color:rgba(255,255,255,0.1); transform:translateY(-3px); box-shadow:0 12px 40px rgba(0,0,0,0.3); }
.course-icon  { font-size:36px; margin-bottom:12px; display:block; }
.course-title { font-size:15px; font-weight:800; margin-bottom:4px; }
.course-level { font-size:11px; color:var(--text-muted); margin-bottom:12px; }
.course-meta  { display:flex; gap:12px; font-size:11px; color:var(--text-secondary); margin-bottom:12px; }
.course-progress-wrap { margin-top:12px; }
.course-prog-bar { height:5px; background:var(--bg-input); border-radius:5px; overflow:hidden; margin-bottom:5px; }
.course-prog-fill { height:100%; border-radius:5px; background:var(--course-color,var(--accent-blue)); transition:width 0.8s ease; }
.course-reward { font-size:11px; color:var(--accent-yellow); font-weight:700; }

/* ═══ LEADERBOARD ═══ */
.leaderboard-table { width:100%; border-collapse:collapse; }
.leaderboard-table th { padding:8px 14px; font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:0.8px; color:var(--text-muted); border-bottom:1px solid var(--border); }
.leaderboard-table td { padding:13px 14px; border-bottom:1px solid rgba(255,255,255,0.02); }
.lb-rank { font-size:18px; font-weight:900; font-family:var(--font-display); }
.lb-rank-1 { color:#F59E0B; }
.lb-rank-2 { color:#CBD5E1; }
.lb-rank-3 { color:#CD7F32; }
.lb-name { font-weight:700; }
.lb-pct { font-size:15px; font-weight:900; font-variant-numeric:tabular-nums; }
.lb-pct.pos { color:var(--accent-green); }
.lb-pct.neg { color:var(--accent-red); }
.lb-streak { font-size:13px; }

/* ═══ CAPITAL STORE ═══ */
.store-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:16px; }
.store-card {
  background:var(--bg-card); border:1px solid var(--border); border-radius:var(--r-xl);
  padding:24px 20px; text-align:center; transition:var(--t); position:relative; overflow:hidden;
}
.store-card.popular { border-color:var(--accent-yellow); }
.store-card.popular::before { content:'⭐ MÁS POPULAR'; position:absolute; top:0; left:0; right:0; background:var(--accent-yellow); color:#000; font-size:10px; font-weight:800; padding:4px; letter-spacing:0.5px; }
.store-card:hover { transform:translateY(-4px); box-shadow:0 12px 40px rgba(0,0,0,0.35); }
.store-icon  { font-size:44px; margin-bottom:10px; margin-top:10px; display:block; }
.store-name  { font-size:16px; font-weight:800; margin-bottom:4px; }
.store-virtual { font-size:24px; font-weight:900; font-family:var(--font-display); color:var(--accent-green); margin-bottom:4px; }
.store-virtual-label { font-size:11px; color:var(--text-muted); margin-bottom:16px; }
.store-price { font-size:28px; font-weight:900; font-family:var(--font-display); margin-bottom:14px; }
.store-per   { font-size:12px; color:var(--text-secondary); margin-top:-10px; margin-bottom:16px; }

/* ═══ TOAST / ALERTS ═══ */
.toast-stack { position:fixed; bottom:24px; right:24px; z-index:99999; display:flex; flex-direction:column; gap:8px; pointer-events:none; max-width:360px; }
.toast {
  background:var(--bg-card); border:1px solid var(--border); border-radius:var(--r-lg);
  padding:14px 16px; display:flex; align-items:center; gap:12px;
  font-size:13px; pointer-events:all; box-shadow:0 10px 40px rgba(0,0,0,0.5);
  animation:toast-slide 0.35s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes toast-slide { from{opacity:0;transform:translateX(30px) scale(0.9)} to{opacity:1;transform:translateX(0) scale(1)} }
.toast.success { border-left:3px solid var(--accent-green); }
.toast.error   { border-left:3px solid var(--accent-red); }
.toast.warning { border-left:3px solid var(--accent-yellow); }
.toast.info    { border-left:3px solid var(--accent-blue); }
.toast-icon    { font-size:18px; flex-shrink:0; }
.toast-close   { margin-left:auto; background:none; border:none; color:var(--text-muted); cursor:pointer; font-size:16px; flex-shrink:0; padding:0 2px; }
.toast-close:hover { color:var(--text-primary); }

/* ═══ MODAL ═══ */
.investai-modal { display:none; position:fixed; inset:0; background:rgba(7,11,20,0.85); z-index:9999; align-items:center; justify-content:center; backdrop-filter:blur(8px); padding:20px; }
.investai-modal.open { display:flex; }
.modal-box {
  background:var(--bg-card); border:1px solid var(--border); border-radius:var(--r-xl);
  padding:28px; width:100%; max-width:500px; position:relative;
  animation:modal-pop 0.3s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes modal-pop { from{opacity:0;transform:scale(0.85)} to{opacity:1;transform:scale(1)} }
.modal-close { position:absolute; top:16px; right:16px; background:var(--bg-input); border:1px solid var(--border); border-radius:8px; color:var(--text-muted); font-size:16px; cursor:pointer; width:30px; height:30px; display:flex; align-items:center; justify-content:center; transition:var(--t); }
.modal-close:hover { color:var(--text-primary); border-color:rgba(255,255,255,0.15); }
.modal-title { font-size:20px; font-weight:800; font-family:var(--font-display); margin-bottom:20px; }

/* Trade direction tabs */
.direction-tabs { display:flex; gap:8px; margin-bottom:18px; }
.dir-tab { flex:1; padding:12px; border-radius:var(--r); cursor:pointer; font-size:14px; font-weight:700; border:2px solid var(--border); background:none; color:var(--text-secondary); transition:var(--t); text-align:center; font-family:var(--font); }
.dir-tab.buy.active  { background:rgba(0,229,184,0.1); border-color:var(--accent-green); color:var(--accent-green); box-shadow:inset 0 0 20px rgba(0,229,184,0.05); }
.dir-tab.sell.active { background:rgba(255,71,87,0.1); border-color:var(--accent-red);   color:var(--accent-red); }

/* Live price preview */
.price-preview-box {
  background:var(--bg-secondary); border:1px solid var(--border); border-radius:var(--r);
  padding:14px 16px; display:flex; justify-content:space-between; align-items:center; margin-bottom:16px;
}
.preview-main-price { font-size:24px; font-weight:900; font-family:var(--font-display); font-variant-numeric:tabular-nums; }
.preview-change { font-size:12px; font-weight:700; }
.preview-change.pos { color:var(--accent-green); }
.preview-change.neg { color:var(--accent-red); }

/* ═══ EXPIRED OVERLAY ═══ */
.expired-overlay { position:fixed; inset:0; background:rgba(7,11,20,0.95); z-index:9998; display:flex; align-items:center; justify-content:center; backdrop-filter:blur(12px); padding:20px; }
.expired-box { background:var(--bg-card); border:1px solid var(--border); border-radius:24px; padding:44px 36px; max-width:560px; width:100%; text-align:center; }

/* ═══ PLANS GRID ═══ */
.plans-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:16px; }
.plan-card {
  background:var(--bg-card); border:1px solid var(--border); border-radius:var(--r-xl);
  padding:26px 22px; text-align:center; transition:var(--t); position:relative; overflow:hidden;
}
.plan-card.featured { border-color:var(--accent-green); }
.plan-card.featured::before { content:'⭐ POPULAR'; position:absolute; top:-1px; left:50%; transform:translateX(-50%); background:var(--accent-green); color:#000; font-size:10px; font-weight:800; padding:5px 14px; border-radius:0 0 12px 12px; letter-spacing:0.5px; }
.plan-card:hover { transform:translateY(-4px); border-color:rgba(255,255,255,0.12); }
.plan-name  { font-size:18px; font-weight:800; font-family:var(--font-display); margin-bottom:6px; }
.plan-price { font-size:38px; font-weight:900; font-family:var(--font-display); margin:16px 0 4px; }
.plan-per   { font-size:12px; color:var(--text-secondary); margin-bottom:20px; }
.plan-feat  { font-size:12px; color:var(--text-secondary); padding:7px 0; border-bottom:1px solid var(--border-light); display:flex; align-items:center; gap:8px; text-align:left; }
.plan-feat i { color:var(--accent-green); width:14px; flex-shrink:0; }

/* ═══ NEWS ═══ */
.news-feed { display:flex; flex-direction:column; gap:10px; }
.news-card {
  background:var(--bg-card); border:1px solid var(--border); border-radius:var(--r-lg);
  padding:14px 16px; display:flex; gap:12px; cursor:pointer; transition:var(--t);
}
.news-card:hover { border-color:rgba(255,255,255,0.1); background:var(--bg-card-hover); }
.news-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; margin-top:5px; }
.news-dot.high   { background:var(--accent-red);    box-shadow:0 0 8px rgba(255,71,87,0.6); }
.news-dot.medium { background:var(--accent-yellow); }
.news-dot.low    { background:var(--accent-green);  }
.news-content { flex:1; min-width:0; }
.news-title  { font-size:13px; font-weight:700; line-height:1.4; margin-bottom:4px; }
.news-meta   { font-size:11px; color:var(--text-muted); display:flex; gap:10px; }

/* ═══ MISSIONS ═══ */
.missions-list { display:flex; flex-direction:column; gap:10px; }
.mission-card {
  background:var(--bg-card); border:1px solid var(--border); border-radius:var(--r-lg);
  padding:14px 16px; display:flex; align-items:center; gap:14px;
}
.mission-card.done { border-color:rgba(0,229,184,0.3); background:rgba(0,229,184,0.03); }
.mission-icon { font-size:24px; flex-shrink:0; }
.mission-content { flex:1; min-width:0; }
.mission-title  { font-size:13px; font-weight:700; margin-bottom:6px; }
.mission-prog-bar { height:5px; background:var(--bg-input); border-radius:5px; overflow:hidden; margin-bottom:4px; }
.mission-prog-fill { height:100%; border-radius:5px; background:linear-gradient(90deg,var(--accent-blue),var(--accent-green)); transition:width 0.8s ease; }
.mission-reward { font-size:11px; color:var(--accent-yellow); font-weight:700; }
.mission-check { font-size:22px; flex-shrink:0; }

/* ═══ TABS ═══ */
.tab-nav { display:flex; border-bottom:1px solid var(--border); margin-bottom:18px; }
.tab-btn { padding:10px 18px; background:none; border:none; border-bottom:2px solid transparent; color:var(--text-secondary); font-size:13px; font-weight:600; cursor:pointer; font-family:var(--font); transition:var(--t); }
.tab-btn:hover { color:var(--text-primary); }
.tab-btn.active { color:var(--accent-green); border-bottom-color:var(--accent-green); }
.tab-content { display:none; }
.tab-content.active { display:block; }

/* ═══ EMPTY STATES ═══ */
.empty-state { text-align:center; padding:40px 20px; }
.empty-state .es-icon { font-size:42px; display:block; margin-bottom:12px; opacity:0.4; }
.empty-state h3 { font-size:16px; font-weight:700; margin-bottom:6px; }
.empty-state p { font-size:13px; color:var(--text-secondary); margin-bottom:18px; }

/* ═══ LOADING ═══ */
.loading-wrap { display:flex; align-items:center; justify-content:center; padding:40px; }
.spinner { width:28px; height:28px; border:3px solid var(--border); border-top-color:var(--accent-green); border-radius:50%; animation:spin 0.75s linear infinite; }
@keyframes spin { to{transform:rotate(360deg)} }

/* ═══ AUTH PAGES ═══ */
.investai-auth-page { min-height:100vh; display:flex; align-items:center; justify-content:center; padding:20px; background:var(--bg-primary); background-image:radial-gradient(ellipse at 15% 50%,rgba(79,142,247,0.07) 0%,transparent 60%),radial-gradient(ellipse at 85% 20%,rgba(0,229,184,0.05) 0%,transparent 50%); }
.auth-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--r-xl); padding:40px 36px; width:100%; max-width:440px; box-shadow:0 30px 70px rgba(0,0,0,0.6); }
.auth-logo { text-align:center; margin-bottom:32px; }
.auth-logo-icon { font-size:44px; display:block; margin-bottom:10px; }
.auth-logo h1 { font-size:24px; font-weight:900; font-family:var(--font-display); background:linear-gradient(135deg,var(--accent-green),var(--accent-blue)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.auth-logo p { font-size:13px; color:var(--text-secondary); margin-top:4px; }
.auth-footer { text-align:center; margin-top:22px; font-size:13px; color:var(--text-secondary); }
.demo-promo { margin-top:20px; padding:14px; background:rgba(0,229,184,0.05); border:1px solid rgba(0,229,184,0.18); border-radius:var(--r); text-align:center; }
.demo-promo-badge { font-size:10px; color:var(--accent-green); font-weight:800; text-transform:uppercase; letter-spacing:0.7px; margin-bottom:4px; }
.demo-promo-text { font-size:12px; color:var(--text-secondary); }

/* ═══ MARKET FILTER TABS ═══ */
.market-filters { display:flex; gap:7px; flex-wrap:wrap; margin-bottom:16px; }
.market-filter { background:var(--bg-input); border:1px solid var(--border); border-radius:20px; padding:6px 14px; font-size:12px; font-weight:600; cursor:pointer; transition:var(--t); color:var(--text-secondary); font-family:var(--font); }
.market-filter:hover { color:var(--text-primary); }
.market-filter.active { background:rgba(0,229,184,0.1); border-color:var(--accent-green); color:var(--accent-green); }

/* ═══ CHANGE CHIP ═══ */
.chip { display:inline-flex; align-items:center; gap:4px; padding:3px 8px; border-radius:7px; font-size:11px; font-weight:700; }
.chip.up   { background:rgba(0,229,184,0.1); color:var(--accent-green); }
.chip.down { background:rgba(255,71,87,0.1); color:var(--accent-red); }

/* ═══ CONFETTI / BLOOD OVERLAY ═══ */
#blood-overlay { position:fixed; inset:0; pointer-events:none; z-index:99990; overflow:hidden; }
.blood-drop {
  position:absolute; top:-20px; width:6px; border-radius:0 0 50% 50%;
  background:linear-gradient(var(--accent-red),#8B0000); opacity:0.9;
  animation:fall linear forwards;
}
@keyframes fall { to{transform:translateY(110vh);opacity:0} }

/* ═══ RESPONSIVE ═══ */
@media(max-width:900px) {
  .investai-dashboard { grid-template-columns:1fr; }
  .investai-sidebar   { display:none; }
  .stats-grid         { grid-template-columns:repeat(2,1fr); }
  .portfolios-grid    { grid-template-columns:1fr; }
  .investai-content   { padding:14px; }
  .signals-grid, .courses-grid, .store-grid { grid-template-columns:1fr; }
  .badges-grid { grid-template-columns:repeat(3,1fr); }
}

/* ═══ LIGHT THEME ═══ */
.investai-wrap.theme-light {
  --bg-primary:    #F0F4FF;
  --bg-secondary:  #FFFFFF;
  --bg-card:       #FFFFFF;
  --bg-card-hover: #F8FAFF;
  --bg-input:      #EEF2FF;
  --border:        #DDE3F0;
  --border-light:  rgba(0,0,0,0.05);
  --text-primary:  #1A2440;
  --text-secondary:#4A5568;
  --text-muted:    #94A3B8;
}

/* ═══ WINNER BANNER ═══ */
.winner-banner {
  position:fixed; top:70px; left:50%; transform:translateX(-50%); z-index:9990;
  background:linear-gradient(135deg,var(--accent-green),var(--accent-blue));
  color:#000; border-radius:var(--r-lg); padding:14px 28px;
  font-size:16px; font-weight:900; font-family:var(--font-display);
  box-shadow:0 8px 40px rgba(0,229,184,0.5); text-align:center;
  animation:banner-in 0.5s cubic-bezier(0.34,1.56,0.64,1);
  pointer-events:none; white-space:nowrap;
}
@keyframes banner-in { from{opacity:0;transform:translateX(-50%) scale(0.7) translateY(-20px)} to{opacity:1;transform:translateX(-50%) scale(1) translateY(0)} }

.loser-banner {
  position:fixed; top:70px; left:50%; transform:translateX(-50%); z-index:9990;
  background:linear-gradient(135deg,var(--accent-red),#8B0000);
  color:#fff; border-radius:var(--r-lg); padding:14px 28px;
  font-size:16px; font-weight:900; font-family:var(--font-display);
  box-shadow:0 8px 40px rgba(255,71,87,0.5); text-align:center;
  animation:banner-in 0.5s cubic-bezier(0.34,1.56,0.64,1);
  pointer-events:none;
}


/* ── PREMIUM COURSE CARDS ── */
#courses-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 20px;
}
.course-card-premium {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-top: 3px solid var(--cc, var(--accent-green));
  border-radius: var(--r);
  padding: 22px 20px;
  transition: transform .2s, box-shadow .2s;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.course-card-premium:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 32px rgba(0,0,0,.3);
}
.course-card-header {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 12px;
}
.course-card-icon {
  width: 48px; height: 48px;
  border-radius: 12px;
  background: rgba(255,255,255,.05);
  display: flex; align-items: center; justify-content: center;
  font-size: 24px;
  flex-shrink: 0;
}
.course-card-title {
  font-size: 16px;
  font-weight: 800;
  color: var(--text-primary);
  line-height: 1.3;
}

/* ── COURSE CONTENT ── */
.course-content h3 { font-size: 18px; font-weight: 800; margin: 20px 0 10px; color: var(--text-primary); }
.course-content p { color: var(--text-secondary); line-height: 1.7; margin-bottom: 14px; }
.course-highlight { background: rgba(0,212,170,.06); border: 1px solid rgba(0,212,170,.2); border-left: 3px solid var(--accent-green); border-radius: var(--r); padding: 16px 20px; margin: 16px 0; }
.course-highlight h4 { font-size: 14px; font-weight: 800; color: var(--accent-green); margin-bottom: 10px; }
.course-highlight ul, .course-highlight ol { color: var(--text-secondary); padding-left: 20px; }
.course-highlight li { margin-bottom: 6px; line-height: 1.6; }
.course-table { overflow-x: auto; margin: 16px 0; border-radius: var(--r); border: 1px solid var(--border); }
.course-table table { width: 100%; border-collapse: collapse; }
.course-table th { background: var(--bg-secondary); color: var(--accent-green); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; padding: 10px 14px; text-align: left; border-bottom: 1px solid var(--border); }
.course-table td { padding: 10px 14px; color: var(--text-secondary); font-size: 13px; border-bottom: 1px solid rgba(255,255,255,.04); }
.course-table tr:last-child td { border-bottom: none; }
.course-table tr:hover td { background: rgba(255,255,255,.02); }
.course-strong { color: var(--text-primary); font-weight: 700; }

/* Course pagination */
.course-pagination { display: flex; align-items: center; justify-content: space-between; padding: 20px 0; border-top: 1px solid var(--border); margin-top: 24px; }
.course-page-dots { display: flex; gap: 6px; }
.course-page-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--border); transition: all .2s; }
.course-page-dot.active { background: var(--accent-green); width: 24px; border-radius: 4px; }
.course-page-dot.done { background: var(--accent-green); opacity: .5; }
.course-page-num { font-size: 12px; color: var(--text-muted); }
.course-progress-bar-wrap { background: var(--bg-secondary); border-radius: 4px; height: 4px; margin-bottom: 20px; overflow: hidden; }
.course-progress-bar { height: 100%; background: linear-gradient(90deg, var(--accent-green), var(--accent-blue)); border-radius: 4px; transition: width .4s ease; }
