/* ═══════════════════════════════════════════════════════════════════
   FITFORGE TRACKER v2 — COMPLETE COMPONENT STYLES
   All new + rebuilt component styles for v2 rebuild
   ═══════════════════════════════════════════════════════════════════ */

/* ── Dashboard ─────────────────────────────────────────────────── */
.dashboard-welcome { display:flex; align-items:center; justify-content:space-between; margin-bottom:var(--s8); padding:var(--s6) var(--s8); background:linear-gradient(135deg,rgba(0,242,254,0.06) 0%,rgba(79,172,254,0.03) 50%,transparent 100%); border:1px solid rgba(0,242,254,0.12); border-radius:var(--r6); position:relative; overflow:hidden; }
.dashboard-welcome::before { content:''; position:absolute; right:-60px; top:-60px; width:240px; height:240px; background:radial-gradient(circle,rgba(0,242,254,0.08) 0%,transparent 70%); pointer-events:none; }
.welcome-text h2 { font-family:var(--font-display); font-size:24px; font-weight:700; color:var(--text-primary); margin-bottom:4px; }
.welcome-text h2 span { color:var(--accent-primary); }
.welcome-text p { font-size:13px; color:var(--text-tertiary); }
.welcome-time { text-align:right; }
.welcome-date { font-family:var(--font-mono); font-size:11px; color:var(--text-muted); letter-spacing:1px; }
.welcome-clock { font-family:var(--font-brand); font-size:22px; color:var(--accent-primary); text-shadow:0 0 20px rgba(0,242,254,0.3); }
.stats-row { display:grid; grid-template-columns:repeat(5,1fr); gap:var(--s4); margin-bottom:var(--s8); }
@media(max-width:1280px){.stats-row{grid-template-columns:repeat(3,1fr);}}
@media(max-width:900px){.stats-row{grid-template-columns:repeat(2,1fr);}}
@media(max-width:480px){.stats-row{grid-template-columns:1fr;}}
.stat-icon { width:40px; height:40px; border-radius:var(--r3); display:flex; align-items:center; justify-content:center; margin-bottom:var(--s4); }
.stat-icon svg { width:20px; height:20px; }
.stat-icon-cyan{background:rgba(0,242,254,0.12);color:var(--accent-primary);}
.stat-icon-blue{background:rgba(79,172,254,0.12);color:var(--blue-400);}
.stat-icon-green{background:rgba(16,185,129,0.12);color:var(--green-400);}
.stat-icon-amber{background:rgba(245,158,11,0.12);color:var(--amber-400);}
.stat-icon-forge{background:rgba(255,107,53,0.12);color:var(--forge-orange);}
.stat-icon-purple{background:rgba(124,58,237,0.12);color:var(--purple-400);}
.quick-dl-panel { background:var(--glass-04); border:1px solid var(--border-soft); border-radius:var(--r6); padding:var(--s6); margin-bottom:var(--s8); }
.quick-dl-label { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:1.5px; color:var(--text-muted); margin-bottom:var(--s4); }
.quick-dl-input-row { display:flex; gap:var(--s3); align-items:stretch; }
.quick-dl-input-row .input-field { flex:1; font-size:15px; }
.platform-strip { display:flex; gap:var(--s3); flex-wrap:wrap; margin-top:var(--s4); }
.platform-pill { display:flex; align-items:center; gap:6px; padding:6px 14px; border-radius:var(--rfull); font-size:12px; font-weight:600; background:var(--glass-04); border:1px solid var(--border-dim); cursor:pointer; transition:all var(--t-base); color:var(--text-secondary); }
.platform-pill:hover { background:var(--glass-08); border-color:var(--border-mid); transform:translateY(-1px); }
.platform-pill .pp-dot { width:7px; height:7px; border-radius:50%; flex-shrink:0; }
.activity-feed { display:flex; flex-direction:column; gap:var(--s3); }
.activity-item { display:flex; align-items:center; gap:var(--s3); padding:var(--s3) var(--s4); background:var(--glass-02); border:1px solid var(--border-dim); border-radius:var(--r4); transition:all var(--t-base); cursor:default; }
.activity-item:hover { background:var(--glass-06); border-color:var(--border-soft); }
.activity-thumb { width:44px; height:44px; border-radius:var(--r2); background:var(--surface); overflow:hidden; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:18px; }
.activity-info { flex:1; min-width:0; }
.activity-title { font-size:13px; font-weight:600; color:var(--text-primary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.activity-sub { font-size:11px; color:var(--text-muted); }
.activity-meta { font-size:11px; color:var(--text-muted); text-align:right; flex-shrink:0; }

/* ── URL Input Section ─────────────────────────────────────────── */
.url-input-section { background:linear-gradient(135deg,rgba(0,242,254,0.04) 0%,rgba(79,172,254,0.02) 100%); border:2px solid rgba(0,242,254,0.15); border-radius:var(--r6); padding:var(--s8); margin-bottom:var(--s6); position:relative; overflow:hidden; transition:border-color var(--t-base); }
.url-input-section:has(input:focus) { border-color:rgba(0,242,254,0.4); box-shadow:var(--glow-sm-cyan); }
.url-input-section::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent 0%,rgba(0,242,254,0.4) 50%,transparent 100%); }
.url-input-label { font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--text-muted); margin-bottom:var(--s4); }
.url-input-row { display:flex; gap:var(--s3); align-items:center; }
.url-detect-badge { display:none; align-items:center; gap:6px; padding:6px 12px; border-radius:var(--rfull); font-size:12px; font-weight:700; white-space:nowrap; flex-shrink:0; }
.url-detect-badge.visible { display:flex; animation:scaleIn 0.3s var(--ease-spring) both; }

