/* ===========================================
   Bloomfolio Rx — Bold DTC (Hims / Whoop / TrumpRx)
   Dark, bold, minimal, retail-friendly
   =========================================== */

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

:root {
  --bg: #0a0a0a;
  --bg-subtle: #111113;
  --bg-muted: #1a1a1f;
  --bg-hover: #222228;
  --surface: #151518;
  --border: #2a2a30;
  --border-focus: #635BFF;
  --text: #f5f5f7;
  --text-secondary: #a1a1aa;
  --text-muted: #6b6b78;
  --primary: #635BFF;
  --primary-light: rgba(99,91,255,0.12);
  --primary-dark: #4b44cc;
  --green: #34d399;
  --green-light: rgba(52,211,153,0.1);
  --red: #f87171;
  --red-light: rgba(248,113,113,0.1);
  --orange: #fbbf24;
  --orange-light: rgba(251,191,36,0.1);
  --blue: #60a5fa;
  --blue-light: rgba(96,165,250,0.1);
  --radius: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.3);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.4);
  --shadow-lg: 0 12px 40px rgba(0,0,0,0.5);
  --font: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --transition: 0.2s ease;
}

html { scroll-behavior:smooth; }
body { font-family:var(--font); background:var(--bg); color:var(--text); line-height:1.5; -webkit-font-smoothing:antialiased; }
a { color:inherit; text-decoration:none; }
.hidden { display:none !important; }

/* Buttons */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:6px; padding:10px 20px; border:none; border-radius:var(--radius); font:600 14px/1 var(--font); cursor:pointer; transition:var(--transition); white-space:nowrap; }
.btn-primary { background:var(--primary); color:#fff; }
.btn-primary:hover { background:var(--primary-dark); transform:translateY(-1px); box-shadow:0 4px 20px rgba(99,91,255,0.4); }
.btn-outline { background:transparent; color:var(--text); border:1px solid var(--border); }
.btn-outline:hover { border-color:var(--primary); color:var(--primary); }
.btn-ghost { background:transparent; color:var(--text-secondary); }
.btn-ghost:hover { color:var(--text); background:var(--bg-muted); }
.btn-green { background:var(--green); color:#000; font-weight:700; }
.btn-green:hover { opacity:0.9; }
.btn-sm { padding:8px 14px; font-size:13px; }
.btn-lg { padding:14px 28px; font-size:15px; border-radius:var(--radius-lg); }
.btn-full { width:100%; }
.btn-icon { background:none; border:none; cursor:pointer; padding:8px; border-radius:50%; color:var(--text-secondary); transition:var(--transition); }
.btn-icon:hover { background:var(--bg-muted); color:var(--text); }

/* Nav */
.nav { position:sticky; top:0; z-index:100; background:rgba(10,10,10,0.88); backdrop-filter:blur(16px); border-bottom:1px solid var(--border); }
.nav-inner { max-width:1200px; margin:0 auto; padding:0 24px; height:56px; display:flex; align-items:center; gap:32px; }
.nav-brand { display:flex; align-items:center; gap:10px; font-weight:700; font-size:17px; }
.nav-links { display:flex; gap:4px; }
.nav-link { padding:8px 14px; border-radius:var(--radius); font-size:14px; font-weight:500; color:var(--text-secondary); transition:var(--transition); }
.nav-link:hover, .nav-link.active { color:var(--text); background:var(--bg-muted); }
.nav-right { margin-left:auto; display:flex; align-items:center; gap:12px; }

/* Search */
.search-box { position:relative; }
.search-box svg { position:absolute; left:12px; top:50%; transform:translateY(-50%); color:var(--text-muted); pointer-events:none; }
.search-box input { width:260px; padding:8px 12px 8px 36px; border:1px solid var(--border); border-radius:var(--radius); font:400 14px var(--font); background:var(--bg-subtle); transition:var(--transition); color:var(--text); }
.search-box input:focus { outline:none; border-color:var(--primary); background:var(--bg-muted); box-shadow:0 0 0 3px rgba(99,91,255,0.15); width:360px; }
.search-box input::placeholder { color:var(--text-muted); }
.search-results { position:absolute; top:calc(100% + 8px); left:0; right:0; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); display:none; max-height:400px; overflow-y:auto; z-index:200; }
.search-results.open { display:block; }
.search-result-item { padding:12px 16px; cursor:pointer; display:flex; align-items:center; gap:12px; transition:var(--transition); }
.search-result-item:hover { background:var(--bg-hover); }
.search-result-item .sr-ticker { font-weight:700; min-width:60px; }
.search-result-item .sr-name { color:var(--text-secondary); font-size:13px; flex:1; }
.search-result-item .sr-score { font-weight:600; color:var(--primary); font-size:13px; }

/* Avatar/Dropdown */
.avatar-menu { position:relative; }
.avatar-btn { width:32px; height:32px; border-radius:50%; background:var(--primary); color:#fff; border:none; cursor:pointer; font:600 14px var(--font); display:flex; align-items:center; justify-content:center; }
.dropdown { position:absolute; top:calc(100% + 8px); right:0; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); min-width:200px; z-index:200; padding:4px 0; }
.dropdown-header { padding:12px 16px; font-size:13px; color:var(--text-muted); border-bottom:1px solid var(--border); }
.dropdown-item { display:block; width:100%; text-align:left; padding:10px 16px; font:400 14px var(--font); color:var(--text); cursor:pointer; transition:var(--transition); background:none; border:none; }
.dropdown-item:hover { background:var(--bg-hover); }
.dropdown-divider { height:1px; background:var(--border); margin:4px 0; }
.notif-dot { position:absolute; top:4px; right:4px; width:8px; height:8px; background:var(--red); border-radius:50%; border:2px solid var(--bg); }

/* Layout */
.container { max-width:1200px; margin:0 auto; padding:0 24px; }
.page { padding:32px 0 80px; }
.page-header { margin-bottom:32px; }
.page-title { font-size:28px; font-weight:800; letter-spacing:-0.02em; margin-bottom:4px; }
.page-subtitle { color:var(--text-secondary); font-size:15px; }

/* Cards */
.card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-xl); overflow:hidden; transition:var(--transition); }
.card:hover { box-shadow:var(--shadow-md); }
.card-body { padding:20px; }

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

