*{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#0b0d11;--bg2:#101218;--bg3:#16181f;--surface:#1a1d27;--surface2:#21242f;--border:rgba(255,255,255,0.05);--border2:rgba(255,255,255,0.08);--text:#e8eaed;--text2:#9aa0b0;--text3:#5c6170;--sky:#2962ff;--sky2:#5a8dff;--sky3:#82b0ff;--gold:#f5a623;--gold2:#ffc107;--green:#00c853;--green2:#00e676;--red:#ff1744;--red2:#ff5252;--radius:10px;--radius-sm:6px;--radius-xs:4px;--shadow:0 2px 16px rgba(0,0,0,0.3);--glass:rgba(255,255,255,0.03);--glass2:rgba(255,255,255,0.05);--transition:0.2s ease}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;overflow-x:hidden;font-size:14px;line-height:1.5}
body::before{content:'';position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse at 15% 0%,rgba(41,98,255,0.06) 0%,transparent 55%),radial-gradient(ellipse at 85% 100%,rgba(245,166,35,0.03) 0%,transparent 55%);pointer-events:none;z-index:0}
body.app-page::after{content:'';position:fixed;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(rgba(255,255,255,0.008) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.008) 1px,transparent 1px);background-size:60px 60px;pointer-events:none;z-index:0}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.06);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,0.12)}

/* ========== LOGO ========== */
.logo{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:700;cursor:default}
.logo-icon{display:flex;position:relative}
.logo-icon svg{display:block}
.logo-accent{background:linear-gradient(135deg,var(--sky2),var(--sky3));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.logo-gold{color:var(--gold)}

/* ========== APP HEADER ========== */
.app-header{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;border-bottom:1px solid var(--border);background:rgba(11,13,17,0.9);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);position:sticky;top:0;z-index:100;gap:12px}
.app-header .logo{font-size:15px;gap:6px}
.app-header .chart-logo{width:20px;height:20px}
.app-user{display:flex;align-items:center;gap:6px;flex-shrink:0}
.app-user span{font-size:12px;color:var(--text2);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mobile-menu-btn{display:none!important}
@media(max-width:768px){
  .mobile-menu-btn{display:block!important;padding:6px 10px;border:none;border-radius:var(--radius-xs);background:var(--glass);color:var(--text2);font-size:16px;cursor:pointer}
  .app-user{display:none;position:absolute;top:52px;left:0;right:0;background:var(--surface);border-bottom:1px solid var(--border);padding:14px;flex-direction:column;align-items:stretch;gap:8px;z-index:99}
  .app-user.mobile-open{display:flex}
  .app-user span{max-width:100%}
  .app-user .btn{width:100%;text-align:center}
  .app-user .btn-theme{width:fit-content}
}
.btn-logout{padding:5px 10px;border:none;border-radius:var(--radius-xs);background:var(--glass);color:var(--text2);font-size:11px;font-weight:500;font-family:inherit;cursor:pointer;transition:var(--transition)}
.btn-logout:hover{background:rgba(255,23,68,0.1);color:var(--red)}
.btn-theme{padding:5px 7px;border:none;border-radius:var(--radius-xs);background:var(--glass);color:var(--text2);font-size:13px;cursor:pointer;transition:var(--transition)}
.btn-theme:hover{background:var(--glass2);color:var(--text)}
.app-main{max-width:1200px;margin:0 auto;padding:16px 20px 48px;position:relative;z-index:1}

/* ========== AUTH MODAL ========== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.7);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:none;align-items:center;justify-content:center;padding:20px;overflow-y:auto}
.modal-overlay.active{display:flex}
.modal{background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);padding:24px;width:100%;max-width:380px;box-shadow:var(--shadow);animation:modalIn 0.25s ease;max-height:85vh;overflow-y:auto}
@keyframes modalIn{from{opacity:0;transform:scale(0.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}
.modal h2{font-size:17px;font-weight:700;margin-bottom:4px}
.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.modal-header h2{font-size:18px;margin:0}
.modal-close{background:none;border:none;color:var(--text3);font-size:20px;cursor:pointer;padding:2px;line-height:1}
.modal-close:hover{color:var(--text)}
#authModal .modal{max-width:380px}
#authModal input{width:100%;padding:10px 12px;border-radius:var(--radius-xs);border:1px solid var(--border);background:var(--bg2);color:var(--text);font-size:13px;font-family:inherit;outline:none;transition:var(--transition)}
#authModal input:focus{border-color:var(--sky);box-shadow:0 0 0 2px rgba(41,98,255,0.15)}
.auth-modal-header{text-align:center;margin-bottom:10px}
.auth-modal-header svg{margin-bottom:4px}
.auth-subtitle{font-size:12px;color:var(--text3);margin-bottom:14px;text-align:center}
.auth-error{font-size:12px;color:var(--red);margin-bottom:8px;display:none;text-align:center}
.auth-divider{display:flex;align-items:center;gap:10px;margin:10px 0}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-divider span{font-size:11px;color:var(--text3);white-space:nowrap}
.auth-toggle{text-align:center;margin-top:10px;font-size:12px;color:var(--text3)}
.auth-toggle a{color:var(--sky2);text-decoration:none;font-weight:500}
.auth-toggle a:hover{text-decoration:underline}
.btn-full{width:100%;justify-content:center}
.btn-google{display:flex;align-items:center;justify-content:center;gap:8px}

/* ========== FORM ELEMENTS ========== */
.form-group{margin-bottom:10px}
.form-group label{display:block;font-size:11px;font-weight:500;color:var(--text2);margin-bottom:4px;text-transform:uppercase;letter-spacing:0.4px}
.form-group input,.form-group select{width:100%;padding:9px 11px;border-radius:var(--radius-xs);border:1px solid var(--border);background:var(--bg2);color:var(--text);font-size:13px;font-family:inherit;outline:none;transition:var(--transition)}
.form-group input:focus,.form-group select:focus{border-color:var(--sky);box-shadow:0 0 0 2px rgba(41,98,255,0.1)}
.form-group input::placeholder{color:var(--text3)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.form-actions{display:flex;gap:8px;margin-top:14px}
.form-section-label{font-size:12px;font-weight:600;color:var(--text);margin-bottom:6px;padding-top:6px}
.btn{padding:8px 16px;border:none;border-radius:var(--radius-xs);font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--transition)}
.btn-submit{background:linear-gradient(135deg,var(--sky),var(--sky2));color:#fff}
.btn-submit:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(41,98,255,0.25)}
.btn-secondary{background:var(--glass2);color:var(--text);border:1px solid var(--border)}
.btn-secondary:hover{background:var(--surface2);border-color:var(--border2)}
.btn-cancel{background:rgba(255,23,68,0.06);color:var(--red2);border:1px solid rgba(255,23,68,0.12)}
.btn-cancel:hover{background:rgba(255,23,68,0.12)}
.btn-primary{background:linear-gradient(135deg,var(--sky),var(--sky2));color:#fff;position:relative;overflow:hidden}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(41,98,255,0.25)}
.btn-danger{background:rgba(255,23,68,0.08);color:var(--red);border:1px solid rgba(255,23,68,0.15)}
.btn-danger:hover{background:rgba(255,23,68,0.15)}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#0a0b0d}
.btn-gold:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(245,166,35,0.25)}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#0a0b0d}
.btn-gold:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(245,166,35,0.25)}
.btn-outline{background:transparent;color:var(--sky2);border:1px solid rgba(41,98,255,0.25)}
.btn-outline:hover{background:rgba(41,98,255,0.06);border-color:var(--sky)}
.btn-sm{padding:4px 8px;font-size:10px;border-radius:4px}