/* ═══════════════════════════════════════════════════════════════
   DOWNLOADER — SCREENSHOT-STYLE UI
   ═══════════════════════════════════════════════════════════════ */
.media-info-bar { display:flex; align-items:center; gap:var(--s4); padding:var(--s4) var(--s5); background:var(--glass-06); border:1px solid var(--border-soft); border-radius:var(--r4); margin-bottom:var(--s5); }
.mib-thumb { width:64px; height:48px; border-radius:var(--r2); object-fit:cover; background:var(--space); flex-shrink:0; overflow:hidden; display:flex; align-items:center; justify-content:center; font-size:24px; }
.mib-thumb img { width:100%; height:100%; object-fit:cover; }
.mib-info { flex:1; min-width:0; }
.mib-title { font-size:14px; font-weight:700; color:var(--text-primary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.mib-meta { font-size:12px; color:var(--text-muted); margin-top:3px; display:flex; gap:var(--s3); align-items:center; }
.mib-actions { display:flex; gap:var(--s2); flex-shrink:0; }

.dl-config-grid { display:grid; grid-template-columns:1fr 1fr; gap:var(--s4); margin-bottom:var(--s5); }
@media(max-width:640px){.dl-config-grid{grid-template-columns:1fr;}}
.dl-config-group { display:flex; flex-direction:column; gap:var(--s2); }
.dl-config-label { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--text-muted); }
.dl-config-select { background:var(--glass-06); border:1.5px solid var(--border-soft); border-radius:var(--r3); padding:10px 14px; color:var(--text-primary); font-size:14px; font-weight:600; cursor:pointer; appearance:none; background-image: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='%236B7A99' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 12px center; padding-right:34px; width:100%; transition:all var(--t-base); }
.dl-config-select:focus { border-color:rgba(0,242,254,0.4); outline:none; box-shadow:var(--glow-xs-cyan); }

.dl-advanced-row { display:flex; gap:var(--s4); flex-wrap:wrap; align-items:center; margin-bottom:var(--s5); padding:var(--s3) var(--s4); background:var(--glass-04); border:1px solid var(--border-dim); border-radius:var(--r3); }
.dl-adv-item { display:flex; flex-direction:column; gap:3px; }
.dl-adv-label { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--text-muted); }
.dl-adv-select { background:transparent; border:none; color:var(--accent-primary); font-size:12px; font-weight:700; cursor:pointer; padding:2px 16px 2px 0; appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%2300F2FE' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 0 center; }
.dl-adv-select:focus { outline:none; }

.quality-list { display:flex; flex-direction:column; gap:2px; margin-bottom:var(--s5); }
.quality-row-item { display:flex; align-items:center; gap:var(--s4); padding:12px var(--s4); border:1.5px solid var(--border-dim); border-radius:var(--r3); cursor:pointer; transition:all var(--t-base); background:var(--glass-02); }
.quality-row-item:hover { background:var(--glass-06); border-color:var(--border-soft); }
.quality-row-item.selected { border-color:var(--accent-primary); background:rgba(0,242,254,0.08); box-shadow:var(--glow-xs-cyan); }
.qri-radio { width:18px; height:18px; border-radius:50%; border:2px solid var(--border-mid); display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:all var(--t-base); }
.quality-row-item.selected .qri-radio { border-color:var(--accent-primary); background:var(--accent-primary); }
.quality-row-item.selected .qri-radio::after { content:''; width:6px; height:6px; border-radius:50%; background:#000; }
.qri-label { font-size:15px; font-weight:700; color:var(--text-primary); min-width:60px; }
.qri-codec { font-size:12px; color:var(--text-muted); font-family:var(--font-mono); flex:1; }
.qri-fps { font-size:12px; color:var(--text-tertiary); min-width:50px; text-align:center; }
.qri-size { font-size:12px; color:var(--text-tertiary); min-width:70px; text-align:right; font-family:var(--font-mono); }
.quality-row-item.locked { opacity:0.4; cursor:not-allowed; }
.quality-row-item.best-badge::after { content:'BEST'; font-size:9px; font-weight:700; padding:1px 6px; border-radius:var(--rfull); background:rgba(0,242,254,0.15); color:var(--accent-primary); border:1px solid rgba(0,242,254,0.3); }

.dl-action-bar { display:flex; gap:var(--s3); align-items:center; padding:var(--s4) var(--s5); background:linear-gradient(135deg,rgba(0,242,254,0.06),rgba(79,172,254,0.03)); border:1px solid rgba(0,242,254,0.15); border-radius:var(--r4); }
.dl-size-estimate { font-size:12px; color:var(--text-muted); margin-left:auto; font-family:var(--font-mono); }

/* Picker (Instagram carousel etc.) */
.picker-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:var(--s3); margin-top:var(--s4); }
.picker-item { position:relative; border-radius:var(--r3); overflow:hidden; cursor:pointer; border:2px solid transparent; transition:all var(--t-base); aspect-ratio:1; background:var(--space); }
.picker-item:hover { border-color:rgba(0,242,254,0.4); transform:scale(1.03); }
.picker-item.selected { border-color:var(--accent-primary); box-shadow:var(--glow-xs-cyan); }
.picker-item img { width:100%; height:100%; object-fit:cover; }
.picker-item-overlay { position:absolute; inset:0; background:rgba(0,0,0,0.4); opacity:0; transition:opacity var(--t-base); display:flex; align-items:center; justify-content:center; }
.picker-item:hover .picker-item-overlay { opacity:1; }
.picker-check { position:absolute; top:6px; right:6px; width:22px; height:22px; border-radius:50%; background:var(--accent-primary); color:#000; display:none; align-items:center; justify-content:center; }
.picker-item.selected .picker-check { display:flex; }
.picker-type-badge { position:absolute; bottom:6px; left:6px; font-size:10px; font-weight:700; padding:2px 7px; border-radius:var(--rfull); background:rgba(0,0,0,0.7); color:#fff; }

/* Download Queue */
.download-queue { margin-top:var(--s6); }
.queue-title { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:1.5px; color:var(--text-muted); margin-bottom:var(--s3); }
.queue-item { display:flex; align-items:center; gap:var(--s4); padding:var(--s3) var(--s4); background:var(--glass-02); border:1px solid var(--border-dim); border-radius:var(--r3); margin-bottom:var(--s2); transition:all var(--t-base); }
.queue-item:hover { background:var(--glass-04); }
.queue-file-icon { width:32px; height:32px; border-radius:var(--r2); background:rgba(0,242,254,0.1); color:var(--accent-primary); display:flex; align-items:center; justify-content:center; flex-shrink:0; font-family:var(--font-mono); font-size:10px; font-weight:700; }
.queue-info { flex:1; min-width:0; }
.queue-filename { font-size:13px; font-weight:600; color:var(--text-primary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.queue-meta { font-size:11px; color:var(--text-muted); }
.queue-progress { margin-top:5px; }
.queue-status { font-size:11px; font-weight:600; flex-shrink:0; }
.queue-status.completed { color:var(--green-400); }
.queue-status.downloading { color:var(--accent-primary); }
.queue-status.queued { color:var(--text-muted); }
.queue-status.error { color:var(--red-400); }
.dl-progress-bar { height:4px; border-radius:var(--rfull); background:var(--grad-primary); background-size:200% 100%; animation:progressFlow 1.2s linear infinite; box-shadow:var(--glow-sm-cyan); transition:width 0.3s var(--ease-out); }

/* ═══════════════════════════════════════════════════════════════
   METADATA & CHANNEL EXTRACTOR
   ═══════════════════════════════════════════════════════════════ */
.metadata-grid { display:grid; grid-template-columns:1fr 1fr; gap:var(--s5); margin-bottom:var(--s6); }
@media(max-width:900px){.metadata-grid{grid-template-columns:1fr;}}
.meta-field-card { background:var(--glass-04); border:1px solid var(--border-dim); border-radius:var(--r4); padding:var(--s4) var(--s5); transition:all var(--t-base); }
.meta-field-card:hover { border-color:var(--border-soft); background:var(--glass-06); }
.meta-field-card.full { grid-column:1/-1; }
.meta-field-label { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:1.5px; color:var(--text-muted); margin-bottom:var(--s2); }
.meta-field-value { font-size:14px; color:var(--text-primary); font-weight:500; line-height:1.5; word-break:break-word; }
.meta-field-value.mono { font-family:var(--font-mono); font-size:13px; }
.tags-cloud { display:flex; flex-wrap:wrap; gap:var(--s2); margin-top:var(--s3); }
.channel-info-panel { display:flex; align-items:flex-start; gap:var(--s5); padding:var(--s6); background:var(--glass-04); border:1px solid var(--border-soft); border-radius:var(--r5); margin-bottom:var(--s6); }
.channel-avatar { width:64px; height:64px; border-radius:50%; background:var(--grad-primary); display:flex; align-items:center; justify-content:center; font-size:24px; font-weight:700; color:#000; flex-shrink:0; box-shadow:var(--glow-sm-cyan); overflow:hidden; }
.channel-avatar img { width:100%; height:100%; object-fit:cover; }
.channel-meta-col { flex:1; min-width:0; }
.channel-name { font-size:18px; font-weight:700; color:var(--text-primary); margin-bottom:var(--s1); }
.channel-handle { font-size:13px; color:var(--text-muted); margin-bottom:var(--s3); }
.channel-stats-row { display:flex; gap:var(--s5); flex-wrap:wrap; }
.channel-stat-item { text-align:center; }
.channel-stat-num { font-family:var(--font-data); font-size:16px; font-weight:700; color:var(--text-primary); display:block; }
.channel-stat-name { font-size:11px; color:var(--text-muted); }
.export-options { display:flex; gap:var(--s3); flex-wrap:wrap; }

/* Thumbnail Gallery */
.thumbnail-gallery { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:var(--s4); margin-bottom:var(--s6); }
.thumb-card { background:var(--glass-04); border:1px solid var(--border-dim); border-radius:var(--r4); overflow:hidden; transition:all var(--t-base); }
.thumb-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-xl); border-color:var(--border-soft); }
.thumb-img-wrap { aspect-ratio:16/9; background:var(--space); display:flex; align-items:center; justify-content:center; overflow:hidden; position:relative; }
.thumb-img-wrap img { width:100%; height:100%; object-fit:cover; }
.thumb-img-wrap .thumb-placeholder { font-size:48px; opacity:0.3; }
.thumb-card-info { padding:var(--s3) var(--s4); display:flex; align-items:center; justify-content:space-between; }
.thumb-size-label { font-size:11px; font-weight:700; color:var(--text-secondary); }
.thumb-dims { font-size:10px; color:var(--text-muted); font-family:var(--font-mono); }
.thumb-dl-btn { font-size:11px; color:var(--accent-primary); font-weight:700; cursor:pointer; background:none; border:none; }
.thumb-dl-btn:hover { text-decoration:underline; }

/* ═══════════════════════════════════════════════════════════════
   CONTENT-SPECIFIC ANALYTICS
   ═══════════════════════════════════════════════════════════════ */
.analytics-controls { display:flex; align-items:center; justify-content:space-between; gap:var(--s4); flex-wrap:wrap; margin-bottom:var(--s6); }
.period-selector { display:flex; gap:2px; padding:3px; background:var(--glass-04); border:1px solid var(--border-dim); border-radius:var(--r3); }
.period-btn { padding:6px 14px; font-size:12px; font-weight:700; color:var(--text-tertiary); border-radius:calc(var(--r3) - 2px); transition:all var(--t-base); cursor:pointer; user-select:none; }
.period-btn:hover { color:var(--text-secondary); background:var(--glass-04); }
.period-btn.active { background:var(--glass-10); color:var(--accent-primary); box-shadow:inset 0 0 0 1px rgba(0,242,254,0.2); }
.chart-wrapper { background:var(--glass-04); border:1px solid var(--border-soft); border-radius:var(--r5); padding:var(--s6); margin-bottom:var(--s6); position:relative; }
.chart-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:var(--s5); flex-wrap:wrap; gap:var(--s3); }
.chart-title { font-family:var(--font-display); font-size:15px; font-weight:700; color:var(--text-primary); }
.chart-canvas-wrapper { position:relative; height:280px; }
.metrics-row { display:grid; grid-template-columns:repeat(4,1fr); gap:var(--s4); margin-bottom:var(--s6); }
@media(max-width:900px){.metrics-row{grid-template-columns:repeat(2,1fr);}}
.metric-card { background:var(--glass-04); border:1px solid var(--border-dim); border-radius:var(--r4); padding:var(--s4) var(--s5); text-align:center; }
.metric-val { font-family:var(--font-brand); font-size:22px; font-weight:400; letter-spacing:0.5px; background:var(--grad-primary); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; margin-bottom:2px; }
.metric-name { font-size:11px; color:var(--text-muted); text-transform:uppercase; letter-spacing:1px; }
.metric-delta { font-size:12px; font-weight:600; margin-top:2px; }
.metric-delta.up { color:var(--green-400); }
.metric-delta.down { color:var(--red-400); }
.platform-breakdown { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s4); }
@media(max-width:900px){.platform-breakdown{grid-template-columns:repeat(2,1fr);}}
.platform-card { background:var(--glass-04); border:1px solid var(--border-dim); border-radius:var(--r4); padding:var(--s4); transition:all var(--t-base); cursor:pointer; }
.platform-card:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); }
.platform-card-name { font-size:13px; font-weight:700; color:var(--text-primary); margin-bottom:var(--s2); }
.platform-card-num { font-family:var(--font-brand); font-size:20px; color:var(--text-primary); }
.platform-card-sub { font-size:11px; color:var(--text-muted); }
.platform-progress-bar { height:3px; background:var(--raised); border-radius:var(--rfull); margin-top:var(--s3); overflow:hidden; }
.platform-progress-fill { height:100%; border-radius:var(--rfull); transition:width 1s var(--ease-out); }
.competitive-panel { background:linear-gradient(135deg,rgba(124,58,237,0.06) 0%,rgba(236,72,153,0.04) 100%); border:1px solid rgba(124,58,237,0.2); border-radius:var(--r5); padding:var(--s6); margin-bottom:var(--s6); }
.competitive-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:var(--s5); }
.competitive-title { font-size:14px; font-weight:700; color:var(--purple-400); display:flex; align-items:center; gap:var(--s2); }
.competitor-input-row { display:flex; gap:var(--s3); margin-bottom:var(--s4); }
.legend-item { display:flex; align-items:center; gap:6px; font-size:12px; color:var(--text-tertiary); }
.legend-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.chart-legend { display:flex; gap:var(--s4); flex-wrap:wrap; }

