:root{--bg:#0a0d12;--s1:#12161d;--s2:#1a1f2a;--br:#252b38;--acc:#6366f1;--grn:#10b981;--red:#ef4444;--txt:#e2e8f0;--mut:#64748b;--gold:#f59e0b;--sat:env(safe-area-inset-top,0px)}
body.theme-light{--bg:#f0f2f7;--s1:#ffffff;--s2:#e8eaf0;--br:#d1d5e0;--acc:#6366f1;--grn:#059669;--red:#dc2626;--txt:#1a1f2a;--mut:#64748b;--gold:#d97706}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}
#bio-pin-btn{width:66px;height:66px;border-radius:50%;background:var(--s2);border:1.5px solid var(--br);color:var(--txt);font-size:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;margin-top:18px;transition:background .15s,transform .1s;-webkit-user-select:none;user-select:none}
#bio-pin-btn:active{background:var(--acc);transform:scale(.93)}
html,body{height:100%;overflow:hidden}
body{background:var(--bg);color:var(--txt);font-family:-apple-system,BlinkMacSystemFont,'SF Pro Display',sans-serif}
.hidden{display:none!important}
.page{position:absolute;inset:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:80px;padding-top:var(--sat)}
.page::-webkit-scrollbar{width:0}
#pin-wrap{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 24px;padding-top:calc(32px + var(--sat))}
.pin-dots{display:flex;gap:18px;margin:24px 0 8px}
.pd{width:14px;height:14px;border-radius:50%;border:2px solid var(--br);transition:all .18s}
.pd.on{background:var(--acc);border-color:var(--acc);transform:scale(1.1)}
.pd.err{background:var(--red);border-color:var(--red)}
.pin-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;width:min(280px,80vw);margin-top:16px}
.pb{height:68px;border-radius:50%;background:var(--s2);border:1px solid var(--br);color:var(--txt);font-size:24px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,transform .1s;user-select:none;-webkit-user-select:none}
.pb:active{background:var(--acc);transform:scale(.93)}
.pb.del{background:transparent;border:none;font-size:20px;color:var(--mut)}
.pb.empty{background:transparent;border:none;pointer-events:none}
nav{position:fixed;bottom:0;left:0;right:0;background:var(--s1);border-top:1px solid var(--br);display:flex;z-index:100;padding-bottom:max(env(safe-area-inset-bottom),6px)}
.nb{flex:1;padding:10px 0 7px;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;font-weight:600;color:var(--mut);cursor:pointer;user-select:none}
.nb i{font-size:20px}
.nb.on{color:var(--acc)}
.fab{display:none!important}
.nb-add{flex:1;padding:0;background:none;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;margin-top:-18px}
.nb-add-inner{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--acc),#818cf8);box-shadow:0 4px 18px rgba(99,102,241,.5);display:flex;align-items:center;justify-content:center;color:#fff;animation:nb-pulse 2.5s ease-in-out infinite}
.nb-add:active .nb-add-inner{transform:scale(.92)!important;animation:none}
@keyframes nb-pulse{0%,100%{box-shadow:0 4px 18px rgba(99,102,241,.5),0 0 0 0 rgba(99,102,241,.3)}60%{box-shadow:0 4px 24px rgba(99,102,241,.7),0 0 0 10px rgba(99,102,241,0)}}
.hdr{background:var(--s1);border-bottom:1px solid var(--br);padding:14px 0 14px;position:sticky;top:0;z-index:50}
.card{background:var(--s1);border:1px solid var(--br);border-radius:16px;padding:16px}
.card2{background:var(--s2);border-radius:12px;padding:11px}
.chip{flex:1;background:var(--s2);border-radius:11px;padding:11px 8px;text-align:center}
.chip-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--mut);margin-bottom:4px}
.chip-val{font-size:15px;font-weight:800}
.seg{background:var(--bg);border-radius:11px;padding:3px;display:flex;gap:2px}
.sb{flex:1;padding:8px 4px;text-align:center;border-radius:8px;cursor:pointer;font-size:12px;font-weight:700;color:var(--mut);transition:all .18s;user-select:none;white-space:nowrap}
.sb.on{background:var(--acc);color:#fff}
.hi{background:var(--s1);border:1px solid var(--br);border-radius:13px;padding:12px 14px;display:flex;align-items:center;gap:12px}
.hico{width:40px;height:40px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.sw{position:relative;overflow:hidden;border-radius:13px;margin-bottom:8px}
.sw-acts{position:absolute;right:0;top:0;bottom:0;display:flex}
.sw-act{width:72px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:#fff;font-size:11px;font-weight:700;cursor:pointer}
.sw-inner{position:relative;z-index:2;transition:transform .28s ease}
.sw-inner.open{transform:translateX(-72px)}
.mo{position:fixed;inset:0;background:rgba(0,0,0,.82);z-index:500;display:flex;align-items:flex-end;justify-content:center}
.ms{background:var(--s1);width:100%;max-width:500px;border-radius:22px 22px 0 0;padding:18px 18px max(env(safe-area-inset-bottom),18px);max-height:92vh;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;transform:translateZ(0)}
.ms::-webkit-scrollbar{width:0}
.mh{width:38px;height:4px;background:var(--br);border-radius:2px;margin:0 auto 18px}
.inp{width:100%;background:var(--bg);border:1.5px solid var(--br);padding:14px;border-radius:12px;color:var(--txt);font-size:16px;outline:none;-webkit-appearance:none;appearance:none;transition:border-color .18s;font-family:inherit}
.inp:focus{border-color:var(--acc)}
select.inp{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%2364748b' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.lbl{font-size:12px;font-weight:600;color:var(--mut);margin-bottom:6px;display:block}
.row{display:flex;gap:10px}
.btn-p{background:var(--acc);color:#fff;border:none;border-radius:12px;padding:16px;font-size:15px;font-weight:700;cursor:pointer;width:100%;font-family:inherit;transition:opacity 0.2s}
.btn-p:active{opacity:.85}
.btn-p:disabled{opacity:0.5;cursor:not-allowed}
.btn-s{background:var(--s2);color:var(--txt);border:1px solid var(--br);border-radius:12px;padding:15px;font-size:14px;font-weight:600;cursor:pointer;width:100%;font-family:inherit;transition:opacity 0.2s}
.btn-s:disabled{opacity:0.5;cursor:not-allowed}
.btn-d{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25);color:var(--red);border-radius:12px;padding:15px;font-size:14px;font-weight:600;cursor:pointer;width:100%;font-family:inherit}
.gap{display:flex;flex-direction:column;gap:12px}
.mn{display:flex;align-items:center;gap:10px;background:var(--s2);border-radius:11px;padding:9px 12px}
.mn button{background:var(--br);border:none;color:var(--txt);width:34px;height:34px;border-radius:9px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.bb{background:var(--br);border-radius:100px;height:5px;overflow:hidden;margin-top:5px}
.bf{height:100%;border-radius:100px;transition:width .4s}
#toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%);background:var(--s1);border:1.5px solid var(--br);color:var(--txt);border-radius:14px;padding:12px 22px;font-size:13px;font-weight:600;z-index:9999;transition:opacity .3s;opacity:0;pointer-events:none;white-space:nowrap;max-width:90vw;text-align:center;box-shadow:0 4px 20px rgba(0,0,0,.18)}
#toast.on{opacity:1}
#toast.toast-ok{border-color:var(--grn);color:var(--grn)}
#toast.toast-err{border-color:var(--red);color:var(--red)}
#toast.toast-info{border-color:var(--acc);color:var(--acc)}
#loading{position:fixed;inset:0;background:var(--bg);z-index:9998;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px}
.spin{width:38px;height:38px;border:3px solid var(--br);border-top-color:var(--acc);border-radius:50%;animation:sp .7s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
#sync-bar{display:none!important}
.drop-zone{border:1.5px dashed var(--br);border-radius:12px;padding:16px;text-align:center;cursor:pointer}
.sc{background:var(--s1);border:1px solid var(--br);border-radius:14px;padding:14px;margin-bottom:10px}
.srow{padding:13px 0;border-bottom:1px solid var(--br);display:flex;align-items:center;gap:12px}
.srow:last-child{border-bottom:none}
.ctag{background:var(--s2);border:1px solid var(--br);border-radius:9px;padding:7px 13px;font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:7px;cursor:pointer;margin:0 6px 6px 0;transition:opacity 0.2s}
.ctag:active{opacity:0.7}
#offline-badge{position:fixed;top:var(--sat);left:0;right:0;background:var(--gold);color:#000;font-size:11px;font-weight:700;text-align:center;padding:8px;z-index:9996;display:none}
.bud-bar-wrap{background:var(--bg);border-radius:100px;height:8px;overflow:hidden;margin-top:6px}
.bud-bar{height:100%;border-radius:100px;transition:width .5s ease}
.bud-bar.ok{background:var(--grn)}
.bud-bar.warn{background:var(--gold)}
.bud-bar.over{background:var(--red)}
.bud-card{background:var(--s1);border:1px solid var(--br);border-radius:14px;padding:14px 16px;margin-bottom:10px}
.bud-card.warn-card{border-color:rgba(245,158,11,.4);background:rgba(245,158,11,.04)}
.bud-card.over-card{border-color:rgba(239,68,68,.4);background:rgba(239,68,68,.04)}

.pf-card{background:var(--s1);border:1px solid var(--br);border-radius:16px;padding:14px;margin-bottom:10px}
.pf-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--br)}
.pf-row:last-child{border-bottom:none}
.pf-ico{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;flex-shrink:0}
.rule-bar{height:8px;border-radius:100px;overflow:hidden;background:var(--bg);margin-top:6px}
.rule-fill{height:100%;border-radius:100px;transition:width .5s}

/* ── FAB пулс ── */
@keyframes fab-pulse{0%,100%{box-shadow:0 4px 20px rgba(99,102,241,.45),0 0 0 0 rgba(99,102,241,.4)}70%{box-shadow:0 4px 20px rgba(99,102,241,.45),0 0 0 14px rgba(99,102,241,0)}}
.fab{animation:fab-pulse 2.4s ease infinite}

/* ── Ripple ── */
.ripple-host{position:relative;overflow:hidden}
@keyframes ripple-anim{to{transform:scale(4);opacity:0}}
.ripple-wave{position:absolute;border-radius:50%;background:rgba(255,255,255,.28);transform:scale(0);animation:ripple-anim .55s linear;pointer-events:none}

/* ── Nav bounce ── */
@keyframes nb-bounce{0%,100%{transform:translateY(0)}30%{transform:translateY(-5px)}60%{transform:translateY(-2px)}}
.nb-bounce{animation:nb-bounce .4s ease}

/* ── Stagger slide-in для списъка ── */
@keyframes slide-in-up{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.hi,.sc,.bud-card,.pf-card{animation:slide-in-up .35s ease both}

/* ── Баланс движещ се градиент ── */
@keyframes grad-move{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
#home-bal-card{background:linear-gradient(135deg,var(--acc),#8b5cf6,#06b6d4,var(--acc));background-size:300% 300%;animation:grad-move 6s ease infinite;border-radius:20px;padding:20px;margin:12px 14px 0;box-shadow:0 8px 32px rgba(99,102,241,.35)}
#h-bal{color:#fff!important;text-shadow:0 2px 12px rgba(0,0,0,.2)}
#h-curr-lbl{color:rgba(255,255,255,.7)!important}
#home-period-row{padding:0 14px;margin-top:12px}

/* ── 3D tilt ── */
.tilt-card{transform-style:preserve-3d;transition:transform .12s ease,box-shadow .12s ease;will-change:transform}

/* ── Skeleton shimmer ── */
@keyframes shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}
.skeleton{background:linear-gradient(90deg,var(--s2) 25%,var(--br) 50%,var(--s2) 75%);background-size:400px 100%;animation:shimmer 1.4s ease infinite;border-radius:8px;display:inline-block}

/* ── Chip pop ── */
@keyframes chip-pop{0%{transform:scale(1)}50%{transform:scale(1.07)}100%{transform:scale(1)}}
.chip-pop{animation:chip-pop .3s ease}

/* ── Countup blur ── */
@keyframes num-appear{from{filter:blur(6px);opacity:0;transform:translateY(6px)}to{filter:blur(0);opacity:1;transform:translateY(0)}}
.num-anim{animation:num-appear .4s ease both}

/* ── Category filter chips ── */
.cat-chips-wrap{display:flex;gap:6px;padding:0 14px 10px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.cat-chips-wrap::-webkit-scrollbar{display:none}
.cat-chip{flex-shrink:0;background:var(--s2);border:1.5px solid var(--br);border-radius:20px;padding:6px 13px;font-size:12px;font-weight:700;color:var(--mut);cursor:pointer;transition:all .18s;white-space:nowrap}
.cat-chip.on{background:var(--acc);border-color:var(--acc);color:#fff}

/* ── Date group headers in history ── */
.date-group-hdr{position:sticky;top:0;z-index:10;background:var(--bg);padding:6px 0 4px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;color:var(--mut);display:flex;align-items:center;gap:8px}
.date-group-hdr::after{content:'';flex:1;height:1px;background:var(--br)}

/* ── Nav SVG icons ── */
.nb-ico{display:flex;align-items:center;justify-content:center;width:24px;height:24px}
.nb-ico svg{width:24px;height:24px}

/* ── iOS nav style: outline=inactive, fill=active ── */
nav.nav-ios .nb-ico-s{display:none!important}
nav.nav-ios .nb.on .nb-ico-o{display:none!important}
nav.nav-ios .nb.on .nb-ico-s{display:flex!important}

/* ── More drawer ── */
#mo-more{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.55);backdrop-filter:blur(2px)}
#mo-more-sheet{position:absolute;bottom:0;left:0;right:0;background:var(--s1);border-radius:24px 24px 0 0;padding:18px 16px max(env(safe-area-inset-bottom),20px);border-top:1px solid var(--br)}
.more-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
.more-item{background:var(--s2);border:1px solid var(--br);border-radius:16px;padding:16px 14px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:opacity .15s;user-select:none}
.more-item:active{opacity:.7}
.more-item-ico{width:40px;height:40px;border-radius:12px;background:rgba(99,102,241,.12);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--acc);font-size:20px;position:relative}
.more-item-ico svg{width:22px;height:22px}
.more-item-lbl{font-size:14px;font-weight:700}

/* ── Nav icon style picker ── */
.nav-style-opts{display:flex;gap:8px;margin-top:10px}
.nav-style-opt{flex:1;background:var(--s2);border:2px solid var(--br);border-radius:14px;padding:10px 6px;text-align:center;cursor:pointer;transition:all .18s;display:flex;flex-direction:column;align-items:center;gap:6px}
.nav-style-opt.on{border-color:var(--acc);background:rgba(99,102,241,.08)}
.nav-style-opt span{font-size:11px;font-weight:700;color:var(--mut)}
.nav-style-opt.on span{color:var(--acc)}
