:root,
:root[data-theme="dark"] {
    --bg: #0a0e17;
    --bg2: #0d1117;
    --surface: #131a27;
    --surface2: #1a2332;
    --surface3: #1e2a3a;
    --border: #2a3444;
    --border-light: #3a4a5a;
    --text: #e1e7ef;
    --text-dim: #7a8a9e;
    --text-muted: #4a5a6e;
    --gold: #f0b90b;
    --gold-dark: #c49a08;
    --gold-glow: rgba(240,185,11,0.15);
    --green: #00d68f;
    --green-dim: rgba(0,214,143,0.12);
    --red: #ff4d6a;
    --red-dim: rgba(255,77,106,0.12);
    --blue: #4a9eff;
    --purple: #a78bfa;
    --orange: #f4a236;
    --cyan: #22d3ee;
    --gradient-gold: linear-gradient(135deg, #f0b90b 0%, #d4a50a 100%);
    --gradient-surface: linear-gradient(180deg, #131a27 0%, #0d1117 100%);
}

/* ═══ LIGHT THEME OVERRIDE — mirrors admin panel palette exactly ═══ */
:root[data-theme="light"] {
    --bg: #f6f7fb;
    --bg2: #eef0f5;
    --surface: #ffffff;
    --surface2: #f9fafc;
    --surface3: #eef2f8;
    --border: #d6dbe3;
    --border-light: #e4e7ee;
    --text: #1a2233;
    --text-dim: #5d6b80;
    --text-muted: #95a0b3;
    --gold: #d98800;
    --gold-dark: #b46f00;
    --gold-glow: rgba(217,136,0,0.14);
    --green: #0a9a5a;
    --green-dim: rgba(10,154,90,0.12);
    --red: #d8364e;
    --red-dim: rgba(216,54,78,0.12);
    --blue: #2563eb;
    --purple: #c084fc;
    --orange: #f08a1f;
    --cyan: #0891b2;
    --gradient-gold: linear-gradient(135deg, #d98800 0%, #b46f00 100%);
    --gradient-surface: linear-gradient(180deg, #ffffff 0%, #f9fafc 100%);
}

/* ═══ THEME TOGGLE BUTTON — matches admin panel .ap-theme-btn ═══ */
.awd-theme-btn {
    background: var(--surface2);
    color: var(--text);
    border: 1px solid var(--border);
    border-radius: 10px;
    width: 36px; height: 36px;
    cursor: pointer;
    font-size: 16px;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: border-color .15s, transform .15s, background .15s;
    padding: 0;
    margin: 0 4px;
}
.awd-theme-btn:hover { border-color: var(--gold); transform: translateY(-1px); }
.awd-theme-btn:focus { outline: none; box-shadow: 0 0 0 2px var(--gold-glow); }
.awd-theme-btn:active { transform: translateY(0); }
* { margin: 0; padding: 0; box-sizing: border-box; }
body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    background: var(--bg);
    color: var(--text);
    min-height: 100vh;
    overflow-x: hidden;
}
::selection { background: var(--gold); color: #000; }

/* ═══ HEADER ═══ */
header {
    position: sticky; top: 0; z-index: 100;
    background: rgba(10,14,23,0.85);
    backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--border);
    padding: 0 24px;
    height: 56px; display: flex; align-items: center; justify-content: space-between;
}
.logo { display: flex; align-items: center; gap: 10px; font-size: 18px; font-weight: 700; }
.logo-icon { font-size: 22px; }
.logo-text { background: var(--gradient-gold); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.header-right { display: flex; align-items: center; gap: 12px; }
.tier-badge {
    font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
    padding: 3px 10px; border-radius: 4px;
}
.tier-badge.free { background: var(--surface3); color: var(--text-dim); }
.tier-badge.pro { background: var(--gold-glow); color: var(--gold); border: 1px solid rgba(240,185,11,0.3); }
.tier-badge.elite { background: rgba(167,139,250,0.15); color: var(--purple); border: 1px solid rgba(167,139,250,0.3); }
.user-info { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--text-dim); }
.btn {
    padding: 7px 16px; border-radius: 6px; font-size: 13px; font-weight: 600;
    cursor: pointer; border: none; transition: all 0.2s; font-family: inherit;
}
.btn-ghost { background: transparent; color: var(--text); border: 1px solid var(--border); }
.btn-ghost:hover { border-color: var(--text-dim); background: var(--surface2); }
.btn-gold { background: var(--gradient-gold); color: #000; }
.btn-gold:hover { filter: brightness(1.1); transform: translateY(-1px); }
.btn-sm { padding: 5px 12px; font-size: 12px; }
.btn-danger { background: transparent; color: var(--red); border: 1px solid rgba(255,77,106,0.3); }
.btn-danger:hover { background: var(--red-dim); }

/* ═══ NAVIGATION TABS ═══ */
.nav-tabs {
    display: flex; gap: 0; background: var(--surface);
    border-bottom: 1px solid var(--border); padding: 0 24px;
}
.nav-tab {
    padding: 12px 20px; font-size: 13px; font-weight: 500; color: var(--text-dim);
    cursor: pointer; border-bottom: 2px solid transparent; transition: all 0.2s;
    display: flex; align-items: center; gap: 6px; user-select: none;
}
.nav-tab:hover { color: var(--text); }
.nav-tab.active { color: var(--gold); border-bottom-color: var(--gold); }
.nav-tab .lock { font-size: 10px; opacity: 0.5; }
.nav-tab .live-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--green); animation: pulse 2s infinite; }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.3; } }

/* ═══ MAIN CONTENT ═══ */
.main-content { padding: 20px 24px; max-width: 1600px; margin: 0 auto; }
.page { display: none; }
.page.active { display: block; }