/* ═══════════════════════════════════════════════════════════════
   MONETIZATION CALCULATOR
   ═══════════════════════════════════════════════════════════════ */
.monetization-layout { display:grid; grid-template-columns:1.4fr 1fr; gap:var(--s6); align-items:start; }
@media(max-width:1000px){.monetization-layout{grid-template-columns:1fr;}}
.monetization-form-panel { background:var(--glass-04); border:1px solid var(--border-soft); border-radius:var(--r5); padding:var(--s6); }
.form-group { margin-bottom:var(--s5); }
.form-label { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--text-tertiary); margin-bottom:var(--s2); display:flex; align-items:center; justify-content:space-between; }
.form-label-value { font-family:var(--font-mono); font-size:13px; font-weight:700; color:var(--accent-primary); background:rgba(0,242,254,0.1); padding:2px 10px; border-radius:var(--rfull); }
.range-slider { -webkit-appearance:none; appearance:none; width:100%; height:4px; border-radius:var(--rfull); background:linear-gradient(90deg,var(--accent-primary) 0%,var(--accent-primary) var(--slider-pct,50%),var(--raised) var(--slider-pct,50%)); outline:none; cursor:pointer; transition:background 0.1s; }
.range-slider::-webkit-slider-thumb { -webkit-appearance:none; appearance:none; width:18px; height:18px; border-radius:50%; background:#fff; border:2px solid var(--accent-primary); box-shadow:var(--glow-xs-cyan),var(--shadow-sm); cursor:grab; transition:all var(--t-fast); }
.range-slider::-webkit-slider-thumb:active { cursor:grabbing; transform:scale(1.2); }
.range-slider::-moz-range-thumb { width:18px; height:18px; border-radius:50%; background:#fff; border:2px solid var(--accent-primary); }
.platform-selector-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s3); margin-bottom:var(--s5); }
@media(max-width:640px){.platform-selector-grid{grid-template-columns:repeat(2,1fr);}}
.platform-select-card { display:flex; flex-direction:column; align-items:center; gap:var(--s2); padding:var(--s3); background:var(--glass-04); border:1.5px solid var(--border-dim); border-radius:var(--r3); cursor:pointer; transition:all var(--t-base); font-size:12px; font-weight:600; color:var(--text-tertiary); }
.platform-select-card:hover { background:var(--glass-08); }
.platform-select-card.active { border-color:var(--accent-primary); background:rgba(0,242,254,0.08); color:var(--accent-primary); box-shadow:var(--glow-xs-cyan); }
.platform-select-icon { font-size:20px; }
.earnings-panel { position:sticky; top:calc(var(--topbar-h) + var(--s5)); }
.earnings-main-card { background:linear-gradient(135deg,rgba(0,242,254,0.08) 0%,rgba(79,172,254,0.05) 100%); border:1px solid rgba(0,242,254,0.2); border-radius:var(--r5); padding:var(--s6); text-align:center; margin-bottom:var(--s4); box-shadow:var(--glow-sm-cyan); }
.earnings-period-label { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:2px; color:var(--text-muted); margin-bottom:var(--s3); }
.earnings-amount { font-family:var(--font-brand); font-size:48px; line-height:1.1; letter-spacing:1px; background:var(--grad-primary); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; margin-bottom:var(--s2); }
.earnings-range { font-size:13px; color:var(--text-muted); margin-bottom:var(--s4); }
.earnings-disclaimer { font-size:10px; color:var(--text-disabled); }
.earnings-breakdown { background:var(--glass-04); border:1px solid var(--border-dim); border-radius:var(--r4); overflow:hidden; margin-bottom:var(--s4); }
.breakdown-row { display:flex; align-items:center; justify-content:space-between; padding:var(--s3) var(--s4); border-bottom:1px solid var(--border-dim); font-size:13px; }
.breakdown-row:last-child { border-bottom:none; }
.breakdown-label { color:var(--text-tertiary); }
.breakdown-value { font-family:var(--font-mono); font-weight:700; color:var(--text-primary); }
.region-list { display:flex; flex-direction:column; gap:var(--s2); }
.region-row { display:flex; align-items:center; justify-content:space-between; gap:var(--s4); font-size:12px; }
.region-name { color:var(--text-tertiary); display:flex; align-items:center; gap:var(--s2); }
.region-flag { font-size:14px; }
.region-bar-track { flex:1; height:4px; background:var(--raised); border-radius:var(--rfull); overflow:hidden; }
.region-bar-fill { height:100%; border-radius:var(--rfull); background:var(--grad-primary); transition:width 1s var(--ease-out); }
.region-multiplier { font-family:var(--font-mono); font-weight:700; color:var(--accent-primary); }