/* ========== TOOLBAR ========== */
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.toolbar-left{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.toolbar-right{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.filter-select{padding:6px 10px;border-radius:var(--radius-xs);border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:11px;font-family:inherit;outline:none;cursor:pointer;transition:var(--transition)}
.filter-select:focus{border-color:var(--sky)}
.trade-count{font-size:11px;color:var(--text3);font-weight:500}

/* ========== DAILY JOURNAL SECTION ========== */
.signals-inline{margin-bottom:16px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);overflow:hidden}
.signals-inline-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;user-select:none}
.sib-left{display:flex;align-items:center;gap:8px}
.sib-icon{font-size:16px}
.sib-title{font-size:13px;font-weight:600}
.sib-sub{font-size:11px;color:var(--text3);font-weight:400}
.signals-list{display:flex;flex-direction:column;gap:8px;padding:0 16px 12px}

/* ========== JOURNAL ENTRY (signal card) ========== */
.journal-entry{padding:14px;border-radius:var(--radius-sm);background:var(--bg2);border:1px solid var(--border);position:relative;overflow:hidden;transition:var(--transition)}
.journal-entry:hover{border-color:var(--border2)}
.journal-featured{border-left:2px solid var(--sky)}
.journal-compact{border-left:2px solid transparent}
.signal-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.signal-pair{font-size:13px;font-weight:700}
.signal-dir{font-size:10px;font-weight:600;padding:2px 6px;border-radius:3px}
.signal-dir.bullish{background:rgba(0,200,83,0.08);color:var(--green)}
.signal-dir.bearish{background:rgba(255,23,68,0.08);color:var(--red)}
.signal-meta{font-size:10px;color:var(--text3);margin-bottom:4px}
.journal-notes{font-size:11px;color:var(--text2);line-height:1.4;margin-bottom:6px}
.signal-actions{margin-top:4px}
.btn-take-trade{padding:5px 12px;border:none;border-radius:4px;background:linear-gradient(135deg,var(--sky),var(--sky2));color:#fff;font-size:10px;font-weight:600;font-family:inherit;cursor:pointer;transition:var(--transition)}
.btn-take-trade:hover{transform:translateY(-1px);box-shadow:0 3px 10px rgba(41,98,255,0.25)}

/* ========== STATS CARDS ========== */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}
.stat-card{padding:16px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);position:relative;overflow:hidden;transition:var(--transition)}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;transition:var(--transition)}
.stat-card:hover{transform:translateY(-1px);border-color:var(--border2)}
.stat-label{font-size:10px;font-weight:500;color:var(--text3);text-transform:uppercase;letter-spacing:0.4px;margin-bottom:3px}
.stat-value{font-size:24px;font-weight:800;letter-spacing:-0.01em}
.stat-value.green{color:var(--green)}
.stat-value.red{color:var(--red)}
.stat-value.blue{color:var(--sky2)}
.stat-value.gold{color:var(--gold)}
.stat-value.white{color:var(--text)}

/* ========== CHART ========== */
.chart-section{padding:16px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);margin-bottom:16px}
.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.chart-header h3{font-size:14px;font-weight:600}
.chart-container{position:relative;height:180px}