/* HERO */
.hero { padding:100px 24px 60px; text-align:center; background:var(--bg); position:relative; overflow:hidden; }
.hero::before { content:''; position:absolute; top:-50%; left:50%; width:800px; height:800px; background:radial-gradient(circle,rgba(99,91,255,0.08) 0%,transparent 70%); transform:translateX(-50%); pointer-events:none; }
.hero h1 { font-size:clamp(36px,6vw,64px); font-weight:900; letter-spacing:-0.04em; line-height:1.05; margin-bottom:20px; position:relative; }
.hero h1 span { background:linear-gradient(135deg,var(--primary),#60a5fa); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.hero p { color:var(--text-secondary); font-size:18px; max-width:520px; margin:0 auto 36px; line-height:1.6; position:relative; }
.hero-cta { display:flex; gap:12px; justify-content:center; margin-bottom:48px; position:relative; }
.hero-metrics { display:flex; gap:48px; justify-content:center; flex-wrap:wrap; position:relative; }
.hero-metric { text-align:center; }
.hero-metric-value { font-size:36px; font-weight:800; color:var(--text); }
.hero-metric-label { font-size:12px; color:var(--text-muted); text-transform:uppercase; letter-spacing:0.08em; margin-top:4px; }

/* Chips / Filters */
.filter-bar-wrapper { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; gap:12px; border-bottom:1px solid var(--border); }
.filter-bar { display:flex; flex-direction:column; gap:10px; padding:16px 0; border-bottom:1px solid var(--border); margin-bottom:24px; }
.filter-chips { display:flex; gap:4px; flex-wrap:wrap; }
.chip { padding:6px 14px; border:1px solid var(--border); border-radius:100px; font:500 12px var(--font); cursor:pointer; transition:var(--transition); background:transparent; color:var(--text-secondary); white-space:nowrap; }
.chip:hover { border-color:var(--primary); color:var(--primary); }
.chip.active { background:var(--primary); color:#fff; border-color:var(--primary); }
.filter-controls { display:flex; gap:6px; flex-wrap:wrap; }
.filter-controls select { padding:6px 28px 6px 10px; border:1px solid var(--border); border-radius:var(--radius); font:500 12px var(--font); background:var(--surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b6b78' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 8px center; appearance:none; color:var(--text); cursor:pointer; }

/* Stock Cards */
.stock-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(360px,1fr)); gap:16px; }
.stock-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-xl); padding:0; transition:var(--transition); position:relative; overflow:hidden; }
.stock-card:hover { box-shadow:var(--shadow-md); transform:translateY(-2px); border-color:var(--primary); }
.stock-card-inner { padding:20px; }
.stock-top { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:12px; }
.stock-ticker { font-size:20px; font-weight:800; }
.stock-name { font-size:13px; color:var(--text-secondary); }
.stock-score { width:48px; height:48px; border-radius:var(--radius); display:flex; flex-direction:column; align-items:center; justify-content:center; font-weight:800; font-size:18px; color:#000; line-height:1; }
.stock-score small { font-size:8px; font-weight:600; opacity:0.8; text-transform:uppercase; letter-spacing:0.05em; }
.score-high { background:var(--green); }
.score-mid { background:var(--primary); color:#fff; }
.score-low { background:var(--orange); }
.stock-tags { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:12px; }
.tag { padding:3px 10px; border-radius:100px; font-size:11px; font-weight:600; }
.tag-area { background:var(--primary-light); color:var(--primary); }
.tag-phase { background:var(--green-light); color:var(--green); }
.tag-fda { background:var(--red-light); color:var(--red); }
.tag-catalyst { background:var(--orange-light); color:var(--orange); }
.stock-drug { font-weight:600; font-size:14px; margin-bottom:2px; }
.stock-indication { font-size:13px; color:var(--text-secondary); margin-bottom:12px; }
.stock-chart-mini { height:48px; margin:0 -20px; }
.stock-metrics { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; padding-top:12px; border-top:1px solid var(--border); margin-top:12px; }
.stock-metric { text-align:center; }
.stock-metric-value { font-size:14px; font-weight:700; }
.stock-metric-label { font-size:10px; color:var(--text-muted); text-transform:uppercase; letter-spacing:0.05em; }

/* Loading skeletons */
.stock-card-skeleton .skeleton-line,
.stock-card-skeleton .skeleton-pill,
.stock-card-skeleton .skeleton-chart {
  background: linear-gradient(90deg, var(--bg-muted) 25%, var(--border) 50%, var(--bg-muted) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.2s infinite;
  border-radius: 8px;
}
.stock-card-skeleton .skeleton-line { height: 12px; margin-bottom: 10px; }
.stock-card-skeleton .w-40 { width: 40%; }
.stock-card-skeleton .w-60 { width: 60%; }
.stock-card-skeleton .w-75 { width: 75%; }
.stock-card-skeleton .w-90 { width: 90%; }
.stock-card-skeleton .skeleton-pill-row { display:flex; gap:6px; margin: 12px 0; }
.stock-card-skeleton .skeleton-pill { width: 72px; height: 20px; border-radius: 999px; display:inline-block; }
.stock-card-skeleton .skeleton-chart { height: 52px; margin-top: 12px; }
@keyframes shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* Sparkline */
.sparkline-container { position:relative; height:52px; margin:8px -20px 0; }
.sparkline-container canvas { width:100% !important; height:100% !important; }

/* Paywall */
.paywall { text-align:center; padding:60px 24px; background:linear-gradient(to bottom,transparent,var(--bg-subtle) 30%); position:relative; margin-top:-120px; padding-top:160px; }
.paywall h3 { font-size:24px; font-weight:800; margin-bottom:8px; }
.paywall p { color:var(--text-secondary); margin-bottom:24px; max-width:480px; margin-left:auto; margin-right:auto; }

/* Heatmap */
.heatmap-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:12px; }
.heatmap-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); padding:20px; transition:var(--transition); }
.heatmap-card:hover { box-shadow:var(--shadow-sm); border-color:var(--primary); }
.heatmap-title { font-weight:700; font-size:15px; margin-bottom:2px; }
.heatmap-area { font-size:12px; color:var(--text-muted); text-transform:uppercase; letter-spacing:0.05em; margin-bottom:12px; }
.heatmap-bar-bg { height:4px; background:var(--bg-muted); border-radius:100px; overflow:hidden; margin-bottom:10px; }
.heatmap-bar-fill { height:100%; border-radius:100px; transition:width 1s ease; }
.heatmap-meta { display:flex; justify-content:space-between; font-size:12px; }
.heatmap-count { font-weight:600; }
.heatmap-trend { color:var(--green); font-weight:600; }

/* Catalyst */
.catalyst-list { max-width:800px; }
.catalyst-item { display:flex; gap:20px; padding:16px 20px; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); margin-bottom:8px; align-items:center; transition:var(--transition); }
.catalyst-item:hover { box-shadow:var(--shadow-sm); border-color:var(--primary); }
.catalyst-date-box { text-align:center; min-width:56px; }
.catalyst-month { font-size:11px; text-transform:uppercase; letter-spacing:0.1em; color:var(--primary); font-weight:700; }
.catalyst-year { font-size:22px; font-weight:800; }
.catalyst-info { flex:1; }
.catalyst-ticker { font-weight:700; }
.catalyst-event { font-size:13px; color:var(--text-secondary); }
.catalyst-badge { padding:4px 12px; border-radius:100px; font-size:11px; font-weight:600; white-space:nowrap; }
.badge-data { background:var(--primary-light); color:var(--primary); }
.badge-fda { background:var(--red-light); color:var(--red); }
.badge-enrollment { background:var(--green-light); color:var(--green); }