/* ═══════════════════════════════════════════════════════════════
   AI LAB
   ═══════════════════════════════════════════════════════════════ */
.ai-tab-content { display:none; padding-top:var(--s5); }
.ai-tab-content.active { display:block; animation:fadeInUp 0.4s var(--ease-out) both; }
.ai-input-section { background:var(--glass-04); border:1.5px solid var(--border-soft); border-radius:var(--r5); padding:var(--s6); margin-bottom:var(--s5); }
.ai-input-label { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:1.5px; color:var(--text-muted); margin-bottom:var(--s3); }
.ai-textarea { background:transparent; border:1px solid var(--border-dim); border-radius:var(--r3); padding:var(--s4); color:var(--text-primary); font-size:14px; font-family:var(--font-body); resize:vertical; width:100%; min-height:100px; transition:border-color var(--t-base); line-height:1.6; }
.ai-textarea::placeholder { color:var(--text-muted); }
.ai-textarea:focus { border-color:rgba(0,242,254,0.35); outline:none; }
.ai-output { display:none; animation:fadeInUp 0.45s var(--ease-out) both; }
.ai-output.visible { display:block; }
.ai-output-panel { background:linear-gradient(135deg,rgba(0,242,254,0.03) 0%,rgba(79,172,254,0.02) 100%); border:1px solid rgba(0,242,254,0.15); border-radius:var(--r5); padding:var(--s6); position:relative; }
.ai-output-panel::before { content:'✦ AI OUTPUT'; position:absolute; top:-10px; left:var(--s5); font-size:10px; font-weight:700; letter-spacing:2px; background:var(--panel); padding:0 var(--s3); color:var(--accent-primary); }
.ai-output-text { font-size:14px; color:var(--text-secondary); line-height:1.75; white-space:pre-wrap; }
.ai-output-section-title { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--accent-primary); margin:var(--s4) 0 var(--s2); }
.ai-bullet { display:flex; align-items:flex-start; gap:var(--s3); padding:var(--s2) 0; font-size:13.5px; color:var(--text-secondary); border-bottom:1px solid var(--border-dim); }
.ai-bullet:last-child { border-bottom:none; }
.ai-bullet::before { content:'▸'; color:var(--accent-primary); flex-shrink:0; margin-top:2px; }
.hooks-grid { display:flex; flex-direction:column; gap:var(--s3); margin-top:var(--s4); }
.hook-card { background:var(--glass-04); border:1px solid var(--border-dim); border-left:3px solid var(--accent-primary); border-radius:var(--r3); padding:var(--s4) var(--s5); display:flex; align-items:flex-start; gap:var(--s4); transition:all var(--t-base); cursor:pointer; }
.hook-card:hover { background:var(--glass-06); transform:translateX(4px); box-shadow:var(--shadow-md); }
.hook-num { font-family:var(--font-mono); font-size:11px; font-weight:700; color:var(--accent-primary); background:rgba(0,242,254,0.1); padding:2px 8px; border-radius:var(--rfull); flex-shrink:0; }
.hook-text { font-size:14px; color:var(--text-primary); line-height:1.5; flex:1; }
.hook-copy-btn { opacity:0; transition:opacity var(--t-fast); flex-shrink:0; }
.hook-card:hover .hook-copy-btn { opacity:1; }
.language-selector { background:var(--glass-04); border:1px solid var(--border-soft); border-radius:var(--r3); padding:8px 12px; color:var(--text-primary); font-size:13px; cursor:pointer; appearance:none; background-image: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='%236B7A99' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 10px center; padding-right:30px; }
.language-selector:focus { border-color:rgba(0,242,254,0.3); outline:none; }
.translator-panel { background:var(--glass-04); border:1px solid var(--border-soft); border-radius:var(--r4); overflow:hidden; }
.translator-panel-header { display:flex; align-items:center; justify-content:space-between; padding:var(--s3) var(--s4); border-bottom:1px solid var(--border-dim); background:var(--glass-02); }
.translator-panel-lang { font-size:12px; font-weight:600; color:var(--accent-primary); }
.timestamp-list { display:flex; flex-direction:column; gap:var(--s3); }
.timestamp-item { display:flex; align-items:center; gap:var(--s4); padding:var(--s3) var(--s4); background:var(--glass-04); border:1px solid var(--border-dim); border-radius:var(--r3); transition:all var(--t-base); cursor:pointer; }
.timestamp-item:hover { background:var(--glass-08); border-color:rgba(0,242,254,0.2); }
.timestamp-time { font-family:var(--font-mono); font-size:13px; font-weight:700; color:var(--accent-primary); background:rgba(0,242,254,0.1); padding:3px 10px; border-radius:var(--rfull); flex-shrink:0; }
.timestamp-desc { font-size:13px; color:var(--text-secondary); flex:1; }
.timestamp-retention { font-size:11px; font-weight:700; padding:2px 8px; border-radius:var(--rfull); flex-shrink:0; }
.timestamp-retention.high { color:var(--green-400); background:rgba(16,185,129,0.1); }
.timestamp-retention.medium { color:var(--amber-400); background:rgba(245,158,11,0.1); }
.timestamp-retention.low { color:var(--red-400); background:rgba(239,68,68,0.1); }
.ab-preview-container { display:grid; grid-template-columns:1fr 1fr; gap:var(--s5); margin-top:var(--s5); }
@media(max-width:640px){.ab-preview-container{grid-template-columns:1fr;}}
.ab-variant-label { display:flex; align-items:center; justify-content:space-between; font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--text-muted); margin-bottom:var(--s3); }
.ab-variant-label .var-badge { padding:2px 10px; border-radius:var(--rfull); font-size:10px; }
.ab-variant-label .var-a { background:rgba(0,242,254,0.12); color:var(--accent-primary); }
.ab-variant-label .var-b { background:rgba(255,107,53,0.12); color:var(--forge-orange); }
.social-feed-preview { background:var(--glass-04); border:1px solid var(--border-soft); border-radius:var(--r4); overflow:hidden; }
.sfp-header { display:flex; align-items:center; gap:var(--s2); padding:var(--s3); border-bottom:1px solid var(--border-dim); }
.sfp-avatar { width:28px; height:28px; border-radius:50%; background:var(--grad-primary); }
.sfp-name { font-size:12px; font-weight:600; color:var(--text-primary); }
.sfp-time { font-size:10px; color:var(--text-muted); margin-left:auto; }
.sfp-thumbnail { width:100%; aspect-ratio:16/9; background:var(--space); display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; }
.sfp-thumbnail-placeholder { font-size:48px; opacity:0.3; }
.sfp-play-icon { position:absolute; width:40px; height:40px; border-radius:50%; background:rgba(0,0,0,0.6); backdrop-filter:blur(4px); display:flex; align-items:center; justify-content:center; color:#fff; }
.sfp-title { padding:var(--s3); font-size:13px; font-weight:600; color:var(--text-primary); line-height:1.3; }
.sfp-meta { padding:0 var(--s3) var(--s3); font-size:11px; color:var(--text-muted); }
.ctr-score-bar { display:flex; align-items:center; gap:var(--s4); padding:var(--s4) var(--s5); background:var(--glass-04); border:1px solid var(--border-dim); border-radius:var(--r3); margin-top:var(--s4); }
.ctr-label { font-size:12px; color:var(--text-muted); font-weight:600; }
.ctr-value { font-family:var(--font-brand); font-size:22px; margin-left:auto; }

/* ═══════════════════════════════════════════════════════════════
   EXTRA TOOLS
   ═══════════════════════════════════════════════════════════════ */
.tools-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:var(--s5); }
.tool-card { background:var(--glass-04); border:1px solid var(--border-dim); border-radius:var(--r5); padding:var(--s6); transition:all var(--t-spring); cursor:pointer; }
.tool-card:hover { transform:translateY(-4px); border-color:var(--border-soft); box-shadow:var(--shadow-xl); }
.tool-card-icon { width:48px; height:48px; border-radius:var(--r4); display:flex; align-items:center; justify-content:center; font-size:24px; margin-bottom:var(--s4); }
.tool-card-title { font-size:15px; font-weight:700; color:var(--text-primary); margin-bottom:var(--s2); }
.tool-card-desc { font-size:13px; color:var(--text-muted); line-height:1.5; }
.tool-card-badge { margin-top:var(--s3); }
.batch-queue { display:flex; flex-direction:column; gap:var(--s3); }
.batch-url-item { display:flex; align-items:center; gap:var(--s3); padding:var(--s3) var(--s4); background:var(--glass-04); border:1px solid var(--border-dim); border-radius:var(--r3); }
.batch-url-text { flex:1; font-size:13px; color:var(--text-secondary); font-family:var(--font-mono); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.batch-url-status { font-size:11px; font-weight:700; flex-shrink:0; }
.subtitle-lang-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:var(--s3); }
.subtitle-lang-card { display:flex; align-items:center; gap:var(--s3); padding:var(--s3) var(--s4); background:var(--glass-04); border:1.5px solid var(--border-dim); border-radius:var(--r3); cursor:pointer; transition:all var(--t-base); }
.subtitle-lang-card:hover { border-color:rgba(0,242,254,0.3); background:var(--glass-08); }
.subtitle-lang-card.selected { border-color:var(--accent-primary); background:rgba(0,242,254,0.08); }
.seo-score-ring { width:80px; height:80px; position:relative; flex-shrink:0; }
.seo-score-ring svg { transform:rotate(-90deg); }
.seo-score-val { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-family:var(--font-brand); font-size:22px; }
.seo-row { display:flex; align-items:center; justify-content:space-between; padding:var(--s3) 0; border-bottom:1px solid var(--border-dim); font-size:13px; }
.seo-row:last-child { border-bottom:none; }
.seo-row-label { color:var(--text-tertiary); }
.seo-row-score { font-weight:700; }
.seo-row-score.good { color:var(--green-400); }
.seo-row-score.ok { color:var(--amber-400); }
.seo-row-score.bad { color:var(--red-400); }