/* ========== TABS ========== */
.tabs{display:flex;gap:3px;margin-bottom:14px;padding:3px;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);overflow-x:auto}
.tab{padding:6px 14px;border:none;border-radius:5px;background:transparent;color:var(--text3);font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;white-space:nowrap;transition:all var(--transition)}
.tab.active{background:var(--sky);color:#fff}
.tab:hover:not(.active){color:var(--text);background:var(--glass)}

/* ========== QUICK ENTRY ========== */
.quick-entry{padding:14px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);margin-bottom:14px}
.qe-label{font-size:10px;font-weight:500;color:var(--text2);margin-bottom:6px;text-transform:uppercase;letter-spacing:0.4px}
.qe-fields{display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.qe-select,.qe-input{padding:5px 7px;border-radius:var(--radius-xs);border:1px solid var(--border);background:var(--bg2);color:var(--text);font-size:11px;font-family:inherit;outline:none;transition:var(--transition)}
.qe-select:focus,.qe-input:focus{border-color:var(--sky);box-shadow:0 0 0 2px rgba(41,98,255,0.1)}
.qe-dir-btn{padding:5px 10px;border:1px solid var(--border);border-radius:var(--radius-xs);background:var(--bg2);color:var(--text3);font-size:11px;font-weight:600;font-family:inherit;cursor:pointer;transition:var(--transition)}
.qe-dir-btn.qe-buy.active{background:rgba(0,200,83,0.1);border-color:var(--green);color:var(--green)}
.qe-dir-btn.qe-sell.active{background:rgba(255,23,68,0.1);border-color:var(--red);color:var(--red)}
.qe-dir-btn:hover{background:var(--glass);color:var(--text)}
.qe-narrow{width:55px}
.qe-w100{width:90px}
.qe-w60{width:55px}

/* ========== OPEN TRADES BAR ========== */
.open-trades-bar{display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:var(--radius-sm);background:rgba(41,98,255,0.04);border:1px solid rgba(41,98,255,0.1);margin-bottom:14px}
.ot-label{font-size:11px;font-weight:600;color:var(--sky2)}
.ot-count{font-size:11px;font-weight:700;color:var(--sky2);background:rgba(41,98,255,0.08);padding:2px 6px;border-radius:4px}

/* ========== TRADE TABLE ========== */
.trade-section{padding:16px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);margin-bottom:16px}
.trade-table-wrap{overflow-x:auto;border-radius:var(--radius-sm);border:1px solid var(--border)}
.trade-table{width:100%;border-collapse:collapse;font-size:11px}
.trade-table thead{background:var(--bg2)}
.trade-table th{padding:8px 10px;text-align:left;font-weight:600;color:var(--text2);font-size:9px;text-transform:uppercase;letter-spacing:0.4px;border-bottom:1px solid var(--border)}
.trade-table td{padding:8px 10px;border-bottom:1px solid var(--border);color:var(--text);font-size:11px}
.trade-table tbody tr{transition:var(--transition)}
.trade-table tbody tr:hover td{background:var(--glass)}
.trade-table tbody tr:nth-child(even) td{background:rgba(255,255,255,0.005)}
.trade-table tbody tr.row-open td{background:rgba(41,98,255,0.03);border-left:2px solid var(--sky2)}
.trade-table tbody tr:last-child td{border-bottom:none}
.trade-table .win{color:var(--green);font-weight:600}
.trade-table .loss{color:var(--red);font-weight:600}
.trade-table .breakeven{color:var(--text3)}
.trade-table .dir-buy{color:var(--green)}
.trade-table .dir-sell{color:var(--red)}
.trade-actions{display:flex;gap:3px}
.btn-sm-edit{padding:3px 6px;border:none;border-radius:3px;background:rgba(41,98,255,0.06);color:var(--sky2);font-size:10px;cursor:pointer;transition:var(--transition)}
.btn-sm-edit:hover{background:rgba(41,98,255,0.12)}
.btn-sm-delete{padding:3px 6px;border:none;border-radius:3px;background:rgba(255,23,68,0.06);color:var(--red2);font-size:10px;cursor:pointer;transition:var(--transition)}
.btn-sm-delete:hover{background:rgba(255,23,68,0.12)}

/* ========== TP BADGES ========== */
.tp-badge{display:inline-block;font-size:9px;font-weight:600;padding:1px 5px;border-radius:3px;margin:1px;white-space:nowrap}
.tp-badge.tp1{background:rgba(0,200,83,0.1);color:var(--green)}
.tp-badge.tp2{background:rgba(41,98,255,0.1);color:var(--sky2)}
.tp-badge.tp3{background:rgba(245,166,35,0.06);color:var(--gold2)}
.tp-badge.tp-full{background:rgba(245,166,35,0.1);color:var(--gold)}
.tp-cell{font-size:10px;line-height:1.4}

/* ========== EMPTY STATE ========== */
.empty-state{text-align:center;padding:32px 16px}
.empty-state .empty-icon{font-size:36px;margin-bottom:10px;opacity:0.4}
.empty-state h3{font-size:14px;color:var(--text3);margin-bottom:3px}
.empty-state p{font-size:12px;color:var(--text3)}

/* ========== NOTES / SCREENSHOT THUMBS ========== */
.screenshot-thumb{display:inline-block;padding:3px 6px;border-radius:3px;background:rgba(41,98,255,0.06);color:var(--sky2);font-size:9px;cursor:pointer;transition:var(--transition)}
.screenshot-thumb:hover{background:rgba(41,98,255,0.12)}
.notes-preview{display:inline-block;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:10px;color:var(--text3);cursor:pointer;padding:3px 6px;border-radius:3px}
.notes-preview:hover{background:var(--glass)}

/* ========== SCREENSHOT MODAL ========== */
.screenshot-modal-content{position:relative;display:inline-block;max-width:90vw;max-height:85vh;padding:14px;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border2)}
.screenshot-close{position:absolute;top:-10px;right:-10px;width:26px;height:26px;border-radius:50%;background:var(--surface2);border:1px solid var(--border2);color:var(--text2);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);z-index:5}
.screenshot-close:hover{background:rgba(255,23,68,0.15);color:var(--red)}