/* News */
.news-list { display:flex; flex-direction:column; gap:8px; }
.news-item { display:flex; gap:16px; padding:16px 20px; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); transition:var(--transition); cursor:pointer; }
.news-item:hover { box-shadow:var(--shadow-sm); border-color:var(--primary); }
.news-sentiment { width:4px; border-radius:100px; flex-shrink:0; }
.news-sentiment.very-positive { background:var(--green); }
.news-sentiment.positive { background:var(--blue); }
.news-sentiment.neutral { background:var(--text-muted); }
.news-sentiment.negative { background:var(--red); }
.news-content { flex:1; }
.news-title { font-weight:600; font-size:14px; margin-bottom:4px; }
.news-summary { font-size:13px; color:var(--text-secondary); line-height:1.5; }
.news-meta { display:flex; gap:12px; margin-top:8px; font-size:12px; color:var(--text-muted); }

/* Pricing */
.pricing-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; max-width:900px; margin:0 auto; }
.pricing-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-xl); padding:32px; text-align:center; position:relative; }
.pricing-card.featured { border-color:var(--primary); box-shadow:0 0 40px rgba(99,91,255,0.15); }
.pricing-badge { position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--primary); color:#fff; padding:4px 16px; border-radius:100px; font-size:12px; font-weight:600; }
.pricing-name { font-weight:600; color:var(--text-secondary); margin-bottom:8px; text-transform:uppercase; letter-spacing:0.1em; font-size:13px; }
.pricing-price { font-size:48px; font-weight:900; margin-bottom:4px; letter-spacing:-0.03em; }
.pricing-price span { font-size:16px; font-weight:400; color:var(--text-muted); }
.pricing-desc { font-size:13px; color:var(--text-muted); margin-bottom:24px; }
.pricing-features { list-style:none; text-align:left; margin-bottom:24px; }
.pricing-features li { padding:6px 0; font-size:14px; display:flex; align-items:center; gap:8px; }
.pricing-features li.yes::before { content:'✓'; color:var(--green); font-weight:700; }
.pricing-features li.no { color:var(--text-muted); }
.pricing-features li.no::before { content:'—'; color:var(--text-muted); }