/* ═══════════════════════════════════════════════════════════════
   SETTINGS PAGE
   ═══════════════════════════════════════════════════════════════ */
.settings-section { margin-bottom:var(--s8); }
.settings-section-title { font-family:var(--font-display); font-size:16px; font-weight:700; color:var(--text-primary); margin-bottom:var(--s5); padding-bottom:var(--s3); border-bottom:1px solid var(--border-dim); }
.settings-item { display:flex; align-items:flex-start; justify-content:space-between; gap:var(--s6); padding:var(--s4) 0; border-bottom:1px solid var(--border-dim); }
.settings-item:last-child { border-bottom:none; }
.settings-item-info { flex:1; }
.settings-item-title { font-size:14px; font-weight:600; color:var(--text-primary); margin-bottom:3px; }
.settings-item-desc { font-size:12px; color:var(--text-muted); line-height:1.5; }
.api-key-input-row { display:flex; gap:var(--s3); align-items:center; margin-top:var(--s3); }
.api-key-input-row .input-field { flex:1; font-family:var(--font-mono); font-size:13px; }
.api-key-status { font-size:11px; font-weight:700; }
.api-key-status.connected { color:var(--green-400); }
.api-key-status.disconnected { color:var(--text-muted); }

/* ═══════════════════════════════════════════════════════════════
   MISC / SHARED
   ═══════════════════════════════════════════════════════════════ */