/* ========== DAYS DASHBOARD ========== */
.days-section{display:none}
.days-section.active{display:block}
.days-header{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.days-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px}
.days-consistency{margin-bottom:14px;padding:16px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border)}
.cons-ref-table-wrap{overflow-x:auto;border-radius:var(--radius-sm);border:1px solid var(--border);margin-bottom:10px}
.cons-ref-table{width:100%;border-collapse:collapse;font-size:11px}
.cons-ref-table th{padding:6px 8px;text-align:left;font-weight:600;color:var(--text2);font-size:9px;text-transform:uppercase;letter-spacing:0.4px;background:var(--bg2);border-bottom:1px solid var(--border)}
.cons-ref-table td{padding:6px 8px;border-bottom:1px solid var(--border);font-size:11px}
.cons-ref-table .td-green{color:var(--green);font-weight:600}
.cons-ref-table .td-red{color:var(--red);font-weight:600}
.cons-ref-table .td-pass{background:rgba(0,200,83,0.05)}
.cons-ref-table .td-fail{background:rgba(255,23,68,0.05)}
.cons-rules-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:10px}
.cons-rule{padding:12px;border-radius:var(--radius-sm);background:var(--bg2);border:1px solid var(--border)}
.cons-rule.pass{border-left:2px solid var(--green)}
.cons-rule.fail{border-left:2px solid var(--red)}
.cons-rule-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.cons-rule-status{font-size:16px}
.cons-rule-desc{font-size:10px;color:var(--text3);line-height:1.3}
.cons-projection{font-size:11px;color:var(--text3)}
.cons-projection .green{color:var(--green)}
.cons-projection .red{color:var(--red)}
.cons-projection .gold{color:var(--gold)}
.cons-summary{padding:10px;border-radius:var(--radius-sm);background:var(--bg2);border:1px solid var(--border);font-size:11px;color:var(--text2);text-align:center}
.days-table-wrap{overflow-x:auto;border-radius:var(--radius-sm);border:1px solid var(--border)}
.days-table{width:100%;border-collapse:collapse;font-size:11px}
.days-table th{padding:8px 10px;text-align:left;font-weight:600;color:var(--text2);font-size:9px;text-transform:uppercase;letter-spacing:0.4px;background:var(--bg2);border-bottom:1px solid var(--border)}
.days-table td{padding:8px 10px;border-bottom:1px solid var(--border);font-size:11px}
.psych-section{margin-top:14px;padding:16px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border)}
.psych-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:6px}
.psych-card{padding:10px;border-radius:var(--radius-sm);background:var(--bg2);border:1px solid var(--border);text-align:center}
.psych-card.psych-good{border-left:2px solid var(--green)}
.psych-card.psych-bad{border-left:2px solid var(--red)}
.psych-emoji{font-size:18px;margin-bottom:3px}
.psych-name{font-size:10px;font-weight:600;margin-bottom:2px}
.psych-count{font-size:16px;font-weight:700}
.psych-pnl{font-size:10px;color:var(--text3)}
.psych-wr{font-size:9px;color:var(--text3)}

/* ========== WEEKLY REVIEW ========== */
.weekly-section{display:none}
.weekly-section.active{display:block}
.weekly-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.weekly-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px}
.weekly-card{padding:16px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border)}
.weekly-card.weekly-win{border-left:2px solid var(--green)}
.weekly-card.weekly-loss{border-left:2px solid var(--red)}
.weekly-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.weekly-week{font-size:13px;font-weight:700}
.weekly-pnl{font-size:14px;font-weight:700}
.weekly-pnl.green{color:var(--green)}
.weekly-pnl.red{color:var(--red)}
.weekly-stats-row{display:flex;gap:10px;font-size:10px;color:var(--text3);flex-wrap:wrap}
.weekly-best-worst{font-size:10px;color:var(--text2);margin-top:4px}
.weekly-lessons{margin-top:6px;padding:8px;border-radius:5px;background:var(--bg2);border:1px solid var(--border)}
.weekly-lessons ul{margin:0;padding-left:14px}
.weekly-lessons li{font-size:10px;color:var(--text3);margin-bottom:2px}

/* ========== SIMULATOR ========== */
.simulator-section{display:none}
.simulator-section.active{display:block}
.sim-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.sim-header select{padding:8px 12px;border-radius:var(--radius-xs);border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:12px;font-family:inherit;outline:none;cursor:pointer;min-width:180px}
.sim-header select:focus{border-color:var(--sky)}
.sim-results{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.sim-card{padding:16px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border)}
.sim-card .sc-label{font-size:10px;font-weight:500;color:var(--text3);margin-bottom:3px;text-transform:uppercase;letter-spacing:0.4px}
.sim-card .sc-value{font-size:20px;font-weight:800}
.sim-card .sc-bar{height:5px;border-radius:3px;background:var(--bg2);margin-top:6px;overflow:hidden}
.sim-card .sc-bar-fill{height:100%;border-radius:3px;transition:width 0.5s ease}
.sc-pass{color:var(--green)!important}
.sc-fail{color:var(--red)!important}
.sc-warn{color:var(--gold)!important}