/* Detail page */
.detail-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:24px; flex-wrap:wrap; gap:16px; }
.detail-title { font-size:32px; font-weight:800; }
.detail-subtitle { color:var(--text-secondary); font-size:15px; }
.detail-chart { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-xl); padding:24px; margin-bottom:24px; }
.detail-chart h3 { font-size:15px; font-weight:700; margin-bottom:16px; }
.chart-container { position:relative; height:300px; }
.detail-grid { display:grid; grid-template-columns:2fr 1fr; gap:16px; }
.detail-section { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-xl); padding:24px; margin-bottom:16px; }
.detail-section h3 { font-size:15px; font-weight:700; margin-bottom:12px; }
.detail-stat { display:flex; justify-content:space-between; padding:10px 0; border-bottom:1px solid var(--border); }
.detail-stat:last-child { border-bottom:none; }
.detail-stat-label { color:var(--text-secondary); font-size:14px; }
.detail-stat-value { font-weight:600; font-size:14px; }

/* Alerts */
.alert-item { display:flex; align-items:center; gap:16px; padding:16px 20px; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); margin-bottom:8px; }
.alert-item .alert-info { flex:1; }
.alert-item .alert-ticker { font-weight:700; }
.alert-item .alert-type { font-size:13px; color:var(--text-secondary); }
.toggle { width:44px; height:24px; border-radius:100px; background:var(--bg-muted); border:none; cursor:pointer; position:relative; transition:var(--transition); }
.toggle.on { background:var(--green); }
.toggle::after { content:''; position:absolute; width:20px; height:20px; border-radius:50%; background:#fff; top:2px; left:2px; transition:var(--transition); box-shadow:var(--shadow-sm); }
.toggle.on::after { left:22px; }

/* Modal */
.modal-backdrop { position:fixed; inset:0; background:rgba(0,0,0,0.7); z-index:1000; display:flex; align-items:center; justify-content:center; padding:24px; backdrop-filter:blur(8px); }
.modal { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-xl); max-width:420px; width:100%; padding:32px; position:relative; animation:modalIn 0.2s ease; }
@keyframes modalIn { from{opacity:0;transform:translateY(10px) scale(0.98)} }
.modal-close { position:absolute; top:12px; right:12px; background:none; border:none; font-size:24px; color:var(--text-muted); cursor:pointer; padding:4px 8px; }
.modal h2 { font-size:22px; font-weight:700; margin-bottom:4px; }
.modal .modal-subtitle { color:var(--text-secondary); font-size:14px; margin-bottom:24px; }
.form-group { margin-bottom:16px; }
.form-group label { display:block; font-size:13px; font-weight:600; margin-bottom:6px; color:var(--text-secondary); }
.form-group input { width:100%; padding:12px 14px; border:1px solid var(--border); border-radius:var(--radius); font:400 14px var(--font); transition:var(--transition); color:var(--text); background:var(--bg-muted); }
.form-group input:focus { outline:none; border-color:var(--primary); box-shadow:0 0 0 3px rgba(99,91,255,0.15); }
.form-error { color:var(--red); font-size:13px; margin-top:6px; }
.form-footer { text-align:center; font-size:13px; color:var(--text-secondary); margin-top:16px; }
.form-footer a { color:var(--primary); font-weight:600; cursor:pointer; }