.empty-state { display:flex; flex-direction:column; align-items:center; justify-content:center; padding:var(--s16) var(--s8); text-align:center; color:var(--text-muted); }
.empty-icon { font-size:48px; margin-bottom:var(--s4); opacity:0.5; }
.empty-title { font-size:16px; font-weight:700; color:var(--text-secondary); margin-bottom:var(--s2); }
.empty-desc { font-size:13px; color:var(--text-muted); max-width:340px; line-height:1.6; }
.labeled-section { margin-bottom:var(--s5); }
.labeled-section-title { font-size:13px; font-weight:700; color:var(--text-secondary); margin-bottom:var(--s3); display:flex; align-items:center; gap:var(--s3); }
.labeled-section-title::after { content:''; flex:1; height:1px; background:var(--border-dim); }
.toggle-switch { position:relative; width:44px; height:24px; cursor:pointer; flex-shrink:0; }
.toggle-switch input { opacity:0; width:0; height:0; position:absolute; }
.toggle-slider { position:absolute; inset:0; background:var(--raised); border-radius:var(--rfull); transition:all var(--t-base); border:1px solid var(--border-dim); }
.toggle-slider::before { content:''; position:absolute; left:3px; top:50%; transform:translateY(-50%); width:16px; height:16px; border-radius:50%; background:var(--text-muted); transition:all var(--t-spring); }
.toggle-switch input:checked + .toggle-slider { background:rgba(0,242,254,0.15); border-color:rgba(0,242,254,0.3); }
.toggle-switch input:checked + .toggle-slider::before { left:calc(100% - 19px); background:var(--accent-primary); box-shadow:var(--glow-xs-cyan); }
.progress-track { background:var(--raised); border-radius:var(--rfull); height:4px; overflow:hidden; }
.progress-fill { height:100%; border-radius:var(--rfull); background:var(--grad-primary); transition:width 0.6s var(--ease-out); box-shadow:var(--glow-xs-cyan); }
.skeleton { background:linear-gradient(90deg,var(--elevated) 0%,var(--surface) 50%,var(--elevated) 100%); background-size:200% 100%; animation:shimmer 1.8s ease-in-out infinite; border-radius:var(--r3); }

