
:root{
  --g:#1d9e75;--gl:#e1f5ee;--gd:#085041;
  --b:#378add;--bl:#e6f1fb;--bd:#0c447c;
  --p:#7f77dd;--pl:#eeedfe;--pd:#3c3489;
  --c:#d85a30;--cl:#faece7;--cd:#712b13;
  --pk:#d4537e;--pkl:#fbeaf0;--pkd:#72243e;
  --a:#ba7517;--al:#faeeda;--ad:#633806;
  --red:#e24b4a;--redl:#fcebeb;
  --t:#111;--t2:#555;--t3:#999;
  --bg:#fff;--bg2:#f7f7f5;--bg3:#efeeeb;
  --bdr:rgba(0,0,0,0.08);--bdr2:rgba(0,0,0,0.15);
  --r:12px;--rsm:8px;--rlg:16px;--rxl:22px;
  --font:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --st:env(safe-area-inset-top);--sb:env(safe-area-inset-bottom);
}
@media(prefers-color-scheme:dark){:root{
  --t:#f0f0ee;--t2:#a0a09e;--t3:#6b6b69;
  --bg:#111110;--bg2:#1c1c1a;--bg3:#252522;
  --bdr:rgba(255,255,255,0.07);--bdr2:rgba(255,255,255,0.13);
  --gl:#0a2e22;--bl:#0a1e30;--pl:#1a1840;--cl:#2e150c;--pkl:#2e101e;--al:#2e1e08;--redl:#2e0f0f;
  --gd:#9fe1cb;--bd:#85b7eb;--pd:#afa9ec;--cd:#f0997b;--pkd:#ed93b1;--ad:#fac775;
}}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
body{font-family:var(--font);background:var(--bg);color:var(--t);min-height:100vh;overflow-x:hidden;}
/* Swipe back indicator */
.swipe-back-indicator{position:fixed;left:0;top:50%;transform:translateY(-50%);width:4px;height:80px;background:var(--g);border-radius:0 4px 4px 0;opacity:0;z-index:9999;transition:opacity .15s,width .15s;pointer-events:none;}
.swipe-back-indicator.visible{opacity:0.7;width:6px;}
.h{display:none!important;}
#app{display:none;}
#app.v{display:block;}
/* LOADING */
#ls{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;}
.spin{width:36px;height:36px;border:3px solid var(--bdr2);border-top-color:var(--g);border-radius:50%;animation:sp .7s linear infinite;}
@keyframes sp{to{transform:rotate(360deg);}}
/* LOGIN */
#login{position:fixed;inset:0;background:var(--bg);z-index:9998;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 24px;}
.ll{width:80px;height:80px;border-radius:24px;background:linear-gradient(135deg,var(--g),#0f6e56);display:flex;align-items:center;justify-content:center;font-size:36px;margin-bottom:28px;box-shadow:0 8px 24px rgba(29,158,117,0.3);}
.lform{width:100%;max-width:340px;display:flex;flex-direction:column;gap:12px;}
.li{font-size:16px;padding:15px 18px;border:0.5px solid var(--bdr2);border-radius:var(--r);background:var(--bg2);color:var(--t);font-family:var(--font);width:100%;}
.li:focus{outline:none;border-color:var(--g);}
.lb{font-size:16px;font-weight:700;padding:15px;border:none;border-radius:var(--r);background:var(--g);color:#fff;cursor:pointer;font-family:var(--font);box-shadow:0 4px 16px rgba(29,158,117,0.3);}
.lb:active{transform:scale(0.98);}
.lerr{font-size:13px;color:var(--red);text-align:center;min-height:18px;}
.ltg{font-size:13px;color:var(--t3);text-align:center;cursor:pointer;}
.ltg span{color:var(--g);font-weight:600;}
.lkb{position:fixed;top:calc(12px + var(--st));right:12px;z-index:600;font-size:14px;font-weight:600;background:var(--bg2);border:0.5px solid var(--bdr2);border-radius:var(--rsm);cursor:pointer;opacity:0.7;padding:7px 12px;letter-spacing:0;}
/* HOME */
#home{min-height:100vh;padding:0 20px;padding-top:calc(28px + var(--st));padding-bottom:calc(36px + var(--sb));}
.hg{font-size:14px;color:var(--t3);margin-bottom:6px;font-weight:500;}
.hn{font-size:32px;font-weight:800;letter-spacing:-1px;margin-bottom:4px;}
.hd{font-size:14px;color:var(--t3);margin-bottom:28px;}
.jcards{display:flex;flex-direction:column;gap:16px;}
.jcard{border-radius:var(--rxl);padding:24px 22px;cursor:pointer;position:relative;overflow:hidden;border:0.5px solid var(--bdr);}
.jcard:active{transform:scale(0.98);}
.jcard.gym{background:linear-gradient(135deg,#eaf7f2,#d5f2e8);}
.jcard.trade{background:linear-gradient(135deg,#e8f2fc,#d0e8fa);}
.jcard.personal{background:linear-gradient(135deg,#f0eeff,#e4deff);}
@media(prefers-color-scheme:dark){
  .jcard.gym{background:linear-gradient(135deg,#0a2e22,#0d3d2c);}
  .jcard.trade{background:linear-gradient(135deg,#0a1e30,#0d2a42);}
  .jcard.personal{background:linear-gradient(135deg,#1a1840,#201c52);}
}
.jci{font-size:36px;margin-bottom:14px;}
.jct{font-size:22px;font-weight:800;margin-bottom:4px;letter-spacing:-0.3px;}
.jcs{font-size:13px;margin-bottom:18px;line-height:1.5;opacity:0.7;}
.jcard.gym .jct{color:var(--gd);}.jcard.trade .jct{color:var(--bd);}.jcard.personal .jct{color:var(--pd);}
.jstats{display:flex;gap:20px;}
.jsv{font-size:18px;font-weight:700;}
.jsl{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;opacity:0.55;margin-top:2px;}
.jcard.gym .jsv{color:var(--gd);}.jcard.trade .jsv{color:var(--bd);}.jcard.personal .jsv{color:var(--pd);}
.jarrow{position:absolute;top:22px;right:22px;font-size:22px;opacity:0.25;}
.dbanner{background:var(--al);border:0.5px solid var(--a);border-radius:var(--r);padding:14px 16px;margin-bottom:18px;display:flex;gap:12px;align-items:flex-start;}
/* JOURNAL SHELL */
.jv{position:fixed;inset:0;background:var(--bg);z-index:200;display:none;flex-direction:column;}
.jv.open{display:flex;}
.jh{display:flex;align-items:center;gap:10px;padding:calc(14px + var(--st)) 70px 14px 16px;border-bottom:0.5px solid var(--bdr);background:var(--bg);flex-shrink:0;}
.jback{font-size:28px;color:var(--t2);background:none;border:none;cursor:pointer;padding:0 8px 0 0;line-height:1;font-weight:300;}
.jhtitle{font-size:18px;font-weight:800;flex:1;letter-spacing:-0.3px;}
.jhmenu{font-size:18px;background:var(--bg2);border:0.5px solid var(--bdr2);border-radius:var(--rsm);cursor:pointer;opacity:0.7;padding:6px 8px;}
.jnav{display:flex;border-bottom:0.5px solid var(--bdr);background:var(--bg);flex-shrink:0;overflow-x:auto;}
.jnav::-webkit-scrollbar{display:none;}
.jni{flex:1;min-width:56px;display:flex;flex-direction:column;align-items:center;padding:10px 4px 8px;cursor:pointer;border-bottom:2.5px solid transparent;gap:3px;}
.jni-icon{font-size:20px;line-height:1;}
.jni-label{font-size:9px;color:var(--t3);font-weight:700;white-space:nowrap;letter-spacing:.03em;text-transform:uppercase;}
.jni.active .jni-label{color:var(--g);}
.jni.active{border-bottom-color:var(--g);}
.jbody{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:20px 16px;padding-bottom:calc(24px + var(--sb));}
.tp{display:none;}.tp.active{display:block;}
/* SHARED */
.card{background:var(--bg);border:0.5px solid var(--bdr);border-radius:var(--rlg);padding:16px 18px;margin-bottom:14px;}
.card-title{font-size:11px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:14px;}
.sec-title{font-size:22px;font-weight:800;letter-spacing:-0.5px;margin-bottom:4px;}
.sec-sub{font-size:14px;color:var(--t3);margin-bottom:20px;}
.pill-row{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:16px;}
.pill{font-size:12px;padding:6px 14px;border:0.5px solid var(--bdr2);border-radius:20px;cursor:pointer;background:var(--bg);color:var(--t2);font-weight:600;}
.pill.active{background:var(--t);color:var(--bg);border-color:var(--t);}
.btn{font-size:13px;font-weight:600;padding:10px 18px;border:0.5px solid var(--bdr2);border-radius:var(--rsm);background:var(--bg);color:var(--t);cursor:pointer;font-family:var(--font);}
.btn:active{transform:scale(0.97);}
.btn-p{background:var(--g);color:#fff;border-color:var(--g);}
.btn-sm{font-size:12px;padding:7px 12px;}
.btn-d{background:var(--redl);color:var(--red);border-color:var(--red);}
.btn-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px;}
input,select,textarea{font-size:16px;padding:10px 12px;border:0.5px solid var(--bdr2);border-radius:var(--rsm);background:var(--bg);color:var(--t);font-family:var(--font);}@media(min-width:768px){input,select,textarea{font-size:14px;}}
input[type=number]{-moz-appearance:textfield;}
input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
input[type=number]{-moz-appearance:textfield;padding-right:12px;}
input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--g);}
textarea{width:100%;resize:vertical;line-height:1.6;}
.field-row{display:flex;gap:8px;margin-bottom:10px;flex-wrap:wrap;align-items:center;}
.fl{font-size:12px;color:var(--t2);min-width:90px;flex-shrink:0;font-weight:500;}
.lift-row{display:flex;align-items:center;gap:8px;padding:10px 0;border-bottom:0.5px solid var(--bdr);}
.lift-row:last-child{border-bottom:none;}
.lname{font-size:14px;flex:1;}
.lval{font-size:14px;font-weight:700;}
.prog-row{display:flex;align-items:center;gap:10px;margin-bottom:10px;}
.pbg{flex:1;height:7px;background:var(--bg3);border-radius:4px;overflow:hidden;}
.pfill{height:100%;border-radius:4px;transition:width .4s;}
.pval{font-size:12px;font-weight:700;min-width:44px;text-align:right;}
.check-row{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:0.5px solid var(--bdr);}
.check-row:last-of-type{border-bottom:none;}
.check-row input[type=checkbox]{width:20px;height:20px;accent-color:var(--g);flex-shrink:0;cursor:pointer;}
.chklbl{font-size:14px;flex:1;font-weight:500;}
.chksub{font-size:12px;color:var(--t3);}
/* METRICS */
.metrics{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px;}
.metric{border-radius:var(--r);padding:16px;cursor:pointer;position:relative;}
.metric:active{transform:scale(0.96);}
.metric-lbl{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;}
.metric-val{font-size:28px;font-weight:800;letter-spacing:-1px;}
.metric-sub{font-size:11px;margin-top:4px;font-weight:500;}
.metric-arr{position:absolute;top:12px;right:12px;font-size:16px;opacity:0.3;}
.mg{background:var(--gl);}.mg .metric-lbl,.mg .metric-sub{color:var(--g);}.mg .metric-val{color:var(--gd);}
.mb{background:var(--bl);}.mb .metric-lbl,.mb .metric-sub{color:var(--b);}.mb .metric-val{color:var(--bd);}
.mp{background:var(--pl);}.mp .metric-lbl,.mp .metric-sub{color:var(--p);}.mp .metric-val{color:var(--pd);}
.ma{background:var(--al);}.ma .metric-lbl,.ma .metric-sub{color:var(--a);}.ma .metric-val{color:var(--ad);}
.mc{background:var(--cl);}.mc .metric-lbl,.mc .metric-sub{color:var(--c);}.mc .metric-val{color:var(--cd);}
/* CHART */
.chart-box{background:var(--bg);border:0.5px solid var(--bdr);border-radius:var(--rlg);padding:16px 18px;margin-bottom:14px;}
.chart-box-title{font-size:14px;font-weight:700;margin-bottom:14px;}
.chart-wrap{position:relative;width:100%;height:180px;}
/* MODAL */
.mo{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:800;display:flex;align-items:flex-end;overscroll-behavior:none;}
.mo.h{display:none!important;}
.ms{background:var(--bg);border-radius:24px 24px 0 0;width:100%;max-height:88vh;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:20px 18px;padding-bottom:calc(36px + var(--sb));overscroll-behavior:contain;touch-action:pan-y;}
.mh{width:40px;height:4px;background:var(--bdr2);border-radius:2px;margin:0 auto 20px;}
.mt{font-size:20px;font-weight:800;letter-spacing:-0.3px;margin-bottom:4px;}
.msub{font-size:14px;color:var(--t3);margin-bottom:18px;}
/* DAY MODAL */
.dm-hdr{display:flex;align-items:flex-start;gap:12px;margin-bottom:20px;}
.dm-date-wrap{flex:1;}
.dm-date-inp{font-size:20px;font-weight:800;background:transparent;border:none;border-bottom:2px dashed var(--bdr2);outline:none;color:var(--t);width:100%;font-family:var(--font);padding-bottom:3px;}
.dm-type-lbl{font-size:13px;color:var(--t3);margin-top:5px;}
.dm-trash{font-size:24px;background:none;border:none;cursor:pointer;color:var(--red);padding:4px;}
.dm-sec{margin-bottom:20px;}
.dm-sec-hdr{display:flex;align-items:center;gap:8px;margin-bottom:10px;}
.dm-sec-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--t3);flex:1;}
.wtype-pills{display:flex;gap:7px;flex-wrap:wrap;}
.wtp{font-size:12px;font-weight:600;padding:7px 12px;border:1.5px solid var(--bdr2);border-radius:20px;cursor:pointer;color:var(--t2);}
.wtp.active{color:#fff;border-color:transparent;}
.wtp[data-t=chest].active{background:#185fa5;}.wtp[data-t=legs].active{background:#633806;}
.wtp[data-t=arms].active{background:#3c3489;}.wtp[data-t=upper].active{background:#712b13;}
.wtp[data-t=rest].active{background:#5f5e5a;}
.supp-mini-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.smi{display:flex;align-items:center;gap:9px;padding:9px 11px;background:var(--bg2);border-radius:var(--rsm);cursor:pointer;border:0.5px solid var(--bdr);}
.smc{width:18px;height:18px;border-radius:50%;border:2px solid var(--bdr2);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;}
.smc.done{background:var(--g);border-color:var(--g);color:#fff;}
.sml{font-size:12px;font-weight:500;}
.att-grid{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;}
.att-img{width:80px;height:80px;object-fit:cover;border-radius:var(--rsm);cursor:pointer;border:0.5px solid var(--bdr);}
.att-add{width:80px;height:80px;border:2px dashed var(--bdr2);border-radius:var(--rsm);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:28px;color:var(--t3);}
/* QUILL */
.qwrap{border:0.5px solid var(--bdr2);border-radius:var(--r);overflow:hidden;margin-bottom:10px;}
.qwrap .ql-toolbar{border:none;border-bottom:0.5px solid var(--bdr);background:var(--bg2);padding:8px 10px;}
.qwrap .ql-container{border:none;font-family:var(--font);font-size:15px;}
.qwrap .ql-editor{min-height:140px;padding:14px 16px;color:var(--t);line-height:1.7;}
.qwrap .ql-editor.ql-blank::before{color:var(--t3);font-style:normal;}
.ql-snow .ql-stroke{stroke:var(--t2);}.ql-snow .ql-fill{fill:var(--t2);}.ql-snow .ql-picker{color:var(--t2);}
/* TRADE CARDS */
.tcard{background:var(--bg2);border-radius:var(--r);padding:14px 16px;margin-bottom:10px;border-left:4px solid transparent;cursor:pointer;}
.tcard:active{opacity:.8;}
.tcard.long{border-left-color:var(--g);}.tcard.short{border-left-color:var(--red);}
.tc-hdr{display:flex;align-items:center;gap:8px;margin-bottom:6px;}
.tc-inst{font-size:14px;font-weight:800;}
.tc-dir{font-size:11px;font-weight:700;padding:3px 8px;border-radius:20px;}
.tc-dir.long{background:var(--gl);color:var(--gd);}.tc-dir.short{background:var(--redl);color:var(--red);}
.tc-pnl{font-size:16px;font-weight:800;margin-left:auto;}
.tc-pnl.pos{color:var(--g);}.tc-pnl.neg{color:var(--red);}
.tc-meta{font-size:12px;color:var(--t3);}
.tc-badge{font-size:10px;padding:3px 8px;border-radius:20px;margin-top:6px;display:inline-block;font-weight:600;}
.tc-badge.rev{background:var(--gl);color:var(--gd);}.tc-badge.norev{background:var(--al);color:var(--ad);}
/* GALLERY */
.gallery-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px;}
.gcard{border-radius:var(--r);overflow:hidden;cursor:pointer;position:relative;background:var(--bg2);border:0.5px solid var(--bdr);}
.gcard:active{transform:scale(0.97);}
.gcard-img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block;}
.gcard-ph{width:100%;aspect-ratio:16/10;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:32px;}
.gcard-foot{padding:8px 10px;}
.gcard-date{font-size:10px;color:var(--t3);font-weight:600;margin-bottom:2px;}
.gcard-pnl{font-size:15px;font-weight:800;}
.gcard-pnl.pos{color:var(--g);}.gcard-pnl.neg{color:var(--red);}
.gcard-badge{position:absolute;top:8px;right:8px;font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px;}
.gcard-badge.pos{background:rgba(29,158,117,0.9);color:#fff;}.gcard-badge.neg{background:rgba(226,75,74,0.9);color:#fff;}
.gal-toggle{display:flex;gap:0;background:var(--bg2);border-radius:var(--r);padding:4px;margin-bottom:14px;}
.autosave-badge{font-size:11px;font-weight:700;color:var(--g);padding:3px 8px;background:var(--gl);border-radius:20px;opacity:0;transition:opacity 1s;}
.autosave-toast{position:fixed;bottom:calc(80px + var(--sb));left:50%;transform:translateX(-50%);background:rgba(0,0,0,0.75);color:#fff;font-size:12px;font-weight:600;padding:8px 18px;border-radius:20px;opacity:0;transition:opacity .3s;pointer-events:none;z-index:2000;white-space:nowrap;}
.autosave-toast.show{opacity:1;}
.autosave-badge.show{opacity:1;transition:opacity 0s;}
.gt-btn{flex:1;padding:10px;border:none;border-radius:var(--rsm);cursor:pointer;background:transparent;color:var(--t2);font-size:13px;font-weight:700;text-align:center;font-family:var(--font);}
.gt-btn.active{background:var(--bg);color:var(--t);box-shadow:0 1px 4px rgba(0,0,0,0.1);}
/* STAT GRID */
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px;}
.stat-box{background:var(--bg2);border-radius:var(--r);padding:12px;text-align:center;}
.stat-val{font-size:18px;font-weight:800;letter-spacing:-0.5px;}
.stat-lbl{font-size:10px;color:var(--t3);font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-top:2px;}
/* PERSONAL */
.qcap{background:var(--bg);border:0.5px solid var(--bdr2);border-radius:var(--rlg);padding:16px;margin-bottom:14px;}
.qcap-foot{display:flex;align-items:center;gap:8px;margin-top:12px;border-top:0.5px solid var(--bdr);padding-top:12px;flex-wrap:wrap;}
.ecard{background:var(--bg);border:0.5px solid var(--bdr);border-radius:var(--rlg);padding:16px;margin-bottom:10px;cursor:pointer;}
.ecard:active{background:var(--bg2);}
.ecard-title{font-size:16px;font-weight:700;margin-bottom:4px;}
.ecard-date{font-size:11px;color:var(--t3);font-weight:600;margin-bottom:8px;}
.ecard-prev{font-size:14px;color:var(--t2);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.etags{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap;}
.etag{font-size:11px;padding:3px 9px;border-radius:20px;font-weight:600;background:var(--pl);color:var(--pd);}
/* GOAL CARDS */
.goal-card{border-radius:var(--rlg);padding:18px;margin-bottom:10px;position:relative;}
.goal-card.trading{background:linear-gradient(135deg,#e8f2fc,#d5e8fa);}
.goal-card.gym{background:linear-gradient(135deg,#e5f7f0,#c8f0e0);}
.goal-card.life{background:linear-gradient(135deg,#f0eeff,#dfd8ff);}
.goal-card.financial{background:linear-gradient(135deg,#fef7e6,#f5dda0);}
.goal-card.mindset{background:linear-gradient(135deg,#fdf0eb,#f8c4a8);}
@media(prefers-color-scheme:dark){
  .goal-card.trading{background:linear-gradient(135deg,#0a1e30,#0d2a42);}
  .goal-card.gym{background:linear-gradient(135deg,#0a2e22,#0d3d2c);}
  .goal-card.life{background:linear-gradient(135deg,#1a1840,#201c52);}
  .goal-card.financial{background:linear-gradient(135deg,#2e1e08,#3d2a0a);}
  .goal-card.mindset{background:linear-gradient(135deg,#2e150c,#3d1e12);}
}
.goal-hdr{display:flex;align-items:flex-start;gap:12px;}
.goal-chk{width:26px;height:26px;border-radius:50%;border:2.5px solid rgba(0,0,0,0.15);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;margin-top:1px;}
.goal-chk.done{background:var(--g);border-color:var(--g);color:#fff;}
.goal-text{font-size:15px;font-weight:600;line-height:1.4;margin-bottom:6px;flex:1;}
.goal-text.done{text-decoration:line-through;opacity:0.45;}
.goal-meta{font-size:11px;font-weight:700;opacity:0.55;text-transform:uppercase;letter-spacing:.04em;}
.goal-del{position:absolute;top:14px;right:14px;font-size:16px;background:none;border:none;cursor:pointer;opacity:0.25;}
.tag-opt{font-size:12px;padding:5px 11px;border:0.5px solid var(--bdr2);border-radius:20px;cursor:pointer;background:var(--bg);color:var(--t2);font-weight:600;}
.tag-opt.sel{background:var(--t);color:var(--bg);}
/* ALERTS */
.alert-card{background:var(--bg2);border-radius:var(--r);padding:14px 16px;margin-bottom:8px;display:flex;align-items:flex-start;gap:12px;}
.alert-body{flex:1;}
.alert-msg{font-size:14px;font-weight:600;margin-bottom:3px;outline:none;}
.alert-time{font-size:12px;color:var(--t3);}
.alert-actions{display:flex;gap:6px;}
.notif-row{display:flex;align-items:center;gap:10px;padding:12px 0;border-bottom:0.5px solid var(--bdr);}
.notif-row:last-child{border-bottom:none;}
.notif-lbl{font-size:14px;font-weight:500;flex:1;}
.notif-time{font-size:12px;color:var(--t2);}
.tgl{position:relative;width:48px;height:28px;flex-shrink:0;}
.tgl input{opacity:0;width:0;height:0;}
.tgl-sl{position:absolute;inset:0;background:var(--bg3);border-radius:14px;cursor:pointer;transition:background .2s;}
.tgl-sl:before{content:'';position:absolute;width:22px;height:22px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 4px rgba(0,0,0,0.2);}
.tgl input:checked+.tgl-sl{background:var(--g);}
.tgl input:checked+.tgl-sl:before{transform:translateX(20px);}
.epick{font-size:24px;cursor:pointer;padding:5px;border-radius:8px;line-height:1;display:inline-block;}
.epick:hover{background:var(--bg2);}
/* SUPPLEMENTS */
.supp-item{padding:16px 0;border-bottom:0.5px solid var(--bdr);}
.supp-item:last-child{border-bottom:none;}
.supp-name{font-size:16px;font-weight:700;}
.supp-when{font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;background:var(--bg2);color:var(--t2);margin-left:8px;}
.supp-desc{font-size:13px;color:var(--t2);line-height:1.6;margin:8px 0;}
.supp-how{font-size:13px;background:var(--bg2);border-radius:var(--rsm);padding:10px 14px;line-height:1.5;}
/* PRE-WORKOUT */
.pw-block{border-radius:var(--rlg);padding:18px;margin-bottom:12px;border:0.5px solid transparent;}
.pw-ti{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;background:transparent;border:none;border-bottom:1.5px dashed rgba(0,0,0,0.15);outline:none;width:100%;font-family:var(--font);margin-bottom:10px;}
.pw-body{font-size:15px;line-height:1.7;min-height:24px;}
.pw-body:focus{outline:2px solid rgba(0,0,0,0.1);border-radius:6px;}
.pw-ctrl{display:flex;gap:6px;margin-top:12px;align-items:center;flex-wrap:wrap;}
.cdot{width:22px;height:22px;border-radius:50%;cursor:pointer;border:2.5px solid transparent;flex-shrink:0;}
.cdot.sel{border-color:rgba(0,0,0,0.5);transform:scale(1.2);}
.pw-del{font-size:12px;color:var(--red);background:none;border:none;cursor:pointer;margin-left:auto;font-weight:700;}
.add-block-btn{width:100%;padding:16px;border:2px dashed var(--bdr2);border-radius:var(--rlg);background:transparent;color:var(--t3);font-size:15px;cursor:pointer;font-family:var(--font);font-weight:600;margin-bottom:12px;}
/* DELOAD */
.deload-c{border-radius:var(--r);padding:14px 16px;margin-bottom:14px;}
.deload-c.ok{background:var(--gl);border:0.5px solid var(--g);}
.deload-c.warn{background:var(--al);border:0.5px solid var(--a);}
.deload-c.danger{background:var(--redl);border:0.5px solid var(--red);}
.deload-t{font-size:13px;font-weight:700;margin-bottom:4px;}
.deload-c.ok .deload-t{color:var(--gd);}.deload-c.warn .deload-t{color:var(--ad);}.deload-c.danger .deload-t{color:var(--red);}
.deload-b{font-size:12px;line-height:1.6;}
.deload-c.ok .deload-b{color:var(--gd);}.deload-c.warn .deload-b{color:var(--ad);}.deload-c.danger .deload-b{color:var(--red);}
/* CALENDAR */
.cal-toolbar{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap;}
.cal-toolbar input[type=month]{font-size:13px;padding:7px 10px;flex:1;}
.tpl-btn{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;padding:8px 14px;border:0.5px solid var(--bdr2);border-radius:var(--r);cursor:pointer;background:var(--bg2);color:var(--t);}
.tpl-btn:hover{background:var(--bg3);}
.tpl-btn-icon{font-size:18px;}
.cal-nav{display:flex;align-items:center;gap:10px;margin-bottom:14px;}
.cal-nav-btn{font-size:22px;color:var(--t2);background:none;border:0.5px solid var(--bdr);border-radius:8px;padding:2px 12px;cursor:pointer;font-weight:300;}
.cal-month-lbl{font-size:16px;font-weight:700;flex:1;}
.cal-dh-row{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:4px;}
.cal-dh{font-size:10px;color:var(--t3);text-align:center;font-weight:700;padding:3px 0;}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;}
.cc{border-radius:var(--rsm);min-height:46px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;border:0.5px solid transparent;padding:3px;}
.cc:active{opacity:.7;}.cc.empty{pointer-events:none;}
.ccn{font-size:13px;font-weight:600;}
.cdots{display:flex;gap:2px;margin-top:3px;justify-content:center;}
.cdot-sm{width:4px;height:4px;border-radius:50%;}
.cc.today{background:var(--bl);border-color:var(--b);}.cc.today .ccn{color:var(--bd);}
.cc.hgym{background:var(--gl);border-color:rgba(29,158,117,0.3);}.cc.hgym .ccn{color:var(--gd);}
.cc.hpos{background:#e8f8f0;border-color:var(--g);}.cc.hpos .ccn{color:var(--gd);}
.cc.hneg{background:#fef0f0;border-color:var(--red);}.cc.hneg .ccn{color:var(--red);}
.wk-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:7px;}
.wk-cell{border-radius:var(--r);padding:8px 4px;border:0.5px solid var(--bdr);text-align:center;cursor:pointer;min-height:72px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:4px;padding-top:10px;}
.wk-cell:active{opacity:.7;}
.wk-lbl{font-size:10px;color:var(--t3);font-weight:700;}
.wk-date{font-size:15px;font-weight:700;margin-bottom:2px;}
.wk-dots{display:flex;gap:3px;justify-content:center;}
.wk-dot{width:7px;height:7px;border-radius:50%;}
.wk-tag{font-size:9px;font-weight:700;padding:3px 6px;border-radius:20px;margin-top:3px;}
.cal-legend{display:flex;gap:12px;flex-wrap:wrap;margin-top:10px;font-size:11px;color:var(--t2);font-weight:600;}
.cal-legend-item{display:flex;align-items:center;gap:5px;}
.cleg-dot{width:8px;height:8px;border-radius:50%;}
/* TEMPLATE EDITOR */
.te-ov{position:fixed;inset:0;background:var(--bg);z-index:900;display:flex;flex-direction:column;}
.te-ov.h{display:none!important;}
.te-hdr{display:flex;align-items:center;gap:12px;padding:calc(14px + var(--st)) 16px 14px;border-bottom:0.5px solid var(--bdr);}
.te-title{font-size:18px;font-weight:800;flex:1;}
.te-body{flex:1;overflow-y:auto;padding:20px 16px;padding-bottom:calc(24px + var(--sb));}
.te-preview{border-radius:var(--rlg);padding:20px;margin-bottom:16px;min-height:60px;border:0.5px solid var(--bdr);background:var(--bg2);}
.tpl-item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg2);border-radius:var(--r);margin-bottom:8px;cursor:pointer;border:1.5px solid var(--bdr);}
.tpl-item.active{border-color:var(--g);}
.tpl-item-dot{width:34px;height:34px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:800;}
.tpl-item-name{font-size:14px;font-weight:700;flex:1;}
.tpl-item-actions{display:flex;gap:6px;}
/* COLOR TABS */
.ctabs-row{display:flex;gap:0;background:var(--bg2);border-radius:var(--r);padding:4px;margin-bottom:14px;}
.ctab{flex:1;font-size:13px;font-weight:700;padding:8px;cursor:pointer;color:var(--t2);border-radius:var(--rsm);text-align:center;border:none;background:transparent;font-family:var(--font);}
.ctab.active{background:var(--bg);color:var(--t);box-shadow:0 1px 4px rgba(0,0,0,0.1);}
.ctab-panel{display:none;}.ctab-panel.active{display:block;}
.color-spectrum{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px;}
.cswatch{width:30px;height:30px;border-radius:50%;cursor:pointer;border:2.5px solid transparent;}
.cswatch.sel{border-color:var(--t);transform:scale(1.2);}
.cswatch:hover{transform:scale(1.1);}
/* TAB EDITOR */
.te-tab-item{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg2);border-radius:var(--r);margin-bottom:8px;border:0.5px solid var(--bdr);}
.te-tab-icon{font-size:22px;background:transparent;border:none;outline:none;width:38px;text-align:center;cursor:text;font-family:var(--font);}
.te-tab-name{flex:1;font-size:14px;font-weight:600;background:transparent;border:none;border-bottom:1.5px solid var(--bdr2);outline:none;font-family:var(--font);color:var(--t);padding-bottom:3px;}
.te-tab-name:focus{border-bottom-color:var(--g);}
/* SEARCH */
.search-bar{display:flex;align-items:center;gap:10px;background:var(--bg2);border:0.5px solid var(--bdr2);border-radius:var(--rlg);padding:13px 16px;margin-bottom:14px;}
.search-inp{flex:1;background:transparent;border:none;font-size:15px;color:var(--t);outline:none;font-family:var(--font);}
.search-inp::placeholder{color:var(--t3);}
.filter-row{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:14px;}
.fpill{font-size:12px;padding:5px 12px;border:0.5px solid var(--bdr2);border-radius:20px;cursor:pointer;background:var(--bg);color:var(--t2);font-weight:600;}
.fpill.active{background:var(--t);color:var(--bg);}
/* DATE RANGE */
.drange{display:flex;gap:8px;align-items:center;margin-bottom:12px;flex-wrap:wrap;}
.drange input{flex:1;}
.drange-lbl{font-size:12px;color:var(--t3);font-weight:600;}
/* EXPORT BAR */
.export-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px;padding:14px 16px;background:var(--bg2);border-radius:var(--r);border:0.5px solid var(--bdr);}
/* IMPORT */
.import-zone{border:2px dashed var(--bdr2);border-radius:var(--r);padding:24px;text-align:center;cursor:pointer;margin-bottom:14px;}
.import-zone:hover{background:var(--bg2);}
.import-zone-t{font-size:15px;font-weight:700;margin-bottom:4px;}
.import-zone-s{font-size:13px;color:var(--t3);}
/* FULLSCREEN IMG */
.fso{position:fixed;inset:0;background:rgba(0,0,0,0.92);z-index:2000;display:flex;align-items:center;justify-content:center;}
.fso.h{display:none!important;}
.fso img{max-width:95vw;max-height:90vh;object-fit:contain;border-radius:var(--rsm);}
.fso-close{position:absolute;top:20px;right:20px;font-size:30px;color:#fff;background:none;border:none;cursor:pointer;}

/* BEAUTIFUL CHARTS */
.chart-card{background:var(--bg);border:0.5px solid var(--bdr);border-radius:var(--rlg);padding:20px;margin-bottom:16px;overflow:hidden;}
.chart-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px;}
.chart-card-title{font-size:15px;font-weight:800;letter-spacing:-0.3px;}
.chart-card-sub{font-size:12px;color:var(--t3);margin-bottom:16px;}
.chart-card-value{font-size:28px;font-weight:800;letter-spacing:-1px;}
.chart-pills{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px;}
.chart-pill{font-size:11px;padding:5px 12px;border:0.5px solid var(--bdr2);border-radius:20px;cursor:pointer;font-weight:700;color:var(--t2);}
.chart-pill.active{background:var(--t);color:var(--bg);}

/* FINANCE CARDS */
.fin-summary{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px;}
.fin-card{border-radius:var(--r);padding:14px 16px;}
.fin-card.income{background:var(--gl);}.fin-card.income .fin-val{color:var(--gd);}
.fin-card.expense{background:var(--redl);}.fin-card.expense .fin-val{color:var(--red);}
.fin-card.net.pos{background:var(--gl);}.fin-card.net.pos .fin-val{color:var(--gd);}
.fin-card.net.neg{background:var(--redl);}.fin-card.net.neg .fin-val{color:var(--red);}
.fin-card.savings{background:var(--bl);}.fin-card.savings .fin-val{color:var(--bd);}
.fin-lbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;opacity:.7;margin-bottom:4px;}
.fin-val{font-size:22px;font-weight:800;letter-spacing:-0.5px;}
.fin-sub{font-size:11px;opacity:.6;margin-top:2px;font-weight:600;}

/* BUDGET BARS */
.budget-row{margin-bottom:14px;}
.budget-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;}
.budget-cat{font-size:13px;font-weight:700;}
.budget-amt{font-size:12px;color:var(--t3);font-weight:600;}
.budget-bar{height:8px;background:var(--bg3);border-radius:4px;overflow:hidden;}
.budget-fill{height:100%;border-radius:4px;transition:width .5s ease;}
.budget-fill.ok{background:var(--g);}
.budget-fill.warn{background:var(--a);}
.budget-fill.over{background:var(--red);}

/* TRANSACTION LIST */
.tx-card{display:flex;align-items:center;gap:12px;padding:13px 0;border-bottom:0.5px solid var(--bdr);}
.tx-card:last-child{border-bottom:none;}
.tx-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.tx-body{flex:1;min-width:0;}
.tx-name{font-size:14px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.tx-meta{font-size:12px;color:var(--t3);margin-top:2px;}
.tx-amt{font-size:16px;font-weight:800;flex-shrink:0;}
.tx-amt.income{color:var(--g);}
.tx-amt.expense{color:var(--red);}

/* FIN CALENDAR */
.fin-cal-day{border-radius:var(--rsm);min-height:52px;border:0.5px solid transparent;cursor:pointer;padding:4px 5px;display:flex;flex-direction:column;}
.fin-cal-day.empty{pointer-events:none;}
.fin-cal-day:active{opacity:.7;}
.fin-cal-day.has-data{background:var(--bg2);border-color:var(--bdr);}
.fin-cal-day.today{border-color:var(--b);background:var(--bl);}
.fcd-num{font-size:11px;font-weight:700;}
.fcd-amt{font-size:9px;font-weight:700;margin-top:2px;}
.fcd-amt.pos{color:var(--g);}
.fcd-amt.neg{color:var(--red);}


/* METRIC ACHIEVEMENT BADGES */
.metric.achieved::after{content:'✓';position:absolute;top:8px;right:8px;font-size:13px;font-weight:800;color:var(--g);background:var(--gl);border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;line-height:22px;text-align:center;}
.metric.close::after{content:'↑';position:absolute;top:8px;right:8px;font-size:13px;font-weight:800;color:var(--a);background:var(--al);border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;line-height:22px;text-align:center;}