/* Footer */
.footer { padding:48px 24px; border-top:1px solid var(--border); background:var(--bg); margin-top:48px; }
.footer-inner { max-width:1200px; margin:0 auto; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px; margin-bottom:32px; }
.footer-brand p { color:var(--text-secondary); font-size:13px; margin-top:8px; }
.footer-col h4 { font-size:13px; font-weight:700; margin-bottom:12px; text-transform:uppercase; letter-spacing:0.05em; color:var(--text-muted); }
.footer-col a { display:block; font-size:14px; color:var(--text-secondary); padding:4px 0; transition:var(--transition); }
.footer-col a:hover { color:var(--text); }
.footer-bottom { padding-top:24px; border-top:1px solid var(--border); font-size:12px; color:var(--text-muted); text-align:center; line-height:1.8; }

/* Legal pages */
.legal-text h2 { font-size:18px; font-weight:700; margin:28px 0 8px; color:var(--text); }
.legal-text p { font-size:14px; line-height:1.8; color:var(--text-secondary); margin-bottom:12px; }
.legal-text strong { color:var(--text); }

/* Nav user */
.nav-user { display:flex; align-items:center; gap:8px; }

/* Plan badges */
.plan-badge { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:0.05em; padding:3px 8px; border-radius:100px; background:var(--primary); color:#fff; }
.plan-badge-inline { background:var(--primary); color:#fff; padding:2px 10px; border-radius:100px; font-size:12px; font-weight:600; }

/* Performance banner */
.perf-banner { background:var(--surface); padding:14px 24px; border-bottom:1px solid var(--border); }
.perf-banner-inner { display:flex; align-items:center; justify-content:center; gap:32px; flex-wrap:wrap; }
.perf-banner-label { font-weight:700; font-size:15px; }
.perf-stat { display:flex; align-items:center; gap:6px; font-size:14px; }
.perf-val { font-weight:800; font-size:15px; }
.perf-label { color:var(--text-muted); font-size:13px; }

/* CTA banner */
.cta-banner { margin-top:48px; padding:40px 32px; background:linear-gradient(135deg,rgba(99,91,255,0.08),rgba(96,165,250,0.06)); border:1px solid var(--border); border-radius:var(--radius-xl); display:flex; align-items:center; justify-content:space-between; gap:32px; }

/* Billing toggle */
.billing-toggle { display:inline-flex; background:var(--bg-muted); border-radius:var(--radius-lg); padding:4px; gap:2px; }
.billing-btn { padding:10px 20px; border:none; border-radius:var(--radius); font:600 14px var(--font); cursor:pointer; background:transparent; color:var(--text-secondary); transition:var(--transition); display:inline-flex; align-items:center; gap:6px; }
.billing-btn.active { background:var(--surface); color:var(--text); box-shadow:var(--shadow-sm); }
.save-badge { font-size:10px; font-weight:700; background:var(--green); color:#000; padding:2px 6px; border-radius:100px; }

/* Proof cards */
.proof-grid { display:flex; gap:16px; justify-content:center; margin-bottom:40px; flex-wrap:wrap; }
.proof-card { text-align:center; padding:16px 20px; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); min-width:120px; }
.proof-val { font-size:22px; font-weight:800; }
.proof-label { font-size:12px; color:var(--text-muted); margin-top:2px; }

/* Testimonial cards */
.testimonial-card { padding:24px; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); text-align:left; font-size:14px; color:var(--text-secondary); line-height:1.7; }

/* Guarantee */
.guarantee-card { display:flex; gap:20px; align-items:center; max-width:600px; margin:48px auto 0; padding:24px; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-xl); }

/* FAQ */
.faq-item { padding:20px 0; border-bottom:1px solid var(--border); }
.faq-item h4 { font-size:15px; font-weight:700; margin-bottom:8px; }
.faq-item p { font-size:14px; color:var(--text-secondary); line-height:1.7; }

/* Locked card */
.locked-card { border-style:dashed !important; }
.locked-card:hover { border-color:var(--primary) !important; }
.locked-card-inner { position:relative; }
.locked-blur { filter:blur(3px); opacity:0.35; pointer-events:none; user-select:none; }
.locked-overlay { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; color:var(--text-secondary); font-weight:600; font-size:14px; z-index:1; }
.locked-overlay svg { opacity:0.6; }
.locked-card:hover .locked-overlay { color:var(--primary); }
.locked-card:hover .locked-overlay svg { stroke:var(--primary); opacity:1; }
.redacted { background:var(--text-muted); color:transparent; border-radius:3px; display:inline-block; }

/* Social auth */
.social-auth { display:flex; flex-direction:column; gap:8px; margin-bottom:20px; }
.btn-social { display:flex; align-items:center; justify-content:center; gap:10px; padding:10px 16px; border:1px solid var(--border); border-radius:var(--radius); font:500 14px var(--font); cursor:pointer; transition:var(--transition); background:var(--bg-muted); color:var(--text); width:100%; }
.btn-social:hover { background:var(--bg-hover); border-color:var(--text-muted); }
.btn-social svg { flex-shrink:0; }
.social-divider { display:flex; align-items:center; gap:12px; margin:16px 0; color:var(--text-muted); font-size:12px; }
.social-divider::before, .social-divider::after { content:''; flex:1; height:1px; background:var(--border); }

