:root,[data-theme=light]{color-scheme:light;--bg-page: #f4f6fb;--bg-surface: #ffffff;--bg-subtle: #f9fafb;--bg-muted: #f3f4f6;--bg-nav: rgba(255,255,255,.95);--border-light: #ebebf0;--border: #e5e7eb;--border-strong: #d1d5db;--text-primary: #1a1a2e;--text-secondary: #374151;--text-muted: #6b7280;--text-placeholder: #9ca3af;--primary: #4f46e5;--primary-hover: #4338ca;--primary-bg: #ede9fe;--primary-text: #4f46e5;--income-bg: #f0fdf4;--income-text: #15803d;--income-bright: #16a34a;--expense-bg: #fef2f2;--expense-text: #dc2626;--expense-bright: #dc2626;--balance-bg: #ede9fe;--balance-text: #4f46e5;--warn-bg: #fef3c7;--warn-bg-alt: #fffbeb;--warn-text: #d97706;--danger-bg: #fef2f2;--danger-text: #dc2626;--success-bg: #dcfce7;--success-text: #16a34a;--overlay: rgba(15,15,30,.5);--shadow-card: 0 1px 3px rgba(0,0,0,.05), 0 4px 16px rgba(0,0,0,.04);--shadow-modal: 0 20px 60px rgba(0,0,0,.18);--shadow-popup: 0 8px 32px rgba(0,0,0,.12)}[data-theme=dark]{color-scheme:dark;--bg-page: #0e0e1a;--bg-surface: #18182c;--bg-subtle: #1e1e30;--bg-muted: #252538;--bg-nav: rgba(24,24,44,.95);--border-light: #2c2c42;--border: #34344e;--border-strong: #464664;--text-primary: #eaeaf8;--text-secondary: #b8b8d8;--text-muted: #8888b8;--text-placeholder: #6868a0;--primary: #6366f1;--primary-hover: #818cf8;--primary-bg: rgba(99,102,241,.18);--primary-text: #818cf8;--income-bg: rgba(22,163,74,.14);--income-text: #4ade80;--income-bright: #22c55e;--expense-bg: rgba(220,38,38,.14);--expense-text: #f87171;--expense-bright: #ef4444;--balance-bg: rgba(99,102,241,.18);--balance-text: #a5b4fc;--warn-bg: rgba(217,119,6,.16);--warn-bg-alt: rgba(217,119,6,.12);--warn-text: #fbbf24;--danger-bg: rgba(220,38,38,.14);--danger-text: #f87171;--success-bg: rgba(22,163,74,.14);--success-text: #4ade80;--overlay: rgba(0,0,0,.7);--shadow-card: 0 1px 3px rgba(0,0,0,.3), 0 4px 16px rgba(0,0,0,.4);--shadow-modal: 0 20px 60px rgba(0,0,0,.55);--shadow-popup: 0 8px 32px rgba(0,0,0,.4)}[data-theme=slate]{color-scheme:dark;--bg-page: #2a2d40;--bg-surface: #33364e;--bg-subtle: #3a3d58;--bg-muted: #424565;--bg-nav: rgba(51,54,78,.95);--border-light: #484b6e;--border: #525578;--border-strong: #636690;--text-primary: #e8eaf8;--text-secondary: #b8bcdc;--text-muted: #8890c0;--text-placeholder: #6870a8;--primary: #818cf8;--primary-hover: #a5b4fc;--primary-bg: rgba(129,140,248,.18);--primary-text: #a5b4fc;--income-bg: rgba(52,211,153,.16);--income-text: #34d399;--income-bright: #10b981;--expense-bg: rgba(248,113,113,.16);--expense-text: #fca5a5;--expense-bright: #f87171;--balance-bg: rgba(129,140,248,.18);--balance-text: #a5b4fc;--warn-bg: rgba(252,211,77,.16);--warn-bg-alt: rgba(252,211,77,.11);--warn-text: #fcd34d;--danger-bg: rgba(248,113,113,.16);--danger-text: #fca5a5;--success-bg: rgba(52,211,153,.16);--success-text: #34d399;--overlay: rgba(0,0,0,.6);--shadow-card: 0 1px 3px rgba(0,0,0,.2), 0 4px 16px rgba(0,0,0,.28);--shadow-modal: 0 20px 60px rgba(0,0,0,.42);--shadow-popup: 0 8px 32px rgba(0,0,0,.32)}[data-theme=dim]{color-scheme:dark;--bg-page: #1a1d2e;--bg-surface: #22253c;--bg-subtle: #282b44;--bg-muted: #2f3252;--bg-nav: rgba(34,37,60,.95);--border-light: #363858;--border: #3e4165;--border-strong: #4e5188;--text-primary: #ccd0e8;--text-secondary: #9498b8;--text-muted: #6468a0;--text-placeholder: #484c7a;--primary: #818cf8;--primary-hover: #a5b4fc;--primary-bg: rgba(129,140,248,.18);--primary-text: #818cf8;--income-bg: rgba(52,211,153,.14);--income-text: #34d399;--income-bright: #10b981;--expense-bg: rgba(248,113,113,.14);--expense-text: #fca5a5;--expense-bright: #f87171;--balance-bg: rgba(129,140,248,.18);--balance-text: #a5b4fc;--warn-bg: rgba(252,211,77,.14);--warn-bg-alt: rgba(252,211,77,.1);--warn-text: #fcd34d;--danger-bg: rgba(248,113,113,.14);--danger-text: #fca5a5;--success-bg: rgba(52,211,153,.14);--success-text: #34d399;--overlay: rgba(0,0,0,.65);--shadow-card: 0 1px 3px rgba(0,0,0,.2), 0 4px 16px rgba(0,0,0,.3);--shadow-modal: 0 20px 60px rgba(0,0,0,.45);--shadow-popup: 0 8px 32px rgba(0,0,0,.35)}:root{--color-text: var(--text-primary);--color-text2: var(--text-muted);--color-text3: var(--text-placeholder);--color-bg: var(--bg-surface);--color-bg2: var(--bg-subtle);--color-primary: var(--primary);--color-hover: var(--bg-muted);--color-border: var(--border)}@media (max-width: 768px){input:not([type=checkbox]):not([type=radio]):not([type=color]),select,textarea{font-size:16px!important}}@media (max-width: 768px){input:not([type=checkbox]):not([type=radio]):not([type=color]),select,textarea{max-width:100%;min-width:0;width:100%;box-sizing:border-box}}.login-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-page)}.login-box{background:var(--bg-surface);border-radius:12px;padding:48px 40px;width:100%;max-width:380px;box-shadow:var(--shadow-modal);border:1px solid var(--border)}.login-title{font-size:1.8rem;font-weight:700;text-align:center;margin:0 0 32px;color:var(--text-primary)}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:.875rem;font-weight:500;margin-bottom:6px;color:var(--text-muted)}.form-group input{width:100%;padding:10px 14px;border:1.5px solid var(--border-strong);border-radius:8px;font-size:1rem;outline:none;box-sizing:border-box;transition:border-color .2s;background:var(--bg-subtle);color:var(--text-primary)}.form-group input:focus{border-color:var(--primary)}.form-remember{margin:12px 0 20px;font-size:.875rem;color:var(--text-muted)}.form-remember label{display:flex;align-items:center;gap:8px;cursor:pointer}.form-remember input[type=checkbox]{width:auto!important;min-width:0!important;flex-shrink:0;margin:0;padding:0;accent-color:var(--primary)}.login-error{color:var(--danger-text);font-size:.875rem;margin:-8px 0 12px}.login-btn{width:100%;padding:12px;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.login-btn:hover:not(:disabled){background:var(--primary-hover)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-tabs{display:flex;border:1.5px solid var(--border);border-radius:8px;overflow:hidden;margin-bottom:28px}.login-tab{flex:1;padding:10px;background:none;border:none;font-size:.9rem;font-weight:500;color:var(--text-muted);cursor:pointer;transition:background .15s,color .15s}.login-tab:hover:not(.active){background:var(--bg-subtle)}.login-tab.active{background:var(--primary);color:#fff;font-weight:600}.form-optional{font-weight:400;font-size:.8rem;color:var(--text-placeholder, #9ca3af)}.gender-btns{display:flex;gap:8px}.gender-btn{flex:1;padding:8px 0;border:1.5px solid var(--border-strong);border-radius:8px;background:var(--bg-subtle);color:var(--text-muted);font-size:.9rem;font-weight:500;cursor:pointer;transition:border-color .15s,background .15s,color .15s}.gender-btn:hover:not(.active){border-color:var(--primary);color:var(--primary)}.gender-btn.active{border-color:var(--primary);background:var(--primary);color:#fff}@media (max-width: 480px){.login-box{padding:32px 20px}.login-title{font-size:1.5rem;margin-bottom:24px}}.pw-strength{display:flex;align-items:center;gap:8px;margin-top:6px}.pw-strength-bars{display:flex;gap:3px;flex:1}.pw-strength-bar{flex:1;height:4px;border-radius:2px;transition:background .2s}.pw-strength-label{font-size:.75rem;font-weight:600;white-space:nowrap;min-width:50px;text-align:right}.home-loading{display:flex;align-items:center;justify-content:center;height:calc(100vh - 58px);color:var(--text-placeholder)}.home-page{min-height:calc(100vh - 58px);background:var(--bg-page);padding-bottom:40px}@keyframes homePageIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.home-page-loaded{animation:homePageIn .35s ease both}.home-page-skeleton .home-hero .skeleton{background:linear-gradient(90deg,#fff3 25%,#ffffff59,#fff3 75%);background-size:400px 100%;animation:skeleton-shimmer 1.4s infinite linear}.home-hero{background:linear-gradient(135deg,#4f46e5,#6d28d9 60%,#7c3aed);color:#fff;padding:32px 28px 36px;position:relative;overflow:hidden}.hero-bg-circle{position:absolute;border-radius:50%;background:#ffffff0f;pointer-events:none}.hero-bg-circle.c1{width:300px;height:300px;top:-100px;right:-60px}.hero-bg-circle.c2{width:180px;height:180px;bottom:-80px;left:40px}.home-hero-inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:20px;max-width:1000px;margin:0 auto}.home-hero-left{display:flex;flex-direction:column;gap:5px}.home-greeting{font-size:.88rem;font-weight:500;opacity:.8;margin:0}.home-date{font-size:1.4rem;font-weight:800;margin:0;letter-spacing:-.02em}.home-weather{display:flex;align-items:center;gap:12px;background:#ffffff2e;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.25);border-radius:16px;padding:12px 18px;flex-shrink:0}.weather-emoji{font-size:2.2rem;line-height:1}.weather-info{display:flex;flex-direction:column;gap:2px}.weather-temp{font-size:1.6rem;font-weight:800;line-height:1}.weather-desc{font-size:.82rem;opacity:.9;font-weight:500}.weather-sub{font-size:.7rem;opacity:.65}.home-body{max-width:1000px;margin:0 auto;padding:20px;display:flex;flex-direction:column;gap:14px}.fortune-card{background:linear-gradient(135deg,#fdf4ff,#faf5ff,#f0f9ff);border:1px solid #e9d5ff;border-radius:18px;padding:18px 20px;display:flex;flex-direction:column;gap:10px}[data-theme=dark] .fortune-card,[data-theme=dim] .fortune-card{background:linear-gradient(135deg,#8b5cf61f,#a855f714,#3b82f614);border-color:#8b5cf640}[data-theme=slate] .fortune-card{background:linear-gradient(135deg,#8b5cf614,#a855f70d,#3b82f60d);border-color:#8b5cf633}.fortune-header{display:flex;align-items:center;gap:8px}.fortune-icon{font-size:1.2rem;line-height:1}.fortune-title{font-size:.9rem;font-weight:700;color:var(--text-primary);flex:1}.fortune-date{font-size:.78rem;color:var(--text-secondary)}.fortune-stars{display:flex;align-items:center;gap:3px}.fortune-star{font-size:1.1rem;color:#c4b5fd;line-height:1}.fortune-star.filled{color:#7c3aed}.fortune-score-label{font-size:.78rem;font-weight:600;color:#7c3aed;margin-left:6px}[data-theme=dark] .fortune-star,[data-theme=dim] .fortune-star{color:#c4b5fd59}[data-theme=slate] .fortune-star{color:#c4b5fd66}[data-theme=dark] .fortune-star.filled,[data-theme=dim] .fortune-star.filled{color:#c084fc}[data-theme=slate] .fortune-star.filled{color:#a855f7}[data-theme=dark] .fortune-score-label,[data-theme=dim] .fortune-score-label{color:#c084fc}[data-theme=slate] .fortune-score-label{color:#a855f7}.fortune-text{font-size:.9rem;line-height:1.65;color:var(--text-primary);margin:0}.fortune-badges{display:flex;gap:8px;flex-wrap:wrap}.fortune-badge{font-size:.78rem;color:var(--text-secondary);background:#8b5cf614;border-radius:20px;padding:3px 12px;border:1px solid rgba(139,92,246,.15)}[data-theme=dark] .fortune-badge,[data-theme=dim] .fortune-badge{background:#8b5cf626;border-color:#8b5cf64d}[data-theme=slate] .fortune-badge{background:#8b5cf61a;border-color:#8b5cf638}.fortune-badge strong{color:#7c3aed;margin-left:3px}[data-theme=dark] .fortune-badge strong,[data-theme=dim] .fortune-badge strong{color:#c084fc}[data-theme=slate] .fortune-badge strong{color:#a855f7}.home-alerts{display:flex;flex-direction:column;gap:6px}.alert-item{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:12px;border:1px solid transparent}.alert-schedule{background:var(--bg-surface);border-color:var(--border-light)}.alert-warn{background:var(--warn-bg-alt);border-color:var(--warn-border, #f59e0b33)}.alert-over{background:var(--expense-bg);border-color:var(--danger-border, #ef444433)}.alert-icon{font-size:1rem;flex-shrink:0;line-height:1}.alert-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.alert-title{font-size:.86rem;font-weight:600;color:var(--text-primary);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.alert-budget-block{flex-direction:column;align-items:stretch;gap:4px}.alert-budget-row1{display:flex;align-items:center;gap:8px}.alert-budget-title{font-size:.86rem;font-weight:600;color:var(--text-primary);flex:1}.alert-budget-row2{display:flex;flex-direction:column;align-items:flex-start;gap:2px;font-size:.8rem;color:var(--text-secondary);padding-left:26px}.alert-badge{font-size:.75rem;font-weight:700;padding:2px 9px;border-radius:20px;white-space:nowrap;flex-shrink:0}.badge-time{background:var(--primary-subtle, #ede9fe);color:var(--primary, #4f46e5)}.badge-warn{background:#fef3c7;color:#b45309}.badge-over{background:var(--expense-bg);color:var(--expense-bright)}.home-top-row{display:grid;grid-template-columns:3fr 2fr;gap:14px}.widget{background:var(--bg-surface);border-radius:18px;padding:18px 20px;box-shadow:var(--shadow-card);border:1px solid var(--border-light);display:flex;flex-direction:column;gap:12px}.widget-head-row{display:flex;align-items:center;gap:8px}.widget-title{font-size:.9rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.widget-sub{font-size:.8rem;color:var(--text-placeholder);font-weight:500;flex:1}.widget-link{font-size:.78rem;color:var(--primary-text);text-decoration:none;font-weight:600;opacity:.8;white-space:nowrap}.widget-link:hover{opacity:1}.widget-empty{font-size:.85rem;color:var(--text-placeholder);margin:0;text-align:center;padding:12px 0}.fin-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.fin-item{border-radius:12px;padding:12px 14px;display:flex;flex-direction:column;gap:4px}.fi-label{font-size:.72rem;font-weight:600;opacity:.7}.fi-val{font-size:1rem;font-weight:800;letter-spacing:-.02em}.fin-item.income{background:var(--income-bg);color:var(--income-text)}.fin-item.expense{background:var(--expense-bg);color:var(--expense-text)}.fin-item.balance{background:var(--balance-bg);color:var(--balance-text)}.fin-item.balance.neg{background:var(--expense-bg);color:var(--expense-text)}.fin-item.budget{background:#ede9fe;color:#5b21b6}.schedule-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.schedule-item{display:flex;align-items:center;gap:8px}.s-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.s-title{font-size:.86rem;font-weight:600;color:var(--text-primary);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.s-time{font-size:.73rem;color:var(--text-placeholder);flex-shrink:0}.widget-photos{gap:14px}.photo-month-section{display:flex;flex-direction:column;gap:8px}.photo-month-label{font-size:.8rem;font-weight:700;color:var(--text-muted);letter-spacing:.02em}.photo-thumb-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.photo-thumb{aspect-ratio:1;border-radius:10px;overflow:hidden;cursor:pointer;background:var(--bg-muted)}.photo-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .2s}.photo-thumb:hover img{transform:scale(1.06)}.memo-add-toggle{background:var(--bg-muted);border:1.5px solid var(--border);border-radius:8px;padding:3px 10px;font-size:.78rem;font-weight:600;color:var(--text-muted);cursor:pointer;transition:background .1s}.memo-add-toggle:hover{background:var(--border-light)}.memo-form{background:var(--bg-subtle);border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:8px;border:1px solid var(--border-light)}.memo-textarea{width:100%;box-sizing:border-box;border:1.5px solid var(--border);border-radius:8px;padding:9px 12px;font-size:.88rem;background:var(--bg-surface);color:var(--text-primary);resize:vertical;outline:none;font-family:inherit;transition:border-color .15s;line-height:1.5}.memo-textarea:focus{border-color:var(--primary)}.memo-form-footer{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.memo-color-row{display:flex;gap:5px;flex:1}.memo-color-dot{width:20px;height:20px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .1s;flex-shrink:0}.memo-color-dot.selected{border-color:#374151;transform:scale(1.15)}.memo-shared-label{font-size:.8rem;color:var(--text-muted);display:flex;align-items:center;gap:4px;cursor:pointer;flex-shrink:0}.memo-submit-btn{background:var(--primary-bg);color:var(--primary-text);border:none;border-radius:8px;padding:6px 16px;font-size:.83rem;font-weight:600;cursor:pointer;flex-shrink:0}.memo-submit-btn:disabled{opacity:.45;cursor:not-allowed}.memo-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}.memo-card{border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:8px;box-shadow:0 2px 6px #00000014;transition:transform .15s,box-shadow .15s;min-height:100px}.memo-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.memo-card.pinned{box-shadow:0 3px 10px #00000026}.memo-card-body{flex:1}.memo-pin{font-size:.85rem;display:block;margin-bottom:3px}.memo-content{font-size:.83rem;line-height:1.55;color:#1f2937;margin:0;white-space:pre-wrap;word-break:break-word}.memo-shared-badge{display:inline-block;font-size:.65rem;font-weight:700;background:#0000001a;color:#374151;border-radius:6px;padding:1px 6px;margin-top:5px}.memo-card-footer{display:flex;align-items:center;justify-content:space-between;border-top:1px solid rgba(0,0,0,.06);padding-top:6px}.memo-owner{font-size:.7rem;color:#0006}.memo-card-btns{display:flex;gap:2px}.memo-card-btns button{background:none;border:none;cursor:pointer;font-size:.8rem;padding:2px 4px;border-radius:4px;color:#00000059;transition:background .1s}.memo-card-btns button:hover{background:#00000014;color:#0009}@media (max-width: 900px) and (min-width: 601px){.home-top-row{grid-template-columns:1fr 1fr}.photo-thumb-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width: 600px){.home-page{min-height:calc(100vh - 116px);padding-bottom:80px}.home-hero{padding:18px 14px 22px}.home-hero-inner{flex-direction:column;align-items:flex-start;gap:12px}.home-date{font-size:1.15rem}.home-weather{width:100%;box-sizing:border-box}.weather-emoji{font-size:1.8rem}.weather-temp{font-size:1.3rem}.home-body{padding:12px;gap:10px}.home-top-row{grid-template-columns:1fr}.fin-row{gap:6px}.fin-item{padding:10px}.fi-label{font-size:.68rem}.fi-val{font-size:.88rem}.widget{padding:14px;border-radius:14px}.photo-thumb-grid{grid-template-columns:repeat(3,1fr);gap:4px}.photo-thumb{border-radius:7px}.otd-desktop-view{display:none}.otd-mobile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.otd-mobile-grid .otd-thumb{width:auto;height:auto;aspect-ratio:1;border-radius:8px;flex-shrink:unset}}@media (max-width: 700px){.otd-desktop-view{display:none}.otd-mobile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.otd-mobile-grid .otd-thumb{width:auto;height:auto;aspect-ratio:1;border-radius:8px;flex-shrink:unset}}.widget-otd{padding-bottom:4px}.otd-year-group{margin-bottom:12px}.otd-year-label{font-size:.78rem;font-weight:600;color:var(--primary);display:block;margin-bottom:6px}.otd-thumb-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}.otd-thumb-row::-webkit-scrollbar{display:none}.otd-thumb{width:112px;height:112px;flex-shrink:0;border-radius:10px;overflow:hidden;cursor:pointer;background:var(--bg-muted)}.otd-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .2s}.otd-thumb:hover img{transform:scale(1.06)}.otd-recent-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.otd-recent-grid .otd-thumb{width:auto;height:auto;aspect-ratio:1;flex-shrink:unset}.otd-mobile-grid{display:none}.otd-desktop-view{display:block}.memo-search-input{width:100%;padding:6px 10px;border:1px solid var(--border-light);border-radius:7px;font-size:.82rem;background:var(--bg-subtle);color:var(--text-primary);outline:none;margin-bottom:6px;box-sizing:border-box}.memo-search-input:focus{border-color:var(--primary)}.ann-widget-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.ann-widget-item{display:flex;align-items:center;gap:6px;font-size:.85rem;padding:4px 0;border-bottom:1px solid var(--border-light)}.ann-widget-item:last-child{border-bottom:none}.ann-widget-emoji{font-size:1rem;flex-shrink:0}.ann-widget-title{flex:1;font-weight:500;color:var(--text-primary);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ann-widget-lunar{font-size:.68rem;font-weight:700;color:#f59e0b;background:#f59e0b22;border:1px solid #f59e0b55;border-radius:8px;padding:1px 5px;flex-shrink:0}.ann-widget-date{font-size:.78rem;color:var(--text-secondary);flex-shrink:0}.ann-widget-dday{font-size:.8rem;font-weight:700;flex-shrink:0;min-width:44px;text-align:right}.ann-widget-dday.today{font-size:.88rem;color:#ec4899!important}.ann-widget-dday.soon{color:#f59e0b!important}.ann-widget-elapsed{font-size:.78rem;font-weight:700;text-align:right;white-space:nowrap;line-height:1.4}.ann-widget-total{font-size:.72rem;font-weight:400;color:var(--text-secondary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay);display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);overflow-y:auto}.modal-box{background:var(--bg-surface);border-radius:20px;padding:24px;width:100%;max-width:480px;max-height:90vh;max-height:90dvh;overflow-y:auto;overflow-x:hidden;box-shadow:var(--shadow-modal);border:1px solid var(--border);flex-shrink:0}input[type=date],input[type=time],input[type=datetime-local]{-webkit-appearance:none;-moz-appearance:none;appearance:none;min-width:0;width:100%;min-height:38px;line-height:1.4}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal-header h3{margin:0;font-size:1.05rem;font-weight:800;letter-spacing:-.02em;color:var(--text-primary)}.modal-close{width:28px;height:28px;border-radius:50%;background:var(--bg-muted);border:none;font-size:.9rem;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:background .15s}.modal-close:hover{background:var(--border);color:var(--text-primary)}.modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}.btn-cancel{padding:9px 20px;border:1.5px solid var(--border);border-radius:10px;background:var(--bg-surface);cursor:pointer;font-size:.88rem;color:var(--text-secondary);font-weight:500;transition:background .15s}.btn-primary{padding:9px 22px;background:var(--primary);color:#fff;border:none;border-radius:10px;cursor:pointer;font-size:.88rem;font-weight:700;transition:opacity .15s}.btn-primary:hover{opacity:.88}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.share-group-label{display:inline-block;margin-left:4px;padding:1px 8px;background:var(--primary);color:#fff;border-radius:20px;font-size:.75rem;font-weight:600;opacity:.85}.form-group{margin-bottom:14px}.form-group label{display:block;font-size:.85rem;color:var(--text-muted);margin-bottom:5px;font-weight:500}.form-group label:has(input[type=checkbox]){display:flex;align-items:center;gap:8px;margin-bottom:0;cursor:pointer}.form-group input[type=checkbox]{width:auto;flex-shrink:0;margin:0;padding:0;accent-color:var(--primary)}.form-group input,.form-group textarea,.form-group select{width:100%;padding:8px 12px;border:1.5px solid var(--border-strong);border-radius:7px;font-size:.95rem;outline:none;box-sizing:border-box;background:var(--bg-subtle);color:var(--text-primary)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--primary)}.form-row{display:flex;gap:12px}.form-row .form-group{flex:1}.color-picker{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}.color-dot{width:28px;height:28px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:transform .1s}.color-dot.active{border-color:var(--text-primary);transform:scale(1.2)}.type-toggle{display:flex;gap:0;border:1.5px solid var(--border);border-radius:8px;overflow:hidden}.type-btn{flex:1;padding:8px;border:none;background:var(--bg-surface);cursor:pointer;font-size:.95rem;transition:background .15s;color:var(--text-secondary)}.type-btn.active-expense{background:var(--expense-bg);color:var(--expense-text);font-weight:600}.type-btn.active-income{background:var(--income-bg);color:var(--income-bright);font-weight:600}.cat-chips{display:flex;flex-wrap:wrap;gap:6px;min-height:30px}.cat-chip{padding:4px 12px;border-radius:20px;border:1.5px solid var(--border-strong);font-size:.85rem;cursor:pointer;background:var(--bg-subtle);color:var(--text-secondary);transition:background .15s,color .15s,border-color .15s}.recurrence-box{background:var(--bg-subtle);border-radius:8px;padding:12px;margin-bottom:14px;border:1.5px solid var(--border)}@media (max-width: 768px){.modal-overlay{align-items:flex-end;padding-top:56px}.modal-box{border-radius:16px 16px 0 0;max-width:100%;width:100%;max-height:92vh;max-height:92dvh;padding:20px 16px;padding-bottom:max(24px,env(safe-area-inset-bottom));margin-top:auto}.form-row{flex-direction:column;gap:0}.form-row .form-group{width:100%}.form-group input,.form-group select,.form-group textarea{width:100%;max-width:100%;box-sizing:border-box}}.scope-box{max-width:360px}.scope-desc{color:var(--text-muted);font-size:.9rem;margin:0 0 16px}.scope-options{display:flex;flex-direction:column;gap:8px}.scope-btn{display:flex;flex-direction:column;gap:3px;padding:14px 16px;border:1.5px solid var(--border);border-radius:8px;background:var(--bg-surface);cursor:pointer;text-align:left;transition:border-color .15s,background .15s}.scope-btn:hover{border-color:var(--primary);background:var(--primary-bg)}.scope-btn strong{font-size:.95rem;color:var(--text-primary)}.scope-btn span{font-size:.8rem;color:var(--text-placeholder)}.cal-page{display:flex;flex-direction:column;height:calc(100vh - 58px);background:var(--bg-page);overflow:hidden}.cal-topbar{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:var(--bg-surface);border-bottom:1px solid var(--border-light);gap:16px;flex-shrink:0}.cal-nav{display:flex;align-items:center;gap:8px}.cal-nav .nav-btn{background:var(--bg-muted);border:none;border-radius:10px;width:32px;height:32px;font-size:1.2rem;line-height:1;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:background .1s}.cal-nav .nav-btn:hover{background:var(--border)}.cal-nav .nav-title{margin:0;font-size:1.05rem;font-weight:800;color:var(--text-primary);white-space:nowrap;letter-spacing:-.02em}.cal-actions{display:flex;align-items:center;gap:6px}.act-btn.schedule{background:var(--primary-bg);color:var(--primary-text)}.cal-grid-wrap{flex:0 0 auto;padding:10px 16px 4px}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border-light);border:1px solid var(--border-light);border-radius:14px;overflow:hidden}.cal-head{background:var(--bg-subtle);text-align:center;padding:7px 0;font-size:.75rem;font-weight:700;color:var(--text-placeholder);letter-spacing:.02em}.cal-head.sun{color:#f87171}.cal-head.sat{color:#60a5fa}.cal-cell{background:var(--bg-surface);min-height:86px;max-height:86px;overflow:hidden;padding:6px 7px;cursor:pointer;transition:background .12s;position:relative;display:flex;flex-direction:column}.cal-cell:hover{background:var(--bg-subtle)}.cal-cell.empty{background:var(--bg-page);cursor:default}.cal-cell.today{background:var(--primary-bg)}.cal-cell.selected{background:var(--primary-bg);outline:2px solid var(--primary);outline-offset:-2px}.cal-cell.sun .cell-date{color:#ef4444}.cal-cell.sat .cell-date{color:#3b82f6}.cell-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:3px}.cell-date{font-size:.82rem;font-weight:600;line-height:1;flex-shrink:0;color:var(--text-primary)}.cal-cell.today .cell-date{background:var(--primary);color:#fff;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700}.cell-weather{font-size:.6rem;color:var(--text-muted);white-space:nowrap;line-height:1;flex-shrink:0}.cell-finance{display:flex;flex-direction:column;align-items:flex-end;gap:1px;margin-left:auto}.cell-fin{font-size:.62rem;font-weight:700;line-height:1.2;white-space:nowrap}.cell-fin.income{color:var(--income-bright)}.cell-fin.expense{color:var(--expense-bright)}.panel-fin-amount{font-size:.88rem;font-weight:700;white-space:nowrap;flex-shrink:0}.panel-fin-amount.income{color:var(--income-bright)}.panel-fin-amount.expense{color:var(--expense-bright)}.cell-chips{display:flex;flex-direction:column;gap:2px;flex:1}.chip{font-size:.68rem;color:#fff;border-radius:3px;padding:1px 5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.chip-more{font-size:.68rem;color:var(--text-placeholder)}.chip.chip-shared{opacity:.82;outline:1.5px dashed rgba(255,255,255,.6);outline-offset:-2px}.cal-bottom-panel{background:var(--bg-surface);border-top:2px solid var(--border-light);flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.bottom-panel-header{display:flex;align-items:center;gap:12px;padding:10px 20px;border-bottom:1px solid var(--border-light);background:var(--bg-subtle);flex-shrink:0}.bottom-date{font-weight:700;font-size:.95rem;color:var(--text-primary)}.bottom-summary{display:flex;gap:10px;font-size:.82rem;font-weight:600}.bottom-summary .fin-income{color:var(--income-bright)}.bottom-summary .fin-expense{color:var(--expense-bright)}.panel-dismiss{margin-left:auto;background:none;border:none;cursor:pointer;color:var(--text-placeholder);font-size:1rem;line-height:1}.panel-dismiss:hover{color:var(--text-muted)}.bottom-panel-body{display:flex;gap:0;flex:1;overflow:hidden}.bottom-section{flex:1;padding:10px 16px;overflow-y:auto;border-right:1px solid var(--border-light)}.bottom-section:last-child{border-right:none}.bottom-section-title{display:flex;align-items:center;justify-content:space-between;font-size:.82rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.section-add-btn{background:none;border:1.5px solid var(--border);border-radius:6px;padding:2px 8px;font-size:.78rem;cursor:pointer;color:var(--text-muted);transition:background .1s}.section-add-btn:hover{background:var(--bg-muted)}.empty-msg{font-size:.85rem;color:var(--text-placeholder);margin:4px 0}.bottom-item{display:flex;align-items:flex-start;gap:8px;padding:7px 0;border-bottom:1px solid var(--bg-subtle)}.bottom-item:last-child{border-bottom:none}.item-color-bar{width:3px;min-width:3px;height:100%;min-height:36px;border-radius:2px;flex-shrink:0}.item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.item-title{font-size:.88rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-title.income-text{color:var(--income-bright)}.item-title.expense-text{color:var(--expense-bright)}.shared-icon{font-size:.8rem;margin-right:2px}.item-meta.shared-owner{color:var(--text-secondary);font-weight:500}.recur-icon{font-size:.8rem;color:#a78bfa;margin-right:3px}.item-meta{font-size:.75rem;color:var(--text-placeholder)}.item-meta.alert{color:var(--warn-text)}.item-meta-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.item-tag{display:inline-block;font-size:.7rem;background:var(--bg-muted);color:var(--text-muted);border-radius:4px;padding:1px 6px}.item-btns{display:flex;gap:2px;flex-shrink:0}.item-btns button{background:none;border:none;cursor:pointer;font-size:.85rem;padding:3px 5px;border-radius:5px;color:var(--text-placeholder);transition:background .1s}.item-btns button:hover{background:var(--bg-muted);color:var(--text-secondary)}@media (max-width: 700px){.cal-page{height:calc(100vh - 116px)}.cal-topbar{flex-wrap:wrap;padding:8px 10px;gap:6px}.cal-nav{flex-shrink:0}.cal-actions{margin-left:auto}.act-btn{padding:5px 9px;font-size:.77rem}.cal-grid-wrap{padding:6px 6px 2px}.cal-cell{min-height:76px;max-height:76px;overflow:hidden;padding:4px}.cell-date{font-size:.75rem}.cal-cell.today .cell-date{width:18px;height:18px;font-size:.72rem}.chip{font-size:.62rem;padding:1px 3px}.cell-fin{font-size:.56rem}.bottom-panel-header{padding:8px 12px}.bottom-panel-body{flex-direction:column}.bottom-section{border-right:none;border-bottom:1px solid var(--border-light);padding:8px 12px;max-height:320px}.bottom-section:last-child{border-bottom:none}}.chip-draggable{cursor:grab}.chip-draggable:active{cursor:grabbing}.cal-cell.drop-target{outline:2px dashed var(--primary);background:var(--primary-faint, rgba(79,70,229,.08))}.year-view{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;padding:12px}.year-month{background:var(--color-bg2, #f9fafb);border-radius:10px;padding:10px;cursor:pointer;transition:box-shadow .15s}.year-month:hover{box-shadow:0 2px 8px #0000001f}.year-month-header{font-weight:700;font-size:.9rem;color:var(--color-text, #111);margin-bottom:4px}.year-month-finance{display:flex;gap:6px;font-size:.68rem;margin-bottom:4px}.ym-income{color:#16a34a;font-weight:600}.ym-expense{color:#dc2626;font-weight:600}.year-mini-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}.ymi-dow{font-size:.6rem;color:var(--color-text3, #9ca3af);text-align:center}.ymi-day{font-size:.62rem;text-align:center;padding:1px;border-radius:3px;position:relative;color:var(--color-text2, #374151)}.ymi-day.today{background:var(--color-primary, #4f46e5);color:#fff;border-radius:50%}.ymi-day.has-event{font-weight:700;color:var(--color-primary, #4f46e5)}.ymi-dot{display:block;width:3px;height:3px;background:var(--color-primary, #4f46e5);border-radius:50%;margin:0 auto}.act-btn{padding:5px 10px;border-radius:8px;border:1px solid var(--color-border, #e5e7eb);background:var(--color-bg2);color:var(--color-text2);cursor:pointer;font-size:.8rem}.act-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.bottom-item.selected{background:var(--primary-alpha, rgba(99,102,241,.08));border-left:3px solid var(--primary, #6366f1)}.section-add-btn.active{background:var(--primary, #6366f1);color:#fff}.import-modal-box{max-width:860px;width:95vw;max-height:90vh;display:flex;flex-direction:column}.import-upload-area{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 24px;text-align:center}.import-desc{font-size:.92rem;color:var(--text-secondary);line-height:1.7;margin:0}.import-file-btn{padding:10px 28px;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:opacity .15s}.import-file-btn:hover{opacity:.85}.import-file-btn:disabled{opacity:.5;cursor:default}.import-error{color:var(--danger-text);font-size:.85rem;background:var(--danger-bg);padding:8px 14px;border-radius:6px;margin:0;width:100%;box-sizing:border-box}.import-tip{font-size:.78rem;color:var(--text-placeholder);line-height:1.7;margin:0}.import-preview-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:var(--bg-subtle);border-bottom:1px solid var(--border);font-size:.88rem;color:var(--text-secondary);flex-shrink:0}.import-check-all{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:.85rem}.import-table-wrap{flex:1;overflow-y:auto;min-height:0}.import-table{width:100%;border-collapse:collapse;font-size:.82rem}.import-table thead th{position:sticky;top:0;background:var(--bg-muted);padding:8px 10px;text-align:left;font-weight:600;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap}.import-table tbody tr{border-bottom:1px solid var(--bg-subtle);transition:background .1s}.import-table tbody tr:hover{background:var(--bg-subtle)}.import-table tbody tr.row-excluded{opacity:.35}.import-table td{padding:7px 10px;vertical-align:middle;color:var(--text-primary)}.td-date{white-space:nowrap;color:var(--text-muted)}.td-desc{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.td-amount{font-weight:600;white-space:nowrap}.td-amount.income{color:var(--income-bright)}.td-amount.expense{color:var(--expense-bright)}.td-select{border:1.5px solid var(--border);border-radius:5px;padding:3px 6px;font-size:.8rem;background:var(--bg-subtle);color:var(--text-secondary);cursor:pointer;outline:none;max-width:110px}.td-select:focus{border-color:var(--primary)}.type-select{max-width:70px}.td-na{color:var(--border-strong)}.import-done{display:flex;flex-direction:column;align-items:center;gap:16px;padding:40px 24px}.import-done-icon{width:56px;height:56px;background:var(--success-bg);color:var(--success-text);border-radius:50%;font-size:1.8rem;display:flex;align-items:center;justify-content:center;font-weight:700}.import-done-msg{font-size:1rem;color:var(--text-secondary);margin:0}@media (max-width: 600px){.import-modal-box{width:100%;border-radius:16px 16px 0 0}.import-table thead th:nth-child(5),.import-table td:nth-child(5){display:none}}.rf-modal-box{max-width:500px;max-height:88vh;display:flex;flex-direction:column}.rf-form{background:var(--bg-subtle);border:1.5px solid var(--border);border-radius:10px;padding:14px;margin-bottom:14px;flex-shrink:0}.rf-form-title{font-size:.82rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}.rf-form-btns{display:flex;gap:8px;justify-content:flex-end;margin-top:10px}.rf-list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;flex-shrink:0}.rf-list-count{font-size:.82rem;color:var(--text-placeholder);font-weight:500}.rf-add-btn{padding:5px 14px;background:var(--primary);color:#fff;border:none;border-radius:7px;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .15s}.rf-add-btn:hover{opacity:.85}.rf-list{list-style:none;margin:0;padding:0;overflow-y:auto;display:flex;flex-direction:column;gap:6px}.rf-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-surface);border:1.5px solid var(--border);border-radius:10px;transition:background .1s}.rf-item:hover{background:var(--bg-subtle)}.rf-inactive{opacity:.45}.rf-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.rf-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.rf-desc{font-size:.9rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rf-meta{font-size:.75rem;color:var(--text-placeholder)}.rf-amount{font-size:.9rem;font-weight:700;flex-shrink:0;white-space:nowrap}.rf-amount.expense{color:var(--expense-text)}.rf-amount.income{color:var(--income-bright)}.rf-btns{display:flex;gap:2px;flex-shrink:0}.rf-btns button{background:none;border:none;cursor:pointer;font-size:.88rem;padding:4px 6px;border-radius:5px;color:var(--text-placeholder);transition:background .1s,color .1s}.rf-btns button:hover{background:var(--bg-muted);color:var(--text-secondary)}.rf-toggle-btn{font-size:.95rem!important}.rf-del:hover{color:var(--danger-text)!important}.rf-empty{text-align:center;color:var(--text-placeholder);font-size:.88rem;padding:24px 0;margin:0}@media (max-width: 600px){.rf-modal-box{max-height:92vh}.rf-amount{font-size:.82rem}}.cat-modal-box{max-width:420px;max-height:88vh;display:flex;flex-direction:column}.cat-tabs{display:flex;border:1.5px solid var(--border);border-radius:8px;overflow:hidden;margin-bottom:14px;flex-shrink:0}.cat-tab{flex:1;padding:8px;background:none;border:none;font-size:.9rem;font-weight:500;color:var(--text-muted);cursor:pointer;transition:background .15s,color .15s}.cat-tab:hover:not(.active){background:var(--bg-subtle)}.cat-tab.active{background:var(--primary);color:#fff;font-weight:600}.cat-form{background:var(--bg-subtle);border:1.5px solid var(--border);border-radius:10px;padding:14px;margin-bottom:14px;flex-shrink:0}.cat-form-title{font-size:.82rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}.cat-color-input{width:28px;height:28px;border:none;border-radius:50%;padding:0;cursor:pointer;background:none}.cat-form-btns{display:flex;gap:8px;justify-content:flex-end}.cat-list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;flex-shrink:0}.cat-list-count{font-size:.82rem;color:var(--text-placeholder);font-weight:500}.cat-add-btn{padding:5px 14px;background:var(--primary);color:#fff;border:none;border-radius:7px;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .15s}.cat-add-btn:hover{opacity:.85}.cat-manage-list{list-style:none;margin:0;padding:0;overflow-y:auto;display:flex;flex-direction:column;gap:6px}.cat-manage-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-surface);border:1.5px solid var(--border);border-radius:10px}.cat-manage-item:hover{background:var(--bg-subtle)}.cat-manage-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0}.cat-manage-name{flex:1;font-size:.92rem;font-weight:600;color:var(--text-primary)}.cat-manage-btns{display:flex;gap:2px}.cat-manage-btns button{background:none;border:none;cursor:pointer;font-size:.85rem;padding:4px 6px;border-radius:5px;color:var(--text-placeholder);transition:background .1s,color .1s}.cat-manage-btns button:hover:not(:disabled){background:var(--bg-muted);color:var(--text-secondary)}.cat-manage-btns button:disabled{opacity:.2;cursor:default}.cat-order-btn{font-size:.8rem!important}.cat-del-btn:hover{color:var(--danger-text)!important}.cat-empty{text-align:center;color:var(--text-placeholder);font-size:.88rem;padding:24px 0;margin:0}@media (max-width: 600px){.cat-modal-box{max-height:92vh}}.finance-page{display:flex;flex-direction:column;height:calc(100vh - 58px);background:var(--bg-page);overflow:hidden}.finance-topbar{display:flex;flex-direction:column;background:var(--bg-surface);border-bottom:1px solid var(--border-light);flex-shrink:0}.finance-topbar-row{display:flex;align-items:center;padding:8px 20px;border-bottom:1px solid var(--border-light)}.finance-topbar-row:last-child{border-bottom:none}.finance-topbar-budget{padding:10px 20px 12px}.finance-nav{display:flex;align-items:center;gap:8px}.finance-nav .nav-btn{background:var(--bg-muted);border:none;border-radius:10px;width:32px;height:32px;font-size:1.2rem;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:background .1s}.finance-nav .nav-btn:hover{background:var(--border)}.finance-nav .nav-title{margin:0;font-size:1.05rem;font-weight:800;color:var(--text-primary);white-space:nowrap;letter-spacing:-.02em}.finance-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.finance-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:100%}.summary-item{display:flex;flex-direction:column;align-items:center;padding:8px 12px;border-radius:12px;gap:2px}.summary-label{font-size:.72rem;font-weight:600;opacity:.7}.summary-value{font-size:1rem;font-weight:800;letter-spacing:-.02em}.summary-item.income{background:var(--income-bg);color:var(--income-text)}.summary-item.expense{background:var(--expense-bg);color:var(--expense-text)}.summary-item.balance{background:var(--balance-bg);color:var(--balance-text)}.summary-item.balance.neg{background:var(--expense-bg);color:var(--expense-text)}.budget-progress-bar-wrap{width:100%;display:flex;flex-direction:column;gap:6px}.bpb-header{display:flex;justify-content:space-between;align-items:center}.bpb-label{font-size:.9rem;color:var(--text-secondary);font-weight:600}.bpb-pct{font-size:.95rem;font-weight:700;color:var(--text-muted)}.bpb-pct.warn{color:#b45309}.bpb-pct.full{color:#7c3aed}.bpb-pct.over{color:var(--expense-bright)}.bpb-track{height:10px;background:var(--bg-muted);border-radius:5px;overflow:hidden}.bpb-fill{height:100%;background:var(--primary);border-radius:5px;transition:width .4s ease}.bpb-fill.warn{background:#f59e0b}.bpb-fill.full{background:#7c3aed}.bpb-fill.over{background:#ef4444}.bpb-footer{display:flex;justify-content:space-between;font-size:.82rem;color:var(--text-secondary);text-align:left}.act-btn{padding:6px 13px;border:none;border-radius:10px;font-size:.82rem;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s;white-space:nowrap}.act-btn:hover{opacity:.85;transform:translateY(-1px)}.act-btn:active{transform:translateY(0)}.act-btn.add{background:var(--primary);color:#fff}.act-btn.recurring{background:var(--warn-bg);color:var(--warn-text)}.act-btn.category{background:var(--expense-bg);color:var(--expense-text)}.act-btn.budget{background:var(--bg-muted);color:var(--text-secondary)}.act-btn.import{background:var(--income-bg);color:var(--income-bright)}.act-btn.export{background:var(--bg-muted);color:var(--text-secondary);text-decoration:none;display:inline-flex;align-items:center}.finance-filter{display:flex;align-items:center;gap:8px;padding:8px 20px;background:var(--bg-subtle);border-bottom:1px solid var(--border-light);flex-shrink:0;flex-wrap:wrap}.filter-tabs{display:flex;gap:2px;border:1.5px solid var(--border);border-radius:8px;overflow:hidden}.filter-tab{padding:5px 14px;border:none;background:none;font-size:.82rem;font-weight:500;color:var(--text-muted);cursor:pointer;transition:background .1s,color .1s}.filter-tab:hover{background:var(--bg-muted)}.filter-tab.active-all{background:var(--bg-muted);color:var(--text-primary);font-weight:600}.filter-tab.active-income{background:var(--income-bg);color:var(--income-bright);font-weight:600}.filter-tab.active-expense{background:var(--expense-bg);color:var(--expense-text);font-weight:600}.filter-cat{padding:5px 12px;border:1.5px solid var(--border);border-radius:8px;font-size:.82rem;color:var(--text-secondary);background:var(--bg-surface);cursor:pointer;outline:none}.filter-cat:focus{border-color:var(--primary)}.filter-search{padding:5px 12px;border:1.5px solid var(--border);border-radius:8px;font-size:.82rem;color:var(--text-primary);background:var(--bg-surface);outline:none;min-width:100px;max-width:160px}.filter-search::placeholder{color:var(--text-placeholder)}.filter-search:focus{border-color:var(--primary)}.finance-total-count{margin-left:auto;font-size:.8rem;color:var(--text-placeholder)}.finance-body{flex:1;overflow-y:auto;padding:12px 20px}.finance-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:100%;color:var(--text-placeholder);font-size:.95rem}.finance-group{margin-bottom:16px}.finance-group-header{display:flex;align-items:center;gap:10px;padding:6px 0;margin-bottom:4px;border-bottom:1px solid var(--border-light)}.finance-group-date{font-size:.82rem;font-weight:700;color:var(--text-muted)}.finance-group-sums{display:flex;gap:8px;margin-left:auto;font-size:.78rem;font-weight:600}.finance-group-sums .g-income{color:var(--income-bright)}.finance-group-sums .g-expense{color:var(--expense-bright)}.finance-item{display:flex;align-items:center;gap:10px;padding:9px 12px;background:var(--bg-surface);border-radius:10px;margin-bottom:4px;border:1px solid var(--border-light);transition:background .1s}.finance-item:hover{background:var(--bg-subtle)}.fi-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.fi-info{flex:1;min-width:0;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.fi-desc{font-size:.88rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0;max-width:180px}.fi-desc.empty{color:var(--text-placeholder);font-style:italic}.fi-cat{font-size:.74rem;background:var(--bg-muted);color:var(--text-muted);border-radius:4px;padding:1px 7px;flex-shrink:0}.fi-method{font-size:.74rem;color:var(--text-placeholder);flex-shrink:0}.fi-recur{font-size:.78rem;color:#a78bfa;flex-shrink:0}.fi-amount{font-size:.95rem;font-weight:700;white-space:nowrap;flex-shrink:0}.fi-amount.income{color:var(--income-bright)}.fi-amount.expense{color:var(--expense-text)}.fi-btns{display:flex;gap:2px;flex-shrink:0}.fi-btns button{background:none;border:none;cursor:pointer;font-size:.85rem;padding:4px 6px;border-radius:6px;color:var(--text-placeholder);transition:background .1s}.fi-btns button:hover{background:var(--bg-muted);color:var(--text-secondary)}.fi-pending{opacity:.55}.fi-pending-tag{font-size:.7rem;background:var(--warn-bg);color:var(--warn-text);border-radius:4px;padding:1px 6px;font-weight:600;flex-shrink:0}.recurring-apply-all-btn{background:none;border:1.5px solid var(--primary);border-radius:6px;padding:2px 10px;font-size:.78rem;font-weight:600;color:var(--primary);cursor:pointer;transition:background .1s,color .1s}.recurring-apply-all-btn:hover{background:var(--primary);color:#fff}@media (max-width: 700px){.finance-page{height:calc(100vh - 116px)}.finance-topbar-row{padding:7px 12px}.finance-actions{flex-wrap:wrap}.act-btn{padding:5px 9px;font-size:.77rem}.summary-value{font-size:.88rem}.summary-label{font-size:.68rem}.summary-item{padding:7px 8px}.finance-filter{padding:6px 12px}.finance-body{padding:10px 12px}.fi-desc{max-width:120px}}.finance-predict-bar{display:flex;align-items:center;gap:.5rem;padding:.45rem 1rem;background:var(--surface-2, #f8fafc);border-bottom:1px solid var(--border-light, #e2e8f0);font-size:.82rem;flex-wrap:wrap}.predict-label{color:var(--text-secondary, #64748b)}.predict-value{font-weight:600;color:var(--expense, #ef4444)}.predict-detail{color:var(--text-tertiary, #94a3b8)}.bulk-checkbox{width:18px;height:18px;flex-shrink:0;cursor:pointer;accent-color:var(--primary, #6366f1);margin-right:4px}.finance-item.selected{background:var(--primary-alpha, rgba(99,102,241,.08));border-left:3px solid var(--primary, #6366f1)}.finance-group-header .bulk-checkbox{margin-right:6px}.act-btn.select-mode.active{background:var(--primary, #6366f1);color:#fff;border-color:var(--primary, #6366f1)}.bulk-action-bar{position:fixed;bottom:70px;left:50%;transform:translate(-50%);display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--surface, #1e293b);color:var(--text, #f1f5f9);border-radius:14px;padding:12px 18px;box-shadow:0 4px 24px #00000059;z-index:200;min-width:280px;max-width:90vw}.bulk-action-count{font-size:.9rem;font-weight:600;white-space:nowrap}.bulk-action-btns{display:flex;gap:8px}.bulk-cancel-btn{background:none;border:1.5px solid rgba(255,255,255,.3);border-radius:8px;color:var(--text, #f1f5f9);padding:6px 14px;font-size:.85rem;cursor:pointer;transition:background .15s}.bulk-cancel-btn:hover{background:#ffffff1a}.bulk-delete-btn{background:#ef4444;border:none;border-radius:8px;color:#fff;padding:6px 16px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s}.bulk-delete-btn:hover:not(:disabled){background:#dc2626}.bulk-delete-btn:disabled{opacity:.5;cursor:not-allowed}.stats-error{background:var(--danger-bg);color:var(--danger-text);font-size:.88rem;padding:10px 20px;text-align:center;flex-shrink:0}.stats-page{display:flex;flex-direction:column;height:calc(100vh - 58px);background:var(--bg-page);overflow:hidden}.stats-topbar{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:var(--bg-surface);border-bottom:1px solid var(--border-light);flex-shrink:0;gap:16px}.stats-nav{display:flex;align-items:center;gap:10px}.stats-nav .nav-btn{background:none;border:1.5px solid var(--border);border-radius:6px;width:32px;height:32px;font-size:1.3rem;line-height:1;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:background .1s}.stats-nav .nav-btn:hover{background:var(--bg-muted)}.stats-nav .nav-title{margin:0;font-size:1.05rem;font-weight:700;color:var(--text-primary);white-space:nowrap}.stats-annual-chips{display:flex;gap:8px;align-items:center}.stats-annual-chips span{font-size:.82rem;font-weight:600;padding:5px 12px;border-radius:20px;white-space:nowrap}.chip-income{background:var(--income-bg);color:var(--income-bright)}.chip-expense{background:var(--expense-bg);color:var(--expense-bright)}.chip-balance{background:var(--balance-bg);color:var(--balance-text)}.chip-balance.neg{background:var(--expense-bg);color:var(--expense-text)}.stats-body{flex:1;overflow-y:auto;padding:16px;display:grid;grid-template-columns:1fr 1fr;gap:16px;align-content:start}@media (max-width: 768px){.stats-body{grid-template-columns:1fr}}@media (max-width: 600px){.stats-page{height:calc(100vh - 116px)}.stats-topbar{flex-wrap:wrap;padding:8px 10px;gap:6px}.stats-annual-chips{width:100%;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none}.stats-annual-chips::-webkit-scrollbar{display:none}.stats-annual-chips span{white-space:nowrap;flex-shrink:0}.stats-body{padding:10px;gap:10px}.stats-card{padding:14px}.line-chart-wrap,.bar-chart-wrap{height:220px}.doughnut-wrap{height:200px}.cat-bar-chart-wrap{min-height:200px}}.stats-card{background:var(--bg-surface);border-radius:12px;border:1px solid var(--border);padding:18px;display:flex;flex-direction:column;gap:14px}.stats-card-title{font-size:.95rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:8px}.month-select{border:1.5px solid var(--border);border-radius:6px;padding:3px 6px;font-size:.8rem;color:var(--text-secondary);background:var(--bg-subtle);cursor:pointer;outline:none;max-width:72px}.month-select:focus{border-color:var(--primary)}.stats-card-full{grid-column:1 / -1}.line-chart-wrap,.bar-chart-wrap{height:280px;position:relative}.month-summary{display:flex;gap:12px;font-size:.82rem;font-weight:600}.ms-income{color:var(--income-bright)}.ms-expense{color:var(--expense-bright)}.ms-balance{color:var(--balance-text)}.ms-balance.neg{color:var(--expense-text)}.doughnut-wrap{height:220px;position:relative}.cat-bar-chart-wrap{flex:1;min-height:220px;position:relative}.no-data{color:var(--text-placeholder);font-size:.88rem;margin:8px 0;text-align:center}.cat-list{display:flex;flex-direction:column;gap:8px}.cat-row{display:flex;align-items:center;gap:8px}.cat-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.cat-name{font-size:.82rem;font-weight:500;width:60px;flex-shrink:0;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cat-bar-bg{flex:1;height:6px;background:var(--bg-muted);border-radius:3px;overflow:hidden}.cat-bar-fill{height:100%;border-radius:3px;transition:width .4s ease}.cat-pct{font-size:.75rem;color:var(--text-muted);width:32px;text-align:right;flex-shrink:0}.cat-amt{font-size:.8rem;font-weight:600;color:var(--text-secondary);width:80px;text-align:right;flex-shrink:0}.stats-tabs{display:flex;gap:0;background:var(--bg-surface);border-bottom:1px solid var(--border-light);flex-shrink:0;padding:0 16px}.stats-tab-btn{background:none;border:none;border-bottom:2px solid transparent;padding:10px 16px;font-size:.88rem;font-weight:600;color:var(--text-muted);cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap}.stats-tab-btn:hover{color:var(--text-secondary)}.stats-tab-btn.active{color:var(--primary-text);border-bottom-color:var(--primary)}.stats-insight-card{background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-subtle) 100%)}.insight-month-label{font-size:.8rem;font-weight:500;color:var(--text-muted);margin-left:4px;flex:1}.insight-btn{margin-left:auto;background:var(--primary-bg);color:var(--primary-text);border:none;border-radius:8px;padding:5px 14px;font-size:.82rem;font-weight:600;cursor:pointer;transition:opacity .15s;white-space:nowrap;flex-shrink:0}.insight-btn:hover{opacity:.85}.insight-btn:disabled{opacity:.5;cursor:not-allowed}.insight-loading{display:flex;align-items:center;gap:10px;font-size:.88rem;color:var(--text-secondary);padding:8px 0}.insight-spinner{width:16px;height:16px;border-radius:50%;border:2px solid var(--border);border-top-color:var(--primary);animation:spin .8s linear infinite;flex-shrink:0}.insight-text{font-size:.9rem;line-height:1.7;color:var(--text-primary);background:var(--bg-subtle);border-radius:10px;padding:14px 16px;border-left:3px solid var(--primary);white-space:pre-wrap}.stats-goals-page{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:14px}.goals-header{display:flex;align-items:center;justify-content:space-between}.goals-title{font-size:1rem;font-weight:700;color:var(--text-primary)}.goal-add-btn{background:var(--primary-bg);color:var(--primary-text);border:none;border-radius:8px;padding:6px 14px;font-size:.83rem;font-weight:600;cursor:pointer;transition:opacity .15s}.goal-add-btn:hover{opacity:.85}.goal-form{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:10px}.goal-input{width:100%;box-sizing:border-box;border:1.5px solid var(--border);border-radius:8px;padding:9px 12px;font-size:.88rem;background:var(--bg-subtle);color:var(--text-primary);outline:none;transition:border-color .15s}.goal-input:focus{border-color:var(--primary)}.goal-form-row{display:flex;align-items:center;gap:10px}.goal-color-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap;flex-shrink:0}.goal-color-dot{width:20px;height:20px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .15s}.goal-color-dot.selected{border-color:var(--text-primary);transform:scale(1.2)}.goal-form-btns{display:flex;gap:8px}.goal-save-btn{flex:1;background:var(--primary-bg);color:var(--primary-text);border:none;border-radius:8px;padding:9px;font-size:.88rem;font-weight:600;cursor:pointer}.goal-save-btn:disabled{opacity:.5;cursor:not-allowed}.goal-cancel-btn{background:var(--bg-muted);color:var(--text-muted);border:none;border-radius:8px;padding:9px 18px;font-size:.88rem;cursor:pointer}.goals-list{display:flex;flex-direction:column;gap:12px}.goal-card{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:14px;padding:14px 16px;display:flex;flex-direction:column;gap:10px;transition:opacity .2s}.goal-card.goal-done{opacity:.65}.goal-card-header{display:flex;align-items:center;gap:8px}.goal-color-bar{width:4px;min-height:22px;border-radius:3px;flex-shrink:0}.goal-card-title{font-size:.92rem;font-weight:700;color:var(--text-primary);flex:1}.goal-dday{font-size:.72rem;font-weight:700;padding:2px 8px;border-radius:10px;background:var(--primary-subtle, #ede9fe);color:var(--primary-text);flex-shrink:0}.goal-dday.soon{background:#fef3c7;color:#b45309}.goal-dday.expired{background:var(--expense-bg);color:var(--expense-bright)}.goal-card-btns{display:flex;gap:2px}.goal-card-btns button{background:none;border:none;cursor:pointer;font-size:.9rem;padding:3px 6px;border-radius:6px;color:var(--text-placeholder);transition:background .1s}.goal-card-btns button:hover{background:var(--bg-muted);color:var(--text-secondary)}.goal-progress-track{height:8px;background:var(--bg-muted);border-radius:4px;overflow:hidden}.goal-progress-fill{height:100%;border-radius:4px;transition:width .5s ease}.goal-progress-info{display:flex;align-items:center;gap:8px;font-size:.78rem}.goal-acc{color:var(--text-secondary);font-weight:600;flex:1}.goal-pct{color:var(--text-muted);font-weight:700}.goal-target{color:var(--text-placeholder)}.stats-tl-page{flex:1;overflow-y:auto;padding:16px 20px 24px}.tl-feed{display:flex;flex-direction:column;gap:0}.tl-day-group{margin-bottom:20px}.tl-day-label{font-size:.78rem;font-weight:700;color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase;margin-bottom:8px;padding-left:4px}.tl-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:12px;background:var(--bg-surface);border:1px solid var(--border-light);margin-bottom:6px;transition:background .12s}.tl-item:hover{background:var(--bg-subtle)}.tl-type-icon{font-size:1rem;line-height:1;flex-shrink:0;margin-top:1px}.tl-item-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.tl-thumb{width:100%;max-width:220px;border-radius:8px;object-fit:cover;margin-bottom:4px;aspect-ratio:16/9}.tl-item-title{font-size:.88rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tl-item-sub{font-size:.78rem;color:var(--text-placeholder);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tl-sched-dot,.tl-fin-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.tl-fin-amount{font-size:.88rem;font-weight:700;align-self:flex-end}.tl-fin-amount.income{color:var(--income-bright)}.tl-fin-amount.expense{color:var(--expense-bright)}.tl-item-owner{font-size:.72rem;color:var(--text-placeholder)}.tl-more-wrap{text-align:center;padding:16px 0}.tl-more-btn{background:var(--bg-surface);border:1.5px solid var(--border);border-radius:20px;padding:8px 24px;font-size:.85rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:background .15s}.tl-more-btn:hover{background:var(--bg-muted)}.tl-more-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 600px){.stats-goals-page,.stats-tl-page{padding:12px 14px}.stats-tab-btn{padding:9px 12px;font-size:.82rem}}.stats-budget-wrap{display:flex;flex-direction:column;gap:6px;padding:12px 14px;background:var(--bg-subtle);border-radius:12px;border:1px solid var(--border-light)}.stats-budget-header{display:flex;justify-content:space-between;align-items:center;font-size:.82rem;font-weight:600;color:var(--text-secondary)}.stats-budget-pct{font-weight:700;color:var(--text-muted)}.stats-budget-pct.warn{color:#b45309}.stats-budget-pct.over{color:#ef4444}.stats-budget-pct.full{color:#7c3aed}.stats-budget-track{height:10px;background:var(--bg-muted);border-radius:5px;overflow:hidden}.stats-budget-fill{height:100%;background:var(--primary);border-radius:5px;transition:width .4s ease}.stats-budget-fill.warn{background:#f59e0b}.stats-budget-fill.over{background:#ef4444}.stats-budget-fill.full{background:#7c3aed}.stats-budget-footer{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-placeholder)}.cat-compare-list{display:flex;flex-direction:column;gap:16px;margin-top:8px}.cat-compare-row{display:flex;flex-direction:column;gap:6px}.cat-compare-name{display:flex;align-items:center;gap:6px;font-size:.85rem;font-weight:600;color:var(--text-primary)}.cat-compare-diff{font-size:.72rem;font-weight:600;margin-left:4px}.cat-compare-diff.up{color:var(--expense-bright)}.cat-compare-diff.down{color:var(--income-bright)}.cat-compare-bars{display:flex;flex-direction:column;gap:4px}.cat-compare-bar-row{display:flex;align-items:center;gap:8px}.cat-compare-label{font-size:.72rem;color:var(--text-muted);width:28px;flex-shrink:0}.cat-compare-track{flex:1;height:10px;background:var(--bg-muted);border-radius:5px;overflow:hidden}.cat-compare-fill{height:100%;border-radius:5px;transition:width .4s ease}.cat-compare-amt{font-size:.72rem;color:var(--text-primary);white-space:nowrap;min-width:60px;text-align:right}.cat-compare-amt.muted{color:var(--text-muted)}.habit-list{display:flex;flex-direction:column;gap:.4rem}.habit-row{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.habit-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.habit-title{flex:1;color:var(--text-primary, #1e293b)}.habit-count{font-weight:600;color:var(--primary, #4f46e5);min-width:2.5rem;text-align:right}.nw-list{display:flex;flex-direction:column;gap:.35rem}.nw-row{display:flex;align-items:center;gap:.6rem;font-size:.8rem;flex-wrap:wrap;padding:.3rem 0;border-bottom:1px solid var(--border-light, #f1f5f9)}.nw-date{color:var(--text-secondary);min-width:5rem}.nw-assets{color:#059669}.nw-liab{color:#dc2626}.nw-net.pos{font-weight:600;color:#4f46e5}.nw-net.neg{font-weight:600;color:#dc2626}.nw-del{margin-left:auto;background:none;border:none;cursor:pointer;color:#94a3b8;font-size:.9rem}.nw-form{display:flex;flex-direction:column;gap:.5rem;margin-top:.75rem;padding:.75rem;background:var(--surface-2, #f8fafc);border-radius:.5rem}.nw-form input,.nw-form select{padding:.4rem .6rem;border:1px solid var(--border, #e2e8f0);border-radius:.375rem;font-size:.85rem;background:var(--surface, white);color:var(--text-primary)}.gallery-page{display:flex;flex-direction:column;height:calc(100vh - 58px);background:var(--bg-page);overflow:hidden}.gallery-viewmode-bar{display:flex;align-items:center;gap:4px;padding:8px 16px;background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0}.viewmode-tab{padding:5px 16px;border:1px solid var(--border);border-radius:20px;background:transparent;color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:background .15s,color .15s;flex-shrink:0}.viewmode-tab:hover{background:var(--bg-muted);color:var(--text-primary)}.viewmode-tab.active{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:600}.gallery-topbar{display:flex;align-items:center;gap:12px;padding:10px 20px;background:var(--bg-surface);border-bottom:1px solid var(--border-light);flex-shrink:0;flex-wrap:wrap}.gallery-nav{display:flex;align-items:center;gap:8px;flex-shrink:0}.gallery-nav .nav-btn{background:none;border:1.5px solid var(--border);border-radius:6px;width:30px;height:30px;font-size:1.2rem;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:background .1s}.gallery-nav .nav-btn:hover{background:var(--bg-muted)}.gallery-nav .nav-title{margin:0;font-size:1rem;font-weight:700;color:var(--text-primary)}.gallery-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}.photo-count{font-size:.82rem;color:var(--text-placeholder)}.upload-btn{padding:7px 14px;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .15s}.upload-btn:hover{opacity:.85}.upload-progress-bar{background:var(--bg-surface);border-bottom:1px solid var(--border-light);padding:8px 16px;flex-shrink:0}.upb-inner{display:flex;align-items:center;gap:12px}.upb-text{font-size:.82rem;font-weight:600;color:var(--text-secondary);white-space:nowrap;flex-shrink:0}.upb-track{flex:1;height:6px;background:var(--bg-muted);border-radius:3px;overflow:hidden}.upb-fill{height:100%;background:var(--primary);border-radius:3px;transition:width .2s ease}.upb-error{background:var(--danger-bg, #fef2f2);border-bottom-color:#fca5a5}.upb-err-text{color:var(--danger-text, #dc2626)!important}.upb-retry-btn{padding:2px 10px;border-radius:5px;font-size:.78rem;font-weight:600;background:var(--primary);color:#fff;border:none;cursor:pointer;flex-shrink:0}.nas-rescan-wrap{padding:4px 16px;background:var(--bg-surface);border-bottom:1px solid var(--border-light);flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:8px}.nas-last-sync{font-size:.75rem;color:var(--text-placeholder)}.nas-rescan-btn{background:none;border:none;font-size:.78rem;font-weight:600;color:var(--text-muted);cursor:pointer;padding:2px 0;flex-shrink:0}.nas-rescan-btn:hover{color:var(--primary)}.upb-indeterminate{width:40%!important;animation:upb-slide 1.2s ease-in-out infinite}@keyframes upb-slide{0%{transform:translate(-100%)}to{transform:translate(350%)}}.gallery-month-bar{display:flex;align-items:center;gap:4px;padding:8px 16px;background:var(--bg-surface);border-bottom:1px solid var(--border-light);flex-shrink:0;overflow-x:auto;scrollbar-width:none}.gallery-month-bar::-webkit-scrollbar{display:none}.month-tab{padding:5px 12px;border:none;border-radius:20px;font-size:.82rem;font-weight:500;cursor:pointer;background:transparent;color:var(--text-muted);white-space:nowrap;transition:background .12s,color .12s;flex-shrink:0}.month-tab:hover{background:var(--bg-muted);color:var(--text-primary)}.month-tab.active{background:var(--primary);color:#fff;font-weight:600}.gallery-search-bar{display:flex;align-items:center;gap:12px;padding:8px 16px;background:var(--bg-surface);border-bottom:1px solid var(--border-light);flex-shrink:0}.gallery-body{flex:1;overflow-y:auto;padding:16px;position:relative}.gallery-photos-wrap{position:relative;min-height:200px}.gallery-photos-wrap.is-loading .gallery-photos-inner{opacity:.4;transition:opacity .15s}.gallery-photos-inner{opacity:1;transition:opacity .25s ease}.gallery-photos-inner.photos-ready{animation:fadeInPhotos .25s ease}@keyframes fadeInPhotos{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.gallery-loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;display:flex;align-items:center;justify-content:center;pointer-events:none}.gallery-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.gallery-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;height:100%;color:var(--text-placeholder);font-size:1rem}.gallery-empty-sub{font-size:.82rem;color:var(--text-placeholder);opacity:.7}.gallery-loading{text-align:center;color:var(--text-placeholder);padding:40px}.gallery-month-group{margin-bottom:24px}.gallery-month-header{display:flex;align-items:center;gap:10px;margin-bottom:10px;padding:0 2px}.gallery-month-title{font-size:.95rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.gallery-month-count{font-size:.8rem;color:var(--text-placeholder);font-weight:500}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}.photo-item{position:relative;aspect-ratio:1 / 1;border-radius:8px;overflow:hidden;cursor:pointer;background:var(--bg-muted)}.photo-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .2s}.photo-item:hover img{transform:scale(1.04)}.photo-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(0,0,0,.5) 0%,transparent 50%);opacity:0;transition:opacity .2s;display:flex;align-items:flex-end;justify-content:space-between;padding:8px}.photo-item:hover .photo-overlay{opacity:1}.photo-title{font-size:.78rem;color:#fff;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.load-more-wrap{display:flex;justify-content:center;padding:20px}.load-more-btn{padding:9px 24px;background:var(--bg-muted);border:1.5px solid var(--border);border-radius:8px;font-size:.88rem;cursor:pointer;color:var(--text-secondary);transition:background .1s}.load-more-btn:hover{background:var(--border)}.load-more-btn:disabled{opacity:.5;cursor:default}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;z-index:1000;display:flex;align-items:center;justify-content:center}.lb-close{position:absolute;top:16px;right:20px;background:none;border:none;color:#fff;font-size:1.6rem;cursor:pointer;z-index:1001;line-height:1}.lb-close:hover{color:#ccc}.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff1a;border:none;color:#fff;font-size:2rem;width:48px;height:60px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;z-index:1001}.lb-nav:hover{background:#fff3}.lb-nav:disabled{opacity:.2;cursor:default}.lb-prev{left:16px}.lb-next{right:16px}.lb-content{display:flex;align-items:center;justify-content:center;cursor:pointer;line-height:0}.lb-content img{max-width:calc(100vw - 120px);max-height:calc(100vh - 40px);object-fit:contain;border-radius:6px;display:block}.lb-info{position:absolute;bottom:0;left:0;right:0;z-index:2;background:linear-gradient(to top,rgba(0,0,0,.97) 0%,rgba(0,0,0,.92) 45%,rgba(0,0,0,.65) 70%,transparent 100%);padding:80px 20px 20px;display:flex;flex-direction:column;align-items:flex-start;gap:5px;max-height:60%;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.3) transparent;transition:opacity .22s,transform .22s}.lb-info.lb-info-hidden{opacity:0;transform:translateY(8px);pointer-events:none}.lb-info-toggle-hint{position:absolute;bottom:14px;right:14px;width:30px;height:30px;border-radius:50%;background:#fff3;border:1.5px solid rgba(255,255,255,.4);color:#fff;font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;z-index:3}.lb-info-toggle-hint:hover{background:#ffffff59}.lb-title{font-size:.95rem;font-weight:600;color:#fff}.lb-meta{font-size:.78rem;color:#9ca3af}.lb-meta-date{cursor:pointer;display:flex;align-items:center;gap:4px;transition:color .15s}.lb-meta-date:hover{color:var(--primary)}.lb-meta-edit-hint{font-size:.72rem;opacity:.6}.lb-date-edit{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.lb-date-edit input[type=date]{padding:4px 8px;border:1.5px solid var(--primary);border-radius:6px;font-size:.82rem;background:var(--bg-subtle);color:var(--text-primary);width:auto}.lb-date-btns{display:flex;gap:4px}.lb-date-btns button{padding:3px 10px;border-radius:5px;font-size:.78rem;font-weight:600;cursor:pointer;border:none}.lb-date-btns button:first-child{background:var(--primary);color:#fff}.lb-date-btns button:last-child{background:var(--bg-muted);color:var(--text-muted)}.lb-comments{width:100%;margin-top:8px;display:flex;flex-direction:column;gap:4px}.lb-comment-brief{display:flex;flex-direction:column;gap:3px}.lb-comment-brief-loading{font-size:.75rem;color:#fff6}.lb-comment-brief-item{display:flex;align-items:baseline;gap:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.82rem;line-height:1.35}.lb-comment-brief-author{font-weight:700;color:#ffffffe6;flex-shrink:0;max-width:80px;overflow:hidden;text-overflow:ellipsis}.lb-comment-brief-text{color:#ffffffa6;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lb-comment-detail-btn{background:none;border:none;color:#ffffff73;font-size:.78rem;font-weight:600;cursor:pointer;padding:3px 0 0;text-align:left;transition:color .15s}.lb-comment-detail-btn:hover{color:#fff}.lb-comment-collapse{background:none;border:none;color:#fff6;font-size:.78rem;font-weight:600;cursor:pointer;padding:2px 0 6px;text-align:left;transition:color .15s}.lb-comment-collapse:hover{color:#fff}.lb-comment-list{display:flex;flex-direction:column;gap:10px;max-height:240px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent}.lb-comment-thread{display:flex;flex-direction:column;gap:6px}.lb-replies{display:flex;flex-direction:column;gap:5px;margin-left:20px;padding-left:12px;border-left:2px solid rgba(255,255,255,.18)}.lb-comment-reply{opacity:.92}.lb-comment-reply .lb-comment-body{background:#ffffff0d}.lb-comment-reply .lb-comment-avatar{width:26px;height:26px;font-size:.72rem}.lb-comment-avatar-sm{width:26px!important;height:26px!important;font-size:.72rem!important}.lb-reply-input-row{display:flex;gap:6px;align-items:flex-end;margin-left:20px;padding:8px 0 2px 12px;border-left:2px solid rgba(79,70,229,.6)}.lb-reply-cancel{background:none;border:none;color:#fff6;font-size:.85rem;cursor:pointer;flex-shrink:0;padding:4px;transition:color .12s}.lb-reply-cancel:hover{color:#fff}.lb-comment-loading,.lb-comment-empty{font-size:.78rem;color:#fff6;margin:0;padding:4px 0}.lb-comment-item{display:flex;gap:8px;align-items:flex-start}.lb-comment-avatar{width:32px;height:32px;border-radius:50%;background:#ffffff26;flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden;font-size:.82rem;font-weight:700;color:#fff}.lb-comment-avatar img{width:100%;height:100%;object-fit:cover}.lb-comment-body{flex:1;min-width:0;background:#ffffff14;border-radius:12px;padding:7px 11px}.lb-comment-header{display:flex;align-items:baseline;gap:6px;margin-bottom:3px;flex-wrap:wrap}.lb-comment-author{font-size:.8rem;font-weight:700;color:#e5e7eb}.lb-comment-time{font-size:.72rem;color:#fff6}.lb-comment-edited{font-style:italic}.lb-comment-text{margin:0;font-size:.85rem;color:#d1d5db;line-height:1.45;word-break:break-word;white-space:pre-wrap}.lb-comment-actions{display:flex;gap:8px;margin-top:4px}.lb-comment-actions button{background:none;border:none;font-size:.72rem;color:#fff6;cursor:pointer;padding:0;transition:color .12s}.lb-comment-actions button:hover{color:#fff}.lb-comment-edit-form{display:flex;flex-direction:column;gap:4px;margin-top:2px}.lb-comment-edit-btns{display:flex;gap:6px}.lb-comment-edit-btns button{padding:3px 10px;border-radius:5px;border:none;font-size:.75rem;font-weight:600;cursor:pointer}.lb-comment-edit-btns button:first-child{background:#4f46e5;color:#fff}.lb-comment-edit-btns button:last-child{background:#ffffff26;color:#d1d5db}.lb-comment-input-row{display:flex;gap:8px;align-items:flex-end;border-top:1px solid rgba(255,255,255,.1);padding-top:10px}.lb-comment-textarea{flex:1;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:18px;color:#fff;padding:8px 14px;font-size:.85rem;resize:none;outline:none;line-height:1.4;font-family:inherit;transition:border-color .15s}.lb-comment-textarea::placeholder{color:#ffffff59}.lb-comment-textarea:focus{border-color:#ffffff73}.lb-comment-send{padding:7px 14px;background:#4f46e5;color:#fff;border:none;border-radius:18px;font-size:.82rem;font-weight:600;cursor:pointer;flex-shrink:0;transition:opacity .15s}.lb-comment-send:hover:not(:disabled){opacity:.85}.lb-comment-send:disabled{opacity:.35;cursor:default}.lb-share-wrap{display:flex;gap:8px;margin-top:4px}.lb-share-btn{padding:5px 14px;background:#4f46e5cc;border:none;border-radius:6px;color:#fff;font-size:.8rem;cursor:pointer;transition:opacity .15s}.lb-share-btn:hover{opacity:.85}.lb-unshare-btn{padding:5px 14px;background:#6b728099;border:none;border-radius:6px;color:#fff;font-size:.8rem;cursor:pointer}@media (max-width: 700px){.gallery-page{height:calc(100vh - 116px)}.gallery-viewmode-bar{padding:6px 10px;gap:4px}.viewmode-tab{padding:4px 12px;font-size:.78rem}.gallery-topbar{padding:8px 10px;gap:6px}.gallery-month-bar{padding:6px 10px;gap:3px}.month-tab{padding:4px 10px;font-size:.78rem}.gallery-search-bar{padding:6px 10px}.gallery-body{padding:10px}.photo-grid{grid-template-columns:repeat(3,1fr);gap:6px}.lb-content img{max-width:100vw;max-height:calc(100vh - env(safe-area-inset-bottom,0px));border-radius:0}.lb-nav{width:36px;height:48px;font-size:1.6rem}.lb-prev{left:4px}.lb-next{right:4px}.lb-info{max-height:50%;padding:60px 16px calc(20px + env(safe-area-inset-bottom,0px));-webkit-overflow-scrolling:touch;border-radius:0}}.lb-img-error{display:flex;align-items:center;justify-content:center;width:100%;min-height:200px;color:var(--text-muted);font-size:.9rem;background:var(--bg-muted);border-radius:8px}.lb-img-loading{display:flex;align-items:center;justify-content:center;width:100%;min-height:200px}.lb-spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.lb-map-wrap{margin-top:12px;display:flex;flex-direction:column;gap:6px}.lb-map-label{font-size:.78rem;color:var(--text-muted);font-weight:600}.lb-map{width:100%;height:200px;border-radius:10px;overflow:hidden;border:1px solid var(--border-light)}.gallery-main-tabs{display:flex;gap:0;border-bottom:1px solid var(--border, #e2e8f0);background:var(--surface, white);padding:0 1rem}.gallery-main-tab{padding:.65rem 1.1rem;border:none;background:none;cursor:pointer;font-size:.875rem;color:var(--text-secondary, #64748b);border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.gallery-main-tab.active{color:var(--primary, #4f46e5);border-bottom-color:var(--primary, #4f46e5);font-weight:600}.albums-page{padding:1rem}.albums-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.albums-title{font-size:1rem;font-weight:600;color:var(--text-primary)}.album-form{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:var(--surface-2, #f8fafc);border-radius:.5rem;margin-bottom:1rem}.album-form input{padding:.4rem .6rem;border:1px solid var(--border);border-radius:.375rem;font-size:.85rem;background:var(--surface, white);color:var(--text-primary)}.album-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem}.album-card{background:var(--surface, white);border:1px solid var(--border-light, #f1f5f9);border-radius:.75rem;overflow:hidden;cursor:pointer;position:relative;transition:box-shadow .15s}.album-card:hover{box-shadow:0 4px 12px #0000001a}.album-cover{aspect-ratio:1;overflow:hidden;background:var(--surface-2, #f8fafc)}.album-cover img{width:100%;height:100%;object-fit:cover}.album-cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2rem}.album-info{padding:.4rem .5rem;display:flex;justify-content:space-between;align-items:center}.album-name{font-size:.82rem;font-weight:500;color:var(--text-primary)}.album-count{font-size:.75rem;color:var(--text-secondary)}.album-actions{display:flex;gap:.25rem;padding:.3rem .5rem;border-top:1px solid var(--border-light, #f1f5f9);justify-content:flex-end}.album-empty{color:var(--text-secondary);font-size:.875rem;padding:2rem 0;text-align:center}.album-view-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.album-view-title{font-size:1rem;font-weight:600;color:var(--text-primary)}.album-thumb{border-radius:.5rem;overflow:hidden;aspect-ratio:1}.album-thumb img{width:100%;height:100%;object-fit:cover}.lb-slideshow{position:absolute;top:16px;right:52px;z-index:10;background:#00000080;color:#fff;border:none;border-radius:8px;padding:6px 14px;cursor:pointer;font-size:1rem;transition:background .15s}.lb-slideshow:hover,.lb-slideshow.active{background:var(--color-primary, #4f46e5)}.lb-slideshow-interval{position:absolute;top:16px;right:120px;z-index:10;background:#0009;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:8px;padding:5px 8px;font-size:.8rem;cursor:pointer}.folder-grid-wrap{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.folder-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;padding:16px}.folder-card{border-radius:10px;overflow:hidden;background:var(--bg-surface);border:1px solid var(--border-light);cursor:pointer;transition:transform .15s,box-shadow .15s}.folder-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001f}.folder-cover{position:relative;aspect-ratio:1;background:var(--bg-muted);overflow:hidden}.folder-cover img{width:100%;height:100%;object-fit:cover;display:block}.folder-cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:var(--text-muted);background:var(--bg-muted)}.folder-info{padding:8px 10px;display:flex;flex-direction:column;gap:2px}.folder-name-label{font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.folder-count-label{font-size:.75rem;color:var(--text-muted)}.folder-view-header{display:flex;align-items:center;gap:10px;padding:8px 16px;background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0}.folder-back-btn{background:none;border:1px solid var(--border);border-radius:8px;padding:4px 12px;font-size:.85rem;color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:background .1s}.folder-back-btn:hover{background:var(--bg-muted)}.folder-view-title{font-size:.95rem;font-weight:700;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gallery-browse-tabs{display:flex;gap:0;padding:0 1rem;background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0}.gallery-browse-tab{padding:.65rem 1.2rem;border:none;background:none;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--text-secondary);border-bottom:2px solid transparent;transition:color .15s,border-color .15s;white-space:nowrap}.gallery-browse-tab:hover{color:var(--text-primary)}.gallery-browse-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.folder-filter-bar{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--bg-surface);border-bottom:1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch;flex-shrink:0;scrollbar-width:none}.folder-filter-bar::-webkit-scrollbar{display:none}.folder-filter-tab{display:inline-flex;align-items:center;gap:5px;padding:5px 14px;border:1.5px solid var(--border);border-radius:20px;background:transparent;color:var(--text-secondary);font-size:.85rem;white-space:nowrap;cursor:pointer;flex-shrink:0;transition:background .15s,color .15s,border-color .15s}.folder-filter-tab:hover{background:var(--bg-muted);color:var(--text-primary)}.folder-filter-tab.active{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:600}.folder-filter-count{font-size:.75rem;opacity:.75}.folder-filter-tab.active .folder-filter-count{opacity:.85}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.admin-page{max-width:600px;margin:0 auto;padding:16px 16px 100px}.admin-header{display:flex;align-items:center;gap:10px;margin-bottom:20px}.admin-back{background:none;border:none;font-size:1.8rem;line-height:1;color:var(--text-primary);cursor:pointer;padding:0 4px}.admin-title{font-size:1.2rem;font-weight:700;color:var(--text-primary);margin:0}.admin-empty{text-align:center;color:var(--text-muted);font-size:.9rem;margin-top:40px}.admin-list{display:flex;flex-direction:column;gap:14px}.admin-card{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow-card)}.admin-card-deleted{opacity:.65;border-style:dashed;border-color:var(--border)}.admin-card-header{display:flex;align-items:center;justify-content:space-between}.admin-user-info{display:flex;flex-direction:column;gap:2px}.admin-username{font-size:.95rem;font-weight:700;color:var(--text-primary)}.admin-username.deleted{text-decoration:line-through;color:var(--text-muted)}.admin-fullname{font-size:.8rem;color:var(--text-muted)}.admin-badges{display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:flex-end}.badge-admin{font-size:.68rem;background:var(--primary);color:#fff;border-radius:4px;padding:2px 7px;font-weight:700}.badge-family{font-size:.68rem;background:var(--income-bright);color:#fff;border-radius:4px;padding:2px 7px;font-weight:700}.badge-saving{font-size:.7rem;color:var(--text-muted)}.badge-deleted{font-size:.68rem;background:var(--warn-text);color:#fff;border-radius:4px;padding:2px 7px;font-weight:700}.admin-section{display:flex;flex-direction:column;gap:6px}.admin-section-label{font-size:.75rem;color:var(--text-muted);font-weight:600}.admin-perm-btns{display:flex;gap:5px;flex-wrap:nowrap}.perm-btn{flex:1;padding:5px 4px;font-size:.75rem;font-weight:600;border-radius:7px;cursor:pointer;border:1.5px solid var(--border);background:var(--bg-subtle);color:var(--text-muted);transition:all .15s;white-space:nowrap}.perm-btn.active{border-color:var(--primary);background:var(--primary);color:#fff}.family-btn{padding:5px 14px;font-size:.8rem;font-weight:600;border-radius:7px;cursor:pointer;border:1.5px solid var(--border);background:var(--bg-subtle);color:var(--text-muted);transition:all .15s;align-self:flex-start}.family-btn.active{border-color:var(--income-bright);background:var(--income-bright);color:#fff}.btn-delete-user{padding:3px 10px;font-size:.72rem;font-weight:600;border-radius:6px;cursor:pointer;border:1.5px solid var(--expense-bright);background:transparent;color:var(--expense-bright);transition:all .15s}.btn-delete-user:hover{background:var(--expense-bright);color:#fff}.btn-delete-user:disabled{opacity:.4;cursor:default}.admin-deleted-section{margin-top:28px}.admin-deleted-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.admin-deleted-title{font-size:.85rem;font-weight:700;color:var(--text-muted)}.admin-deleted-desc{font-size:.75rem;color:var(--text-muted);background:var(--bg-subtle);border-radius:4px;padding:1px 7px}.admin-deleted-actions{display:flex;gap:8px}.btn-restore{padding:5px 14px;font-size:.8rem;font-weight:600;border-radius:7px;cursor:pointer;border:1.5px solid var(--income-bright);background:transparent;color:var(--income-bright);transition:all .15s}.btn-restore:hover{background:var(--income-bright);color:#fff}.btn-restore:disabled{opacity:.4;cursor:default}.btn-force-delete{padding:5px 14px;font-size:.8rem;font-weight:600;border-radius:7px;cursor:pointer;border:1.5px solid var(--expense-bright);background:transparent;color:var(--expense-bright);transition:all .15s}.btn-force-delete:hover{background:var(--expense-bright);color:#fff}.btn-force-delete:disabled{opacity:.4;cursor:default}.admin-share-row{display:flex;align-items:center;justify-content:space-between}.btn-share-setting{padding:3px 10px;font-size:.72rem;font-weight:600;border-radius:6px;cursor:pointer;border:1.5px solid var(--primary);background:transparent;color:var(--primary-text);transition:all .15s}.btn-share-setting:hover{background:var(--primary-bg)}.btn-share-setting:disabled{opacity:.4;cursor:default}.admin-share-partners{display:flex;flex-wrap:wrap;align-items:center;gap:6px}.share-partner-badge{font-size:.75rem;font-weight:600;background:var(--primary-bg);color:var(--primary-text);border-radius:5px;padding:2px 8px}.share-partner-with{font-size:.75rem;color:var(--text-muted)}.share-none-label{font-size:.78rem;color:var(--text-muted)}.group-name-row{display:flex;align-items:center;gap:6px;margin-bottom:6px}.group-name-badge{display:inline-block;padding:2px 10px;background:var(--primary-bg);color:var(--primary);border-radius:20px;font-size:.78rem;font-weight:700}.btn-rename{background:none;border:none;cursor:pointer;font-size:.78rem;color:var(--text-muted);padding:2px 4px}.btn-rename:hover{color:var(--primary)}.group-rename-row{display:flex;align-items:center;gap:6px;margin-bottom:6px}.group-rename-input{flex:1;padding:4px 8px;border:1.5px solid var(--primary);border-radius:6px;font-size:.82rem;background:var(--bg-subtle);color:var(--text-primary);outline:none}.btn-rename-confirm{padding:3px 10px;background:var(--primary);color:#fff;border:none;border-radius:6px;font-size:.78rem;cursor:pointer}.btn-rename-cancel{padding:3px 10px;background:var(--bg-muted);color:var(--text-muted);border:none;border-radius:6px;font-size:.78rem;cursor:pointer}.share-modal-box{max-width:360px}.share-modal-desc{font-size:.82rem;color:var(--text-muted);margin:-6px 0 0}.share-name-row{display:flex;align-items:center;gap:8px;margin:10px 0 4px}.share-name-label{font-size:.82rem;color:var(--text-muted);white-space:nowrap;font-weight:500}.share-name-input{flex:1;padding:6px 10px;border:1.5px solid var(--border-strong);border-radius:7px;font-size:.88rem;background:var(--bg-subtle);color:var(--text-primary);outline:none}.share-name-input:focus{border-color:var(--primary)}.share-empty{font-size:.85rem;color:var(--text-muted);text-align:center;padding:8px 0;margin:0}.share-user-list{display:flex;flex-direction:column;gap:6px;max-height:240px;overflow-y:auto}.share-user-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;border:1.5px solid var(--border);background:var(--bg-subtle);cursor:pointer;transition:all .15s}.share-user-item:hover,.share-user-item.checked{border-color:var(--primary);background:var(--primary-bg)}.share-user-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.share-user-names{display:flex;flex-direction:column;gap:1px}.share-user-username{font-size:.88rem;font-weight:600;color:var(--text-primary)}.share-user-fullname{font-size:.75rem;color:var(--text-muted)}.btn-confirm-save{padding:7px 16px;font-size:.85rem;font-weight:600;border-radius:8px;cursor:pointer;border:none;background:var(--primary);color:#fff;transition:all .15s}.btn-confirm-save:hover{background:var(--primary-hover)}.admin-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.admin-confirm-box{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:14px;padding:24px 20px;width:100%;max-width:320px;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow-modal)}.admin-confirm-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}.admin-confirm-msg{font-size:.88rem;color:var(--text-secondary);line-height:1.6;margin:0}.admin-confirm-btns{display:flex;gap:8px;justify-content:flex-end}.btn-cancel{padding:7px 16px;font-size:.85rem;font-weight:600;border-radius:8px;cursor:pointer;border:1.5px solid var(--border);background:var(--bg-subtle);color:var(--text-muted);transition:all .15s}.btn-cancel:hover{background:var(--bg-muted)}.btn-confirm-delete{padding:7px 16px;font-size:.85rem;font-weight:600;border-radius:8px;cursor:pointer;border:none;background:var(--expense-bright);color:#fff;transition:all .15s}.btn-confirm-delete:hover{opacity:.85}.btn-confirm-force{padding:7px 16px;font-size:.85rem;font-weight:600;border-radius:8px;cursor:pointer;border:1.5px solid var(--expense-bright);background:var(--danger-bg);color:var(--danger-text);transition:all .15s}.btn-confirm-force:hover{background:var(--expense-bright);color:#fff}.nas-folder-badge{display:inline-block;margin-top:4px;padding:3px 10px;background:var(--primary-bg, rgba(79,70,229,.08));color:var(--primary);border-radius:6px;font-size:.8rem;font-weight:500;word-break:break-all}.folder-list{display:flex;flex-direction:column;gap:4px;max-height:320px;overflow-y:auto;margin:8px 0 12px;border:1px solid var(--border);border-radius:10px;padding:6px}.folder-item{display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:8px;cursor:pointer;transition:background .1s;-webkit-user-select:none;user-select:none}.folder-item:hover{background:var(--bg-muted)}.folder-item.checked{background:var(--primary-bg, rgba(79,70,229,.08))}.folder-icon{font-size:1rem;flex-shrink:0}.folder-name{flex:1;font-size:.85rem;color:var(--text-primary);word-break:break-all}.folder-check{color:var(--primary);font-weight:700;font-size:.9rem;flex-shrink:0}.btn-history{background:none;border:none;cursor:pointer;font-size:.9rem;padding:2px 4px;opacity:.6}.btn-history:hover{opacity:1}.history-list{display:flex;flex-direction:column;gap:6px;max-height:280px;overflow-y:auto;margin:4px 0 8px}.history-item{display:flex;align-items:center;gap:10px;padding:7px 10px;background:var(--bg-subtle);border-radius:8px;font-size:.8rem}.history-time{color:var(--text-primary);font-weight:500;flex:1}.history-ip{color:var(--text-muted);font-size:.75rem}.history-ua{font-size:1rem;flex-shrink:0}.memos-page{max-width:720px;margin:0 auto;padding:16px}.memos-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.memos-header h2{margin:0;font-size:1.3rem;color:var(--color-text)}.memos-add-btn{background:var(--color-primary);color:#fff;border:none;padding:7px 16px;border-radius:8px;font-size:.88rem;cursor:pointer;font-weight:600}.memos-search-row{display:flex;gap:6px;margin-bottom:14px;position:relative}.memos-search-input{flex:1;border:1px solid var(--color-border);border-radius:8px;padding:7px 32px 7px 12px;font-size:.88rem;background:var(--color-bg);color:var(--color-text)}.memos-search-clear{position:absolute;right:64px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--color-text3);cursor:pointer;font-size:.85rem;padding:4px}.memos-search-btn{background:var(--color-bg2);border:1px solid var(--color-border);color:var(--color-text2);padding:7px 14px;border-radius:8px;font-size:.85rem;cursor:pointer}.memos-section-label{font-size:.78rem;font-weight:600;color:var(--color-text3);text-transform:uppercase;letter-spacing:.05em;padding:4px 2px 8px}.memos-empty{text-align:center;color:var(--color-text3);padding:48px 0;font-size:.95rem}.memos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-bottom:16px}.memo-card{border-radius:12px;display:flex;flex-direction:column;gap:0;min-height:120px;border:1px solid rgba(0,0,0,.07);box-shadow:0 1px 4px #00000014;transition:box-shadow .15s,transform .12s;cursor:pointer;overflow:hidden}.memo-card:hover{box-shadow:0 4px 14px #00000024;transform:translateY(-2px)}.memo-card-img-wrap{width:100%;height:110px;overflow:hidden;flex-shrink:0}.memo-card-img{width:100%;height:100%;object-fit:cover;display:block}.memo-card-body{flex:1;padding:12px 14px 6px}.memo-card-content{margin:0;font-size:.9rem;line-height:1.55;word-break:break-word;white-space:pre-wrap;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.memo-card-footer{display:flex;align-items:center;justify-content:space-between;padding:4px 14px 12px;margin-top:auto}.memo-card-date{font-size:.72rem}.memo-card-shared{font-size:.68rem;opacity:.8}.memo-card-badges{display:flex;gap:3px;font-size:.78rem}.memo-badge{opacity:.75}.memo-dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;display:flex;align-items:center;justify-content:center;padding:16px}.memo-detail{position:relative;width:100%;max-width:480px;border-radius:18px;padding:0;box-shadow:0 12px 40px #00000047;overflow:hidden;border:1px solid rgba(0,0,0,.1)}.memo-detail-img-wrap{width:100%;max-height:260px;overflow:hidden}.memo-detail-img{width:100%;max-height:260px;object-fit:cover;display:block}.memo-detail-content{padding:20px 20px 10px;margin:0;font-size:1rem;line-height:1.7;white-space:pre-wrap;word-break:break-word}.memo-detail-meta{padding:0 20px 12px;font-size:.78rem;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.memo-detail-shared-badge{display:inline-flex;align-items:center;gap:3px;font-size:.74rem;padding:2px 8px;border-radius:20px;font-weight:500}.memo-detail-actions{display:flex;gap:8px;padding:0 20px 20px;flex-wrap:wrap}.memo-detail-action-btn{flex:1;min-width:80px;border:1px solid rgba(0,0,0,.1);padding:8px 12px;border-radius:10px;cursor:pointer;font-size:.85rem;font-weight:500;transition:filter .12s}.memo-detail-action-btn:hover{filter:brightness(.93)}.memo-detail-edit{font-weight:600}.memo-detail-close{position:absolute;top:12px;right:14px;background:#0000001f;border:none;border-radius:50%;width:28px;height:28px;font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.memo-detail-close:hover{background:#00000038}.memo-dialog{width:100%;max-width:440px;border-radius:16px;padding:20px;box-shadow:0 8px 32px #00000040;border:1px solid rgba(0,0,0,.1)}.memo-dialog-img-section{margin-bottom:12px}.memo-dialog-img-add{width:100%;padding:10px;border:1.5px dashed;border-radius:10px;background:#0000000a;cursor:pointer;font-size:.88rem;transition:background .12s}.memo-dialog-img-add:hover{background:#00000017}.memo-dialog-img-preview-wrap{position:relative;border-radius:10px;overflow:hidden}.memo-dialog-img-preview{width:100%;max-height:200px;object-fit:cover;display:block;border-radius:10px}.memo-dialog-img-remove{position:absolute;top:6px;right:6px;background:#00000080;color:#fff;border:none;border-radius:50%;width:24px;height:24px;font-size:.78rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.memo-dialog-textarea{width:100%;box-sizing:border-box;background:#ffffffbf;border:1.5px solid rgba(0,0,0,.18);border-radius:10px;padding:10px 12px;font-size:.95rem;line-height:1.6;resize:vertical;font-family:inherit;outline:none;color:#1f2937;transition:border-color .15s,background .15s}.memo-dialog-textarea:focus{background:#ffffffeb;border-color:#00000059}.memo-dialog-textarea::placeholder{color:#6b7280;opacity:.8}.memo-dialog-colors{display:flex;gap:10px;margin:12px 0 10px;flex-wrap:wrap;align-items:center}.memo-dialog-colors-label{font-size:.75rem;margin-right:2px}.memo-color-dot{width:28px;height:28px;border-radius:50%;border:2px solid rgba(0,0,0,.15);cursor:pointer;transition:transform .12s,box-shadow .12s;box-shadow:0 1px 3px #00000026}.memo-color-dot:hover{transform:scale(1.15)}.memo-color-dot.selected{border-color:#374151;border-width:2.5px;transform:scale(1.2);box-shadow:0 0 0 2px #fff,0 0 0 4px #374151}.memo-share-btn{width:100%;padding:9px 14px;border:1px solid;border-radius:10px;font-size:.88rem;font-weight:500;cursor:pointer;margin-bottom:4px;transition:filter .12s;text-align:center}.memo-share-btn:hover{filter:brightness(.93)}.memo-share-btn.active{font-weight:700}.memo-dialog-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px}.memo-dialog-cancel{background:#00000014;border:1px solid rgba(0,0,0,.1);padding:8px 18px;border-radius:8px;cursor:pointer;font-size:.88rem;color:#374151}.memo-dialog-cancel:hover{background:#00000021}.memo-dialog-save{border:none;padding:8px 20px;border-radius:8px;cursor:pointer;font-size:.88rem;font-weight:600}.memo-dialog-save:disabled{opacity:.4;cursor:not-allowed}@media (max-width: 480px){.memos-grid{grid-template-columns:1fr 1fr;gap:8px}.memo-card{min-height:100px}.memo-detail{max-width:100%;border-radius:14px}.memo-detail-actions{gap:6px}.memo-detail-action-btn{font-size:.8rem;padding:7px 8px}}.ann-page{max-width:640px;margin:0 auto;padding:16px}.ann-header{display:flex;align-items:center;margin-bottom:12px}.ann-header h2{margin:0;font-size:1.3rem;color:var(--color-text)}.ann-form{background:var(--color-bg2);border-radius:12px;padding:14px;margin-bottom:16px;display:flex;flex-direction:column;gap:10px}.ann-form-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.ann-options-row{flex-wrap:nowrap}.ann-emoji-picker{display:flex;gap:4px;flex-wrap:wrap}.ann-emoji-btn{background:var(--color-bg);border:2px solid transparent;border-radius:8px;padding:4px 7px;font-size:1.1rem;cursor:pointer;transition:all .1s}.ann-emoji-btn.active{border-color:var(--color-primary);background:var(--color-hover)}.ann-input{flex:1;min-width:120px;border:1px solid var(--color-border);border-radius:8px;padding:7px 10px;font-size:.88rem;background:var(--color-bg);color:var(--color-text)}.ann-color-input{width:36px;height:36px;border:none;border-radius:8px;cursor:pointer;padding:2px}.ann-repeat-label{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;gap:6px;font-size:.85rem;color:var(--color-text2);cursor:pointer;white-space:nowrap;flex-shrink:0}.ann-repeat-label input[type=checkbox]{flex-shrink:0;width:16px;height:16px;margin:0;cursor:pointer}.ann-save-btn{background:var(--color-primary);color:#fff;border:none;padding:7px 18px;border-radius:8px;cursor:pointer;font-size:.85rem}.ann-cancel-btn{background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text2);padding:7px 14px;border-radius:8px;cursor:pointer;font-size:.85rem}.ann-loading,.ann-empty{text-align:center;color:var(--color-text3);padding:40px}.ann-list{display:flex;flex-direction:column;gap:10px}.ann-card{background:var(--color-bg2);border-radius:10px;padding:12px 14px;display:flex;align-items:center;justify-content:space-between;gap:10px;border-left:4px solid var(--color-primary);transition:box-shadow .15s}.ann-card.today{box-shadow:0 0 0 2px var(--color-primary)}.ann-card-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.ann-card-emoji{font-size:1.5rem;flex-shrink:0}.ann-card-info{display:flex;flex-direction:column;min-width:0}.ann-card-title{font-size:.95rem;font-weight:600;color:var(--color-text)}.ann-card-date{font-size:.78rem;color:var(--color-text3);margin-top:2px}.ann-card-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}.ann-dday{font-size:.85rem;font-weight:700;padding:3px 10px;border-radius:20px}.ann-dday.dday-today{font-size:1rem}.ann-dday.dday-soon{font-weight:600}.ann-card-actions{display:flex;gap:4px}.ann-action-btn{background:none;border:none;cursor:pointer;padding:2px 6px;border-radius:6px;font-size:.85rem}.ann-action-btn:hover{background:var(--color-hover)}.ann-action-btn.danger:hover{background:#fee2e2}.ann-date-wrap{position:relative;display:flex;align-items:center;gap:6px;flex:1;min-width:120px}.ann-date-wrap .ann-input{flex:1}.ann-lunar-badge{background:#f59e0b22;color:#f59e0b;font-size:.72rem;font-weight:700;padding:2px 7px;border-radius:10px;white-space:nowrap;border:1px solid #f59e0b66}.ann-lunar-tag{background:#f59e0b22;color:#f59e0b;font-size:.68rem;font-weight:700;padding:1px 6px;border-radius:8px;border:1px solid #f59e0b55;margin-left:6px;vertical-align:middle}.ann-card-title-row{display:flex;align-items:center}.ann-lunar-hint{font-size:.78rem;color:#f59e0b;margin:0;padding:0 2px}.ann-mode-row{display:flex;gap:8px}.ann-mode-btn{flex:1;padding:7px 12px;border:2px solid var(--color-border);border-radius:10px;background:var(--color-bg);color:var(--color-text2);font-size:.85rem;cursor:pointer;transition:all .15s}.ann-mode-btn.active{border-color:var(--color-primary);background:var(--color-hover);color:var(--color-text);font-weight:600}.ann-group-row{position:relative}.ann-select{flex:1;min-width:160px;border:1px solid var(--color-border);border-radius:8px;padding:7px 10px;font-size:.88rem;background:var(--color-bg);color:var(--color-text);cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.ann-select:focus{outline:2px solid var(--color-primary);outline-offset:1px}.ann-new-group-popup{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:1000}.ann-new-group-card{background:var(--color-bg2);border-radius:14px;padding:20px;width:300px;max-width:calc(100vw - 32px);display:flex;flex-direction:column;gap:12px;box-shadow:0 8px 32px #00000040}.ann-new-group-title{margin:0;font-size:1rem;font-weight:700;color:var(--color-text)}.ann-new-group-btns{display:flex;gap:8px;justify-content:flex-end}.ann-section{margin-bottom:20px}.ann-section-title{font-size:.9rem;font-weight:700;color:var(--color-text2);margin:0 0 10px 2px}.ann-group-header{display:flex;align-items:center;gap:8px;font-size:.82rem;font-weight:700;color:var(--color-text3);text-transform:uppercase;letter-spacing:.05em;margin:0 0 8px 4px}.ann-group-header:after{content:"";flex:1;height:1px;background:var(--color-border)}.elapsed-card{align-items:flex-start}.elapsed-label{text-align:right}.elapsed-text{font-size:.82rem;font-weight:700;line-height:1.5;white-space:nowrap}.elapsed-future{font-size:1rem;font-weight:800}.search-page{max-width:640px;margin:0 auto;padding:16px}.search-form{display:flex;gap:8px;margin-bottom:14px}.search-input{flex:1;border:1px solid var(--color-border);border-radius:10px;padding:10px 14px;font-size:.95rem;background:var(--color-bg2);color:var(--color-text);outline:none}.search-input:focus{border-color:var(--color-primary)}.search-btn{background:var(--color-primary);color:#fff;border:none;padding:10px 18px;border-radius:10px;cursor:pointer;font-size:.9rem}.search-tabs{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}.search-tab{padding:5px 12px;border-radius:20px;border:1px solid var(--color-border);background:var(--color-bg2);color:var(--color-text2);cursor:pointer;font-size:.82rem;display:flex;align-items:center;gap:4px}.search-tab.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.search-tab-count{background:#ffffff40;padding:1px 6px;border-radius:10px;font-size:.72rem}.search-tab:not(.active) .search-tab-count{background:var(--color-bg);color:var(--color-text3)}.search-empty{text-align:center;color:var(--color-text3);padding:40px}.search-hint{text-align:center;color:var(--color-text3);padding:48px 24px;font-size:.9rem}.search-results{display:flex;flex-direction:column;gap:16px}.search-section-title{font-size:.8rem;font-weight:700;color:var(--color-text3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.search-item{display:flex;gap:10px;align-items:flex-start;background:var(--color-bg2);border-radius:10px;padding:10px 12px;transition:background .15s}.search-item:hover{background:var(--color-hover)}.search-item-icon{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;color:#fff}.search-item-body{flex:1;min-width:0}.search-item-title{font-size:.9rem;font-weight:500;color:var(--color-text)}.search-item-meta{font-size:.75rem;color:var(--color-text3);margin-top:2px}.search-item-desc{font-size:.78rem;color:var(--color-text2);margin-top:3px}.search-hl{background:#fef08a;color:#78350f;border-radius:2px;padding:0 1px}.search-photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px}.search-photo-card{background:var(--color-bg2);border-radius:8px;overflow:hidden;cursor:pointer}.search-photo-card:hover{opacity:.85}.search-photo-thumb{width:100%;aspect-ratio:1;object-fit:cover;display:block}.search-photo-placeholder{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:var(--color-bg)}.search-photo-name{font-size:.7rem;color:var(--color-text3);padding:4px 6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.changelog-page{max-width:680px;margin:0 auto;padding:16px 16px 100px;color:var(--text, #f1f5f9)}.changelog-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.changelog-back{background:none;border:none;color:var(--text-secondary, #94a3b8);font-size:1.8rem;line-height:1;cursor:pointer;padding:0 4px 0 0;flex-shrink:0}.changelog-back:hover{color:var(--text, #f1f5f9)}.changelog-title{font-size:1.15rem;font-weight:700;margin:0;color:var(--text, #f1f5f9)}.changelog-sub{font-size:.78rem;color:var(--text-muted, #64748b);margin:3px 0 0}.changelog-section{background:var(--surface, #1e293b);border-radius:14px;overflow:hidden;margin-bottom:14px}.changelog-section-header{display:flex;align-items:center;gap:8px;padding:12px 16px;border-left:4px solid #6366f1;background:#ffffff08}.changelog-section-emoji{font-size:1.15rem;line-height:1}.changelog-section-name{font-size:.92rem;font-weight:700;flex:1;color:var(--text, #f1f5f9)}.changelog-section-count{font-size:.72rem;color:var(--text-muted, #64748b);background:var(--bg, #0f172a);border-radius:10px;padding:2px 8px}.changelog-card{display:flex;align-items:flex-start;gap:10px;padding:10px 16px;border-top:1px solid var(--border, #334155)}.changelog-card-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:6px}.changelog-card-content{display:flex;flex-direction:column;gap:3px}.changelog-card-title{font-size:.875rem;font-weight:600;color:var(--text, #f1f5f9)}.changelog-card-desc{font-size:.78rem;color:var(--text-secondary, #94a3b8);line-height:1.5}.changelog-footer{text-align:center;font-size:.78rem;color:var(--text-muted, #64748b);padding:12px 0 4px}@media (max-width: 600px){.changelog-page{padding:12px 12px 80px}.changelog-section{border-radius:10px;margin-bottom:10px}.changelog-section-header{padding:10px 12px}.changelog-card{padding:9px 12px}}*,*:before,*:after{box-sizing:border-box}@keyframes skeleton-shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg,var(--bg-muted) 25%,var(--bg-subtle, #e5e7eb) 50%,var(--bg-muted) 75%);background-size:800px 100%;animation:skeleton-shimmer 1.4s infinite linear;border-radius:6px}.skeleton-text{height:14px;width:100%;margin-bottom:8px}.skeleton-text.w60{width:60%}.skeleton-text.w40{width:40%}.skeleton-text.w80{width:80%}.skeleton-title{height:20px;width:50%;margin-bottom:12px}.skeleton-card{height:80px;border-radius:12px;margin-bottom:10px}.skeleton-chart{height:200px;border-radius:12px;margin-bottom:16px}.skeleton-avatar{width:48px;height:48px;border-radius:50%;flex-shrink:0}html{overflow-x:hidden;max-width:100%}body{margin:0;overflow-x:hidden;max-width:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans KR,sans-serif;background:var(--bg-page);color:var(--text-primary);-webkit-font-smoothing:antialiased}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 28px;height:58px;background:var(--bg-surface);border-bottom:1px solid var(--border-light);position:sticky;top:0;z-index:100;gap:16px}.app-header-logo{display:flex;align-items:center;gap:8px;flex-shrink:0}.app-logo-icon{font-size:1.1rem;color:var(--primary);line-height:1}.app-header-title{font-size:1.05rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.desktop-nav{display:flex;align-items:center;gap:4px;flex:1;justify-content:center}.desktop-nav-link{padding:6px 18px;border-radius:20px;font-size:.88rem;font-weight:500;color:var(--text-muted);text-decoration:none;transition:background .15s,color .15s}.desktop-nav-link:hover{background:var(--bg-muted);color:var(--text-primary)}.desktop-nav-link.active{background:var(--primary-bg);color:var(--primary-text);font-weight:700}.settings-wrap{position:relative}.settings-btn{width:36px;height:36px;border-radius:50%;border:none;background:var(--bg-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}.settings-btn:hover{background:var(--border)}.settings-icon{font-size:1rem}.settings-popup{position:absolute;top:calc(100% + 10px);right:0;background:var(--bg-surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-popup);min-width:240px;z-index:200;padding:8px 0}.settings-popup-title{font-size:.78rem;font-weight:700;color:var(--text-placeholder);padding:6px 16px 10px;display:flex;align-items:center;gap:6px;text-transform:uppercase;letter-spacing:.05em}.settings-back{background:none;border:none;font-size:1.1rem;cursor:pointer;color:var(--text-muted);padding:0;line-height:1}.settings-back:hover{color:var(--text-primary)}.settings-item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 16px;background:none;border:none;font-size:.9rem;color:var(--text-secondary);cursor:pointer;text-align:left;transition:background .12s}.settings-item:hover{background:var(--bg-subtle)}.settings-item.danger{color:var(--danger-text)}.settings-item.danger:hover{background:var(--danger-bg)}.settings-divider{height:1px;background:var(--bg-muted);margin:4px 0}.settings-theme-section{padding:8px 16px 12px}.settings-theme-label{font-size:.75rem;font-weight:700;color:var(--text-placeholder);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.settings-theme-btns{display:flex;gap:6px}.theme-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;border:1.5px solid var(--border);border-radius:10px;background:var(--bg-subtle);cursor:pointer;transition:border-color .15s,background .15s}.theme-btn:hover{background:var(--bg-muted);border-color:var(--border-strong)}.theme-btn.active{border-color:var(--primary);background:var(--primary-bg)}.theme-btn-icon{font-size:1.1rem;line-height:1}.theme-btn-label{font-size:.7rem;font-weight:600;color:var(--text-muted)}.theme-btn.active .theme-btn-label{color:var(--primary-text)}.settings-field-label{font-size:.8rem;font-weight:600;color:var(--text-muted);padding:0 2px}.settings-gender-btns{display:flex;gap:6px}.settings-gender-btns .gender-btn{flex:1;padding:7px 0;border:1.5px solid var(--border);border-radius:8px;background:var(--bg-subtle);color:var(--text-muted);font-size:.85rem;font-weight:500;cursor:pointer;transition:border-color .15s,background .15s,color .15s}.settings-gender-btns .gender-btn:hover:not(.active){border-color:var(--primary);color:var(--primary)}.settings-gender-btns .gender-btn.active{border-color:var(--primary);background:var(--primary);color:#fff}.settings-pw-form{display:flex;flex-direction:column;gap:8px;padding:0 12px 12px}.settings-pw-form input{padding:8px 10px;border:1.5px solid var(--border);border-radius:8px;font-size:.85rem;outline:none;background:var(--bg-subtle);color:var(--text-primary)}.settings-pw-form input:focus{border-color:var(--primary)}.settings-error{color:var(--danger-text);font-size:.8rem;margin:0}.settings-success{color:var(--success-text);font-size:.8rem;margin:0}.settings-pw-btn{padding:9px;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:.88rem;font-weight:600;cursor:pointer;margin-top:2px;transition:opacity .15s}.settings-pw-btn:hover:not(:disabled){opacity:.88}.settings-pw-btn:disabled{opacity:.6;cursor:not-allowed}.app-main{min-height:calc(100vh - 58px);padding-bottom:0}.loading{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--text-muted)}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:64px;background:var(--bg-nav);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border-light);z-index:100;padding:0 8px;padding-bottom:env(safe-area-inset-bottom)}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;flex:1;text-decoration:none;color:var(--text-placeholder);transition:color .15s;padding:8px 0}.bottom-nav-item.active{color:var(--primary)}.bnav-icon{font-size:1.4rem;line-height:1}.bnav-label{font-size:.68rem;font-weight:500}@media (max-width: 700px){.app-header{padding:0 16px;height:52px}.desktop-nav{display:none}.bottom-nav{display:flex}.app-main{padding-bottom:64px;min-height:calc(100vh - 116px)}}@media (min-width: 701px){.bottom-nav{display:none!important}}.app-main:has(.gallery-page),.app-main:has(.cal-page),.app-main:has(.finance-page),.app-main:has(.stats-page){min-height:unset;height:calc(100vh - 58px);overflow:hidden;padding-bottom:0!important}@media (max-width: 700px){.app-main:has(.gallery-page),.app-main:has(.cal-page),.app-main:has(.finance-page),.app-main:has(.stats-page){height:calc(100vh - 116px)}}