/* ========== CHALLENGE ========== */
.challenge-section{display:none}
.challenge-section.active{display:block}
.challenge-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:10px}
.challenge-month-label{font-size:12px;color:var(--text3);font-weight:500}
.challenge-status{font-size:11px;font-weight:600;padding:3px 10px;border-radius:5px}
.challenge-score-circle{display:flex;align-items:center;justify-content:center;margin-bottom:16px;position:relative}
.challenge-ring{position:relative;width:140px;height:140px}
.challenge-score-text{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.challenge-score-num{font-size:32px;font-weight:800;letter-spacing:-0.02em}
.challenge-score-label{font-size:10px;color:var(--text3);font-weight:500}
.challenge-metrics{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
.challenge-metric{padding:12px;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border)}
.ch-metric-label{font-size:10px;color:var(--text3);margin-bottom:4px;font-weight:500}
.ch-metric-bar{height:5px;border-radius:3px;background:var(--bg2);overflow:hidden;margin-bottom:4px}
.ch-metric-fill{height:100%;border-radius:3px;transition:width 0.5s ease}
.ch-metric-fill.green{background:var(--green)}
.ch-metric-fill.gold{background:var(--gold)}
.ch-metric-fill.blue{background:var(--sky2)}
.ch-metric-stats{display:flex;justify-content:space-between;font-size:10px;color:var(--text2)}
.ch-metric-stats span:first-child{color:var(--text)}
.challenge-badges{padding:14px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);margin-bottom:14px}
.ch-badge-title{font-size:12px;font-weight:600;margin-bottom:8px}
.ch-badges-row{display:flex;gap:6px;flex-wrap:wrap}
.ch-badge{display:inline-flex;align-items:center;gap:3px;padding:5px 10px;border-radius:16px;font-size:11px;font-weight:600;background:var(--bg2);border:1px solid var(--border);color:var(--text);transition:var(--transition);white-space:nowrap}
.ch-badge.earned{background:rgba(245,166,35,0.08);border-color:rgba(245,166,35,0.2)}
.ch-badge.empty{opacity:0.35;font-size:11px;font-weight:400;width:100%;border-radius:var(--radius-sm);white-space:normal}
.challenge-history{padding:14px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border)}
.ch-history-title{font-size:12px;font-weight:600;margin-bottom:8px}
.ch-history-list{display:flex;flex-direction:column;gap:5px}
.ch-history-item{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:var(--radius-xs);background:var(--bg2);border:1px solid var(--border);cursor:pointer}
.ch-history-item:hover{background:var(--glass)}
.ch-history-month{font-size:11px;font-weight:600}
.ch-history-score{font-size:12px;font-weight:700}
.ch-history-badges{font-size:13px}

/* ========== ANALYSIS CALENDAR ========== */
.analysis-section{display:none}
.analysis-section.active{display:block}
.analysis-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.analysis-nav{display:flex;align-items:center;gap:6px}
.analysis-nav button{padding:5px 10px;border:none;border-radius:5px;background:var(--glass);color:var(--text2);font-size:12px;cursor:pointer;transition:var(--transition);font-family:inherit}
.analysis-nav button:hover{background:var(--glass2);color:var(--text)}
.analysis-nav span{font-size:13px;font-weight:600}
.analysis-calendar{overflow-x:auto}
.analysis-cal-table{width:100%;border-collapse:separate;border-spacing:2px;table-layout:fixed}
.analysis-cal-table th{padding:6px 3px;text-align:center;font-size:9px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:0.8px;border:none;background:transparent}
.analysis-cal-table td{padding:0;text-align:center;vertical-align:top;border:none;height:70px;font-size:10px;cursor:pointer;border-radius:8px;transition:all 0.15s ease;background:var(--bg2)}
.analysis-cal-table td:hover{background:var(--glass)}
.analysis-cal-table td.ac-empty{background:transparent;cursor:default}
.analysis-cal-table td.ac-has-data{background:var(--surface);border:1px solid var(--border)}
.analysis-cal-table td.ac-has-data:hover{border-color:var(--sky)}
.analysis-cal-table td.ac-today{background:rgba(41,98,255,0.06);border:1px solid rgba(41,98,255,0.2)!important}
.ac-day{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:4px;gap:1px}
.ac-day-num{font-size:14px;font-weight:700;line-height:1.1}
.ac-badge{font-size:6px;padding:1px 4px;border-radius:6px;font-weight:700;background:var(--sky);color:#fff;margin-left:3px;vertical-align:middle}
.ac-pnl{font-size:9px;font-weight:700;line-height:1.3}
.ac-pnl-plus{color:var(--green)}
.ac-pnl-minus{color:var(--red)}
.analysis-detail{padding:16px;border-radius:10px;background:var(--surface);border:1px solid var(--border);margin-top:14px;min-height:60px}
.analysis-detail h4{font-size:14px;font-weight:700;margin-bottom:10px;display:flex;align-items:center;gap:6px}
.ad-trade{display:flex;gap:8px;align-items:center;padding:8px 12px;background:var(--bg2);border-radius:8px;margin-bottom:5px;font-size:11px}
.ad-trade-pair{font-weight:700;min-width:65px}
.ad-trade-dir{font-size:9px;padding:1px 6px;border-radius:3px;font-weight:600}
.ad-trade-dir.buy{background:rgba(0,200,83,0.1);color:var(--green)}
.ad-trade-dir.sell{background:rgba(255,23,68,0.1);color:var(--red)}
.ad-trade-meta{display:flex;gap:10px;color:var(--text2);font-size:10px;flex-wrap:wrap}
.ad-trade-pnl{font-weight:700;margin-left:auto;font-size:12px}

/* ========== CARD (generic) ========== */
.card{padding:20px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border)}