/* Live badge */
.live-badge { display:inline-flex; align-items:center; gap:6px; font-size:11px; font-weight:700; color:var(--green); background:rgba(52,211,153,0.1); padding:4px 10px; border-radius:20px; letter-spacing:0.5px; white-space:nowrap; }
.live-dot { width:7px; height:7px; border-radius:50%; background:var(--green); animation:livePulse 2s ease-in-out infinite; }
@keyframes livePulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.4;transform:scale(0.8)} }

/* Toast */
.toast { position:fixed; bottom:24px; left:50%; transform:translateX(-50%) translateY(20px); background:var(--surface); border:1px solid var(--primary); color:var(--text); padding:12px 24px; border-radius:var(--radius-lg); font:600 14px var(--font); z-index:10000; opacity:0; transition:all 0.3s ease; box-shadow:0 8px 32px rgba(99,91,255,0.3); }
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }

/* Demo badge */
#demo-badge { position:fixed; top:60px; right:16px; background:var(--orange); color:#fff; padding:6px 14px; border-radius:var(--radius); font:700 12px var(--font); z-index:9999; display:none; letter-spacing:0.05em; box-shadow:0 4px 12px rgba(245,166,35,0.3); }
#demo-badge.show { display:flex; align-items:center; }

/* Feature cards */
.feature-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); padding:20px; transition:var(--transition); }
.feature-card:hover { border-color:var(--primary); transform:translateY(-2px); box-shadow:0 8px 24px rgba(99,91,255,0.12); }

/* Pops/transitions table */
.pops-table { display:flex; flex-direction:column; gap:1px; background:var(--border); border:1px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; }
.pops-header { display:flex; padding:12px 16px; background:var(--bg-subtle); font-size:11px; font-weight:700; color:var(--text-muted); text-transform:uppercase; letter-spacing:0.05em; }
.pops-row { display:flex; padding:14px 16px; background:var(--surface); align-items:center; transition:var(--transition); }
.pops-row:hover { background:var(--bg-hover); }