/* ── Dividers ─────────────────────────────────────────────── */
.divider { height:1px; background:var(--border-dim); width:100%; margin:var(--s6) 0; }

/* ── Quality Option ───────────────────────────────────────── */
.quality-option { display:flex; flex-direction:column; align-items:center; padding:var(--s3) var(--s4); border:1.5px solid var(--border-soft); border-radius:var(--r4); cursor:pointer; transition:all var(--t-base); background:var(--glass-02); gap:4px; }
.quality-option:hover { border-color:rgba(0,242,254,0.25); background:rgba(0,242,254,0.05); }
.quality-option.selected { border-color:var(--accent-primary); background:rgba(0,242,254,0.10); box-shadow:var(--glow-xs-cyan); }
.quality-option .q-label { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.5px; color:var(--text-secondary); }
.quality-option .q-desc { font-size:10px; color:var(--text-muted); }
.quality-option.selected .q-label { color:var(--accent-primary); }

/* ── Tab Bar ──────────────────────────────────────────────── */
.tab-bar { display:flex; gap:4px; padding:4px; background:var(--glass-04); border:1px solid var(--border-dim); border-radius:var(--r4); flex-wrap:wrap; }
.tab-item { display:flex; align-items:center; gap:var(--s2); padding:8px 16px; font-size:13px; font-weight:600; color:var(--text-tertiary); border-radius:var(--r3); transition:all var(--t-base); cursor:pointer; user-select:none; }
.tab-item:hover { color:var(--text-secondary); background:var(--glass-04); }
.tab-item.active { background:var(--glass-10); color:var(--accent-primary); box-shadow:inset 0 0 0 1px rgba(0,242,254,0.2); }
.tab-item svg { width:15px; height:15px; flex-shrink:0; }

/* ── Grid 2-1 fallback ────────────────────────────────────── */
@media(max-width:900px){.grid-2-1{grid-template-columns:1fr;}}