/* ========== ADMIN ========== */
.admin-section{display:none}
.admin-section.active{display:block}
.admin-tabs{display:flex;gap:3px;margin-bottom:14px;padding:3px;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);overflow-x:auto}
.admin-subtab{padding:6px 14px;border:none;border-radius:5px;background:transparent;color:var(--text3);font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;white-space:nowrap;transition:all var(--transition)}
.admin-subtab.active{background:var(--gold);color:#0a0b0d}
.admin-subtab:hover:not(.active){color:var(--text);background:var(--glass)}
.astab{display:none}
.astab:first-of-type{display:block}
.admin-title{font-size:14px;font-weight:700;margin-bottom:10px}
.admin-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;flex-wrap:wrap;gap:6px}
.admin-count{font-size:11px;color:var(--text3)}
.admin-table-wrap{overflow-x:auto;border-radius:var(--radius-sm);border:1px solid var(--border)}
.admin-table{width:100%;border-collapse:collapse;font-size:11px}
.admin-table th{padding:8px 10px;text-align:left;font-weight:600;color:var(--text2);font-size:9px;text-transform:uppercase;letter-spacing:0.4px;background:var(--bg2);border-bottom:1px solid var(--border)}
.admin-table td{padding:8px 10px;border-bottom:1px solid var(--border);font-size:11px}
.admin-table tbody tr:hover td{background:var(--glass)}
.admin-table tbody tr:last-child td{border-bottom:none}
.admin-nav{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;border-bottom:1px solid var(--border);background:rgba(11,13,17,0.9);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);position:sticky;top:0;z-index:100;gap:10px}
.admin-nav .logo{font-size:15px;gap:6px}
.admin-nav .logo .logo-accent{color:var(--gold)}
.admin-nav-right{display:flex;align-items:center;gap:6px;flex-shrink:0}
.admin-nav-right .nav-email{font-size:11px;color:var(--text3)}
.admin-nav-right .nav-link{color:var(--text2);text-decoration:none;font-size:11px;transition:var(--transition)}
.admin-nav-right .nav-link:hover{color:var(--text)}

/* ========== ADMIN WELCOME ========== */
.admin-welcome{text-align:center;padding:60px 20px}
.admin-welcome h2{font-size:22px;margin-bottom:6px;color:var(--text)}
.admin-welcome p{color:var(--text3);margin-bottom:20px;font-size:13px}

/* ========== ADMIN ENTRY FORM ========== */
.entry-form{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.entry-form .full-width{grid-column:1/-1}
.entry-form label{display:block;font-size:10px;font-weight:500;color:var(--text2);margin-bottom:3px;text-transform:uppercase;letter-spacing:0.4px}
.entry-form select,.entry-form input,.entry-form textarea{width:100%;padding:8px 10px;border-radius:var(--radius-xs);border:1px solid var(--border);background:var(--bg2);color:var(--text);font-size:12px;font-family:inherit;outline:none;transition:var(--transition);box-sizing:border-box}
.entry-form select:focus,.entry-form input:focus,.entry-form textarea:focus{border-color:var(--sky);box-shadow:0 0 0 2px rgba(41,98,255,0.1)}
.entry-form textarea{resize:vertical;min-height:50px}
.setup-grid{display:flex;flex-wrap:wrap;gap:3px}
.setup-grid label{display:flex;align-items:center;gap:3px;font-size:9px;font-weight:400;text-transform:none;letter-spacing:0;color:var(--text3);cursor:pointer;padding:3px 6px;border-radius:3px;background:var(--glass);border:1px solid transparent;transition:var(--transition)}
.setup-grid label:hover{border-color:var(--border);color:var(--text2)}
.setup-grid input[type=checkbox]{accent-color:var(--sky)}
.img-upload-row{display:flex;flex-direction:column}
.image-preview{display:none;margin-top:3px;max-width:120px;border-radius:5px;overflow:hidden;border:1px solid var(--border)}
.image-preview img{width:100%;display:block;border-radius:5px}
.paste-zone{margin-top:3px;padding:8px;border:1px dashed var(--border);border-radius:6px;text-align:center;font-size:9px;color:var(--text3);cursor:pointer;background:var(--glass);transition:var(--transition)}
.paste-zone:hover{border-color:var(--text3);color:var(--text2)}
.paste-zone a{color:var(--sky2);text-decoration:none}

/* ========== ADMIN ENTRY CARDS ========== */
.entry-card{padding:14px;border-radius:var(--radius-sm);background:var(--bg2);border:1px solid var(--border);margin-bottom:8px;transition:var(--transition)}
.entry-card:hover{border-color:var(--border2)}
.entry-card.featured{border-left:2px solid var(--gold)}
.entry-card.compact{border-left:2px solid transparent}
.entry-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:11px}
.entry-pair{font-weight:700;font-size:12px}
.entry-direction{font-size:10px;font-weight:600;padding:1px 6px;border-radius:3px}
.entry-direction.bullish{background:rgba(0,200,83,0.08);color:var(--green)}
.entry-direction.bearish{background:rgba(255,23,68,0.08);color:var(--red)}
.entry-meta{font-size:10px;color:var(--text3)}
.entry-images{display:flex;gap:5px;flex-wrap:wrap;margin:4px 0}
.entry-images .img-wrap{flex:1;min-width:70px;max-width:100px}
.entry-images.featured .img-wrap{flex:1;min-width:140px;max-width:100%}
.entry-images .img-wrap img{width:100%;border-radius:5px;display:block;max-height:50px;object-fit:cover}
.entry-images.featured .img-wrap img{max-height:none}
.entry-images .img-label{font-size:9px;color:var(--text3);margin-bottom:1px}
.entry-setup{font-size:10px;color:var(--text3);margin:3px 0}
.entry-notes{font-size:11px;color:var(--text2);line-height:1.4;margin:3px 0}
.entry-actions{display:flex;gap:5px;margin-top:4px}
.older-toggle{font-size:11px;color:var(--text3);cursor:pointer;padding:6px;user-select:none}
.older-toggle:hover{color:var(--text2)}
.older-entries{padding:6px 0}

@media(max-width:768px){
  .entry-form{grid-template-columns:1fr}
  .entry-images.featured .img-wrap{min-width:100%}
  .entry-images .img-wrap{max-width:100%}
}

/* ========== CALC DISPLAY ========== */
.calc-display{padding:6px 10px;border-radius:var(--radius-xs);background:var(--bg2);border:1px solid var(--border);font-size:11px;color:var(--text2);margin-bottom:6px}