/* Trial timeline */
.trial-timeline { display:flex; align-items:center; gap:0; overflow-x:auto; padding:16px 0; }
.tl-step { display:flex; flex-direction:column; align-items:center; gap:6px; min-width:72px; position:relative; }
.tl-dot { width:32px; height:32px; border-radius:50%; border:2px solid var(--border); background:var(--bg-muted); display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:700; color:var(--text-muted); transition:var(--transition); flex-shrink:0; }
.tl-step.done .tl-dot { background:var(--green); border-color:var(--green); color:#000; }
.tl-step.active .tl-dot { background:var(--primary); border-color:var(--primary); color:#fff; box-shadow:0 0 0 4px rgba(99,91,255,0.25); animation:tlPulse 2s ease-in-out infinite; }
.tl-label { font-size:11px; color:var(--text-muted); white-space:nowrap; text-align:center; font-weight:500; }
.tl-step.done .tl-label { color:var(--green); font-weight:600; }
.tl-step.active .tl-label { color:var(--primary); font-weight:700; }
.tl-line { flex:1; height:2px; background:var(--border); min-width:16px; margin:0 -2px; position:relative; top:-10px; }
.tl-line.done { background:var(--green); }
@keyframes tlPulse { 0%,100% { box-shadow:0 0 0 4px rgba(99,91,255,0.25); } 50% { box-shadow:0 0 0 8px rgba(99,91,255,0.1); } }

/* Milestones */
.milestone-list { display:flex; flex-direction:column; gap:4px; }
.milestone-item { display:flex; align-items:flex-start; gap:12px; padding:10px 0; border-bottom:1px solid var(--border); }
.milestone-item:last-child { border-bottom:none; }
.milestone-icon { font-size:20px; flex-shrink:0; width:28px; text-align:center; }
.milestone-content { flex:1; min-width:0; }
.milestone-label { font-size:12px; color:var(--text-muted); text-transform:uppercase; letter-spacing:0.04em; font-weight:600; margin-bottom:2px; }
.milestone-value { font-size:14px; font-weight:600; color:var(--text); line-height:1.4; }

/* Score rationale drawer */
.score-drawer-backdrop { position:fixed; inset:0; background:rgba(0,0,0,0.6); z-index:1100; backdrop-filter:blur(4px); opacity:0; transition:opacity 0.25s ease; }
.score-drawer-backdrop.open { opacity:1; }
.score-drawer { position:fixed; right:0; top:0; bottom:0; width:min(420px,90vw); background:var(--surface); border-left:1px solid var(--border); z-index:1101; transform:translateX(100%); transition:transform 0.3s ease; overflow-y:auto; padding:32px 24px; }
.score-drawer.open { transform:translateX(0); }
.score-drawer-close { position:absolute; top:12px; right:12px; background:none; border:none; font-size:24px; color:var(--text-muted); cursor:pointer; padding:4px 8px; }
.score-bar-bg { height:8px; background:var(--bg-muted); border-radius:100px; overflow:hidden; }
.score-bar-fill { height:100%; border-radius:100px; transition:width 0.6s ease; }
.score-subscore { padding:12px 0; border-bottom:1px solid var(--border); }
.score-subscore:last-child { border-bottom:none; }
.score-subscore-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:6px; }
.score-subscore-label { font-size:13px; font-weight:600; }
.score-subscore-value { font-size:15px; font-weight:800; }
.score-subscore-detail { font-size:12px; color:var(--text-secondary); line-height:1.5; margin-top:6px; }

/* Loading spinner for buttons */
.btn-loading { position:relative; color:transparent !important; pointer-events:none; }
.btn-loading::after { content:''; position:absolute; width:18px; height:18px; border:2px solid rgba(255,255,255,0.3); border-top-color:#fff; border-radius:50%; animation:btnSpin 0.6s linear infinite; }
@keyframes btnSpin { to { transform:rotate(360deg); } }

/* Forgot password link */
.forgot-link { display:block; text-align:right; font-size:12px; color:var(--primary); cursor:pointer; margin-top:-8px; margin-bottom:12px; }
.forgot-link:hover { text-decoration:underline; }

/* Verification banner */
.verify-banner { padding:12px 16px; background:var(--orange-light); border:1px solid rgba(251,191,36,0.3); border-radius:var(--radius); margin-bottom:16px; display:flex; align-items:center; gap:10px; font-size:13px; color:var(--orange); }
.verify-banner a { color:var(--primary); font-weight:600; cursor:pointer; text-decoration:underline; }

/* Admin badge */
.admin-badge { font-size:10px; color:var(--orange); font-weight:600; }

/* Mobile hamburger & search toggle */
.hamburger { display:none; background:none; border:none; cursor:pointer; padding:8px; color:var(--text); }
.hamburger svg { display:block; }
.mobile-search-toggle { display:none; background:none; border:none; cursor:pointer; padding:6px; color:var(--text-secondary); }
.mobile-search-toggle svg { display:block; }
.mobile-menu { display:none; position:fixed; inset:0; z-index:999; background:rgba(0,0,0,0.85); backdrop-filter:blur(20px); flex-direction:column; padding:80px 24px 40px; }
.mobile-menu.open { display:flex; }
.mobile-menu-close { position:absolute; top:16px; right:16px; background:none; border:none; color:var(--text); font-size:28px; cursor:pointer; padding:8px; }
.mobile-menu a { font-size:24px; font-weight:700; padding:16px 0; border-bottom:1px solid var(--border); color:var(--text); display:block; }
.mobile-menu a:hover { color:var(--primary); }

/* Responsive — tablet */
@media(max-width:1024px) {
  .nav-inner { gap:16px; }
  .search-box input { width:180px; }
  .search-box input:focus { width:220px; }
  .stock-grid { grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); }
  .pricing-grid { grid-template-columns:1fr; max-width:400px; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:24px; }
  .detail-grid { grid-template-columns:1fr; }
}

/* Responsive — mobile */
@media(max-width:768px) {
  .nav-links { display:none; }
  .hamburger { display:block; }
  .nav-inner { padding:0 12px; gap:6px; }
  .search-box { order:10; position:absolute; top:56px; left:0; right:0; padding:8px 12px; background:var(--surface); border-bottom:1px solid var(--border); display:none; z-index:99; }
  .search-box.mobile-open { display:block; }
  .search-box input { width:100%; }
  .search-box input:focus { width:100%; }
  .nav-right { gap:6px; }
  #nav-auth .btn { padding:6px 10px; font-size:12px; }
  .mobile-search-toggle { display:flex; }

  .container { padding:0 16px; }
  .page { padding:24px 0 60px; }

  .hero { padding:60px 16px 40px; }
  .hero h1 { font-size:clamp(26px,7vw,36px); }
  .hero p { font-size:15px; margin-bottom:24px; }
  .hero-cta { flex-direction:column; align-items:center; gap:8px; }
  .hero-cta .btn { width:100%; max-width:320px; }
  .hero-metrics { gap:16px; }
  .hero-metric-value { font-size:24px; }
  .hero-metric-label { font-size:10px; }

  .perf-banner { padding:10px 16px; overflow-x:auto; }
  .perf-banner-inner { gap:12px; justify-content:flex-start; }
  .perf-banner-label { font-size:13px; width:100%; }
  .perf-val { font-size:13px; }
  .perf-label { font-size:11px; }

  .filter-bar-wrapper { flex-direction:column; align-items:stretch; gap:8px; }
  .filter-bar { padding:12px 0; gap:8px; }
  .filter-chips { overflow-x:auto; flex-wrap:nowrap; -webkit-overflow-scrolling:touch; scrollbar-width:none; gap:4px; }
  .filter-chips::-webkit-scrollbar { display:none; }
  .chip { flex-shrink:0; padding:5px 10px; font-size:11px; }
  .filter-controls { gap:4px; }
  .filter-controls select { flex:1; min-width:0; font-size:11px; padding:5px 22px 5px 6px; }

  .stock-grid { grid-template-columns:1fr; gap:12px; }
  .stock-card-inner { padding:16px; }
  .stock-ticker { font-size:17px; }
  .stock-name { font-size:12px; }
  .stock-score { width:42px; height:42px; font-size:16px; }
  .stock-metrics { grid-template-columns:repeat(3,1fr); gap:4px; }
  .stock-metric-value { font-size:13px; }

  .grid-2, .grid-3, .grid-4 { grid-template-columns:1fr; }
  .heatmap-grid { grid-template-columns:1fr; }

  .pricing-grid { grid-template-columns:1fr; max-width:100%; }
  .pricing-card { padding:24px 20px; }
  .pricing-price { font-size:40px; }
  .pricing-badge { font-size:11px; padding:3px 12px; }

  .detail-grid { grid-template-columns:1fr; }
  .detail-header { flex-direction:column; }
  .detail-title { font-size:24px; }
  .detail-section { padding:16px; }
  .detail-chart { padding:16px; }
  .chart-container { height:220px; }

  .catalyst-item { flex-direction:column; align-items:flex-start; gap:10px; padding:14px 16px; }
  .catalyst-badge { align-self:flex-start; }

  .trial-timeline { gap:0; padding:12px 0; overflow-x:auto; -webkit-overflow-scrolling:touch; }
  .tl-step { min-width:56px; }
  .tl-dot { width:28px; height:28px; font-size:10px; }
  .tl-label { font-size:9px; }
  .tl-line { min-width:8px; }
  .score-drawer { width:100vw; padding:24px 16px; }

  .news-item { padding:12px 16px; }
  .news-title { font-size:13px; }
  .news-summary { font-size:12px; }

  .cta-banner { flex-direction:column; text-align:center; padding:28px 20px; gap:20px; }

  .footer { padding:32px 16px; margin-top:32px; }
  .footer-grid { grid-template-columns:1fr; gap:20px; }
  .footer-col { text-align:center; }
  .footer-brand { text-align:center; }

  .page-title { font-size:22px; }
  .page-subtitle { font-size:13px; }

  .paywall { padding:40px 16px; margin-top:-80px; padding-top:120px; }
  .paywall h3 { font-size:20px; }

  .modal { padding:24px 20px; margin:16px; max-width:calc(100vw - 32px); }
  .modal h2 { font-size:20px; }

  .billing-toggle { width:100%; }
  .billing-btn { flex:1; padding:8px 12px; font-size:13px; }
  .proof-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-bottom:24px; }
  .proof-card { min-width:0; padding:12px 8px; }
  .proof-val { font-size:18px; }

  .guarantee-card { flex-direction:column; text-align:center; padding:20px 16px; }

  .testimonial-card { padding:16px; font-size:13px; }

  .avatar-menu .dropdown { right:-8px; min-width:180px; }
}

