:root{--bg:#090b0f;--bg2:#0e1117;--bg3:#141820;--bg4:#1a1f2e;--border:rgba(255,255,255,0.07);--border2:rgba(255,255,255,0.13);--text:#f0f2f7;--text2:#8b93a8;--text3:#4a5268;--ac:#00d68f;--ac2:#00b87a;--adim:rgba(0,214,143,0.09);--adim2:rgba(0,214,143,0.18);--red:#ff4d6d;--rdim:rgba(255,77,109,0.11);--amber:#ffb347;--amdim:rgba(255,179,71,0.11);--blue:#4d9fff;--bdim:rgba(77,159,255,0.11);--purple:#9d7fff;--sw:215px;--fd:'Syne',sans-serif;--fb:'Instrument Sans',sans-serif;--fm:'JetBrains Mono',monospace}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:var(--fb)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border2)}.app{display:flex;height:100vh;width:100vw;overflow:hidden}.sidebar{width:var(--sw);min-width:var(--sw);background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100vh;flex-shrink:0;overflow-y:auto}.main{flex:1;overflow:hidden;display:flex;flex-direction:column;height:100vh}.page{display:none;padding:24px 28px;width:100%;box-sizing:border-box}.page.on{display:block}.logo{padding:16px 15px 12px;border-bottom:1px solid var(--border)}.logo-row{display:flex;align-items:center;gap:9px}.logo-ico{width:28px;height:28px;background:var(--ac);border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.logo-ico svg{width:14px;height:14px;fill:none;stroke:#000;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}.logo-name{font-family:var(--fd);font-size:15px;font-weight:800}.logo-sub{font-size:8px;color:var(--text3);letter-spacing:.12em;text-transform:uppercase;margin-top:1px}.acc-sw{padding:9px 10px;border-bottom:1px solid var(--border)}.acc-lbl{font-size:8px;color:var(--text3);letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px;font-family:var(--fd)}.acc-btn{display:flex;align-items:center;gap:7px;padding:6px 8px;border-radius:6px;cursor:pointer;font-size:11px;font-weight:500;color:var(--text2);border:none;background:none;width:100%;margin-bottom:2px;transition:all .15s}.acc-btn:hover{background:var(--bg3);color:var(--text)}.acc-btn.on{background:var(--adim2);color:var(--ac)}.acc-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.acc-ct{margin-left:auto;font-size:9px;font-family:var(--fm);color:var(--text3)}.acc-btn.on .acc-ct{color:var(--ac)}.nav{padding:8px 8px;flex:1;overflow-y:auto}.nsec{font-size:8px;color:var(--text3);letter-spacing:.12em;text-transform:uppercase;padding:9px 9px 5px;font-family:var(--fd)}.ni{display:flex;align-items:center;gap:8px;padding:7px 9px;border-radius:6px;cursor:pointer;color:var(--text2);font-size:12px;font-weight:500;transition:all .15s;margin-bottom:2px;border:none;background:none;width:100%;text-align:left}.ni:hover{background:var(--bg3);color:var(--text)}.ni.on{background:var(--adim2);color:var(--ac)}[data-theme="light"] .ni.on,[data-theme="cream"] .ni.on,[data-theme="sky"] .ni.on{color:#000}.ni svg{width:15px;height:15px;flex-shrink:0;opacity:.6}.ni.on svg{opacity:1}.sbot{padding:10px;border-top:1px solid var(--border)}.ucard{display:flex;align-items:center;gap:8px;padding:8px;border-radius:7px;background:var(--bg3);cursor:pointer}.uav{width:36px;height:36px;border-radius:50%;background:var(--ac);display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:13px;font-weight:700;color:#000;flex-shrink:0;border:2px solid transparent;transition:all .3s;position:relative}.av-img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}.topbar{height:50px;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 22px;gap:10px;flex-shrink:0}.tb-title{font-family:var(--fd);font-size:13px;font-weight:700;flex:1}.tilt-pill{display:flex;align-items:center;gap:5px;padding:4px 11px;border-radius:20px;font-size:10px;font-weight:600;font-family:var(--fm);border:1px solid transparent}.tp-safe{background:var(--adim);color:var(--ac);border-color:rgba(0,214,143,.2)}.tp-warn{background:var(--amdim);color:var(--amber);border-color:rgba(255,179,71,.2)}.tp-danger{background:var(--rdim);color:var(--red);border-color:rgba(255,77,109,.2)}.tp-dot{width:5px;height:5px;border-radius:50%;background:currentColor}.tbtn{padding:6px 14px;border-radius:7px;font-size:11px;font-weight:700;cursor:pointer;font-family:var(--fd);border:none;transition:all .15s;letter-spacing:.02em}.tbtn-pri{background:var(--ac);color:#000}.tbtn-pri:hover{background:var(--ac2);transform:scale(1.02)}.tbtn-sec{background:var(--bg3);color:var(--text2);border:1px solid var(--border)}.tbtn-sec:hover{background:var(--bg4);color:var(--text)}.g{display:grid;gap:12px}.g2{grid-template-columns:1fr 1fr}.g3{grid-template-columns:1fr 1fr 1fr}.g4{grid-template-columns:1fr 1fr 1fr 1fr}.g13{grid-template-columns:1fr 2.2fr}.g12{grid-template-columns:1fr 2fr}.card{background:var(--bg2);border:1px solid var(--border);border-radius:11px;padding:16px}.ct{font-family:var(--fd);font-size:9px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);margin-bottom:12px}.mc{background:var(--bg2);border:1px solid var(--border);border-radius:11px;padding:16px}.ml{font-size:9px;color:var(--text3);letter-spacing:.1em;text-transform:uppercase;font-family:var(--fd);margin-bottom:4px}.mv{font-family:var(--fm);font-size:22px;font-weight:400;line-height:1}.ms{font-size:10px;color:var(--text3);margin-top:4px}.mu{color:var(--ac)}.md{color:var(--red)}.mw{color:var(--amber)}.tm-track{height:7px;border-radius:4px;background:linear-gradient(to right,var(--red),var(--amber) 45%,var(--ac));position:relative;margin:8px 0}.tm-needle{position:absolute;top:-7px;width:21px;height:21px;border-radius:50%;background:var(--bg);border:2px solid var(--text);transform:translateX(-50%);transition:left .6s cubic-bezier(.34,1.56,.64,1);box-shadow:0 0 0 3px rgba(0,0,0,.5)}.tm-labels{display:flex;justify-content:space-between;font-size:9px;color:var(--text3)}.tm-big{font-family:var(--fm);font-size:36px;font-weight:300;text-align:center;line-height:1;margin:5px 0}.sl-row{margin-bottom:12px}.sl-head{display:flex;justify-content:space-between;margin-bottom:5px}.sl-name{font-size:12px;color:var(--text2)}.sl-val{font-family:var(--fm);font-size:14px;font-weight:500}input[type=range]{-webkit-appearance:none;width:100%;height:4px;border-radius:2px;background:var(--bg4);outline:none;cursor:pointer}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--ac);cursor:pointer}.emo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.emo-opt{border:1px solid var(--border);border-radius:8px;padding:9px 5px;text-align:center;cursor:pointer;background:var(--bg3);transition:all .15s}.emo-opt:hover{border-color:var(--border2)}.emo-opt.on{border-color:var(--ac);background:var(--adim2)}.emo-opt.on.neg{border-color:var(--red);background:var(--rdim)}.emo-opt.on.warn{border-color:var(--amber);background:var(--amdim)}.emo-ico{font-size:18px;display:block;margin-bottom:2px}.emo-name{font-size:9px;color:var(--text2);font-weight:500;line-height:1.2}.emo-opt.on .emo-name{color:var(--ac)}.emo-opt.on.neg .emo-name{color:var(--red)}.emo-opt.on.warn .emo-name{color:var(--amber)}.fg{margin-bottom:11px}.fl{font-size:9px;color:var(--text3);letter-spacing:.07em;text-transform:uppercase;margin-bottom:5px;display:block;font-family:var(--fd)}input[type=text],input[type=number],input[type=date],input[type=email],select,textarea{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:7px;padding:8px 11px;font-size:12px;color:var(--text);font-family:var(--fb);outline:none;transition:border-color .15s}input:focus,select:focus,textarea:focus{border-color:var(--ac)}select option{background:var(--bg2)}.fr{display:grid;gap:9px}.fr2{grid-template-columns:1fr 1fr}.fr3{grid-template-columns:1fr 1fr 1fr}.btn{padding:8px 16px;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;border:none;font-family:var(--fb)}.btn-pri{background:var(--ac);color:#000}.btn-pri:hover{background:var(--ac2)}.btn-sec{background:var(--bg3);color:var(--text2);border:1px solid var(--border)}.btn-sec:hover{background:var(--bg4);color:var(--text)}.btn-red{background:var(--rdim);color:var(--red);border:1px solid rgba(255,77,109,.2)}.btn-sm{padding:5px 10px;font-size:10px}.btn-full{width:100%;text-align:center}.btn-grp{display:flex;gap:7px}.alert{border-radius:8px;padding:10px 13px;font-size:12px;line-height:1.6;margin-bottom:9px;border:1px solid transparent}.ar{background:var(--rdim);border-color:rgba(255,77,109,.22);color:#ffaab8}.aa{background:var(--amdim);border-color:rgba(255,179,71,.22);color:#ffd699}.ag{background:var(--adim);border-color:rgba(0,214,143,.22);color:var(--ac)}.ab{background:var(--bdim);border-color:rgba(77,159,255,.22);color:var(--blue)}.bw{display:inline-flex;align-items:center;padding:2px 7px;border-radius:20px;font-size:9px;font-weight:600;font-family:var(--fm)}.bwin{background:rgba(0,214,143,.12);color:var(--ac)}.bloss{background:var(--rdim);color:var(--red)}.bbe{background:var(--bg4);color:var(--text3)}.blong{background:var(--adim);color:var(--ac)}.bshort{background:var(--rdim);color:var(--red)}.tw{overflow-x:auto}table{width:100%;border-collapse:collapse;min-width:480px}th{text-align:left;padding:6px 10px;font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border);font-family:var(--fd);font-weight:600}td{padding:8px 10px;font-size:11px;color:var(--text2);border-bottom:1px solid var(--border)}tr:hover td{background:var(--bg3)}tr:last-child td{border-bottom:none}.chip{font-size:9px;padding:2px 7px;border-radius:4px;font-family:var(--fm);font-weight:500;display:inline-block}.chip-e{background:var(--bdim);color:var(--blue)}.chip-c{background:var(--adim);color:var(--ac)}.chip-bad{background:var(--rdim);color:var(--red)}.chip-n{background:var(--bg4);color:var(--text3)}.isr{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);font-size:11px}.isr:last-child{border-bottom:none}.isl{color:var(--text2)}.isv{font-family:var(--fm);font-weight:500}.br-row{display:flex;align-items:center;gap:9px;margin-bottom:7px}.br-lbl{font-size:10px;color:var(--text2);width:68px;text-align:right;flex-shrink:0}.br-track{flex:1;background:var(--bg4);border-radius:3px;height:19px;overflow:hidden}.br-fill{height:100%;border-radius:3px;display:flex;align-items:center;padding-left:7px;font-size:9px;font-weight:700;font-family:var(--fm);color:#000;transition:width .5s;min-width:3px}.br-ct{font-size:9px;color:var(--text3);font-family:var(--fm);width:30px}.stl{display:flex;gap:3px;flex-wrap:wrap;padding:3px 0}.std{width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;font-family:var(--fm)}.stw{background:rgba(0,214,143,.13);color:var(--ac);border:1px solid rgba(0,214,143,.2)}.stl2{background:var(--rdim);color:var(--red);border:1px solid rgba(255,77,109,.2)}.stb{background:var(--bg4);color:var(--text3);border:1px solid var(--border)}.stag{display:inline-flex;align-items:center;padding:2px 6px;border-radius:3px;font-size:9px;font-weight:500}.slon{background:var(--bdim);color:var(--blue)}.sny{background:var(--rdim);color:var(--red)}.sas{background:rgba(157,127,255,.1);color:var(--purple)}.soth{background:var(--bg4);color:var(--text3)}.ck-item{display:flex;align-items:center;gap:9px;padding:9px 0;border-bottom:1px solid var(--border);cursor:pointer}.ck-item:last-child{border-bottom:none}.ck-box{width:16px;height:16px;border-radius:4px;border:1.5px solid var(--border2);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.ck-item.on .ck-box{background:var(--ac);border-color:var(--ac)}.ck-txt{font-size:12px;color:var(--text2);flex:1}.ck-item.on .ck-txt{color:var(--text3);text-decoration:line-through}.tog{width:36px;height:20px;border-radius:10px;background:var(--bg4);position:relative;cursor:pointer;transition:background .2s;border:none;flex-shrink:0}.tog.on{background:var(--ac)}.tknob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:left .2s}.tog.on .tknob{left:18px}.div{height:1px;background:var(--border);margin:14px 0}.ph{margin-bottom:18px}.ph1{font-family:var(--fd);font-size:18px;font-weight:800;margin-bottom:2px}.ph2{font-size:11px;color:var(--text3)}.empty{text-align:center;padding:48px 20px;color:var(--text3)}.ei{font-size:28px;margin-bottom:9px;opacity:.35}.et{font-family:var(--fd);font-size:13px;font-weight:600;color:var(--text2);margin-bottom:4px}.es{font-size:11px;line-height:1.6}.notif{position:fixed;top:16px;right:16px;background:var(--bg2);border:1px solid var(--border2);border-radius:8px;padding:10px 14px;font-size:12px;color:var(--text);box-shadow:0 8px 32px rgba(0,0,0,.5);z-index:600;transform:translateX(130%);transition:transform .3s cubic-bezier(.34,1.56,.64,1);max-width:280px;line-height:1.5}.notif.show{transform:translateX(0)}.notif-ok{border-left:3px solid var(--ac)}.notif-err{border-left:3px solid var(--red)}.notif-overtake{border-left:3px solid #ffd700;background:linear-gradient(135deg,var(--bg2),rgba(255,215,0,0.06))}.overlay{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:200;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(12px)}.big-card{background:var(--bg2);border:1px solid var(--border2);border-radius:16px;width:620px;max-width:95vw;max-height:92vh;overflow-y:auto;box-shadow:0 24px 64px rgba(0,0,0,.7)}.big-head{padding:20px 22px 0;display:flex;justify-content:space-between;align-items:flex-start}.big-body{padding:18px 22px 22px}.big-title{font-family:var(--fd);font-size:17px;font-weight:800}.big-sub{font-size:11px;color:var(--text3);margin-top:2px}.sp{display:flex;gap:4px;margin:14px 0}.sp-d{height:3px;flex:1;border-radius:2px;background:var(--bg4);transition:background .3s}.sp-d.on{background:var(--ac)}.bstep{display:none}.bstep.on{display:block}.xbtn{background:none;border:none;color:var(--text3);cursor:pointer;font-size:20px;padding:4px;line-height:1}.xbtn:hover{color:var(--text)}.so-wrap{text-align:center;padding:8px 0}.so-ico{font-size:38px;margin-bottom:12px}.so-title{font-family:var(--fd);font-size:20px;font-weight:800;color:var(--ac);margin-bottom:10px}.so-msg{font-size:13px;color:var(--text2);line-height:1.8;margin-bottom:18px}.so-box{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:14px 16px;font-size:12px;color:var(--text2);line-height:1.8;text-align:left;margin-bottom:16px}.ra-wrap{background:linear-gradient(135deg,var(--bg3),var(--bg4));border:1px solid var(--border2);border-radius:12px;padding:20px;margin-bottom:16px}.ra-title{font-family:var(--fd);font-size:14px;font-weight:700;color:var(--ac);margin-bottom:8px}.ra-statement{font-size:14px;color:var(--text);line-height:1.8;font-style:italic;padding:14px;background:rgba(0,0,0,.3);border-radius:8px;border-left:3px solid var(--ac);margin-bottom:14px}.ra-checks{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.ra-check{display:flex;align-items:center;gap:10px;cursor:pointer;padding:8px 10px;border-radius:7px;border:1px solid var(--border);transition:all .15s}.ra-check:hover{background:var(--bg3)}.ra-check.on{background:var(--adim);border-color:rgba(0,214,143,.2)}.ra-check-box{width:18px;height:18px;border-radius:4px;border:1.5px solid var(--border2);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.ra-check.on .ra-check-box{background:var(--ac);border-color:var(--ac)}.ra-check-txt{font-size:12px;color:var(--text2)}.vr-wrap{background:var(--bg3);border:1px solid var(--border);border-radius:9px;padding:13px;margin-bottom:12px}.vr-row{display:flex;align-items:center;gap:10px}.vr-btn{width:38px;height:38px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;background:var(--bg4);color:var(--text2)}.vr-btn.rec{background:var(--red);color:#fff;animation:pr 1.5s infinite}@keyframes pr{0%,100%{box-shadow:0 0 0 0 rgba(255,77,109,.4)}50%{box-shadow:0 0 0 8px rgba(255,77,109,0)}}.vr-st{font-size:11px;font-weight:500;color:var(--text2)}.vr-hint{font-size:10px;color:var(--text3);margin-top:1px}.vr-wave{display:flex;align-items:center;gap:2px;height:20px;margin-top:8px}.wbar{width:3px;border-radius:2px;background:var(--red);animation:wa .8s ease-in-out infinite}.wbar:nth-child(2){animation-delay:.1s}.wbar:nth-child(3){animation-delay:.2s}.wbar:nth-child(4){animation-delay:.3s}.wbar:nth-child(5){animation-delay:.4s}.wbar:nth-child(6){animation-delay:.3s}.wbar:nth-child(7){animation-delay:.2s}@keyframes wa{0%,100%{height:4px}50%{height:16px}}.vr-tr{font-size:11px;color:var(--text2);line-height:1.6;margin-top:8px;padding:7px;background:var(--bg);border-radius:6px;min-height:36px}.va-box{border-radius:10px;padding:14px;margin-top:10px;border:1px solid transparent}.va-safe{background:var(--adim);border-color:rgba(0,214,143,.2)}.va-warn{background:var(--amdim);border-color:rgba(255,179,71,.2)}.va-danger{background:var(--rdim);border-color:rgba(255,77,109,.2)}.va-title{font-family:var(--fd);font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}.va-msg{font-size:12px;line-height:1.6}.va-metrics{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap}.va-metric{background:rgba(0,0,0,.2);border-radius:6px;padding:6px 10px;font-size:10px;font-family:var(--fm)}.refl-q{margin-bottom:14px}.refl-lbl{font-size:12px;color:var(--text);font-weight:500;margin-bottom:7px;display:block}.refl-opts{display:flex;gap:6px;flex-wrap:wrap}.refl-opt{padding:6px 12px;border-radius:6px;border:1px solid var(--border);background:var(--bg3);font-size:11px;color:var(--text2);cursor:pointer;transition:all .15s}.refl-opt:hover{border-color:var(--border2)}.refl-opt.on{border-color:var(--ac);background:var(--adim2);color:var(--ac)}.img-drop{border:2px dashed var(--border2);border-radius:10px;padding:22px;text-align:center;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}.img-drop:hover,.img-drop:focus-within{border-color:var(--ac);background:var(--adim)}.img-drop.has-img{border-style:solid;border-color:var(--ac)}.img-preview{width:100%;max-height:180px;object-fit:contain;border-radius:7px;display:none}input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;font-size:0}.rank-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-family:var(--fd);font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.xp-bar{height:8px;border-radius:4px;background:var(--bg4);overflow:hidden;position:relative}.xp-fill{height:100%;border-radius:4px;transition:width .8s cubic-bezier(.4,0,.2,1)}.badge-card{padding:14px;background:var(--bg3);border-radius:12px;border:1px solid var(--border);display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;transition:all .2s;position:relative}.badge-card.earned{border-color:var(--ac);background:var(--adim)}.badge-card.locked{opacity:.4;filter:grayscale(.8)}.badge-card .badge-ico{font-size:28px}.badge-card .badge-name{font-size:10px;font-weight:700;color:var(--text2);font-family:var(--fd);letter-spacing:.04em}.badge-card.earned .badge-name{color:var(--ac)}.badge-new{position:absolute;top:-4px;right:-4px;background:var(--red);color:#fff;font-size:8px;font-weight:800;padding:2px 5px;border-radius:8px;font-family:var(--fd)}.lb-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:10px;background:var(--bg3);border:1px solid var(--border);transition:all .2s;margin-bottom:6px}.lb-row.me{background:var(--adim);border-color:var(--ac)}.lb-pos{font-family:var(--fm);font-size:14px;font-weight:700;min-width:28px;text-align:center}.lb-av{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;font-family:var(--fd);flex-shrink:0}@keyframes rankUp{0%{transform:scale(1)}50%{transform:scale(1.3)}100%{transform:scale(1)}}
@keyframes slideUp{from{opacity:0;transform:translateX(-50%) translateY(20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.cal-day{border-radius:7px;padding:6px 8px;min-height:62px;position:relative;cursor:default;transition:all .15s;border:1px solid transparent}.cal-day.has-trades{cursor:pointer}.cal-day.has-trades:hover{border-color:var(--border2);transform:scale(1.04)}.cal-day.cal-win{background:rgba(0,214,143,.12);border-color:rgba(0,214,143,.2)}.cal-day.cal-loss{background:rgba(255,77,109,.12);border-color:rgba(255,77,109,.2)}.cal-day.cal-be{background:rgba(255,179,71,.08);border-color:rgba(255,179,71,.15)}.cal-day.cal-today{box-shadow:0 0 0 2px var(--ac)}.cal-day-num{font-size:10px;font-weight:700;color:var(--text3);font-family:var(--fd)}.cal-day.has-trades .cal-day-num{color:var(--text2)}.cal-day-r{font-family:var(--fm);font-size:11px;font-weight:500;margin-top:4px}.cal-day-ct{font-size:9px;color:var(--text3);margin-top:1px}.inst-cats{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:12px}.ict{padding:5px 11px;border-radius:5px;font-size:10px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--bg3);color:var(--text2);transition:all .15s}.ict.on{background:var(--adim2);color:var(--ac);border-color:rgba(0,214,143,.2)}.inst-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(95px,1fr));gap:6px;margin-bottom:8px}.iopt{padding:8px;border-radius:7px;border:1px solid var(--border);cursor:pointer;background:var(--bg3);transition:all .15s;text-align:center;position:relative}.iopt .fav-star{position:absolute;top:4px;right:5px;font-size:10px;opacity:.3;transition:opacity .15s}.iopt:hover .fav-star{opacity:.8}.iopt.faved .fav-star{opacity:1}.iopt:hover{border-color:var(--border2);background:var(--bg4)}.iopt.on{border-color:var(--ac);background:var(--adim2)}.itick{font-family:var(--fm);font-size:11px;font-weight:500;color:var(--text);display:block;margin-bottom:1px}.idesc{font-size:9px;color:var(--text3);display:block}.rc-result{background:var(--bg3);border:1px solid var(--border2);border-radius:9px;padding:14px;margin-bottom:9px}.rc-big{font-family:var(--fm);font-size:24px;font-weight:400;margin-bottom:3px}.rc-lbl{font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:.07em;font-family:var(--fd)}.rr-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--border);font-size:11px}.rr-row:last-child{border-bottom:none}.rr-l{color:var(--text2)}.rr-v{font-family:var(--fm);font-weight:500}.rr-v.pos{color:var(--ac)}.rr-v.neg{color:var(--red)}.rr-v.warn{color:var(--amber)}.set-row{display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--border)}.set-row:last-child{border-bottom:none}.sr-t{font-size:12px;color:var(--text);font-weight:500}.sr-s{font-size:10px;color:var(--text3);margin-top:1px}.j-thumb{width:40px;height:28px;object-fit:cover;border-radius:4px;cursor:pointer;border:1px solid var(--border)}.chat-bubble{position:fixed;bottom:20px;right:20px;z-index:4500}@media(max-width:600px){.chat-bubble{bottom:20px;right:12px}.chat-win{bottom:80px;right:12px;width:calc(100vw - 24px);height:70vh}}.chat-toggle{width:50px;height:50px;border-radius:50%;background:var(--ac);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,214,143,.35);transition:all .2s}.chat-toggle:hover{background:var(--ac2);transform:scale(1.06)}.chat-toggle svg{width:22px;height:22px;fill:none;stroke:#000;stroke-width:2.5;stroke-linecap:round}.chat-win{position:fixed;bottom:80px;right:20px;width:360px;height:480px;background:var(--bg2);border:1px solid var(--border2);border-radius:14px;display:flex;flex-direction:column;box-shadow:0 12px 48px rgba(0,0,0,.6);z-index:4500;transform:scale(0.92) translateY(10px);opacity:0;pointer-events:none;transition:all .25s cubic-bezier(.34,1.56,.64,1);transform-origin:bottom right}.chat-win.open{transform:scale(1) translateY(0);opacity:1;pointer-events:all}.chat-head{padding:12px 15px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:9px;flex-shrink:0}.chat-av{width:30px;height:30px;border-radius:50%;background:var(--ac);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}.chat-name{font-size:12px;font-weight:700;color:var(--text)}.chat-status{font-size:10px;color:var(--ac)}.chat-msgs{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px}.chat-msg{display:flex;gap:6px;animation:msgIn .2s ease}@keyframes msgIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.chat-msg.user{flex-direction:row-reverse}.chat-bbl{max-width:250px;padding:9px 12px;border-radius:12px;font-size:12px;line-height:1.6}.chat-msg.bot .chat-bbl{background:var(--bg3);border:1px solid var(--border);color:var(--text2);border-radius:12px 12px 12px 3px}.chat-msg.user .chat-bbl{background:var(--ac);color:#000;border-radius:12px 12px 3px 12px}.chat-typing{display:flex;gap:3px;padding:9px 12px;background:var(--bg3);border-radius:12px;border:1px solid var(--border);width:fit-content}.chat-typing span{width:5px;height:5px;border-radius:50%;background:var(--text3);animation:ty .9s infinite}.chat-typing span:nth-child(2){animation-delay:.2s}.chat-typing span:nth-child(3){animation-delay:.4s}.cm-msg{display:flex;gap:8px;align-items:flex-start;animation:msgIn .22s ease;margin-bottom:2px}.cm-msg.mine .cm-bubble{background:var(--adim);border-color:var(--ac);border-radius:12px 12px 3px 12px;margin-left:auto}.cm-msg.mine{flex-direction:row-reverse}.cm-av{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;font-family:var(--fd);flex-shrink:0;border:2px solid transparent}.cm-bubble{max-width:72%;background:var(--bg3);border:1px solid var(--border);border-radius:12px 12px 12px 3px;padding:7px 11px;font-size:12px;color:var(--text);line-height:1.6}.cm-meta{font-size:9px;color:var(--text3);margin-bottom:3px;font-weight:600;letter-spacing:.02em}.cm-input-row{display:flex;gap:8px;padding:10px 12px;border-top:1px solid var(--border);align-items:center;flex-shrink:0;background:var(--bg2)}.cm-input{flex:1;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:9px 12px;font-size:12px;color:var(--text);font-family:var(--fb);resize:none;outline:none;max-height:80px}.cm-input:focus{border-color:var(--ac)}.cm-send{width:36px;height:36px;border-radius:8px;background:var(--ac);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.cm-send:hover{background:var(--ac2)}.cm-send svg{width:16px;height:16px;fill:none;stroke:#000;stroke-width:2.5;stroke-linecap:round}@keyframes ty{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-5px)}}.chat-inp-row{padding:10px;border-top:1px solid var(--border);display:flex;gap:7px;flex-shrink:0}.chat-inp{flex:1;background:var(--bg3);border:1px solid var(--border);border-radius:7px;padding:8px 10px;font-size:12px;color:var(--text);font-family:var(--fb);outline:none;resize:none;min-height:36px;max-height:80px}.chat-inp:focus{border-color:var(--ac)}.chat-send{background:var(--ac);border:none;border-radius:7px;width:36px;height:36px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.chat-send:hover{background:var(--ac2)}.chat-send svg{width:14px;height:14px;fill:none;stroke:#000;stroke-width:2.5;stroke-linecap:round}.ob{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:500;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(12px)}.ob-card{background:var(--bg2);border:1px solid var(--border2);border-radius:16px;padding:32px;width:440px;max-width:92vw;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.7)}.ob-step{display:none}.ob-step.on{display:block}.ob-prog{display:flex;gap:4px;margin-bottom:22px}.ob-pd{height:3px;flex:1;border-radius:2px;background:var(--bg4);transition:background .3s}.ob-pd.on{background:var(--ac)}.ob-h{font-family:var(--fd);font-size:20px;font-weight:800;margin-bottom:6px}.ob-p{font-size:12px;color:var(--text2);margin-bottom:20px;line-height:1.6}.ob-sn{font-size:9px;color:var(--text3);letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px;font-family:var(--fd)}.cg{display:grid;grid-template-columns:repeat(4,1fr);gap:7px;margin-bottom:20px}.co{height:30px;border-radius:6px;cursor:pointer;border:2px solid transparent;transition:all .15s;position:relative}.co.on::after{content:'✓';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#000;font-weight:800;font-size:13px}.email-note{font-size:10px;color:var(--text3);line-height:1.5;margin-top:6px;padding:8px;background:var(--bg3);border-radius:6px}@media(max-width:900px){.sidebar{width:54px;min-width:54px}.acc-lbl,.acc-btn span,.acc-ct,.nsec,.ni span,.ucard div{display:none}.ni{justify-content:center}.acc-btn{justify-content:center}.ucard{justify-content:center}}@media(max-width:768px){:root{--sw:52px}.page{padding:16px 14px}.g4{grid-template-columns:1fr 1fr}.g3{grid-template-columns:1fr 1fr}.g12{grid-template-columns:1fr}.g13{grid-template-columns:1fr}.ph1{font-size:22px}.topbar{padding:0 14px}.big-card{width:96vw;padding:20px 16px}.ob-card{padding:24px 18px}}@media(max-width:600px){:root{--sw:0px}.sidebar{display:none!important}.sidebar .acc-section,.sidebar .nsec,.sidebar .sbot,.ucard,.acc-ct,.acc-lbl{display:none!important}.ni{flex-direction:column;gap:2px;padding:5px 4px;font-size:9px;min-width:44px;justify-content:center;align-items:center;border-radius:8px;height:48px}.ni svg{width:18px;height:18px}.ni span{display:block!important;font-size:8px;color:var(--text3);text-align:center;line-height:1;font-family:var(--fd);font-weight:600;letter-spacing:.02em}.ni.on span{color:var(--ac)}.main{padding-bottom:0px}.page{padding:14px 12px;padding-bottom:20px}.g2,.g3,.g4,.g12,.g13{grid-template-columns:1fr!important}.topbar{padding:0 10px;gap:6px}.topbar .tb-title{font-size:13px}.big-card{width:100vw;max-width:100vw;border-radius:16px 16px 0 0;position:fixed;bottom:0;left:0;right:0;max-height:92vh;margin:0}.ob-card{width:100vw;max-width:100vw;border-radius:16px 16px 0 0;position:fixed;bottom:0;left:0;right:0;max-height:94vh;margin:0;padding:22px 16px}.ph1{font-size:20px}.ph2{font-size:12px}.card{padding:12px}.mc{padding:12px}.tw{overflow-x:auto;-webkit-overflow-scrolling:touch}table{min-width:500px}.fr.fr2{grid-template-columns:1fr!important}.pt-ov-inner{border-radius:16px 16px 0 0!important;position:fixed!important;bottom:0!important;left:0!important;right:0!important;top:auto!important;max-height:94vh;overflow-y:auto}#pt-ov .big-card,#to-ov .big-card{bottom:0!important;max-height:calc(94vh - 0px)!important;padding-bottom:24px}.big-head{position:sticky;top:0;background:var(--bg2);z-index:10;padding-bottom:8px}.xbtn{min-width:40px!important;min-height:40px!important;font-size:24px!important;padding:0!important}.overlay{z-index:500!important}.btn{padding:11px 14px;font-size:13px}.btn-grp{flex-wrap:wrap}#cal-weekly{border-left:none!important;padding-left:0!important;margin-top:14px}.cal-day{min-height:44px;padding:4px 5px}.cal-day-r{font-size:9px}.cal-day-ct{font-size:8px;display:none}.ni[onclick*="legal"],.ni[onclick*="privacy"]{display:none!important}#terms-modal>div{border-radius:16px 16px 0 0;position:fixed;bottom:0;left:0;right:0;max-width:100vw;max-height:90vh}#logpast-modal>div{border-radius:16px 16px 0 0!important;position:fixed!important;bottom:0!important;left:0!important;right:0!important;width:100%!important;max-height:92vh!important;overflow-y:auto!important}.lb-row{padding:8px 10px;gap:8px}#ranks-xp-breakdown .isr{flex-wrap:wrap}.guide-node{width:56px!important;height:56px!important}.notif{top:auto;bottom:10px;right:10px;left:10px;max-width:100%}[id^="news-detail-"]{padding:10px 12px}#ranks-tier-strip{gap:4px!important}#psych-zone-bars{grid-template-columns:repeat(5,1fr)!important;font-size:10px}#news-tz{width:100%}#pt-emo-grid{grid-template-columns:repeat(4,1fr)!important}.ob-card{padding:20px 14px!important}.ict-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap!important}#pt-e-v,#pt-c-v,#pt-m-v{font-size:18px!important}.acc-sw{overflow-x:auto;-webkit-overflow-scrolling:touch}#freq-player{width:calc(100vw - 20px)!important;max-width:320px!important;bottom:10px!important;right:10px!important;left:auto!important}#freq-toggle-btn{bottom:10px!important;right:10px!important}#guide-tooltip{display:none!important}}#page-risk{overflow-y:auto!important;-webkit-overflow-scrolling:touch;padding-bottom:100px!important}.tb-dots-menu{min-width:200px!important;max-height:70vh!important;overflow-y:auto!important}@media(max-width:600px){#cal-layout{grid-template-columns:1fr!important}#cal-weekly{border-left:none!important;border-top:1px solid var(--border)!important;padding-left:0!important;padding-top:14px!important;margin-top:14px!important;max-height:none!important}#page-community{padding-bottom:80px!important}.cm-input-row{position:sticky;bottom:0;z-index:20;background:var(--bg2)}#guide-map{min-height:900px!important;overflow-x:hidden!important}.guide-node{width:52px!important;height:52px!important;font-size:18px!important}}.mqn-btn{display:inline-block;padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:var(--bg3);color:var(--text2);font-size:11px;font-weight:700;font-family:var(--fd);cursor:pointer;transition:all .2s;margin-right:6px;white-space:nowrap;letter-spacing:.02em}.mqn-btn:hover,.mqn-btn.mqn-on{background:rgba(0,214,143,.12);border-color:rgba(0,214,143,.35);color:var(--ac)}#mobile-quicknav::-webkit-scrollbar{display:none}@media(max-width:600px){#mobile-quicknav{display:block!important}}@media(max-width:380px){.ni{min-width:36px;padding:4px 2px}.ni span{font-size:7px}.page{padding:12px 10px}.ph1{font-size:18px}}[data-theme="obsidian"]{--bg:#080b0e;--bg2:#0c1015;--bg3:#111620;--bg4:#161d2a;--border:rgba(255,255,255,0.07);--border2:rgba(255,255,255,0.13);--text:#f0f2f7;--text2:#8b93a8;--text3:#4a5268}[data-theme="midnight"]{--bg:#05080f;--bg2:#080d1a;--bg3:#0d1426;--bg4:#121c34;--border:rgba(100,140,255,0.1);--border2:rgba(100,140,255,0.18);--text:#e8eeff;--text2:#7a8aaa;--text3:#3a4a6a}[data-theme="abyss"]{--bg:#000000;--bg2:#080808;--bg3:#0f0f0f;--bg4:#161616;--border:rgba(255,255,255,0.06);--border2:rgba(255,255,255,0.12);--text:#f5f5f5;--text2:#888888;--text3:#444444}[data-theme="charcoal"]{--bg:#111111;--bg2:#181818;--bg3:#202020;--bg4:#282828;--border:rgba(255,255,255,0.08);--border2:rgba(255,255,255,0.14);--text:#f0f0f0;--text2:#909090;--text3:#505050}[data-theme="forest"]{--bg:#060e08;--bg2:#091209;--bg3:#0f1c10;--bg4:#142416;--border:rgba(80,200,100,0.1);--border2:rgba(80,200,100,0.17);--text:#e8f5e8;--text2:#7a9a7a;--text3:#3a5a3a}[data-theme="mocha"]{--bg:#0e0a08;--bg2:#150f0b;--bg3:#1d160f;--bg4:#251c14;--border:rgba(200,140,80,0.1);--border2:rgba(200,140,80,0.18);--text:#f5ede6;--text2:#a08070;--text3:#604030}[data-theme="slate"]{--bg:#080c10;--bg2:#0d1218;--bg3:#131a24;--bg4:#1a2330;--border:rgba(140,180,220,0.1);--border2:rgba(140,180,220,0.18);--text:#e8f0f8;--text2:#7898b8;--text3:#3a5878}[data-theme="nord"]{--bg:#2e3440;--bg2:#3b4252;--bg3:#434c5e;--bg4:#4c566a;--border:rgba(236,239,244,0.08);--border2:rgba(236,239,244,0.15);--text:#eceff4;--text2:#d8dee9;--text3:#81a1c1}[data-theme="dusk"]{--bg:#1a1228;--bg2:#221832;--bg3:#2d2040;--bg4:#3a2d52;--border:rgba(180,140,255,0.1);--border2:rgba(180,140,255,0.18);--text:#f0eaff;--text2:#b8a8d8;--text3:#7860a8}[data-theme="steel"]{--bg:#1a2030;--bg2:#1e2840;--bg3:#253050;--bg4:#2e3a60;--border:rgba(120,160,220,0.1);--border2:rgba(120,160,220,0.18);--text:#e8f0ff;--text2:#8898c0;--text3:#4858a0}[data-theme="light"]{--bg:#f8f9fa;--bg2:#ffffff;--bg3:#f1f3f5;--bg4:#e9ecef;--border:rgba(0,0,0,0.12);--border2:rgba(0,0,0,0.18);--text:#0a0c10;--text2:#1a1f2e;--text3:#4a5268}[data-theme="cream"]{--bg:#faf8f3;--bg2:#fffef9;--bg3:#f5f2e8;--bg4:#eae7dc;--border:rgba(0,0,0,0.10);--border2:rgba(0,0,0,0.16);--text:#1a1208;--text2:#3d2e1a;--text3:#7a6a52}[data-theme="sky"]{--bg:#e3f2fd;--bg2:#f1f8ff;--bg3:#d1e7fa;--bg4:#bbdefb;--border:rgba(0,0,0,0.10);--border2:rgba(0,0,0,0.16);--text:#080e1a;--text2:#1a2840;--text3:#4a6280}[data-density="compact"] .page{padding:12px 16px}[data-density="compact"] .card{padding:10px}[data-density="compact"] .g{gap:8px}.theme-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.theme-opt{border-radius:10px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all .2s}.theme-opt.on{border-color:var(--ac);box-shadow:0 0 12px rgba(0,214,143,.2)}.theme-opt:hover{transform:scale(1.04)}.theme-swatch{height:40px;display:flex}.ts-main{flex:2}.ts-side{flex:1}.theme-name{font-size:9px;font-weight:700;text-align:center;padding:4px 0;letter-spacing:.06em;text-transform:uppercase;font-family:'Syne',sans-serif}
/* ── TILT WARNING MODAL ── */
.tilt-ov{position:fixed;inset:0;background:rgba(0,0,0,.95);z-index:800;display:none;align-items:center;justify-content:center;backdrop-filter:blur(16px)}
.tilt-ov.open{display:flex}
.tilt-card{background:var(--bg2);border:1px solid rgba(255,77,109,.35);border-radius:18px;width:480px;max-width:94vw;padding:32px 28px;box-shadow:0 0 80px rgba(255,77,109,.15),0 24px 64px rgba(0,0,0,.8);animation:tiltIn .35s cubic-bezier(.34,1.56,.64,1)}
@keyframes tiltIn{from{transform:scale(.88) translateY(20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
.tilt-icon{font-size:48px;text-align:center;margin-bottom:12px;animation:pulse-red 1.4s ease-in-out infinite}
@keyframes pulse-red{0%,100%{filter:drop-shadow(0 0 0px rgba(255,77,109,0))}50%{filter:drop-shadow(0 0 12px rgba(255,77,109,.7))}}
.tilt-title{font-family:var(--fd);font-size:22px;font-weight:800;color:var(--red);text-align:center;margin-bottom:6px}
.tilt-sub{font-size:12px;color:var(--text2);text-align:center;margin-bottom:22px;line-height:1.6}
.tilt-streak-display{display:flex;justify-content:center;gap:6px;margin-bottom:20px}
.tilt-streak-dot{width:32px;height:32px;border-radius:50%;background:var(--rdim);border:2px solid var(--red);display:flex;align-items:center;justify-content:center;font-size:14px}
.tilt-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:22px}
.tilt-stat{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:12px 8px;text-align:center}
.tilt-stat-val{font-family:var(--fm);font-size:20px;font-weight:400;color:var(--red)}
.tilt-stat-lbl{font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;font-family:var(--fd);margin-top:3px}
.tilt-check-row{display:flex;align-items:center;gap:10px;padding:14px;background:rgba(255,77,109,.07);border:1px solid rgba(255,77,109,.2);border-radius:10px;cursor:pointer;margin-bottom:18px;transition:all .15s}
.tilt-check-row:hover{background:rgba(255,77,109,.12)}
.tilt-check-row.on{background:rgba(255,77,109,.14);border-color:rgba(255,77,109,.4)}
.tilt-checkbox{width:20px;height:20px;border-radius:5px;border:2px solid rgba(255,77,109,.5);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.tilt-check-row.on .tilt-checkbox{background:var(--red);border-color:var(--red)}
.tilt-check-txt{font-size:12px;color:var(--text2);line-height:1.5;font-weight:500}
.tilt-proceed{width:100%;padding:13px;border-radius:10px;background:var(--rdim);color:var(--red);border:1px solid rgba(255,77,109,.3);font-family:var(--fd);font-size:13px;font-weight:700;cursor:not-allowed;opacity:.4;transition:all .2s;letter-spacing:.03em}
.tilt-proceed.ready{background:var(--red);color:#fff;opacity:1;cursor:pointer;box-shadow:0 4px 20px rgba(255,77,109,.3)}
.tilt-proceed.ready:hover{transform:scale(1.02)}
.tilt-dismiss{width:100%;padding:10px;background:none;border:none;color:var(--text3);font-size:11px;cursor:pointer;margin-top:8px;font-family:var(--fb);transition:color .15s}
.tilt-dismiss:hover{color:var(--text2)}
/* ── CONFETTI CANVAS ── */
#confetti-canvas{position:fixed;inset:0;pointer-events:none;z-index:9999;display:none}
/* ── XP TICK ── */
@keyframes xpGlow{0%,100%{box-shadow:none}50%{box-shadow:0 0 12px rgba(0,214,143,.5)}}
.xp-ticking{animation:xpGlow .6s ease}

.tb-dots{display:none;background:var(--bg3);border:1px solid var(--border);border-radius:8px;width:36px;height:36px;align-items:center;justify-content:center;cursor:pointer;font-size:18px;color:var(--text2);flex-shrink:0;position:relative}
.tb-dots-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg2);border:1px solid var(--border2);border-radius:10px;min-width:180px;box-shadow:0 8px 32px rgba(0,0,0,.6);z-index:400;overflow:hidden;display:none}
.tb-dots-menu.open{display:block}
.tb-dots-item{display:flex;align-items:center;gap:9px;padding:11px 14px;font-size:12px;font-weight:600;color:var(--text2);cursor:pointer;border:none;background:none;width:100%;text-align:left;font-family:var(--fd);transition:background .15s}
.tb-dots-item:hover{background:var(--bg3);color:var(--text)}
.tb-dots-item:active{background:var(--bg4)}
.tb-dots-divider{height:1px;background:var(--border);margin:2px 0}
.tb-color-box{width:20px;height:20px;border-radius:6px;border:1px solid var(--border2);cursor:pointer;flex-shrink:0;transition:transform .15s,opacity .15s}
.tb-color-box:hover{transform:scale(1.15);opacity:.8}
@media(max-width:600px){
  .tb-dots{display:flex}
  #to-btn,#share-btn{display:none!important}
  .tbtn-pri{font-size:10px;padding:6px 10px;flex-shrink:1}
  #ql-btn{font-size:11px;padding:6px 10px;flex-shrink:1}
}
@media(max-width:480px){.tb-color-box{display:none!important}}

@keyframes dot{0%,80%,100%{opacity:.2;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(0,214,143,.3)}50%{box-shadow:0 0 0 10px rgba(0,214,143,0)}}

.yt-track{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:10px;border:1px solid var(--border);background:var(--bg3);cursor:pointer;transition:all .2s}.yt-track:hover{border-color:rgba(0,214,143,.25);background:var(--bg4)}.yt-track.active{border-color:rgba(0,214,143,.35);background:rgba(0,214,143,.07)}.yt-track-ico{font-size:16px;flex-shrink:0;width:22px;text-align:center}.yt-track-info{flex:1;min-width:0}.yt-track-name{font-family:var(--fd);font-size:11px;font-weight:700;color:var(--text)}.yt-track-desc{font-size:9px;color:var(--text3);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.yt-track-play{font-size:12px;color:var(--text3);flex-shrink:0;width:18px;text-align:center;transition:color .2s}.yt-track.active .yt-track-play{color:var(--ac)}.yt-track.active .yt-track-name{color:var(--ac)}

@keyframes rankUpBounce{0%{transform:scale(0);opacity:0}60%{transform:scale(1.3)}80%{transform:scale(0.9)}100%{transform:scale(1);opacity:1}}@keyframes confettiFall{0%{transform:translateY(-20px) rotate(0deg);opacity:1}100%{transform:translateY(100vh) rotate(720deg);opacity:0}}
/* ── XP POPUP NOTIFICATIONS ──────────────────────────────────────────────── */
#xp-popup-stack{position:fixed;bottom:72px;left:10px;display:flex;flex-direction:column-reverse;gap:7px;z-index:9500;pointer-events:none;align-items:flex-start}
.xp-popup{background:#0e1117;border:1px solid rgba(0,214,143,.25);border-radius:11px;padding:10px 14px;min-width:170px;max-width:240px;box-shadow:0 8px 28px rgba(0,0,0,.6),0 0 0 1px rgba(0,214,143,.06);animation:xpPopIn .35s cubic-bezier(.34,1.56,.64,1) forwards}
.xp-popup.out{animation:xpPopOut .3s ease-in forwards}
.xp-popup-xp{font-family:'Syne',sans-serif;font-size:15px;font-weight:800;color:#00d68f;letter-spacing:.02em}
.xp-popup-badge{font-size:12px;color:#f0f2f7;margin-top:4px;opacity:.85}
.xp-popup-rank{font-family:'Syne',sans-serif;font-size:11px;font-weight:800;color:#ffd700;margin-top:5px;letter-spacing:.06em;text-transform:uppercase}
@keyframes xpPopIn{from{opacity:0;transform:translateY(14px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes xpPopOut{from{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-8px) scale(.95)}}
@media(max-width:600px){#xp-popup-stack{left:50%;transform:translateX(-50%);bottom:82px;align-items:center}}

/* ── STORY MIC BUTTON ───────────────────────────────────────────────────── */
#cr-story-mic-btn.cr-mic-recording{border-color:var(--red);color:var(--red);background:var(--rdim);animation:micPulse 1.2s ease-in-out infinite}
@keyframes micPulse{0%,100%{box-shadow:0 0 0 0 rgba(255,77,109,.4)}50%{box-shadow:0 0 0 5px rgba(255,77,109,0)}}

/* ── NOTES ───────────────────────────────────────────────────────────────── */
.notes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}
.note-card{background:var(--bg2);border:1px solid var(--border);border-radius:11px;padding:16px;cursor:pointer;transition:border-color .15s,background .15s;display:flex;flex-direction:column;gap:7px}
.note-card:hover{border-color:var(--border2);background:var(--bg3)}
.note-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.note-title{font-family:var(--fd);font-size:13px;font-weight:700;color:var(--text);line-height:1.35;flex:1;word-break:break-word}
.note-tag-chip{font-size:8px;font-weight:800;padding:2px 7px;border-radius:4px;font-family:var(--fd);border:1px solid;flex-shrink:0;white-space:nowrap;letter-spacing:.04em;text-transform:uppercase}
.note-preview{font-size:12px;color:var(--text3);line-height:1.6;word-break:break-word}
.note-date{font-size:10px;color:var(--text3);font-family:var(--fm);margin-top:2px}
.notes-tag-btn{padding:5px 11px;border-radius:6px;border:1px solid var(--border);background:var(--bg3);color:var(--text3);font-family:var(--fd);font-size:10px;font-weight:700;cursor:pointer;transition:all .15s}
.notes-tag-btn:hover{border-color:var(--border2);color:var(--text2)}
.notes-tag-btn.on{background:var(--adim);border-color:var(--ac);color:var(--ac)}
@media(max-width:600px){.notes-grid{grid-template-columns:1fr}}
@media(max-width:600px){
  /* Notes tabs — full-width comfortable touch targets */
  .notes-main-tab{font-size:12px;padding:11px 6px;letter-spacing:0}
  /* Vision cards — tighter padding on mobile */
  .vis-card{padding:16px 14px}
  /* Drag handle — bigger touch target */
  .vis-drag-handle{font-size:26px;padding:6px 8px;min-width:36px;text-align:center;line-height:1}
  /* Vis buttons — larger for touch */
  .vis-btn-save,.vis-btn-ai{padding:10px 16px;font-size:12px}
  /* Note editor save row — stack cleanly */
  #note-editor{padding:14px 12px}
}

/* ── PLAYLISTS PANEL ─────────────────────────────────────────────────────── */
.pl-cat-btn{padding:5px 10px;border-radius:6px;border:1px solid var(--border);background:var(--bg3);color:var(--text3);font-family:var(--fd);font-size:9px;font-weight:700;cursor:pointer;transition:all .15s;white-space:nowrap}
.pl-cat-btn:hover{border-color:var(--border2);color:var(--text2)}
.pl-cat-btn.on{background:var(--adim);border-color:var(--ac);color:var(--ac)}
.pl-card{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:12px;transition:border-color .15s}
.pl-card:hover{border-color:var(--border2)}
.pl-card-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}
.pl-card-name{font-family:var(--fd);font-size:12px;font-weight:700;color:var(--text)}
.pl-cat-chip{font-size:8px;font-weight:800;padding:2px 7px;border-radius:4px;font-family:var(--fd);border:1px solid;white-space:nowrap;letter-spacing:.04em;text-transform:uppercase}
.pl-card-desc{font-size:11px;color:var(--text3);line-height:1.5;margin-top:4px}

/* ── CALENDAR NOTE DOT ───────────────────────────────────────────────────── */
.cal-note-dot{font-size:9px;line-height:1;cursor:pointer;margin-top:2px;display:inline-block;transition:transform .1s}
.cal-note-dot:hover{transform:scale(1.3)}

/* ── NOTES MAIN TABS ─────────────────────────────────────────────────────── */
.notes-main-tab{flex:1;padding:8px 12px;border-radius:8px;border:none;background:transparent;color:var(--text3);font-family:var(--fd);font-size:11px;font-weight:700;cursor:pointer;transition:all .15s;letter-spacing:.02em}
.notes-main-tab.on{background:var(--bg2);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,.3)}
.notes-main-tab:hover:not(.on){color:var(--text2)}

/* ── VISION & MINDSET ────────────────────────────────────────────────────── */
.vis-card{background:var(--bg2);border:1px solid rgba(157,127,255,.18);border-radius:14px;padding:20px;margin-bottom:14px;box-shadow:0 2px 12px rgba(0,0,0,.25)}
.vis-card-hd{display:flex;align-items:flex-start;gap:10px;margin-bottom:14px}
.vis-card-title{font-family:var(--fd);font-size:14px;font-weight:800;color:#d4a943;letter-spacing:.02em;margin-bottom:4px}
.vis-card-sub{font-size:11px;color:var(--text3);line-height:1.5}
.vis-drag-handle{cursor:grab;color:var(--text3);font-size:18px;line-height:1;padding:2px 2px;flex-shrink:0;margin-top:1px;user-select:none;-webkit-user-select:none;touch-action:none;opacity:.5;transition:opacity .15s}
.vis-drag-handle:hover{opacity:1;color:var(--text2)}
.vis-drag-handle:active{cursor:grabbing}
.vis-dragging{opacity:.35;pointer-events:none}
.vis-drag-over-top{border-top:3px solid #4d9fff!important}
.vis-drag-over-bottom{border-bottom:3px solid #4d9fff!important}

/* Vision buttons */
.vis-btn-save{padding:8px 16px;background:rgba(212,169,67,.15);color:#d4a943;border:1px solid rgba(212,169,67,.3);border-radius:8px;font-family:var(--fd);font-size:11px;font-weight:800;cursor:pointer;transition:all .15s}
.vis-btn-save:hover{background:rgba(212,169,67,.25);border-color:rgba(212,169,67,.5)}
.vis-btn-ai{padding:8px 16px;background:rgba(157,127,255,.12);color:#9d7fff;border:1px solid rgba(157,127,255,.25);border-radius:8px;font-family:var(--fd);font-size:11px;font-weight:800;cursor:pointer;transition:all .15s}
.vis-btn-ai:hover{background:rgba(157,127,255,.22);border-color:rgba(157,127,255,.45)}
.vis-btn-ai:disabled{opacity:.5;cursor:default}

/* AI result box */
.vis-ai-result{background:linear-gradient(135deg,rgba(157,127,255,.08),rgba(212,169,67,.06));border:1px solid rgba(157,127,255,.2);border-radius:10px;padding:14px 16px}
.vis-aff-suggestion{font-size:12px;color:var(--text2);line-height:1.7;padding:5px 8px;border-radius:6px;cursor:pointer;transition:background .12s}
.vis-aff-suggestion:hover{background:rgba(157,127,255,.1);color:#9d7fff}

/* Manifestation entry */
.vis-manifest-entry{background:rgba(212,169,67,.05);border:1px solid rgba(212,169,67,.14);border-radius:9px;padding:12px 14px;margin-bottom:8px}

/* Therapy chat */
.therapy-msg{display:flex;flex-direction:column;max-width:88%}
.therapy-msg-user{align-self:flex-end;align-items:flex-end}
.therapy-msg-ai{align-self:flex-start;align-items:flex-start}
.therapy-msg-text{font-size:13px;line-height:1.7;padding:10px 14px;border-radius:12px;word-break:break-word}
.therapy-msg-user .therapy-msg-text{background:rgba(157,127,255,.18);color:var(--text);border-bottom-right-radius:3px}
.therapy-msg-ai .therapy-msg-text{background:rgba(212,169,67,.1);color:var(--text);border-bottom-left-radius:3px;border:1px solid rgba(212,169,67,.15)}
.therapy-sage-label{font-size:9px;font-weight:800;color:#d4a943;font-family:var(--fd);letter-spacing:.06em;margin-bottom:3px;padding-left:2px}

/* Goals */
.vis-goal-row{background:rgba(212,169,67,.04);border:1px solid rgba(212,169,67,.14);border-radius:10px;padding:14px}
.vis-goal-bar-track{height:5px;background:var(--bg4);border-radius:3px;overflow:hidden}
.vis-goal-bar-fill{height:100%;border-radius:3px;transition:width .4s ease}

/* ── GRATITUDE ───────────────────────────────────────────────────────────── */
.grat-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:10px;cursor:pointer;transition:all .18s;background:rgba(212,169,67,.05);border:1px solid rgba(212,169,67,.12);user-select:none}
.grat-item:hover{background:rgba(212,169,67,.1);border-color:rgba(212,169,67,.25)}
.grat-item.grat-checked{background:rgba(212,169,67,.12);border-color:rgba(212,169,67,.3)}
.grat-item.grat-checked .grat-text{color:var(--text);text-decoration:none}
.grat-sun{font-size:18px;flex-shrink:0;transition:all .2s}
.grat-text{font-size:13px;color:var(--text2);line-height:1.5;transition:color .2s}
.grat-item.grat-checked .grat-text{color:var(--text)}
#intro-canvas{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:9999;background:#000000;display:none;touch-action:none}

/* ── QUICK LOG ───────────────────────────────────────────────────────────── */
.ql-big-btn{width:100%;padding:14px 16px;border-radius:10px;border:1px solid var(--border);background:var(--bg3);color:var(--text);font-size:13px;font-family:var(--fd);font-weight:700;cursor:pointer;transition:all .2s;min-height:52px;text-align:left;display:block}
.ql-big-btn:hover{border-color:var(--ac);background:var(--adim);color:var(--ac)}
.ql-dir-btn{flex:1;padding:16px;border-radius:10px;border:1px solid var(--border);background:var(--bg3);color:var(--text2);font-size:15px;font-family:var(--fd);font-weight:800;cursor:pointer;transition:all .2s;min-height:56px}
.ql-comp-btn{flex:1;padding:13px;border-radius:10px;border:1px solid var(--border);background:var(--bg3);color:var(--text2);font-size:13px;font-family:var(--fd);font-weight:700;cursor:pointer;transition:all .2s;min-height:50px}
.ql-res-btn{flex:1;padding:16px 8px;border-radius:10px;border:1px solid var(--border);background:var(--bg3);color:var(--text2);font-size:13px;font-family:var(--fd);font-weight:800;cursor:pointer;transition:all .2s;min-height:56px;text-align:center}
.ql-upload-area{border:2px dashed var(--border2);border-radius:10px;padding:16px;text-align:center;cursor:pointer;color:var(--text3);font-size:12px;transition:border-color .2s;font-family:var(--fd)}
.ql-upload-area:hover{border-color:var(--ac);color:var(--ac)}
@media(max-width:600px){
  #ql-overlay .big-card,#ql-close-overlay .big-card{position:fixed;bottom:0;left:0;right:0;width:100%;max-width:100%;border-radius:20px 20px 0 0;margin:0;max-height:88vh;animation:qlSlideUp .25s ease}
  #ql-overlay,#ql-close-overlay{align-items:flex-end}
}
@keyframes qlSlideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
/* ── JOURNAL SESSION GROUPS ──────────────────────────────────────────────── */
.j-sess-hd{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;background:var(--bg3);border:1px solid var(--border);border-radius:10px;cursor:pointer;margin-bottom:6px;transition:background .15s;user-select:none}
.j-sess-hd:hover{background:var(--bg4)}
.j-sess-title{font-family:var(--fd);font-size:12px;font-weight:800;color:var(--text)}
.j-sess-meta{display:flex;gap:10px;align-items:center;font-size:11px;color:var(--text3);font-family:var(--fm)}
.j-sess-chev{font-size:11px;color:var(--text3)}
.j-sess-cards{margin-bottom:4px}
.j-sess-trade-card{background:var(--bg2);border:1px solid var(--border);border-radius:9px;padding:11px 14px;margin-bottom:5px;display:flex;align-items:center;justify-content:space-between;gap:8px}

/* ── Dashboard Animations ─────────────────────────────────────────────────── */
@keyframes dashStatIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes streakDotIn{0%{opacity:0;transform:scale(0.3)}65%{transform:scale(1.18)}100%{opacity:1;transform:scale(1)}}
@keyframes numPulse{0%{color:inherit;text-shadow:none}30%{color:#00d68f;text-shadow:0 0 16px rgba(0,214,143,0.75)}100%{color:inherit;text-shadow:none}}
@keyframes xpShimmerMove{0%{transform:translateX(-100%)}100%{transform:translateX(400%)}}
.num-pulse{animation:numPulse 0.7s ease forwards}
.streak-dot-in{animation:streakDotIn 0.32s cubic-bezier(0.34,1.56,0.64,1) both}
.xp-fill{position:relative;overflow:hidden}
.xp-fill-shimmer::after{content:'';position:absolute;inset:0;width:40%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.28),transparent);animation:xpShimmerMove 1.1s ease 0.4s 1 forwards}
@keyframes emoPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
@keyframes emoBounce{0%,100%{transform:translateY(0)}40%{transform:translateY(-14px)}60%{transform:translateY(-6px)}}
@keyframes emoBreathe{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}
@keyframes emoShake{0%,100%{transform:translateX(0)}20%{transform:translateX(-5px)}40%{transform:translateX(5px)}60%{transform:translateX(-3px)}80%{transform:translateX(3px)}}
@keyframes emoDroop{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(4px) rotate(-3deg)}}
.emo-pulse{animation:emoPulse 3s ease-in-out infinite;display:inline-block}
.emo-bounce{animation:emoBounce 1.4s ease-in-out infinite;display:inline-block}
.emo-breathe{animation:emoBreathe 4s ease-in-out infinite;display:inline-block}
.emo-shake{animation:emoShake 1.8s ease-in-out infinite;display:inline-block}
.emo-droop{animation:emoDroop 3.5s ease-in-out infinite;display:inline-block}
/* ─── MINI PLAYER BAR ─── */
#mini-player-bar{position:fixed;bottom:0;left:var(--sw);right:0;height:52px;background:var(--bg2);border-top:1px solid var(--border2);z-index:7990;display:flex;align-items:center;padding:0 14px;gap:10px;cursor:pointer}
#mini-player-bar .mp-icon{font-size:16px;flex-shrink:0}
#mini-player-bar .mp-name{flex:1;font-size:12px;font-weight:600;color:var(--text);font-family:var(--fd);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#mini-player-bar .mp-controls{display:flex;align-items:center;gap:0;flex-shrink:0}
#mini-player-bar .mp-btn{background:none;border:none;color:var(--text2);cursor:pointer;font-size:14px;padding:6px 9px;border-radius:6px;line-height:1;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:color .15s}
#mini-player-bar .mp-btn:hover{color:var(--text)}
#mini-player-bar .mp-pp{color:var(--ac);font-size:16px}
#mini-player-bar .mp-dismiss{font-size:18px;color:var(--text3);padding:4px 8px}
@media(max-width:600px){#mini-player-bar{height:56px;left:0}}

/* ─── MOBILE AUDIT FIXES (≤ 600px) ─── */

/* Community — dynamic chat height + bigger touch targets */
@media(max-width:600px){
  #cm-card{height:calc(100dvh - 260px)!important;min-height:260px!important}
  .cm-send{width:44px!important;height:44px!important;border-radius:10px!important}
  label[for="cm-img-input"]{width:44px!important;height:44px!important;border-radius:10px!important}
}

/* Trade Scanner — 2-column upload grid for easier tapping */
@media(max-width:600px){
  .ts-chart-grid{grid-template-columns:repeat(2,1fr)!important}
  .ts-chart-grid>[id^="ts-zone-"]{min-height:96px!important}
}

/* Frequencies — compact Spotify embeds in floating player */
@media(max-width:600px){
  #freq-panel-pl iframe{height:152px!important}
}

/* Settings — theme grid 2 columns so swatches are tappable */
@media(max-width:600px){
  .theme-grid{grid-template-columns:repeat(2,1fr)!important}
}

/* Pattern Intel — run button full width on mobile */
@media(max-width:600px){
  #pi-run-btn{width:100%!important;text-align:center!important}
}

/* Content Engine — mode-switcher buttons 44px touch target */
@media(max-width:600px){
  #cr-mode-scripts,#cr-mode-affiliate{min-height:44px!important;padding:10px 8px!important}
}

/* Risk Calc — fr3 (3-column) collapses to single column */
@media(max-width:600px){
  .fr.fr3{grid-template-columns:1fr!important}
}

/* Topbar — ql-btn compact on mobile so it never overflows */
@media(max-width:600px){
  #ql-btn{font-size:10px!important;padding:6px 8px!important}
}

/* Journal — view-toggle buttons 44px minimum height */
@media(max-width:600px){
  #j-vbtn-table,#j-vbtn-day,#j-vbtn-sessions{padding:10px 12px!important;min-height:44px!important;font-size:12px!important}
  #j-filter{min-height:44px!important;padding:9px 11px!important}
}

/* Calendar nav buttons 44px touch targets */
@media(max-width:600px){
  .cal-nav-btn{width:44px!important;height:44px!important;min-width:44px!important;border-radius:8px!important}
}

/* Dashboard flame + game plan cards — ensure single column flow */
@media(max-width:600px){
  #d-dayview-banner{width:100%;flex-wrap:wrap}
}

/* Pending — account toggle and action buttons 44px */
@media(max-width:600px){
  #pend-acc-toggle button{min-height:44px!important;padding:8px 14px!important}
  #pend-close-all-btn{min-height:44px!important;padding:10px 16px!important}
}

/* Notes — gratitude checkboxes larger tap area */
@media(max-width:600px){
  .grat-item{min-height:44px!important;display:flex!important;align-items:center!important}
  .grat-item input[type=checkbox]{width:20px!important;height:20px!important}
}

/* Leaderboard — XP bar visible, rows wrap cleanly */
@media(max-width:600px){
  #ranks-xp-bar-wrap{width:100%}
  .lb-score-badge{font-size:11px!important}
}

/* Quick Log — upload area bigger tap zone */
@media(max-width:600px){
  .ql-upload-area{padding:22px 16px!important;font-size:13px!important}
}

/* Modals on mobile — ensure overlay z-index above bottom bar */
@media(max-width:600px){
  .overlay{z-index:510!important}
  #pt-ov,#to-ov,#ql-overlay,#ql-close-overlay{z-index:510!important}
}

@keyframes navGlow{
  0%{background:transparent}
  50%{background:var(--adim2);color:var(--ac);transform:scale(1.04)}
  100%{background:transparent}
}

/* ── Ritual checklist styles — moved from app.html 17 Apr 2026 ── */
.ritual-item{display:flex;align-items:center;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.ritual-cb{width:20px;min-width:20px;height:20px;border-radius:5px;border:2px solid var(--border2);background:var(--bg3);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:transparent}
.ritual-cb.checked{background:var(--ac);border-color:var(--ac);color:#fff;box-shadow:0 0 8px var(--ac)}
.ritual-text{font-size:13px;color:var(--text2);font-family:var(--fd);margin-left:12px;transition:all .2s ease}
.ritual-item.checked .ritual-text{color:var(--text);text-decoration:line-through;opacity:.6}