/* ========== CHALLENGE FIRM SELECT ========== */
.challenge-firm-select{display:flex;align-items:center;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.challenge-firm-select label{font-size:11px;color:var(--text3);font-weight:500}
.challenge-firm-select select{padding:6px 10px;border-radius:var(--radius-xs);border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:11px;font-family:inherit;outline:none;cursor:pointer}
.challenge-firm-select select:focus{border-color:var(--sky)}

/* ========== TOAST ========== */
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(70px);padding:10px 18px;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border2);color:var(--text);font-size:12px;font-weight:500;z-index:2000;opacity:0;transition:all 0.3s ease;pointer-events:none;white-space:nowrap;max-width:90vw;overflow:hidden;text-overflow:ellipsis}
.toast.active{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}
.toast.success{border-color:rgba(0,200,83,0.25)}
.toast.info{border-color:rgba(41,98,255,0.25)}

/* ========== FOOTER ========== */
footer{padding:16px 20px;border-top:1px solid var(--border);text-align:center;position:relative;z-index:1}
.footer-links{display:flex;align-items:center;justify-content:center;gap:3px;font-size:11px;color:var(--text3)}
.footer-links a{color:var(--text3);text-decoration:none;transition:var(--transition)}
.footer-links a:hover{color:var(--sky2)}
.footer-links .sep{color:var(--text3);margin:0 3px}

/* ========== RESULT BADGE ========== */
.result-badge{display:inline-block;padding:1px 6px;border-radius:8px;font-size:9px;font-weight:700;line-height:1.3}
.result-win{background:rgba(0,200,83,0.12);color:var(--green)}
.result-loss{background:rgba(255,23,68,0.12);color:var(--red)}
.result-breakeven{background:rgba(255,193,7,0.12);color:#ffc107}

/* ========== SHARE STATS CARD ========== */
.stats-card-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.8);z-index:3000;display:none;align-items:center;justify-content:center;padding:20px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}
.stats-card-overlay.active{display:flex}
.stats-card-content{background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);padding:20px;width:100%;max-width:380px;box-shadow:var(--shadow)}
.stats-card-header{text-align:center;margin-bottom:14px}
.stats-card-title{font-size:15px;font-weight:700}
.stats-card-subtitle{font-size:10px;color:var(--text3)}
.stats-card-body{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
.stats-card-row{grid-column:1/-1;display:grid;grid-template-columns:1fr 1fr;gap:8px}
.stats-card-item{text-align:center;padding:8px;border-radius:var(--radius-xs);background:var(--bg2);border:1px solid var(--border)}
.stats-card-label{font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:0.4px}
.stats-card-value{font-size:16px;font-weight:700}
.stats-card-value.blue{color:var(--sky2)}
.stats-card-value.gold{color:var(--gold)}
.stats-card-value.green{color:var(--green)}
.stats-card-balance{grid-column:1/-1;padding:10px;border-radius:var(--radius-xs);background:var(--bg2);border:1px solid var(--border)}
.stats-card-balance-label{font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:0.4px;margin-bottom:3px}
.stats-card-bar{height:6px;border-radius:3px;background:var(--border);overflow:hidden}
.stats-card-bar-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--green),var(--sky2));transition:width 0.5s ease}
.stats-card-footer{display:flex;justify-content:center;gap:6px;margin-top:6px}