/* Responsive — small phones */
@media(max-width:380px) {
  .hero h1 { font-size:24px; }
  .hero p { font-size:14px; }
  .hero-metrics { flex-direction:column; gap:12px; }
  .hero-metric { display:flex; align-items:center; gap:8px; }
  .hero-metric-value { font-size:20px; }
  .nav-brand span { display:none; }
  #nav-auth .btn:first-child { display:none; }
  .stock-ticker { font-size:15px; }
  .stock-card-inner { padding:12px; }
  .pricing-price { font-size:32px; }
  .etf-header { flex-direction:column; gap:16px; }
  .etf-stats { flex-wrap:wrap; justify-content:center; }
  .etf-chart-container { height:220px !important; }
  .chart-range-btns { gap:2px; }
  .chart-range-btn { padding:4px 8px; font-size:11px; }
  .filter-dropdowns { flex-direction:column; width:100%; }
  .filter-dropdowns select { width:100%; }
}

/* Chart range buttons */
.chart-range-btns { display:flex; gap:4px; }
.chart-range-btn { padding:5px 12px; font-size:12px; font-weight:600; border:1px solid var(--border); border-radius:var(--radius); background:var(--surface); color:var(--text-muted); cursor:pointer; transition:all 0.15s; }
.chart-range-btn:hover { color:var(--text); border-color:var(--text-muted); }
.chart-range-btn.active { background:var(--primary); color:#fff; border-color:var(--primary); }

/* ETF section */
.etf-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-xl); padding:32px; }
.etf-header { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:16px; }
.etf-chart-container { position:relative; }