/* ═══ LANDING PAGE ═══ */
.landing { text-align: center; padding: 40px 0; }
.landing-hero h1 {
    font-size: 42px; font-weight: 800; line-height: 1.15; margin-bottom: 16px;
    background: linear-gradient(135deg, #fff 0%, #b0c4de 50%, var(--gold) 100%);
    -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.landing-hero p { color: var(--text-dim); font-size: 16px; margin-bottom: 40px; letter-spacing: 0.5px; }
.stats-bar {
    display: flex; justify-content: center; gap: 40px; margin: 36px 0 48px;
    padding: 20px; background: var(--surface); border-radius: 12px; border: 1px solid var(--border);
}
.stat-item { text-align: center; }
.stat-value { font-size: 28px; font-weight: 800; color: var(--gold); }
.stat-label { font-size: 12px; color: var(--text-dim); margin-top: 4px; text-transform: uppercase; letter-spacing: 0.5px; }

/* Pricing Cards */
.pricing-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; max-width: 1240px; margin: 0 auto 48px; }
.price-card {
    background: var(--surface); border: 1px solid var(--border); border-radius: 16px;
    padding: 32px 24px; text-align: center; position: relative; transition: all 0.3s;
}
.price-card:hover { transform: translateY(-4px); box-shadow: 0 12px 40px rgba(0,0,0,0.4); }
.price-card.featured {
    border-color: var(--gold); background: var(--surface2);
    box-shadow: 0 0 30px var(--gold-glow), inset 0 1px 0 rgba(240,185,11,0.1);
}
.price-card.featured::before {
    content: 'MOST POPULAR'; position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
    background: var(--gradient-gold); color: #000; font-size: 10px; font-weight: 800;
    padding: 4px 16px; border-radius: 20px; letter-spacing: 1px;
}
.price-tier { font-size: 14px; font-weight: 600; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 12px; }
.price-tier.free-t { color: var(--text-dim); }
.price-tier.pro-t { color: var(--gold); }
.price-tier.elite-t { color: var(--purple); }
.price-tier.premium-t { color: #06b6d4; }
.price-amount { font-size: 48px; font-weight: 800; margin: 8px 0; }
.price-amount span { font-size: 16px; font-weight: 400; color: var(--text-dim); }
.price-features { list-style: none; text-align: left; margin: 24px 0; }
.price-features li {
    padding: 8px 0; font-size: 13px; color: var(--text-dim); display: flex; align-items: center; gap: 10px;
    border-bottom: 1px solid rgba(42,52,68,0.5);
}
.price-features li:last-child { border: none; }
.price-features .check { color: var(--green); font-weight: 700; min-width: 18px; }
.price-features .cross { color: var(--text-muted); min-width: 18px; }
.price-cta { width: 100%; padding: 12px; border-radius: 8px; font-size: 14px; font-weight: 700; cursor: pointer; border: none; transition: all 0.2s; font-family: inherit; }
.price-cta.free-btn { background: var(--surface3); color: var(--text); border: 1px solid var(--border); }
.price-cta.free-btn:hover { border-color: var(--text-dim); }
.price-cta.pro-btn { background: var(--gradient-gold); color: #000; }
.price-cta.pro-btn:hover { filter: brightness(1.1); }
.price-cta.elite-btn { background: linear-gradient(135deg, #a78bfa 0%, #7c3aed 100%); color: #fff; }
.price-cta.elite-btn:hover { filter: brightness(1.15); }
.price-cta.premium-btn { background: rgba(6,182,212,0.08); color: #06b6d4; border: 1.5px solid rgba(6,182,212,0.3); cursor: not-allowed; opacity: 0.7; }
.price-card.premium-card { opacity: 0.72; border-style: dashed; }
.dev-badge { display:inline-flex;align-items:center;gap:5px;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background:rgba(6,182,212,0.12);color:#06b6d4;border:1px solid rgba(6,182,212,0.3);border-radius:20px;padding:3px 10px;margin-bottom:10px; }

.crypto-badges { display: flex; justify-content: center; gap: 12px; margin-top: 20px; }
.crypto-badge {
    background: var(--surface); border: 1px solid var(--border); border-radius: 8px;
    padding: 8px 16px; font-size: 12px; font-weight: 600; color: var(--text-dim);
}

/* ═══ SUMMARY CARDS ═══ */
.summary-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 12px; margin-bottom: 20px; }
.summary-card {
    background: var(--surface); border: 1px solid var(--border); border-radius: 10px; padding: 16px; text-align: center;
}
.summary-card .value { font-size: 28px; font-weight: 700; margin: 4px 0; }
.summary-card .label { font-size: 11px; color: var(--text-dim); text-transform: uppercase; letter-spacing: 0.5px; }
.summary-card.os2 .value { color: var(--green); }
.summary-card.ob2 .value { color: var(--red); }
.summary-card.os1 .value { color: var(--blue); }
.summary-card.ob1 .value { color: var(--orange); }

/* ═══ PAIR GRID ═══ */
.pairs-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 12px; margin-bottom: 20px; }
.pair-card {
    background: var(--surface); border: 1px solid var(--border); border-radius: 10px;
    padding: 16px; cursor: pointer; transition: all 0.2s; position: relative; overflow: hidden;
}
.pair-card:hover { border-color: var(--gold); transform: translateY(-2px); box-shadow: 0 4px 16px rgba(0,0,0,0.3); }
.pair-card.active { border-color: var(--gold); background: var(--surface2); }
.zone-badge {
    position: absolute; top: 0; right: 0; padding: 4px 10px; font-size: 11px;
    font-weight: 700; border-radius: 0 10px 0 8px; letter-spacing: 0.5px;
}
.zone-badge.OS_L2 { background: var(--green); color: #000; }
.zone-badge.OB_L2 { background: var(--red); color: #fff; }
.zone-badge.OS_L1 { background: var(--blue); color: #000; }
.zone-badge.OB_L1 { background: var(--orange); color: #000; }
.hook-badge { margin-left: 6px; font-size: 10px; background: rgba(255,255,255,0.15); padding: 1px 5px; border-radius: 3px; }
.pair-card .pair-name { font-size: 16px; font-weight: 700; margin-bottom: 8px; }
.pair-card .pair-price { font-size: 20px; font-weight: 600; margin-bottom: 6px; }
.pair-card .pair-change { font-size: 13px; font-weight: 600; }
.positive { color: var(--green); }
.negative { color: var(--red); }
.pair-meta { display: grid; grid-template-columns: 1fr 1fr; gap: 4px 6px; margin-top: 10px; font-size: 11px; color: var(--text-dim); }
.meta-item { display: flex; justify-content: space-between; }
.meta-val { color: var(--text); font-weight: 600; }
.meta-val.long { color: var(--green); }
.meta-val.short { color: var(--red); }

/* ═══ PAYWALL OVERLAY ═══ */
.paywall-overlay {
    position: relative; min-height: 200px; display: flex; align-items: center;
    justify-content: center; flex-direction: column; gap: 16px;
    background: var(--surface); border: 1px solid var(--border); border-radius: 12px;
    padding: 40px; text-align: center; margin: 20px 0;
}
.paywall-overlay::before {
    content: ''; position: absolute; inset: 0; border-radius: 12px;
    background: linear-gradient(135deg, var(--gold-glow), transparent);
    pointer-events: none;
}
.paywall-icon { font-size: 48px; margin-bottom: 8px; }
.paywall-title { font-size: 20px; font-weight: 700; }
.paywall-desc { font-size: 14px; color: var(--text-dim); max-width: 400px; }

/* ═══ CHARTS ═══ */
.chart-section {
    background: var(--surface); border: 1px solid var(--border); border-radius: 10px;
    overflow: hidden; margin-bottom: 20px;
}
.chart-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 12px 20px; border-bottom: 1px solid var(--border);
}
.chart-header h2 { font-size: 16px; font-weight: 600; }
.chart-legend { display: flex; gap: 14px; font-size: 12px; color: var(--text-dim); align-items: center; }
.chart-legend .leg { display: flex; align-items: center; gap: 5px; }
.leg-line { width: 16px; height: 2px; border-radius: 1px; }
.leg-area { width: 16px; height: 10px; border-radius: 2px; opacity: 0.4; }
.rh-status { display: flex; gap: 16px; padding: 8px 20px; border-top: 1px solid var(--border); background: var(--surface2); flex-wrap: wrap; }
.rh-stat { display: flex; align-items: center; gap: 6px; font-size: 12px; }
.rh-stat .stat-label { color: var(--text-dim); }
.rh-stat .stat-val { font-weight: 700; }
.rh-stat .stat-val.up { color: var(--green); }
.rh-stat .stat-val.down { color: var(--red); }
.rh-stat .stat-val.neutral { color: var(--text-dim); }

/* ═══ SIGNAL TABLE ═══ */
.signals-section { margin-bottom: 20px; }
.section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.section-header h2 { font-size: 18px; font-weight: 600; display: flex; align-items: center; gap: 8px; }
.signal-table {
    width: 100%; border-collapse: collapse; background: var(--surface);
    border: 1px solid var(--border); border-radius: 10px; overflow: hidden;
}
.signal-table th {
    background: var(--surface2); padding: 10px 14px; text-align: left; font-size: 11px;
    text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-dim); border-bottom: 1px solid var(--border);
}
.signal-table td { padding: 10px 14px; font-size: 13px; border-bottom: 1px solid var(--border); }
.signal-table tr:last-child td { border-bottom: none; }
.signal-table tr:hover { background: var(--surface2); }
.dir-long { color: var(--green); font-weight: 700; }
.dir-short { color: var(--red); font-weight: 700; }
.status-sent { color: var(--blue); }
.status-tp { color: var(--green); }
.status-sl { color: var(--red); }
.status-closed { color: var(--text-dim); }
.liq-win-btn { background:var(--surface3);border:1px solid var(--border);border-radius:5px;padding:4px 10px;font-size:12px;color:var(--text-dim);cursor:pointer;transition:all 0.15s }
.liq-win-btn:hover { border-color:var(--gold);color:var(--gold) }
.liq-win-btn.active { background:rgba(240,185,11,0.15);border-color:var(--gold);color:var(--gold);font-weight:700 }
.liq-dir-btn { background:var(--surface3);border:1px solid var(--border);border-radius:5px;padding:3px 9px;font-size:11px;color:var(--text-dim);cursor:pointer;transition:all 0.15s }
.liq-dir-btn[data-d="LONG"].active { background:rgba(0,214,143,0.15);border-color:var(--green);color:var(--green);font-weight:700 }
.liq-dir-btn[data-d="SHORT"].active { background:rgba(255,77,106,0.15);border-color:var(--red);color:var(--red);font-weight:700 }
.liq-dir-btn[data-d="auto"].active { background:rgba(240,185,11,0.12);border-color:var(--gold);color:var(--gold);font-weight:700 }
.liq-card { background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px 18px; }
.liq-card-accent-red  { border-top:2px solid rgba(255,77,106,0.6); }
.liq-card-accent-green{ border-top:2px solid rgba(0,214,143,0.6); }
.liq-card-accent-gold { border-top:2px solid rgba(240,185,11,0.6); }
.liq-card-accent-blue { border-top:2px solid rgba(80,180,255,0.5); }
.liq-label { font-size:10px;font-weight:700;letter-spacing:.08em;color:var(--text-dim);text-transform:uppercase;margin-bottom:6px }
.liq-metric-row { display:flex;align-items:baseline;gap:6px }
.liq-metric-val { font-size:22px;font-weight:700;line-height:1 }
.liq-metric-unit { font-size:11px;color:var(--text-dim) }
.liq-pair-chip { display:inline-flex;align-items:center;gap:5px;padding:3px 10px 3px 8px;border-radius:20px;font-size:11px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:all 0.15s;white-space:nowrap }
.liq-pair-chip:hover { filter:brightness(1.2) }
.liq-sum-chip { display:inline-flex;align-items:center;gap:8px;padding:5px 12px;border-radius:6px;font-size:12px }
.liq-ctx-pill { display:flex;flex-direction:column;gap:2px;padding:8px 14px;border-right:1px solid var(--border);min-width:80px }
.liq-ctx-pill:last-child { border-right:none }
.liq-ctx-pill-label { font-size:10px;font-weight:700;letter-spacing:.07em;color:var(--text-dim);text-transform:uppercase }
.liq-ctx-pill-val { font-size:13px;font-weight:700 }
#liq-context-bar { display:flex;flex-wrap:wrap;background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden;margin-bottom:12px }
.liq-cluster-row:hover { background:rgba(255,255,255,0.04) !important }
.liq-tbl-rank { width:28px;text-align:center;color:var(--text-dim);font-size:11px }
.pnl-pos { color: var(--green); font-weight: 600; }
.pnl-neg { color: var(--red); font-weight: 600; }
.pnl-zero { color: var(--text-dim); }
.tp-outcome { display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:2px 8px;border-radius:5px; }
.tp-outcome.win  { background:rgba(0,214,143,0.12);color:var(--green); }
.tp-outcome.loss { background:rgba(255,77,106,0.12);color:var(--red); }
.tp-outcome.age  { background:rgba(122,138,158,0.12);color:var(--text-dim); }
.live-pnl-wrap { display:flex; flex-direction:column; align-items:flex-end; gap:1px; }
.live-pnl-lev { font-size:15px; font-weight:700; }
.live-pnl-raw { font-size:10px; color:var(--text-dim); }
.live-dot { display:inline-block; width:6px; height:6px; border-radius:50%; background:var(--green); margin-right:3px; animation: pulse-dot 1.5s infinite; }
@keyframes pulse-dot { 0%,100%{opacity:1} 50%{opacity:0.3} }
.blurred { filter: blur(8px); pointer-events: none; user-select: none; }

/* ═══ SIGNAL CARDS ═══ */
.signal-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 14px; }
.signal-card {
    background: var(--surface); border: 1px solid var(--border); border-radius: 12px;
    padding: 16px; position: relative; overflow: hidden; transition: border-color 0.2s;
}
.signal-card:hover { border-color: var(--border-light); }
.signal-card .sc-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
.signal-card .sc-pair { font-size: 18px; font-weight: 800; }
.signal-card .sc-dir { font-size: 12px; font-weight: 700; padding: 3px 10px; border-radius: 6px; }
.signal-card .sc-dir.long { background: rgba(0,214,143,0.15); color: var(--green); }
.signal-card .sc-dir.short { background: rgba(255,77,106,0.15); color: var(--red); }
.signal-card .sc-meta { display: flex; gap: 12px; font-size: 11px; color: var(--text-dim); margin-bottom: 12px; }
.signal-card .sc-meta span { display: flex; align-items: center; gap: 3px; }
.signal-card .sc-footer { display: flex; justify-content: space-between; align-items: center; margin-top: 12px; padding-top: 10px; border-top: 1px solid var(--border); }

/* Price Ladder */
.price-ladder { position: relative; margin: 4px 0; padding: 6px 0; }
.pl-row { display: flex; align-items: center; gap: 8px; padding: 4px 0; font-size: 12px; }
.pl-label { width: 50px; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; text-align: right; flex-shrink: 0; }
.pl-bar { flex: 1; height: 6px; border-radius: 3px; position: relative; }
.pl-price { font-weight: 600; font-size: 12px; min-width: 70px; }
.pl-pct { font-size: 10px; color: var(--text-dim); min-width: 40px; }
.pl-row.tp .pl-label { color: var(--green); }
.pl-row.tp .pl-bar { background: rgba(0,214,143,0.2); }
.pl-row.tp .pl-price { color: var(--green); }
.pl-row.tp-hit .pl-label { color: #aaa; text-decoration: line-through; }
.pl-row.tp-hit .pl-bar { background: rgba(0,214,143,0.08); }
.pl-row.tp-hit .pl-price { color: #aaa; }
.pl-row.tp-hit::after { content: '\2714'; color: var(--green); font-size: 11px; margin-left: 4px; opacity: 0.8; }
.pl-row.entry .pl-label { color: var(--gold); }
.pl-row.entry .pl-bar { background: rgba(244,162,54,0.3); height: 8px; }
.pl-row.entry .pl-price { color: var(--gold); font-weight: 700; }
.pl-row.sl .pl-label { color: var(--red); }
.pl-row.sl .pl-bar { background: rgba(255,77,106,0.2); }
.pl-row.sl .pl-price { color: var(--red); }

/* R:R Badge */
.rr-badge { font-size: 11px; font-weight: 700; padding: 3px 8px; border-radius: 5px; }
.rr-badge.good { background: rgba(0,214,143,0.15); color: var(--green); }
.rr-badge.ok { background: rgba(244,162,54,0.15); color: var(--orange); }
.rr-badge.bad { background: rgba(255,77,106,0.15); color: var(--red); }

/* Chart signal overlay legend */
.chart-signal-info { background: #0d1220; border: 1px solid #1e2d40; border-radius: 8px; padding: 12px 16px; margin-top: 8px; display: flex; gap: 18px; flex-wrap: wrap; font-size: 12px; align-items: center; }
.chart-signal-info .csi-item { display: flex; align-items: center; gap: 6px; }
.chart-signal-info .csi-item b { color: var(--text); font-weight: 600; }
.chart-signal-info .csi-dot { width: 10px; height: 3px; border-radius: 2px; flex-shrink: 0; }
.csi-pct { font-size: 11px; font-weight: 700; padding: 1px 6px; border-radius: 4px; }
.csi-pct.red   { background: rgba(255,77,106,0.15); color: #ff4d6a; }
.csi-pct.green { background: rgba(0,214,143,0.15);  color: #00d68f; }
.csi-meta { color: var(--text-dim); font-size: 11px; margin-left: auto; }

/* Analytics signal breakdown */
.analytics-breakdown { margin-top: 20px; }
.analytics-breakdown h3 { font-size: 15px; margin-bottom: 10px; }
.delayed-badge { background: var(--surface3); color: var(--text-dim); font-size: 10px; padding: 2px 8px; border-radius: 4px; font-weight: 600; }

/* ═══ ANALYTICS CARDS ═══ */
.analytics-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 12px; margin-bottom: 20px; }
.metric-card {
    background: var(--surface); border: 1px solid var(--border); border-radius: 10px;
    padding: 20px; text-align: center;
}
.metric-card .metric-value { font-size: 32px; font-weight: 800; margin: 8px 0; }
.metric-card .metric-label { font-size: 12px; color: var(--text-dim); text-transform: uppercase; letter-spacing: 0.5px; }
.metric-card .metric-sub { font-size: 11px; color: var(--text-muted); margin-top: 4px; }
.metric-card.green .metric-value { color: var(--green); }
.metric-card.red .metric-value { color: var(--red); }
.metric-card.gold .metric-value { color: var(--gold); }
.metric-card.blue .metric-value { color: var(--blue); }

/* ═══ MODAL ═══ */
.modal-bg {
    display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.7);
    z-index: 1000; align-items: center; justify-content: center;
    backdrop-filter: blur(4px);
}
.modal-bg.open { display: flex; }
.modal {
    background: var(--surface); border: 1px solid var(--border); border-radius: 16px;
    padding: 32px; width: 90%; max-width: 420px; position: relative;
}
.modal h2 { font-size: 22px; font-weight: 700; margin-bottom: 24px; text-align: center; }
.modal-close {
    position: absolute; top: 12px; right: 16px; background: none; border: none;
    color: var(--text-dim); font-size: 20px; cursor: pointer;
}
.form-group { margin-bottom: 16px; }
.form-group label { display: block; font-size: 12px; font-weight: 600; color: var(--text-dim); margin-bottom: 6px; text-transform: uppercase; letter-spacing: 0.5px; }
.form-input {
    width: 100%; padding: 10px 14px; background: var(--bg2); border: 1px solid var(--border);
    border-radius: 8px; color: var(--text); font-size: 14px; font-family: inherit; outline: none;
    transition: border-color 0.2s;
}
.form-input:focus { border-color: var(--gold); }
.form-error { color: var(--red); font-size: 13px; margin-bottom: 12px; padding: 10px 14px; background: rgba(255,77,106,0.1); border: 1px solid rgba(255,77,106,0.3); border-radius: 8px; display: none; text-align: center; }
.form-submit {
    width: 100%; padding: 12px; background: var(--gradient-gold); color: #000;
    border: none; border-radius: 8px; font-size: 15px; font-weight: 700; cursor: pointer;
    font-family: inherit; transition: all 0.2s; margin-top: 8px;
}
.form-submit:hover { filter: brightness(1.1); }
.form-switch { text-align: center; margin-top: 16px; font-size: 13px; color: var(--text-dim); }
.form-switch a { color: var(--gold); text-decoration: none; font-weight: 600; cursor: pointer; }

/* ═══ PAYMENT MODAL ═══ */
.plan-select { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 16px; }
.plan-option {
    background: var(--bg2); border: 1px solid var(--border); border-radius: 8px;
    padding: 12px; cursor: pointer; text-align: center; transition: all 0.2s;
}
.plan-option:hover { border-color: var(--gold); }
.plan-option.selected { border-color: var(--gold); background: var(--gold-glow); }
.plan-option .plan-name { font-size: 12px; font-weight: 700; color: var(--gold); text-transform: uppercase; }
.plan-option .plan-price { font-size: 20px; font-weight: 800; margin: 4px 0; }
.plan-option .plan-period { font-size: 11px; color: var(--text-dim); }
.crypto-select { display: flex; gap: 8px; margin-bottom: 16px; }
.crypto-option {
    flex: 1; background: var(--bg2); border: 1px solid var(--border); border-radius: 8px;
    padding: 10px; cursor: pointer; text-align: center; transition: all 0.2s; font-size: 12px; font-weight: 600;
}
.crypto-option:hover { border-color: var(--gold); }
.crypto-option.selected { border-color: var(--gold); background: var(--gold-glow); }
.payment-address {
    background: var(--bg2); border: 1px solid var(--border); border-radius: 8px;
    padding: 14px; margin: 16px 0; word-break: break-all; font-family: monospace; font-size: 13px;
    color: var(--gold); text-align: center;
}

/* ═══ RESPONSIVE — TABLET (iPad landscape / 1024px) ═══ */
@media (max-width: 1024px) {
    .main-content { padding: 16px 18px; }
    .pricing-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; max-width: 700px; }
    .analytics-grid { grid-template-columns: repeat(3, 1fr); }
    .admin-stats { grid-template-columns: repeat(2, 1fr); }
    .signal-cards { grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); }
    .pairs-grid { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }
}

/* ═══ RESPONSIVE — TABLET PORTRAIT / LARGE PHONE (768px) ═══ */
@media (max-width: 768px) {
    /* Layout */
    .main-content { padding: 12px 14px; }

    /* Header */
    .logo-text { font-size: 15px; }
    .logo-img { height: 28px !important; width: 28px !important; }
    .user-info { display: none; }
    .sub-timer { font-size: 10px; padding: 3px 7px; }

    /* Nav tabs — scrollable pill strip */
    .nav-tabs {
        overflow-x: auto; -webkit-overflow-scrolling: touch;
        scrollbar-width: none; padding: 0 10px; gap: 2px;
    }
    .nav-tabs::-webkit-scrollbar { display: none; }
    .nav-tab { white-space: nowrap; padding: 11px 13px; font-size: 12px; }

    /* Landing */
    .landing-hero h1 { font-size: 26px; }
    .landing-hero p { font-size: 14px; }
    .stats-bar { flex-wrap: wrap; gap: 14px; justify-content: center; padding: 16px; }
    .stat-value { font-size: 22px; }
    .pricing-grid { grid-template-columns: 1fr; max-width: 380px; gap: 14px; }
    .crypto-badges { flex-wrap: wrap; }

    /* Cards & grids */
    .signal-cards { grid-template-columns: 1fr; }
    .pairs-grid { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 10px; }
    .summary-row { grid-template-columns: repeat(2, 1fr); }
    .analytics-grid { grid-template-columns: repeat(2, 1fr); }
    .admin-stats { grid-template-columns: repeat(2, 1fr); }
    .presignal-grid { grid-template-columns: 1fr; }
    .screener-grid { grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); }

    /* Signal card internals */
    .signal-card .sc-header { flex-wrap: wrap; gap: 6px; }
    .signal-card .sc-meta { flex-wrap: wrap; gap: 6px; }
    .signal-card .sc-footer { flex-wrap: wrap; gap: 8px; }

    /* Copy-trading */
    .ct-config-grid { grid-template-columns: 1fr; }

    /* Liquidity heatmap */
    #liq-suggest-card > div:last-child { grid-template-columns: 1fr !important; }
    #liq-velocity-card, #liq-bias-card { min-width: 100% !important; }
    #liq-quick-pairs { overflow-x: auto; flex-wrap: nowrap !important; -webkit-overflow-scrolling: touch; padding-bottom: 4px; }
    #liq-context-bar { font-size: 11px; padding: 8px 10px; flex-wrap: wrap; }
    .liq-win-btn { padding: 4px 8px; font-size: 11px; }
    .liq-ctx-pill { min-width: 60px; }

    /* Tables → horizontal scroll */
    .signal-table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .signal-table th, .signal-table td { padding: 8px 10px; font-size: 12px; white-space: nowrap; }
    .admin-table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .admin-table th, .admin-table td { padding: 8px 10px; font-size: 12px; white-space: nowrap; }

    /* Forms & modals */
    .modal { padding: 24px 20px; width: 95%; }
    .plan-select { grid-template-columns: 1fr 1fr; }
    .manual-table-row { grid-template-columns: 120px 1fr; }

    /* Chart */
    .chart-header { flex-wrap: wrap; gap: 8px; }
    .chart-legend { flex-wrap: wrap; gap: 8px; }
    .rh-status { padding: 8px 12px; gap: 10px; }

    /* Elite banner */
    .elite-banner { flex-direction: column; align-items: flex-start; }

    /* Screener toolbar */
    .screener-toolbar { gap: 8px; }
    .screener-toolbar .cache-info { margin-left: 0; width: 100%; }
}

/* ═══ RESPONSIVE — PHONE (480px) ═══ */
@media (max-width: 480px) {
    .main-content { padding: 10px 10px; }

    /* Header */
    .logo-text { font-size: 14px; }
    .btn-sm { padding: 6px 10px; font-size: 11px; }

    /* Nav */
    .nav-tab { padding: 10px 11px; font-size: 11px; }

    /* Landing */
    .landing-hero h1 { font-size: 20px; }
    .stats-bar { gap: 10px; }
    .stat-value { font-size: 20px; }

    /* Grids */
    .summary-row { grid-template-columns: repeat(2, 1fr); gap: 8px; }
    .analytics-grid { grid-template-columns: repeat(2, 1fr); gap: 8px; }
    .admin-stats { grid-template-columns: repeat(2, 1fr); }
    .pairs-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
    .pair-card { padding: 12px; }
    .pair-card .pair-name { font-size: 14px; }
    .pair-card .pair-price { font-size: 16px; }

    /* Summary cards */
    .summary-card .value { font-size: 22px; }
    .summary-card { padding: 12px; }

    /* Metric cards */
    .metric-card .metric-value { font-size: 26px; }
    .metric-card { padding: 14px; }

    /* Copy-trading stats */
    .ct-stats-grid { grid-template-columns: repeat(2, 1fr); }

    /* Manual */
    .manual-cards { grid-template-columns: 1fr; }

    /* Screener */
    .screener-grid { grid-template-columns: 1fr; }

    /* Touch targets — min 44px for iOS HIG compliance */
    .btn, .btn-sm, .nav-tab, .price-cta, .form-submit,
    .plan-option, .crypto-option, .liq-win-btn, .liq-dir-btn,
    .admin-btn, .ct-toggle { min-height: 44px; }
    .nav-tab { display: flex; align-items: center; justify-content: center; }
    .form-input { padding: 12px 14px; font-size: 16px; } /* 16px prevents iOS auto-zoom */
}

/* ═══ RESPONSIVE — SMALL PHONE (390px / iPhone 15 Pro) ═══ */
@media (max-width: 390px) {
    .main-content { padding: 8px; }
    .logo-text { display: none; }
    .logo-img { height: 30px !important; width: 30px !important; }
    .summary-row { grid-template-columns: 1fr 1fr; gap: 6px; }
    .analytics-grid { grid-template-columns: 1fr 1fr; gap: 6px; }
    .nav-tab { padding: 10px 9px; font-size: 10px; }
    .section-header { flex-direction: column; align-items: flex-start; gap: 8px; }
    .signal-card { padding: 12px; }
    .signal-card .sc-pair { font-size: 16px; }
}

/* ═══ iOS SAFE AREA (notch + home indicator) ═══ */
@supports (padding: env(safe-area-inset-top)) {
    header {
        padding-top: env(safe-area-inset-top);
    }
    body {
        padding-left: env(safe-area-inset-left);
        padding-right: env(safe-area-inset-right);
        padding-bottom: env(safe-area-inset-bottom);
    }
    .nav-tabs {
        padding-left: max(10px, env(safe-area-inset-left));
        padding-right: max(10px, env(safe-area-inset-right));
    }
}

/* ═══ iPAD SPECIFIC (768–1024px, pointer: coarse) ═══ */
@media (min-width: 768px) and (max-width: 1024px) and (pointer: coarse) {
    .nav-tab { padding: 13px 16px; font-size: 13px; }
    .pricing-grid { grid-template-columns: repeat(2, 1fr); }
    .signal-cards { grid-template-columns: repeat(2, 1fr); }
    .pairs-grid { grid-template-columns: repeat(3, 1fr); }
    .analytics-grid { grid-template-columns: repeat(3, 1fr); }
    .admin-stats { grid-template-columns: repeat(4, 1fr); }
    .ct-config-grid { grid-template-columns: 1fr 1fr; }
    .btn, .price-cta, .form-submit, .plan-option { min-height: 44px; }
    .form-input { font-size: 16px; } /* prevent iOS zoom on focus */
}

/* ═══ LANDSCAPE PHONES ═══ */
@media (max-height: 500px) and (orientation: landscape) {
    header { position: relative; } /* don't sticky on landscape phone — saves vertical space */
    .main-content { padding: 8px 12px; }
    .landing-hero { padding: 16px 0; }
    .landing-hero h1 { font-size: 20px; margin-bottom: 8px; }
    .stats-bar { margin: 16px 0 24px; }
}
/* Tables scrollable on mobile */
.table-scroll-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.table-scroll-wrap table { min-width: 540px; }
/* Canvas responsive — height set dynamically by heatmap.js */
#liq-canvas, #liq-price-canvas { width: 100% !important; display: block; }

/* ═══ TICKER MARQUEE ═══ */
@keyframes ticker-scroll {
    0%   { transform: translateX(100vw); }
    100% { transform: translateX(-100%); }
}
.ticker-sep { display:inline-block; margin:0 32px; color:rgba(168,85,247,0.5); font-size:14px; }

/* Heatmap controls — single row on desktop */
@media (min-width: 769px) {
    #liq-controls { flex-direction: row !important; align-items: center !important; gap: 12px !important; flex-wrap: wrap; }
    #liq-controls > div { flex-shrink: 0; }
    #liq-controls > div:last-child { flex: 1; min-width: 0; }
}
/* Heatmap mobile */
@media (max-width: 768px) {
    #liq-header-meta { flex-wrap: wrap !important; gap: 6px !important; font-size: 11px; }
    #liq-legend { font-size: 10px !important; gap: 8px !important; }
    .liq-win-btn { min-height: 36px; padding: 0 12px; font-size: 12px; }
    .liq-pair-chip { min-height: 32px; font-size: 12px; }
    #liq-context-bar { overflow-x: auto; -webkit-overflow-scrolling: touch; flex-wrap: nowrap !important; scrollbar-width: none; }
    #liq-context-bar::-webkit-scrollbar { display: none; }
    .liq-ctx-pill { flex-shrink: 0; }
}

.loading { text-align: center; padding: 60px; color: var(--text-dim); font-size: 14px; }
.loading .spinner { width: 32px; height: 32px; border: 3px solid var(--border); border-top-color: var(--gold); border-radius: 50%; animation: spin 0.8s linear infinite; margin: 0 auto 12px; }
@keyframes spin { to { transform: rotate(360deg); } }
.no-data { text-align: center; padding: 40px; color: var(--text-dim); }

/* ═══ ELITE TELEGRAM BANNER ═══ */
.elite-banner {
    display: none; background: linear-gradient(135deg, rgba(167,139,250,0.12) 0%, rgba(124,58,237,0.08) 100%);
    border: 1px solid rgba(167,139,250,0.3); border-radius: 12px;
    padding: 16px 24px; margin-bottom: 20px; display: none;
    align-items: center; justify-content: space-between; gap: 16px;
}
.elite-banner.visible { display: flex; }
.elite-banner-text { display: flex; align-items: center; gap: 12px; }
.elite-banner-text .icon { font-size: 24px; }
.elite-banner-text .title { font-weight: 700; font-size: 14px; color: var(--purple); }
.elite-banner-text .desc { font-size: 12px; color: var(--text-dim); margin-top: 2px; }
.btn-telegram {
    background: linear-gradient(135deg, #2AABEE 0%, #229ED9 100%); color: #fff;
    padding: 10px 20px; border-radius: 8px; font-size: 13px; font-weight: 700;
    border: none; cursor: pointer; text-decoration: none; white-space: nowrap; transition: all 0.2s;
}
.btn-telegram:hover { filter: brightness(1.15); transform: translateY(-1px); }

/* ═══ SCREENER ═══ */
.screener-toolbar { display:flex; align-items:center; gap:12px; margin-bottom:16px; flex-wrap:wrap; }
.screener-toolbar .tv-badge { display:flex; align-items:center; gap:6px; background:rgba(37,99,235,0.15); border:1px solid rgba(37,99,235,0.35); border-radius:6px; padding:5px 12px; font-size:12px; color:#60a5fa; font-weight:600; }
.screener-toolbar .refresh-btn { background:rgba(244,162,54,0.12); border:1px solid rgba(244,162,54,0.3); color:var(--gold); border-radius:6px; padding:5px 14px; font-size:12px; cursor:pointer; transition:all 0.2s; }
.screener-toolbar .refresh-btn:hover { background:rgba(244,162,54,0.22); }
.screener-toolbar .cache-info { font-size:11px; color:var(--text-dim); margin-left:auto; }
.screener-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:12px; }
.screener-card { background:var(--card); border:1px solid var(--border); border-radius:10px; padding:14px 16px; transition:border-color 0.2s; position:relative; overflow:hidden; }
.screener-card:hover { border-color:rgba(244,162,54,0.4); }
.screener-card.bias-long  { border-left:3px solid var(--green); }
.screener-card.bias-short { border-left:3px solid var(--red); }
.screener-card.bias-neutral { border-left:3px solid var(--border); }
.screener-card .sc-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.screener-card .sc-pair { font-size:15px; font-weight:700; letter-spacing:0.3px; }
.screener-card .sc-bias { font-size:11px; font-weight:700; padding:2px 8px; border-radius:4px; }
.screener-card .sc-bias.long  { background:rgba(34,197,94,0.15); color:var(--green); }
.screener-card .sc-bias.short { background:rgba(239,68,68,0.15); color:var(--red); }
.screener-card .sc-bias.neutral { background:rgba(255,255,255,0.06); color:var(--text-dim); }
.screener-card .sc-row { display:flex; justify-content:space-between; align-items:center; margin:4px 0; font-size:12px; }
.screener-card .sc-label { color:var(--text-dim); }
.screener-card .sc-val { font-weight:600; }
.screener-card .sc-rsi-bar { height:4px; border-radius:2px; background:var(--border); margin-top:3px; overflow:hidden; }
.screener-card .sc-rsi-fill { height:100%; border-radius:2px; transition:width 0.4s; }
.screener-card .sc-score { font-size:10px; color:var(--text-dim); white-space:nowrap; }
.screener-filters { display:flex; gap:8px; margin-bottom:14px; flex-wrap:wrap; }
.screener-filters .filter-btn { background:rgba(255,255,255,0.05); border:1px solid var(--border); border-radius:6px; padding:4px 12px; font-size:12px; color:var(--text-dim); cursor:pointer; transition:all 0.15s; }
.screener-filters .filter-btn.active { background:rgba(244,162,54,0.15); border-color:var(--gold); color:var(--gold); }
/* ═══ PRE-SIGNALS ═══ */
.presignal-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 12px; }
.presignal-card {
    background: var(--surface); border: 1px solid var(--border); border-radius: 10px;
    padding: 16px; position: relative; overflow: hidden;
}
.presignal-card .readiness { position: absolute; top: 0; right: 0; padding: 4px 10px; font-size: 10px; font-weight: 700; border-radius: 0 10px 0 8px; letter-spacing: 0.5px; }
.presignal-card .readiness.HIGH { background: var(--green); color: #000; }
.presignal-card .readiness.MEDIUM { background: var(--orange); color: #000; }
.presignal-card .expected { font-size: 20px; font-weight: 800; margin: 8px 0; }
.presignal-card .expected.long { color: var(--green); }
.presignal-card .expected.short { color: var(--red); }

/* ═══ SUBSCRIPTION TIMER ═══ */
.sub-timer { display: none; font-size: 11px; padding: 4px 10px; border-radius: 6px; margin-right: 8px; font-weight: 600; }
.sub-timer.visible { display: inline-block; }
.sub-timer.ok { background: rgba(0,214,143,0.15); color: var(--green); }
.sub-timer.warning { background: rgba(244,162,54,0.15); color: var(--orange); }
.sub-timer.critical { background: rgba(255,77,106,0.2); color: var(--red); animation: pulse 1.5s infinite; }

/* ═══ ADMIN PANEL ═══ */
.admin-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.admin-table th { text-align: left; padding: 10px 12px; border-bottom: 2px solid var(--border); color: var(--text-dim); font-size: 11px; text-transform: uppercase; letter-spacing: 0.5px; }
.admin-table td { padding: 10px 12px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.admin-table tr:hover { background: var(--surface2); }
.admin-table .tier-cell { font-weight: 700; text-transform: uppercase; font-size: 11px; }
.admin-table .tier-cell.free { color: var(--text-dim); }
.admin-table .tier-cell.pro { color: var(--gold); }
.admin-table .tier-cell.elite { color: var(--purple); }
.admin-table .tier-cell.expired { color: var(--red); }
.admin-table .days-cell { font-weight: 600; }
.admin-table .days-cell.ok { color: var(--green); }
.admin-table .days-cell.warning { color: var(--orange); }
.admin-table .days-cell.critical { color: var(--red); }
.admin-actions { display: flex; gap: 6px; }
.admin-btn { padding: 4px 10px; border-radius: 6px; font-size: 11px; font-weight: 600; border: 1px solid var(--border); background: var(--surface); color: var(--text); cursor: pointer; transition: all 0.2s; }
.admin-btn:hover { border-color: var(--gold); color: var(--gold); }
.admin-btn.danger { border-color: rgba(255,77,106,0.3); }
.admin-btn.danger:hover { border-color: var(--red); color: var(--red); }
.admin-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 20px; }
.admin-stat { background: var(--surface); border: 1px solid var(--border); border-radius: 10px; padding: 16px; text-align: center; }
.admin-stat .val { font-size: 28px; font-weight: 800; }
.admin-stat .lbl { font-size: 11px; color: var(--text-dim); margin-top: 4px; }
.admin-modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.7); z-index: 1000; display: flex; align-items: center; justify-content: center; }
.admin-modal { background: var(--surface); border: 1px solid var(--border); border-radius: 12px; padding: 24px; min-width: 320px; }
.admin-modal h3 { margin: 0 0 16px; font-size: 16px; }
.admin-modal select, .admin-modal input { width: 100%; padding: 8px 12px; background: var(--bg2); border: 1px solid var(--border); border-radius: 6px; color: var(--text); font-size: 14px; margin-bottom: 12px; }
.admin-modal .btn-row { display: flex; gap: 8px; justify-content: flex-end; }

/* ═══ COPY-TRADING ═══ */
.ct-config-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 20px; }
.ct-config-card {
    background: var(--surface); border: 1px solid var(--border); border-radius: 10px; padding: 20px;
}
.ct-config-card h3 { font-size: 14px; font-weight: 700; margin-bottom: 16px; display: flex; align-items: center; gap: 8px; }
.ct-form-row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.ct-form-row label { font-size: 12px; color: var(--text-dim); font-weight: 600; }
.ct-form-row input[type="number"],
.ct-form-row input[type="text"],
.ct-form-row input[type="password"] {
    width: 120px; padding: 6px 10px; background: var(--bg2); border: 1px solid var(--border);
    border-radius: 6px; color: var(--text); font-size: 13px; text-align: right;
}
.ct-form-row input:focus { border-color: var(--gold); outline: none; }
.ct-toggle {
    position: relative; width: 48px; height: 26px; background: var(--surface3);
    border-radius: 13px; cursor: pointer; transition: background 0.3s; border: 1px solid var(--border);
}
.ct-toggle.active { background: rgba(0,214,143,0.3); border-color: var(--green); }
.ct-toggle::after {
    content: ''; position: absolute; top: 3px; left: 3px; width: 18px; height: 18px;
    background: var(--text-dim); border-radius: 50%; transition: all 0.3s;
}
.ct-toggle.active::after { left: 25px; background: var(--green); }
.ct-status-pill {
    display: inline-flex; align-items: center; gap: 6px; padding: 4px 14px;
    border-radius: 20px; font-size: 12px; font-weight: 700;
}
.ct-status-pill.active { background: rgba(0,214,143,0.15); color: var(--green); border: 1px solid rgba(0,214,143,0.3); }
.ct-status-pill.inactive { background: var(--surface3); color: var(--text-dim); border: 1px solid var(--border); }
.ct-stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: 10px; margin-bottom: 16px; }
.ct-stat { background: var(--surface2); border-radius: 8px; padding: 12px; text-align: center; }
.ct-stat .val { font-size: 20px; font-weight: 800; }
.ct-stat .lbl { font-size: 10px; color: var(--text-dim); margin-top: 2px; text-transform: uppercase; letter-spacing: 0.5px; }
.ct-security-notice {
    background: rgba(255,77,106,0.06); border: 1px solid rgba(255,77,106,0.2);
    border-radius: 8px; padding: 12px 16px; font-size: 12px; color: var(--text-dim);
    margin-bottom: 16px; line-height: 1.5;
}
.ct-security-notice strong { color: var(--red); }
@media (max-width: 768px) {
    .ct-config-grid { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════
   USER MANUAL
 */
#page-manual { position: relative; }

.manual-section {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 24px;
    margin-bottom: 16px;
    transition: filter 0.3s, opacity 0.3s;
}
.manual-section p { font-size: 14px; color: var(--text-dim); line-height: 1.7; margin: 0 0 14px; }

.manual-locked-section.is-locked {
    filter: blur(4px);
    opacity: 0.45;
    pointer-events: none;
    user-select: none;
}

.manual-sec-header {
    display: flex; align-items: center; gap: 10px;
    margin-bottom: 14px;
}
.manual-sec-icon { font-size: 22px; flex-shrink: 0; }
.manual-sec-header h3 { margin: 0; font-size: 17px; font-weight: 700; flex: 1; }

.manual-tier-badge {
    font-size: 10px; font-weight: 800; padding: 3px 9px;
    border-radius: 20px; letter-spacing: .05em; flex-shrink: 0;
}
.manual-tier-badge.pro {
    background: rgba(244,162,54,0.15); color: var(--gold);
    border: 1px solid rgba(244,162,54,0.35);
}
.manual-tier-badge.elite {
    background: rgba(139,92,246,0.15); color: var(--purple);
    border: 1px solid rgba(139,92,246,0.35);
}

.manual-tip {
    display: flex; align-items: flex-start; gap: 10px;
    background: rgba(244,162,54,0.07);
    border: 1px solid rgba(244,162,54,0.25);
    border-radius: 8px; padding: 12px 14px;
    font-size: 13px; color: var(--text-dim); line-height: 1.6;
    margin: 12px 0 0;
}
.manual-tip-icon { font-size: 16px; flex-shrink: 0; margin-top: 1px; }

.manual-cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 10px; margin-top: 12px;
}
.manual-card {
    display: flex; align-items: flex-start; gap: 10px;
    background: var(--surface3);
    border: 1px solid var(--border);
    border-radius: 8px; padding: 12px;
}
.manual-card-icon { font-size: 20px; flex-shrink: 0; }
.manual-card strong { font-size: 13px; }
.manual-card span { font-size: 12px; color: var(--text-dim); line-height: 1.5; }

.manual-table {
    border: 1px solid var(--border);
    border-radius: 8px; overflow: hidden;
    font-size: 13px; margin-top: 12px;
}
.manual-table-row {
    display: grid; grid-template-columns: 200px 1fr;
    border-bottom: 1px solid var(--border);
}
.manual-table-row:last-child { border-bottom: none; }
.manual-table-row > span {
    padding: 9px 14px; line-height: 1.5;
}
.manual-table-row > span:first-child {
    background: var(--surface3);
    font-weight: 600; color: var(--text);
    border-right: 1px solid var(--border);
}
.manual-table-row > span:last-child { color: var(--text-dim); }
.manual-table-row.header > span {
    font-size: 11px; text-transform: uppercase;
    letter-spacing: .07em; color: var(--text-dim) !important;
    font-weight: 700 !important;
    background: var(--surface3) !important;
}

.manual-steps { display: flex; flex-direction: column; gap: 12px; margin-top: 12px; }
.manual-step {
    display: flex; align-items: flex-start; gap: 12px;
    background: var(--surface3); border-radius: 8px; padding: 12px 14px;
}
.manual-step-num {
    width: 26px; height: 26px; border-radius: 50%;
    background: var(--gold); color: #000;
    font-size: 12px; font-weight: 800;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.manual-step strong { font-size: 13px; display: block; margin-bottom: 3px; }
.manual-step span { font-size: 12px; color: var(--text-dim); line-height: 1.5; }

.manual-faq { display: flex; flex-direction: column; gap: 2px; }
.manual-faq-item {
    border-bottom: 1px solid var(--border);
    padding: 12px 0;
}
.manual-faq-item:last-child { border-bottom: none; }
.manual-faq-q {
    font-size: 13px; font-weight: 600; color: var(--text);
    margin-bottom: 5px; cursor: default;
}
.manual-faq-a { font-size: 13px; color: var(--text-dim); line-height: 1.6; }

/* TOC sidebar */
.manual-toc-link {
    display: block; font-size: 12px; padding: 6px 10px;
    border-radius: 6px; color: var(--text-dim);
    cursor: pointer; border-left: 2px solid transparent;
    transition: all 0.15s;
}
.manual-toc-link:hover { color: var(--text); background: var(--surface2); }
.manual-toc-link.active {
    color: var(--gold); background: rgba(244,162,54,0.08);
    border-left-color: var(--gold);
}

@media (max-width: 768px) {
    #manual-toc { display: none; }
    .manual-table-row { grid-template-columns: 130px 1fr; }
}