/* ========== LIGHT MODE ========== */
body.light-mode{--bg:#f0f2f5;--bg2:#e4e6eb;--bg3:#d8dae0;--surface:#fff;--surface2:#f4f5f7;--border:rgba(0,0,0,0.06);--border2:rgba(0,0,0,0.1);--text:#1a1d26;--text2:#5c6170;--text3:#8a8fa0;--glass:rgba(0,0,0,0.02);--glass2:rgba(0,0,0,0.04);--shadow:0 2px 12px rgba(0,0,0,0.06)}
body.light-mode::before,body.light-mode::after{display:none}
body.light-mode .logo-accent{background:linear-gradient(135deg,#2563eb,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
body.light-mode .app-header{border-bottom-color:var(--border)}
body.light-mode .app-user span{color:var(--text2)}
body.light-mode .btn-logout{background:var(--glass);color:var(--text2)}
body.light-mode .btn-logout:hover{background:rgba(239,68,68,0.06);color:#ef4444}
body.light-mode .btn-theme{background:var(--glass);color:var(--text2)}
body.light-mode .btn-theme:hover{background:var(--glass2);color:var(--text)}
body.light-mode .btn-cancel{background:rgba(239,68,68,0.05);color:#ef4444;border-color:rgba(239,68,68,0.1)}
body.light-mode .modal-overlay{background:rgba(0,0,0,0.3)}
body.light-mode .modal{background:var(--surface);border-color:var(--border2)}
body.light-mode .modal h2{color:var(--text)}
body.light-mode .modal label{color:var(--text2)}
body.light-mode .modal input,body.light-mode .modal select,body.light-mode .modal textarea{background:var(--bg2);border-color:var(--border);color:var(--text)}
body.light-mode .stat-card{background:var(--surface);border-color:var(--border)}
body.light-mode .stat-label{color:var(--text2)}
body.light-mode .stat-value.white{color:var(--text)}
body.light-mode .quick-entry{background:var(--surface);border-color:var(--border)}
body.light-mode .qe-select,body.light-mode .qe-input{background:var(--bg2);border-color:var(--border);color:var(--text)}
body.light-mode .qe-dir-btn{background:var(--bg2);border-color:var(--border);color:var(--text2)}
body.light-mode .open-trades-bar{background:rgba(37,99,235,0.03);border-color:rgba(37,99,235,0.08)}
body.light-mode .ot-count{background:rgba(37,99,235,0.06)}
body.light-mode .signal-card,.light-mode .entry-card{background:var(--bg2);border-color:var(--border)}
body.light-mode .signal-pair{color:var(--text)}
body.light-mode .signals-inline{background:var(--surface);border-color:var(--border)}
body.light-mode .sib-title{color:var(--text)}
body.light-mode .signal-card .btn-take-trade{background:linear-gradient(135deg,#2563eb,#3b82f6)}
body.light-mode .trade-section{background:var(--surface);border-color:var(--border)}
body.light-mode .trade-table-wrap{border-color:var(--border)}
body.light-mode .trade-table th{background:var(--bg2);color:var(--text2);border-bottom-color:var(--border)}
body.light-mode .trade-table td{color:var(--text);border-bottom-color:var(--border)}
body.light-mode .filter-select{background:var(--surface);border-color:var(--border);color:var(--text)}
body.light-mode .tabs{background:var(--surface);border-color:var(--border)}
body.light-mode .tab.active{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff}
body.light-mode .chart-section{background:var(--surface);border-color:var(--border)}
body.light-mode .chart-header h3{color:var(--text)}
body.light-mode .cons-rule{background:var(--bg2);border-color:var(--border)}
body.light-mode .days-consistency{background:var(--surface);border-color:var(--border)}
body.light-mode .days-table-wrap{border-color:var(--border)}
body.light-mode .days-table th{background:var(--bg2);color:var(--text2);border-bottom-color:var(--border)}
body.light-mode .days-table td{border-bottom-color:var(--border)}
body.light-mode .psych-section{background:var(--surface);border-color:var(--border)}
body.light-mode .psych-card{background:var(--bg2);border-color:var(--border)}
body.light-mode .weekly-card{background:var(--surface);border-color:var(--border)}
body.light-mode .weekly-week{color:var(--text)}
body.light-mode .sim-card{background:var(--surface);border-color:var(--border)}
body.light-mode .sim-header select{background:var(--surface);border-color:var(--border);color:var(--text)}
body.light-mode .challenge-metric{background:var(--surface);border-color:var(--border)}
body.light-mode .challenge-badges{background:var(--surface);border-color:var(--border)}
body.light-mode .challenge-history{background:var(--surface);border-color:var(--border)}
body.light-mode .ch-history-item{background:var(--bg2);border-color:var(--border)}
body.light-mode .analysis-cal-table td{background:var(--surface)}
body.light-mode .analysis-cal-table td.ac-has-data{background:rgba(0,200,83,0.02)}
body.light-mode .analysis-cal-table td.ac-today{background:rgba(37,99,235,0.04);border-color:rgba(37,99,235,0.15)!important}
body.light-mode .analysis-detail{background:var(--bg2);border-color:var(--border)}
body.light-mode .admin-table-wrap{border-color:var(--border)}
body.light-mode .admin-table th{background:var(--bg2);color:var(--text2);border-bottom-color:var(--border)}
body.light-mode .admin-table td{border-bottom-color:var(--border)}
body.light-mode .admin-tabs{background:var(--surface);border-color:var(--border)}
body.light-mode .footer-links{color:var(--text3)}
body.light-mode .footer-links a{color:var(--text3)}
body.light-mode .footer-links a:hover{color:#2563eb}
body.light-mode .stats-card-content{background:var(--surface);border-color:var(--border2)}
body.light-mode .stats-card-item{background:var(--bg2);border-color:var(--border)}
body.light-mode .stats-card-balance{background:var(--bg2);border-color:var(--border)}
body.light-mode .screenshot-modal-content{background:var(--surface);border-color:var(--border2)}
body.light-mode .screenshot-close{background:var(--surface2);border-color:var(--border2);color:var(--text2)}
body.light-mode .btn-outline{color:#2563eb;border-color:rgba(37,99,235,0.25)}
body.light-mode ::-webkit-scrollbar-thumb{background:rgba(0,0,0,0.08)}

/* ========== RESPONSIVE ========== */
@media(max-width:900px){
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .days-stats{grid-template-columns:repeat(2,1fr)}
  .cons-rules-grid{grid-template-columns:1fr}
  .sim-results{grid-template-columns:1fr}
}
@media(max-width:600px){
  .app-main{padding:12px 12px 36px}
  .app-header{padding:8px 12px}
  .stats-grid{gap:6px}
  .stat-value{font-size:20px}
  .stat-card{padding:12px}
  .toolbar{flex-direction:column;align-items:stretch}
  .toolbar-left{flex-wrap:wrap}
  .toolbar-left .btn,.toolbar-left .filter-select{flex:1;min-width:0}
  .toolbar-right{display:flex;flex-wrap:wrap;gap:4px;width:100%}
  .toolbar-right .btn{flex:1;min-width:0}
  .form-row{grid-template-columns:1fr}
  .form-actions{flex-direction:column}
  .tabs{gap:2px;padding:2px}
  .tab{padding:5px 8px;font-size:11px}
  .chart-container{height:150px}
  .days-stats{grid-template-columns:1fr 1fr}
  .challenge-score-num{font-size:26px}
  .challenge-ring{width:120px;height:120px}
  .challenge-metrics{grid-template-columns:1fr}
  .weekly-grid{grid-template-columns:1fr}
  .psych-grid{grid-template-columns:repeat(2,1fr)}
  .analysis-cal-table td{height:55px;font-size:9px}
  .ac-day-num{font-size:12px}
  .modal{padding:18px;margin:8px}
  .stats-card-content{padding:16px}
  .footer-links{font-size:10px;flex-wrap:wrap}
  .admin-table{min-width:550px}
  .admin-tabs .admin-subtab{font-size:10px;padding:6px 8px}
}
