*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--font-sans:"Pretendard", "Outfit", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, Consolas, monospace;--bg:#f7f5f0;--bg-2:#f1ede4;--surface:#fff;--surface-2:#faf8f3;--accent:#059669;--accent-hover:#047857;--accent-light:#ecfdf5;--accent-soft:#d1fae5;--accent-ink:#064e3b;--accent-border:#a7f3d0;--text:#1c1917;--text-primary:#1c1917;--text-secondary:#57534e;--text-2:#57534e;--text-muted:#a8a29e;--expense:#dc2626;--expense-light:#fef2f2;--income:#059669;--transfer:#8b5cf6;--cat-blue:#3b82f6;--cat-purple:#8b5cf6;--cat-amber:#f59e0b;--cat-pink:#ec4899;--cat-teal:#14b8a6;--cat-indigo:#6366f1;--border:#1c191712;--border-strong:#1c19171f;--shadow-xs:0 1px 2px #1c19170a;--shadow-sm:0 1px 3px #1c19170d, 0 1px 2px #1c191708;--shadow-md:0 4px 14px -4px #1c191714, 0 2px 6px #1c19170a;--shadow-lg:0 20px 40px -20px #1c191726, 0 8px 20px -10px #1c19170f;--shadow-accent:0 10px 24px -8px #05966973;--shadow-card:0 1px 3px #1c19170d, 0 4px 16px #1c19170d;--radius-sm:10px;--radius:16px;--radius-lg:20px;--radius-xl:28px;--side-w:260px;--top-h:64px}html,body{height:100%;font-family:var(--font-sans);letter-spacing:-.005em;color:var(--text-primary);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:15px;line-height:1.5}#root{width:100%;min-height:100%}button,input,select,textarea{font-family:var(--font-sans)}.tabular{font-variant-numeric:tabular-nums}.mono{font-family:var(--font-mono)}.app-shell{grid-template-columns:var(--side-w) 1fr;background:var(--bg);min-height:100dvh;display:grid}.main-content{flex-direction:column;min-width:0;display:flex}.app-main{flex:1;padding-bottom:80px;overflow-y:auto}main.content{width:100%;max-width:1400px;margin:0 auto;padding:40px 48px 80px}.page-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:32px;display:flex}.page-head h1{letter-spacing:-.02em;color:var(--text-primary);margin:0;font-size:28px;font-weight:700}.page-head .sub{color:var(--text-secondary);margin-top:4px;font-size:14px}.page-content{max-width:1100px;margin:0 auto;padding:24px 32px 0}aside.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;gap:4px;height:100dvh;padding:24px 16px;display:flex;position:sticky;top:0;overflow-y:auto}aside.sidebar .brand{letter-spacing:-.01em;color:var(--text-primary);align-items:center;gap:10px;padding:8px 10px 24px;font-size:16px;font-weight:700;display:flex}aside.sidebar .brand-mark{background:linear-gradient(135deg, var(--accent) 0%, #10b981 100%);color:#fff;border-radius:10px;flex-shrink:0;place-items:center;width:32px;height:32px;display:grid;position:relative;box-shadow:0 8px 20px #05966947}aside.sidebar .brand-mark:after{content:"";background:radial-gradient(circle at 30% 25%,#ffffff59,#0000 60%);border-radius:6px;position:absolute;inset:4px}aside.sidebar .brand-mark svg{z-index:1;width:16px;height:16px;position:relative}aside.sidebar .nav-section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:14px 12px 6px;font-size:11px;font-weight:600}aside.sidebar .nav-item{color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:12px;width:100%;padding:11px 12px;font-size:14.5px;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}aside.sidebar .nav-item svg{opacity:.85;flex-shrink:0;width:18px;height:18px}aside.sidebar .nav-item:hover{background:var(--bg);color:var(--text-primary)}aside.sidebar .nav-item.active{background:var(--accent-light);color:var(--accent-hover);font-weight:600}aside.sidebar .nav-item.active svg{color:var(--accent);opacity:1}aside.sidebar .nav-section-label-admin{color:#b45309;margin-top:6px}aside.sidebar .nav-item-admin{color:#92400e}aside.sidebar .nav-item-admin svg{color:#b45309;opacity:.95}aside.sidebar .nav-item-admin:hover,aside.sidebar .nav-item-admin.active{color:#78350f;background:#fef3c7}aside.sidebar .nav-item-admin.active svg{color:#b45309;opacity:1}aside.sidebar .nav-item-admin-back{color:var(--text-muted);border:1px dashed var(--border);border-radius:10px;align-items:center;gap:12px;margin-bottom:6px;padding:11px 12px;font-size:13.5px;font-weight:500;text-decoration:none;display:flex}aside.sidebar .nav-item-admin-back:hover{background:var(--bg);color:var(--text-primary);border-style:solid}aside.sidebar .nav-item-admin-back svg{opacity:.75;flex-shrink:0;width:18px;height:18px}aside.sidebar .sidebar-spacer{flex:1}aside.sidebar .user-chip-wrap{margin-bottom:4px;position:relative}aside.sidebar .user-chip{background:var(--bg);border:1px solid var(--border);cursor:pointer;text-align:left;border-radius:14px;align-items:center;gap:10px;width:100%;padding:12px;transition:background .15s,border-color .15s;display:flex}aside.sidebar .user-chip:hover,aside.sidebar .user-chip.open{background:var(--bg-2);border-color:var(--accent-soft)}aside.sidebar .user-chip-caret{color:var(--text-muted);flex-shrink:0;margin-left:auto;transition:transform .2s}aside.sidebar .user-chip.open .user-chip-caret{transform:rotate(180deg)}aside.sidebar .user-dropdown{background:var(--bg);border:1px solid var(--border);z-index:50;border-radius:14px;padding:6px;position:absolute;bottom:calc(100% + 8px);left:0;right:0;box-shadow:0 -4px 24px #0000001a}aside.sidebar .user-drop-item{width:100%;color:var(--text-primary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:10px;padding:10px 12px;font-size:13.5px;font-weight:500;transition:background .13s;display:flex}aside.sidebar .user-drop-item:hover{background:var(--bg-2)}aside.sidebar .user-drop-item.danger{color:#ef4444}aside.sidebar .user-drop-item.danger:hover{background:#fef2f2}aside.sidebar .user-drop-divider{background:var(--border);height:1px;margin:4px 0}aside.sidebar .user-chip .avatar{background:var(--accent-light);width:34px;height:34px;color:var(--accent-hover);border:1.5px solid var(--accent-border);border-radius:50%;flex-shrink:0;place-items:center;font-size:14px;font-weight:700;display:grid;overflow:hidden}aside.sidebar .user-chip .info{flex:1;min-width:0}aside.sidebar .user-chip .info .nm{color:var(--text-primary);white-space:nowrap;align-items:center;gap:6px;font-size:13.5px;font-weight:600;display:flex;overflow:hidden}aside.sidebar .user-chip .info .em{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11.5px;overflow:hidden}@media (width<=1100px){:root{--side-w:72px}aside.sidebar{padding:20px 12px}aside.sidebar .brand{justify-content:center;padding:8px 6px 20px}aside.sidebar .brand>span,aside.sidebar .nav-item>span{display:none}aside.sidebar .nav-item{justify-content:center;padding:11px 0}aside.sidebar .nav-section-label{display:none}aside.sidebar .user-chip{justify-content:center;padding:8px}aside.sidebar .user-chip .info,aside.sidebar .user-chip-caret{display:none}main.content{padding:28px 28px 80px}}@media (width<=768px){.app-shell{grid-template-columns:1fr;height:auto;min-height:100dvh}.app-main{flex:none;overflow-y:visible}.main-content{height:auto}aside.sidebar{z-index:300;width:260px;height:100dvh;box-shadow:none;transition:transform .28s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}aside.sidebar.sidebar-mobile-open{transform:translate(0);box-shadow:4px 0 24px #00000026}aside.sidebar .brand>span,aside.sidebar .nav-item>span{display:block}aside.sidebar .nav-item{justify-content:flex-start;padding:11px 16px}aside.sidebar .nav-section-label{display:block}aside.sidebar .user-chip{justify-content:flex-start;padding:12px}aside.sidebar .user-chip .info{display:flex}aside.sidebar .user-chip-caret{display:block}main.content{padding:16px 16px 80px}.page-head{display:none}}.sidebar-overlay{display:none}@media (width<=768px){.sidebar-overlay{z-index:299;background:#0006;animation:.2s fadeIn;display:block;position:fixed;inset:0}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.hamburger-btn{display:none}@media (width<=768px){.hamburger-btn{width:36px;height:36px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;place-items:center;margin-right:4px;display:grid}.hamburger-btn:hover{background:var(--bg-2)}}@media (width<=640px){.page-content{padding:16px 16px 0}}.bottom-nav{background:var(--surface);border-top:1px solid var(--border);z-index:100;justify-content:space-around;align-items:center;height:64px;padding:0 8px;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav-item{cursor:pointer;color:var(--text-muted);background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:8px 0;font-size:11px;font-weight:500;text-decoration:none;transition:color .15s;display:flex}.bottom-nav-item:hover{color:var(--text-secondary)}.bottom-nav-active{color:var(--accent)!important}.bottom-nav-fab{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:8px;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:0 4px 12px #05966959}.bottom-nav-fab:hover{transform:scale(1.05);box-shadow:0 6px 16px #05966973}@media (width>=769px){.bottom-nav{display:none}.app-main{padding-bottom:0}}.page-head-action{flex-shrink:0}.loading-screen{background:var(--bg);flex-direction:column;justify-content:center;align-items:center;gap:14px;min-height:100dvh;display:flex}.loading-spinner{border:2.5px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;width:30px;height:30px;animation:.65s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--text-muted);font-size:13px;font-weight:500}.auth-root{grid-template-columns:1fr 1fr;min-height:100dvh;display:grid}@media (width<=768px){.auth-root{grid-template-columns:1fr}}.auth-brand{background:#052e16;justify-content:center;align-items:center;padding:56px 48px;display:flex;position:relative;overflow:hidden}@media (width<=768px){.auth-brand{display:none}}.auth-brand:before{content:"";pointer-events:none;background:radial-gradient(at 80% 10%,#10b9812e 0%,#0000 55%),radial-gradient(at 10% 90%,#05966924 0%,#0000 50%);position:absolute;inset:0}.auth-brand-inner{z-index:1;width:100%;max-width:360px;position:relative}.auth-mark{letter-spacing:-.5px;color:#6ee7b7;background:#ffffff14;border:1px solid #ffffff24;border-radius:13px;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:44px;font-size:16px;font-weight:700;display:flex}.auth-brand-name{letter-spacing:-.6px;color:#fff;margin:0 0 12px;font-size:28px;font-weight:700;line-height:1.2}.auth-brand-tagline{color:#ffffff80;margin-bottom:44px;font-size:14.5px;line-height:1.65}.auth-brand-divider{background:#ffffff14;height:1px;margin-bottom:36px}.auth-features{flex-direction:column;gap:16px;display:flex}.auth-feature-item{color:#fff9;align-items:center;gap:10px;font-size:13.5px;line-height:1.4;display:flex}.auth-feature-dot{background:#34d399;border-radius:50%;flex-shrink:0;width:6px;height:6px}.auth-panel{background:var(--surface);justify-content:center;align-items:center;padding:48px 40px;display:flex}.auth-form-inner{width:100%;max-width:370px}.auth-form-eyebrow{text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin-bottom:8px;font-size:12px;font-weight:600}.auth-form-title{letter-spacing:-.5px;color:var(--text-primary);margin:0 0 32px;font-size:28px;font-weight:700;line-height:1.2}.auth-form{flex-direction:column;gap:18px;display:flex}.field-group{flex-direction:column;gap:6px;display:flex}.field-label{color:var(--text-secondary);font-size:13px;font-weight:500}.field-input{border-radius:var(--radius);height:46px;color:var(--text-primary);background:var(--surface);border:1.5px solid #e2e8f0;outline:none;width:100%;padding:0 14px;font-size:14px;transition:border-color .16s,box-shadow .16s}.field-input::placeholder{color:var(--text-muted)}.field-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0596691a}.btn-primary{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;letter-spacing:-.1px;border:none;height:48px;margin-top:4px;font-size:15px;font-weight:600;transition:background .16s,transform .1s}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:active{transform:scale(.98)}.auth-switch{color:var(--text-muted);text-align:center;margin-top:22px;font-size:13px}.auth-switch-btn{color:var(--accent);cursor:pointer;text-underline-offset:2px;background:0 0;border:none;margin-left:4px;padding:0;font-size:13px;font-weight:600;text-decoration:underline}.auth-msg{border-radius:8px;margin:0;padding:8px 12px;font-size:12.5px}.auth-msg.ok{color:#059669;background:#ecfdf5}.auth-msg.err{color:#dc2626;background:#fff1f2}.auth-guest-section{margin-top:28px}.auth-guest-divider{color:var(--text-muted);align-items:center;gap:12px;margin-bottom:16px;font-size:12px;display:flex}.auth-guest-divider:before,.auth-guest-divider:after{content:"";background:#e2e8f0;flex:1;height:1px}.auth-guest-btn{width:100%;height:46px;color:var(--accent);border:1.5px solid var(--accent);border-radius:var(--radius);cursor:pointer;letter-spacing:-.1px;background:0 0;font-size:14.5px;font-weight:600;transition:background .16s,color .16s,transform .1s}.auth-guest-btn:hover{background:var(--accent);color:#fff}.auth-guest-btn:active{transform:scale(.98)}.auth-guest-hint{color:var(--text-muted);text-align:center;margin:12px 0 0;font-size:12px;line-height:1.55}.onb-root{background:linear-gradient(135deg,#f0fdf4 0%,#ecfdf5 50%,#f0f9ff 100%);justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}.onb-card{background:#fff;border-radius:20px;flex-direction:column;width:100%;max-width:440px;min-height:420px;padding:40px 36px;display:flex;box-shadow:0 8px 40px #0000001a}.onb-dots{justify-content:center;gap:8px;margin-bottom:36px;display:flex}.onb-dot{background:#e2e8f0;border-radius:50%;width:8px;height:8px;transition:all .2s}.onb-dot-active{background:var(--accent);border-radius:4px;width:24px}.onb-dot-done{background:#a7f3d0}.onb-step{text-align:center;flex-direction:column;flex:1;align-items:center;display:flex}.onb-icon{margin-bottom:20px;font-size:48px;line-height:1}.onb-title{color:var(--text-primary);letter-spacing:-.5px;margin-bottom:10px;font-size:22px;font-weight:700;line-height:1.35}.onb-desc{color:var(--text-muted);margin-bottom:28px;font-size:14px;line-height:1.6}.onb-btn-primary{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:12px;width:100%;height:48px;margin-top:auto;font-size:15px;font-weight:600;transition:background .15s}.onb-btn-primary:hover{background:#047857}.onb-btn-primary:disabled{opacity:.6;cursor:not-allowed}.onb-actions{gap:10px;width:100%;margin-top:auto;display:flex}.onb-actions .onb-btn-primary{flex:1;margin-top:0}.onb-btn-skip{height:48px;color:var(--text-muted);cursor:pointer;white-space:nowrap;background:#f1f5f9;border:none;border-radius:12px;padding:0 20px;font-size:14px;font-weight:500;transition:background .15s}.onb-btn-skip:hover{background:#e2e8f0}.onb-btn-skip:disabled{opacity:.6;cursor:not-allowed}.onb-day-grid{grid-template-columns:repeat(3,1fr);gap:10px;width:100%;margin-bottom:16px;display:grid}.onb-day-btn{border:1.5px solid var(--border);height:44px;color:var(--text-secondary);cursor:pointer;background:#fff;border-radius:10px;font-size:14px;font-weight:500;transition:all .15s}.onb-day-btn:hover{border-color:var(--accent);color:var(--accent)}.onb-day-btn-active{border-color:var(--accent);background:var(--accent-light);color:var(--accent);font-weight:700}.onb-custom-day{align-items:center;gap:8px;width:100%;margin-bottom:24px;display:flex}.onb-custom-day .onb-field-label{flex-shrink:0}.onb-custom-day .onb-input{text-align:center;width:80px}.onb-fields{text-align:left;flex-direction:column;gap:14px;width:100%;margin-bottom:24px;display:flex}.onb-field-group{text-align:left;flex-direction:column;gap:6px;width:100%;display:flex}.onb-field-label{color:var(--text-secondary);font-size:12.5px;font-weight:600}.onb-input{border:1.5px solid var(--border);height:42px;color:var(--text-primary);box-sizing:border-box;background:#fff;border-radius:10px;outline:none;width:100%;padding:0 12px;font-size:14px;transition:border-color .15s}.onb-input:focus{border-color:var(--accent)}.onb-input-lg{height:52px;font-size:18px;font-weight:600}.onb-input-wrap{align-items:center;gap:8px;width:100%;display:flex}.onb-input-wrap .onb-input{flex:1}.onb-unit{color:var(--text-muted);flex-shrink:0;font-size:14px}.goals-page{padding-bottom:24px}.goals-header{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.goals-title{color:var(--text-primary);font-size:20px;font-weight:700}.goals-subtitle{color:var(--text-muted);margin-top:2px;font-size:13px}.btn-add-goal{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;flex-shrink:0;align-items:center;gap:6px;height:36px;padding:0 14px;font-size:13px;font-weight:600;display:flex}.btn-add-goal:hover{background:var(--accent-hover)}.goals-filter-tabs{gap:8px;margin-bottom:16px;display:flex}.goals-filter-tab{border:1px solid var(--border);background:var(--surface);height:32px;color:var(--text-secondary);cursor:pointer;border-radius:20px;padding:0 14px;font-size:13px}.goals-filter-active{background:var(--accent-light);border-color:var(--accent-border);color:var(--accent);font-weight:600}.goals-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px;display:grid}.goal-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-align:left;cursor:pointer;width:100%;padding:16px;transition:box-shadow .15s,border-color .15s}.goal-card:hover{box-shadow:var(--shadow-card);border-color:var(--accent-border)}.goal-card-header{align-items:center;gap:10px;margin-bottom:12px;display:flex}.goal-card-icon{flex-shrink:0;font-size:24px;line-height:1}.goal-card-title-wrap{flex:1;min-width:0}.goal-card-title{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:600;display:block;overflow:hidden}.goal-card-type{color:var(--text-muted);font-size:12px}.goal-status-badge{white-space:nowrap;border-radius:20px;flex-shrink:0;padding:2px 8px;font-size:11px;font-weight:600}.goal-status-active{color:#059669;background:#ecfdf5}.goal-status-completed{color:#2563eb;background:#eff6ff}.goal-status-paused{color:#ca8a04;background:#fefce8}.goal-progress-wrap{align-items:center;gap:8px;margin-bottom:12px;display:flex}.goal-progress-bar{background:#e2e8f0;border-radius:999px;flex:1;height:6px;overflow:hidden}.goal-progress-fill{background:var(--accent);border-radius:999px;height:100%;transition:width .3s}.goal-progress-done{background:#2563eb}.goal-progress-pct{color:var(--text-secondary);flex-shrink:0;font-size:12px;font-weight:600}.goal-card-amounts{gap:16px;margin-bottom:12px;display:flex}.goal-card-amounts>div{flex-direction:column;gap:2px;display:flex}.goal-amount-label{color:var(--text-muted);font-size:11px}.goal-amount-value{color:var(--text-primary);font-size:13px;font-weight:600}.goal-card-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding-top:10px;display:flex}.goal-footer-item{color:var(--text-secondary);font-size:12px}.goal-footer-dday{color:var(--accent);font-size:12px;font-weight:600}.goals-empty{flex-direction:column;align-items:center;gap:12px;padding:60px 24px;display:flex}.goals-empty-icon{font-size:40px}.goals-empty-text{color:var(--text-muted);font-size:15px}.btn-add-goal-empty{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;height:40px;margin-top:4px;padding:0 20px;font-size:14px;font-weight:600}.btn-add-goal-empty:hover{background:var(--accent-hover)}.modal-body{flex-direction:column;flex:1;gap:16px;padding:20px 24px 24px;display:flex;overflow-y:auto}.field-row-2{grid-template-columns:1fr 1fr;gap:12px;display:grid}.field-input-suffix{align-items:center;display:flex;position:relative}.field-input-suffix .field-input{padding-right:32px}.input-suffix{color:var(--text-muted);pointer-events:none;font-size:13px;position:absolute;right:12px}.required{color:#ef4444;margin-left:2px}.goal-type-grid{grid-template-columns:repeat(5,1fr);gap:8px;display:grid}.goal-type-btn{background:var(--bg);border:1.5px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:10px;flex-direction:column;align-items:center;gap:4px;padding:10px 4px;font-size:12px;transition:all .15s;display:flex}.goal-type-btn span:first-child{font-size:20px}.goal-type-active{background:var(--accent-light);border-color:var(--accent);color:var(--accent);font-weight:600}.goal-calc-box{background:var(--accent-light);border:1px solid var(--accent-border);border-radius:10px;flex-direction:column;gap:8px;margin-bottom:4px;padding:14px 16px;display:flex}.goal-calc-row{justify-content:space-between;align-items:center;font-size:13px;display:flex}.goal-calc-label{color:var(--text-secondary)}.goal-calc-value{color:var(--text-primary);font-weight:600}.goal-calc-highlight .goal-calc-label{color:var(--accent);font-weight:600}.goal-calc-highlight .goal-calc-value{color:var(--accent);font-size:15px}.modal-sheet-tall{max-height:90dvh}.goal-detail-title-row{align-items:center;gap:10px;display:flex}.goal-detail-icon{font-size:24px}.goal-detail-type{color:var(--text-muted);margin-top:2px;font-size:12px;display:block}.goal-detail-progress-section{margin-bottom:20px}.goal-detail-pct-row{align-items:center;gap:10px;margin-bottom:8px;display:flex}.goal-detail-pct{color:var(--text-primary);font-size:24px;font-weight:700}.goal-completed-badge{font-size:14px}.goal-feasibility{font-size:13px;font-weight:600}.goal-detail-amounts{background:var(--bg);border-radius:10px;gap:0;margin-bottom:16px;padding:14px 16px;display:flex}.goal-detail-amount-item{flex-direction:column;flex:1;align-items:center;gap:4px;min-width:0;display:flex;overflow:hidden}.goal-detail-amount-divider{background:var(--border);width:1px;margin:4px 0}.goal-amount-val-lg{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:14px;font-weight:700;overflow:hidden}.goal-detail-info{background:var(--bg);border-radius:10px;flex-direction:column;gap:10px;margin-bottom:16px;padding:14px 16px;display:flex}.goal-info-row{justify-content:space-between;align-items:center;font-size:13px;display:flex}.goal-info-label{color:var(--text-muted)}.goal-info-value{color:var(--text-primary);text-align:right;font-weight:500}.btn-contribute{background:var(--accent-light);width:100%;height:44px;color:var(--accent);border:1.5px solid var(--accent-border);cursor:pointer;border-radius:10px;margin-bottom:12px;font-size:14px;font-weight:600}.btn-contribute:hover{background:#d1fae5}.contribute-form{background:var(--bg);border-radius:10px;flex-direction:column;gap:10px;margin-bottom:12px;padding:14px;display:flex}.contribution-section{margin-top:4px}.contribution-section-title{color:var(--text-primary);align-items:center;gap:6px;margin-bottom:10px;font-size:14px;font-weight:600;display:flex}.contribution-count{background:var(--bg);color:var(--text-muted);border-radius:20px;padding:1px 7px;font-size:12px}.contribution-empty{color:var(--text-muted);text-align:center;padding:16px 0;font-size:13px}.contribution-list{flex-direction:column;gap:2px;list-style:none;display:flex}.contribution-item{background:var(--bg);border-radius:8px;justify-content:space-between;align-items:center;padding:10px 12px;display:flex}.contribution-item-info{flex-direction:column;gap:2px;display:flex}.contribution-date{color:var(--text-secondary);font-size:13px;font-weight:500}.contribution-note{color:var(--text-muted);font-size:12px}.contribution-item-right{align-items:center;gap:10px;display:flex}.contribution-amount{color:var(--income);font-size:14px;font-weight:600}.contribution-delete{width:22px;height:22px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:12px;display:flex}.contribution-delete:hover{color:var(--expense);background:#fee2e2}.goal-detail-actions{border-top:1px solid var(--border);gap:8px;margin-top:20px;padding-top:16px;display:flex}.btn-ghost-small{background:var(--bg);border:1px solid var(--border);height:38px;color:var(--text-secondary);cursor:pointer;border-radius:8px;flex:1;font-size:13px}.btn-ghost-small:hover{border-color:var(--border-strong)}.btn-danger-small{height:38px;color:var(--expense);cursor:pointer;background:#fff1f2;border:1px solid #fecdd3;border-radius:8px;flex:1;font-size:13px}.btn-danger-small:hover{background:#ffe4e6}.btn-danger-small:disabled{opacity:.6;cursor:not-allowed}.fa2-goals-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:24px;display:flex}.fa2-goals-header .eyebrow{color:var(--text-secondary);font-size:13px;font-weight:500}.fa2-goals-header .title{letter-spacing:-.015em;margin-top:2px;font-size:22px;font-weight:700}.fa2-goals-header .actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.fa2-goals-tabs{background:var(--bg-2);scrollbar-width:none;border-radius:12px;align-items:center;gap:2px;max-width:100%;height:40px;padding:4px;display:inline-flex;overflow-x:auto}.fa2-goals-tabs::-webkit-scrollbar{display:none}.fa2-goals-tabs button{height:32px;color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:9px;flex-shrink:0;padding:0 14px;font-size:13px;font-weight:500;transition:background .15s,color .15s}.fa2-goals-tabs button.on{background:var(--surface);color:var(--text-primary);box-shadow:var(--shadow-xs);font-weight:600}.fa2-goals-header .fa2-btn.btn-primary{height:40px;padding:0 18px}.fa2-goals-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;display:grid}.fa2-goal-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;text-align:left;width:100%;padding:24px;transition:border-color .2s,transform .15s,box-shadow .2s}.fa2-goal-card:hover{border-color:var(--accent-soft);box-shadow:var(--shadow-md);transform:translateY(-2px)}.fa2-goal-card .top{align-items:flex-start;gap:16px;margin-bottom:18px;display:flex}.fa2-goal-card .emoji-box{background:var(--accent-light);border-radius:12px;flex-shrink:0;place-items:center;width:44px;height:44px;font-size:22px;display:grid}.fa2-goal-card .nm{letter-spacing:-.01em;font-size:16px;font-weight:600}.fa2-goal-card .tag{color:var(--text-muted);margin-top:2px;font-size:12px}.fa2-goal-card .badge{background:var(--accent-light);color:var(--accent-ink);border-radius:99px;flex-shrink:0;margin-left:auto;padding:4px 10px;font-size:11.5px;font-weight:600}.fa2-goal-card .badge.done{color:var(--text-secondary);background:#f1f5f9}.fa2-goal-card .badge.paused{color:#a16207;background:#fefce8}.fa2-goal-card .badge.waiting{color:#64748b;background:#f8fafc}.fa2-goal-card .bar-wrap{align-items:center;gap:10px;margin-bottom:14px;display:flex}.fa2-goal-card .bar{background:var(--bg-2);border-radius:99px;flex:1;height:8px;overflow:hidden}.fa2-goal-card .bar span{background:linear-gradient(90deg, var(--accent), #10b981);border-radius:inherit;height:100%;transition:width .8s cubic-bezier(.3,.8,.3,1);display:block}.fa2-goal-card .pct{color:var(--accent);font-size:13px;font-weight:700}.fa2-goal-card .nums{justify-content:space-between;font-size:13px;display:flex}.fa2-goal-card .nums .cur{color:var(--text-muted)}.fa2-goal-card .nums .cur b{color:var(--text-primary);font-weight:600}.fa2-goal-card .nums .tgt{font-variant-numeric:tabular-nums;font-weight:600}.fa2-goal-card .foot{border-top:1px dashed var(--border);color:var(--text-muted);justify-content:space-between;align-items:center;margin-top:14px;padding-top:14px;font-size:12.5px;display:flex}.fa2-goal-card .foot .dday{color:var(--accent);font-weight:700}.fa2-goal-add-card{border:2px dashed var(--border-strong);min-height:220px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:20px;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:24px;font-weight:500;transition:border-color .2s,color .2s,background .2s;display:flex}.fa2-goal-add-card:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.fa2-goal-add-card .plus-circle{border:2px solid;border-radius:50%;place-items:center;width:48px;height:48px;display:grid}@media (width<=480px){.goal-detail-amounts{background:0 0;flex-direction:column;gap:0;padding:0}.goal-detail-amount-divider{display:none}.goal-detail-amount-item{background:var(--bg);border-radius:0;flex-direction:row;justify-content:space-between;align-items:center;padding:10px 16px;overflow:visible}.goal-detail-amount-item:first-child{border-radius:10px 10px 0 0}.goal-detail-amount-item:last-child{border-radius:0 0 10px 10px}.goal-detail-amount-item+.goal-detail-amount-item{border-top:1px solid var(--border)}.goal-amount-label{color:var(--text-muted);font-size:12px;font-weight:500}.goal-amount-val-lg{white-space:nowrap;text-overflow:clip;max-width:none;font-size:15px;overflow:visible}}.goal-monthly-section{background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;margin-bottom:4px;padding:12px 14px}.goal-monthly-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.goal-monthly-label{color:#1e40af;font-size:12.5px;font-weight:600}.goal-monthly-pct{color:#1e40af;font-size:13px;font-weight:700}.goal-monthly-amounts{color:var(--text-secondary);font-size:12.5px}.goal-monthly-done{color:var(--text-primary);font-weight:700}.goal-monthly-auto{color:var(--text-muted);font-size:11px}.field-label-hint{color:var(--accent);margin-left:8px;font-size:11px;font-weight:400}.goal-plan-toggle{background:var(--bg-2);border-radius:12px;grid-template-columns:1fr 1fr;gap:4px;padding:4px;display:grid}.goal-plan-toggle button{height:36px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:9px;font-size:13.5px;font-weight:500;transition:background .15s,color .15s}.goal-plan-toggle button.active{background:var(--surface);color:var(--accent-ink);box-shadow:var(--shadow-xs);font-weight:600}.goal-plan-desc{color:var(--text-muted);background:var(--accent-light);border-radius:8px;margin:-6px 0 0;padding:8px 12px;font-size:12.5px;line-height:1.5}.goal-calc-box--monthly{background:#eef2ff;border-color:#a5b4fc}.goal-calc-box--monthly .goal-calc-highlight .goal-calc-label{color:#4f46e5}.goal-calc-box--monthly .goal-calc-highlight .goal-calc-value{color:#4338ca}.mp-auto-badge{color:#4f46e5;background:#eef2ff;border-radius:20px;margin-left:6px;padding:2px 7px;font-size:11px;font-weight:600}.mp-auto-field .field-input{color:#4338ca;cursor:default;background:#eef2ff;font-weight:600}.mp-auto-date-display{color:#4338ca;background:#eef2ff;border:1.5px solid #a5b4fc;border-radius:10px;padding:10px 14px;font-size:14px;font-weight:600}.dashboard-root{max-width:840px;margin:0 auto;padding:40px 24px 80px}.dash-header{z-index:50;background:var(--surface);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 24px;display:flex;position:sticky;top:0}@media (width>=769px){.main-content>.dash-header{display:none}}.dash-header-left{align-items:center;gap:13px;display:flex}.user-avatar{background:var(--accent-light);border:1.5px solid var(--accent-border);width:40px;height:40px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex;overflow:hidden}.dash-greeting{flex-direction:column;gap:1px;display:flex}.dash-greeting-sub{color:var(--text-muted);font-size:11.5px;font-weight:400}.dash-greeting-name{color:var(--text-primary);letter-spacing:-.2px;font-size:15px;font-weight:600}.btn-tx-add{background:var(--accent);color:#fff;cursor:pointer;letter-spacing:-.1px;border:none;border-radius:8px;height:34px;padding:0 16px;font-size:13px;font-weight:600;transition:background .16s,transform .1s}.btn-tx-add:hover{background:var(--accent-hover)}.btn-tx-add:active{transform:scale(.97)}.btn-logout{border:1.5px solid var(--border-strong);height:34px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;padding:0 14px;font-size:13px;font-weight:500;transition:all .16s}.btn-logout:hover{color:var(--text-primary);background:#f8fafc;border-color:#cbd5e1}.summary-grid{grid-template-rows:auto auto;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:32px;display:grid}.summary-card-hero{grid-column:1/-1}.summary-secondary{display:contents}.monthly-toggle-btn{display:none}@media (width<=640px){.summary-grid{flex-direction:column;gap:10px;margin-bottom:16px;display:flex}.monthly-toggle-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;color:var(--text-primary);box-shadow:var(--shadow-card);text-align:left;justify-content:space-between;align-items:center;width:100%;padding:14px 18px;font-size:14px;font-weight:600;transition:background .15s;display:flex}.monthly-toggle-btn:hover{background:var(--surface-hover)}.monthly-toggle-label{color:var(--text-primary);font-size:13px;font-weight:600}.monthly-toggle-chevron{color:var(--text-muted);flex-shrink:0;transition:transform .25s}.monthly-toggle-btn--open .monthly-toggle-chevron{transform:rotate(180deg)}.summary-secondary{flex-direction:column;gap:0;max-height:0;margin-top:-10px;transition:max-height .35s;display:flex;overflow:hidden}.summary-secondary--open{max-height:1000px}.summary-secondary .summary-card{border-top:none;border-radius:0;flex-flow:wrap;justify-content:space-between;align-items:center;gap:12px;padding:13px 18px 13px 22px}.summary-secondary .summary-card:first-child{border-radius:var(--radius-lg) var(--radius-lg) 0 0;border-top:1px solid var(--border)}.summary-secondary .summary-card:last-child{border-radius:0 0 var(--radius-lg) var(--radius-lg)}.summary-secondary .summary-card:before{border-radius:0;width:3px;height:auto;inset:0 auto 0 0}.summary-secondary .summary-card:first-child:before{border-radius:var(--radius-lg) 0 0 0}.summary-secondary .summary-card:last-child:before{border-radius:0 0 0 var(--radius-lg)}.summary-secondary .summary-card>.summary-label{white-space:nowrap;flex:none;align-self:center}.summary-secondary .summary-card>.summary-amount{text-align:right;white-space:nowrap;flex:none;align-self:center;margin-top:0;margin-left:auto;font-size:16px}.summary-secondary .summary-card>.summary-sub{color:var(--text-muted);flex:0 0 100%;order:10;margin-top:-4px;font-size:10px}}.summary-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);flex-direction:column;gap:5px;padding:18px 20px;transition:box-shadow .15s,transform .15s;display:flex;position:relative;overflow:hidden}.summary-card:before{content:"";border-radius:var(--radius-lg) var(--radius-lg) 0 0;background:var(--border);height:3px;position:absolute;top:0;left:0;right:0}.summary-card--income:before{background:var(--income)}.summary-card--expense:before{background:var(--expense)}.summary-card--spendable:before{background:#0ea5e9}.summary-card--saving:before{background:#8b5cf6}.summary-card-hero{background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 12%, var(--surface)) 0%, var(--surface) 100%);border-color:color-mix(in srgb, var(--accent) 30%, var(--border));flex-direction:row;justify-content:space-between;align-items:center;gap:20px;padding:22px 28px;display:flex}.summary-card-hero:before{background:var(--accent)}.summary-hero-left{flex-direction:column;gap:4px;display:flex}.summary-hero-right{flex-direction:column;align-items:flex-end;gap:6px;display:flex}.summary-hero-badge{background:color-mix(in srgb, var(--accent) 15%, transparent);color:var(--accent);white-space:nowrap;border-radius:20px;padding:3px 10px;font-size:11.5px;font-weight:600}.summary-hero-period{color:var(--text-muted);white-space:nowrap;font-size:11px}.summary-label-hero{font-size:11px}.summary-amount-hero{font-family:var(--font-mono);color:var(--text-primary);letter-spacing:-1px;font-size:32px;font-weight:600;line-height:1.15}@media (width<=640px){.summary-card-hero{flex-direction:column;align-items:flex-start;gap:12px;padding:20px}.summary-hero-right{flex-direction:row;align-items:flex-start;gap:10px}.summary-amount-hero{font-size:26px}}.summary-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);font-size:11px;font-weight:600}.summary-amount{font-family:var(--font-mono);color:var(--text-primary);letter-spacing:-.5px;margin-top:2px;font-size:20px;font-weight:500;line-height:1.2}.summary-income{color:var(--income)}.summary-expense{color:var(--expense)}.summary-spendable{color:#0ea5e9}.summary-saving{color:#8b5cf6}.summary-invest{color:#f97316}.summary-sub{color:var(--text-muted);margin-top:2px;font-size:11px}.grid-12{grid-template-columns:repeat(12,1fr);gap:20px;display:grid}.grid-12 .col-4{grid-column:span 4}.grid-12 .col-5{grid-column:span 5}.grid-12 .col-6{grid-column:span 6}.grid-12 .col-7{grid-column:span 7}.grid-12 .col-8{grid-column:span 8}.grid-12 .col-12{grid-column:span 12}.fa2-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;transition:border-color .2s,box-shadow .2s}.fa2-card-title{color:var(--text-secondary);letter-spacing:-.005em;justify-content:space-between;align-items:center;margin:0 0 18px;font-size:13px;font-weight:600;display:flex}.fa2-card-title .spread{color:var(--text-muted);font-size:12.5px;font-weight:500}.fa2-btn{cursor:pointer;letter-spacing:-.005em;white-space:nowrap;color:inherit;background:0 0;border:none;border-radius:10px;align-items:center;gap:6px;padding:10px 16px;font-size:14px;font-weight:600;transition:background .15s,transform .12s,box-shadow .2s;display:inline-flex}.fa2-btn.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-accent);margin-top:0}.fa2-btn.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px)}.fa2-btn.btn-ghost{color:var(--text-secondary);background:var(--bg-2)}.fa2-btn.btn-ghost:hover{background:color-mix(in oklab, var(--bg-2) 70%, var(--text) 5%);color:var(--text-primary)}.fa2-btn.btn-logout{color:#ef4444;background:#fef2f2;border:1.5px solid #fecaca;align-items:center;gap:6px;display:flex}.fa2-btn.btn-logout:hover{background:#fee2e2;border-color:#ef4444}.fa2-btn.btn-outline{color:var(--accent-ink);background:var(--surface);border:1.5px solid var(--accent-soft)}.fa2-btn.btn-outline:hover{background:var(--accent-light);border-color:var(--accent)}.fa2-btn.btn-sm{border-radius:20px;height:35px;padding:0 20px;font-size:14px}.fa2-btn.btn-icon{background:var(--bg-2);width:36px;height:36px;color:var(--text-secondary);border-radius:10px;place-items:center;padding:0;display:grid}.balance-hero{color:#fff;border-radius:var(--radius-xl);background:linear-gradient(135deg,#064e3b 0%,#047857 55%,#059669 100%);border:none;height:100%;padding:40px;position:relative;overflow:hidden}.balance-hero:before{content:"";pointer-events:none;background:radial-gradient(circle at 85% 15%,#ffffff1f,#0000 40%),radial-gradient(circle at 10% 90%,#ffffff0f,#0000 40%);position:absolute;inset:0}.balance-hero .row1{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex;position:relative}.balance-hero .label{letter-spacing:.05em;text-transform:uppercase;color:#ffffffb3;font-size:12px;font-weight:600}.balance-hero .eye-btn{color:#fff;cursor:pointer;background:#ffffff1f;border:none;border-radius:10px;place-items:center;width:36px;height:36px;display:grid}.balance-hero .eye-btn:hover{background:#fff3}.balance-hero .amount{letter-spacing:-.028em;font-variant-numeric:tabular-nums;word-break:break-all;margin-bottom:14px;font-size:44px;font-weight:700;line-height:1;position:relative}.balance-hero .amount .won{opacity:.8;margin-left:4px;font-size:24px}.balance-hero .meta{color:#ffffffbf;flex-wrap:wrap;align-items:center;gap:14px;font-size:13px;display:flex;position:relative}.balance-hero .chip{color:#fff;background:#ffffff26;border-radius:99px;padding:5px 10px;font-size:12px;font-weight:600}.hero-bar-wrap{flex-direction:column;gap:10px;display:flex;position:relative}.hero-bar-track{background:#ffffff1f;border-radius:6px;gap:2px;height:10px;display:flex;overflow:hidden}.hero-bar-seg{height:100%;transition:width .5s}.hero-bar-legend{flex-wrap:wrap;gap:16px;display:flex}.hero-bar-item{color:#ffffffd9;white-space:nowrap;align-items:center;gap:5px;font-size:12px;display:flex}.hero-bar-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.hero-bar-label{font-weight:500}.hero-bar-pct{color:#fff;font-variant-numeric:tabular-nums;font-weight:700}.hero-bar-amt{color:#fff9;font-variant-numeric:tabular-nums;font-size:11px}.quick-actions-grid{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.quick-action{--qa-accent:var(--accent);background:linear-gradient(180deg, color-mix(in srgb, var(--qa-accent) 11%, #fff) 0%, color-mix(in srgb, var(--qa-accent) 4%, #fff) 100%);border:1px solid color-mix(in srgb, var(--qa-accent) 22%, var(--border));color:var(--text-primary);cursor:pointer;border-radius:14px;flex-direction:column;align-items:center;gap:8px;padding:16px 8px 14px;font-size:12.5px;font-weight:600;transition:transform .18s,border-color .18s,box-shadow .18s,background .18s;display:flex}.quick-action--record{--qa-accent:#10b981}.quick-action--account{--qa-accent:#3b82f6}.quick-action--transfer{--qa-accent:#8b5cf6}.quick-action .qa-icon{background:color-mix(in srgb, var(--qa-accent) 18%, #fff);width:38px;height:38px;color:var(--qa-accent);box-shadow:0 1px 2px color-mix(in srgb, var(--qa-accent) 14%, transparent);border-radius:12px;place-items:center;transition:transform .2s,background .18s;display:grid}.quick-action .qa-label{letter-spacing:-.1px;color:color-mix(in srgb, var(--qa-accent) 65%, var(--text-primary))}.quick-action:hover{background:linear-gradient(180deg, color-mix(in srgb, var(--qa-accent) 16%, #fff) 0%, color-mix(in srgb, var(--qa-accent) 7%, #fff) 100%);border-color:color-mix(in srgb, var(--qa-accent) 50%, var(--border));box-shadow:0 8px 18px -6px color-mix(in srgb, var(--qa-accent) 35%, transparent);transform:translateY(-2px)}.quick-action:hover .qa-icon{background:color-mix(in srgb, var(--qa-accent) 26%, #fff);transform:scale(1.08)}.quick-action:active{transform:translateY(0)scale(.97);box-shadow:0 1px 3px #0000000f}.quick-hint{background:var(--accent-light);color:var(--accent-ink);border-radius:14px;align-items:center;gap:10px;margin-top:16px;padding:14px 16px;font-size:13px;display:flex}.quick-hint b{font-variant-numeric:tabular-nums}.monthly-grid{grid-template-columns:repeat(5,1fr);gap:0;display:grid}.monthly-cell{border-left:3px solid var(--accent);padding:4px 20px;position:relative}.monthly-cell .ml{color:var(--text-secondary);margin-bottom:6px;font-size:12.5px;font-weight:500}.monthly-cell .mv{letter-spacing:-.015em;font-variant-numeric:tabular-nums;word-break:break-all;font-size:22px;font-weight:700}.monthly-cell .mn{color:var(--text-muted);margin-top:4px;font-size:11.5px}.monthly-cell.income{border-color:#10b981}.monthly-cell.income .mv{color:#059669}.monthly-cell.expense{border-color:#ef4444}.monthly-cell.expense .mv{color:#dc2626}.monthly-cell.available{border-color:#3b82f6}.monthly-cell.available .mv{color:#2563eb}.monthly-cell.savings{border-color:#8b5cf6}.monthly-cell.savings .mv{color:#7c3aed}.monthly-cell.subscription{border-color:#f59e0b}.monthly-cell.subscription .mv{color:#d97706}.monthly-cell.invest{border-color:#818cf8}.monthly-cell.invest .mv{color:#4f46e5}.collapse-head{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;display:flex}.collapse-head h3{letter-spacing:-.01em;margin:0;font-size:16px;font-weight:600}.collapse-head .chev{width:32px;height:32px;color:var(--text-muted);border-radius:8px;flex-shrink:0;place-items:center;transition:background .15s,transform .2s;display:grid}.collapse-head .chev.open{transform:rotate(180deg)}.collapse-head:hover .chev{background:var(--bg-2)}.collapse-body{opacity:1;max-height:4000px;margin-top:24px;transition:max-height .3s,opacity .3s,margin .3s;overflow:hidden}.collapse-body.closed{opacity:0;margin-top:0;max-height:0!important}.acc-head{flex-direction:column!important;align-items:stretch!important;gap:6px!important}.acc-head-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.acc-head-title-area{flex-wrap:wrap;align-items:center;gap:10px;min-width:0;display:flex}.acc-head-title-area h3{flex-shrink:0;margin:0}.acc-total{font-variant-numeric:tabular-nums;color:var(--text-primary);padding-top:2px;font-size:21px;font-weight:700;line-height:1.3;display:block}.acc-head-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.acc-head-pills{flex-wrap:wrap;gap:6px;display:flex}.acc-pill{background:var(--bg-2);color:var(--text-secondary);border-radius:99px;align-items:center;gap:6px;padding:4px 10px;font-size:11.5px;font-weight:600;display:inline-flex}.acc-pill b{color:var(--text-primary)}.acc-pill.green{background:var(--accent-light);color:var(--accent-ink)}.acc-pill.blue{color:#1e40af;background:#dbeafe}.acc-pill.purple{color:#6d28d9;background:#ede9fe}.acc-pill.amber{color:#b45309;background:#fef3c7}.fa2-acc-group{margin-top:20px}.fa2-acc-group-head{align-items:baseline;gap:6px;margin:0 0 10px;display:flex}.fa2-acc-group-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:600}.fa2-acc-group-head .gtot{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:12px;font-weight:600}.fa2-acc-row{cursor:pointer;border-radius:12px;align-items:center;gap:14px;padding:14px 16px;transition:background .15s;display:flex}.fa2-acc-row:hover{background:var(--bg-2)}.fa2-acc-row .ci{background:var(--bg-2);width:40px;height:40px;color:var(--text-secondary);border-radius:12px;flex-shrink:0;place-items:center;font-size:15px;font-weight:600;display:grid}.fa2-acc-row .ci.accent{background:var(--accent-light);color:var(--accent-ink)}.fa2-acc-row .info{flex:1;min-width:0}.fa2-acc-row .info .nm{align-items:center;gap:8px;font-size:14.5px;font-weight:600;display:flex;overflow:hidden}.fa2-acc-row .info .nm .nm-text{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.fa2-acc-row .info .sub{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;margin-top:2px;font-size:12px;overflow:hidden}.fa2-acc-row .amt{font-variant-numeric:tabular-nums;white-space:nowrap;flex-shrink:0;font-size:15px;font-weight:600}.fa2-acc-badge{border-radius:99px;flex-shrink:0;padding:2px 7px;font-size:10px;font-weight:500}.fa2-acc-badge.general{background:var(--bg-2);color:var(--text-secondary)}.fa2-acc-badge.savings{background:var(--accent-light);color:var(--accent-ink)}.fa2-acc-badge.invest{color:#6d28d9;background:#ede9fe}.fa2-tx-head{flex-wrap:nowrap;align-items:center;gap:8px;margin-bottom:6px;display:flex}.fa2-tx-label{color:var(--text-secondary);white-space:nowrap;font-size:13px;font-weight:600}.fa2-tx-cnt{color:var(--text-muted);white-space:nowrap;font-size:12.5px;font-weight:500}.fa2-tx-head .sel{background:var(--bg-2);border:1px solid var(--border);cursor:pointer;color:var(--text-secondary);white-space:nowrap;border-radius:10px;flex-shrink:0;align-items:center;gap:6px;padding:7px 11px;font-size:13px;font-weight:500;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.fa2-tx-head .sel:hover{background:var(--surface);border-color:var(--border-strong);color:var(--text-primary)}.fa2-tx-head .sel.active{background:var(--accent-light);color:var(--accent-ink);border-color:var(--accent-soft)}.fa2-tx-head .spread{flex:1}.tx-search-toggle{padding:7px 9px!important}.fa2-tx-chips{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;align-items:center;gap:6px;padding:4px 0 10px;display:flex;overflow-x:auto}.fa2-tx-chips::-webkit-scrollbar{display:none}.fa2-tx-chips .sel{background:var(--bg-2);border:1px solid var(--border);cursor:pointer;color:var(--text-secondary);white-space:nowrap;border-radius:10px;flex-shrink:0;align-items:center;padding:6px 11px;font-size:13px;font-weight:500;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.fa2-tx-chips .sel:hover{background:var(--surface);border-color:var(--border-strong);color:var(--text-primary)}.fa2-tx-chips .sel.active{background:var(--accent-light);color:var(--accent-ink);border-color:var(--accent-soft)}.fa2-tx-chip-sep{background:var(--border-strong);flex-shrink:0;width:1px;height:18px;margin:0 4px}.fa2-tx-chips .sel.type-chip{background:var(--surface);border-color:var(--border-strong);color:var(--text-primary);font-weight:600}.fa2-tx-chips .sel.type-chip:hover{background:var(--bg-2);border-color:var(--accent-soft)}.fa2-tx-chips .sel.type-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}.fa2-tx-chips .sel.cat-chip{background:var(--bg-2);border-color:var(--border);color:var(--text-secondary);font-size:12.5px;font-weight:400}.fa2-tx-chips .sel.cat-chip.active{background:var(--accent-light);color:var(--accent-ink);border-color:var(--accent-soft);font-weight:500}.tx-date-btn{white-space:nowrap;font-size:12px!important}.fa2-tx-date-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:10px;margin-bottom:6px;padding:12px 14px;animation:.15s slideDown;display:flex}@keyframes slideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.tx-date-quick{flex-direction:row;gap:6px;display:flex}.tx-date-quick-btn{border:1px solid var(--border);background:var(--bg-2);color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:20px;padding:5px 13px;font-size:12px;font-weight:500;transition:background .12s,color .12s,border-color .12s}.tx-date-quick-btn:hover{background:var(--accent-light);color:var(--accent-ink);border-color:var(--accent-soft)}.tx-date-pickers{background:var(--surface);border:1.5px solid var(--border);border-radius:10px;align-items:center;gap:0;width:fit-content;padding:0 6px;transition:border-color .15s;display:flex}.tx-date-pickers:focus-within{border-color:var(--accent)}.tx-date-pickers .react-datepicker-wrapper,.tx-date-pickers .react-datepicker__input-container{width:auto}.tx-date-sep{color:var(--text-muted);flex-shrink:0;padding:0 2px;font-size:13px}.tx-dp-input{color:var(--text-primary);cursor:pointer;background:0 0;border:none;border-radius:0;outline:none;width:78px;padding:7px 8px;font-size:13px}.tx-dp-input:focus{outline:none}.react-datepicker{overflow:hidden;border:1px solid var(--border)!important;border-radius:12px!important;font-family:inherit!important;box-shadow:0 8px 24px #0000001f!important}.react-datepicker__header{background:var(--bg-2)!important;border-bottom:1px solid var(--border)!important;padding-top:10px!important}.react-datepicker__current-month{color:var(--text-primary)!important;font-size:13px!important;font-weight:600!important}.react-datepicker__day-name{color:var(--text-muted)!important;font-size:11px!important}.react-datepicker__day{color:var(--text-primary)!important;border-radius:6px!important;font-size:12px!important}.react-datepicker__day:hover{background:var(--accent-light)!important;color:var(--accent-ink)!important}.react-datepicker__day--selected,.react-datepicker__day--range-start,.react-datepicker__day--range-end{background:var(--accent)!important;color:#fff!important}.react-datepicker__day--in-range{background:var(--accent-light)!important;color:var(--accent-ink)!important}.react-datepicker__day--outside-month{opacity:.4;color:var(--text-muted)!important}.react-datepicker__navigation-icon:before{border-color:var(--text-secondary)!important}.fa2-tx-search{background:var(--surface);border:1px solid var(--border);border-radius:12px;align-items:center;gap:10px;margin-bottom:6px;padding:9px 14px;animation:.15s slideDown;display:flex}.fa2-tx-search svg{color:var(--text-muted);flex-shrink:0}.tx-search-q{min-width:0;color:var(--text-primary);background:0 0;border:none;border-radius:0;outline:none;flex:1;padding:4px 0;font-size:13.5px}.tx-search-q::placeholder{color:var(--text-muted)}.tx-search-q:focus{outline:none}.tx-date-q{border:1px solid var(--border);background:var(--bg-2);color:var(--text-primary);border-radius:8px;outline:none;flex-shrink:0;padding:6px 8px;font-size:13px}.tx-date-q:focus{border-color:var(--accent)}.tx-search-clear{background:var(--bg-3);color:var(--text-secondary);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:11px;display:flex}.tx-search-clear:hover{background:var(--border);color:var(--text-primary)}.fa2-tx-list{flex-direction:column;gap:2px;display:flex}.tx-empty-generic{text-align:center;color:var(--text-muted);padding:40px 0;font-size:14px}.tx-empty-category{flex-direction:column;align-items:center;gap:14px;padding:36px 0 28px;display:flex}.tx-empty-msg{color:var(--text-muted);margin:0;font-size:14px}.tx-empty-cat-name{color:var(--text-secondary);font-weight:600}.tx-empty-add-row{border:1.5px dashed var(--accent-soft);background:var(--accent-light);color:var(--accent-ink);cursor:pointer;border-radius:10px;align-items:center;gap:7px;padding:10px 20px;font-size:13px;font-weight:500;transition:background .15s,border-color .15s;display:inline-flex}.tx-empty-add-row:hover{background:var(--accent-soft);border-color:var(--accent)}.fa2-tx-item{cursor:pointer;border-radius:12px;align-items:center;gap:14px;padding:14px 12px;transition:background .15s,transform .15s;display:flex;position:relative}.fa2-tx-item:hover{background:var(--accent-light,#ecfdf5);transform:translate(2px)}.fa2-tx-item:before{content:"";background:var(--expense,#ef4444);border:1.5px solid var(--bg-1,#fff);border-radius:50%;flex-shrink:0;width:8px;height:8px;position:absolute;top:50%;left:-22px;transform:translateY(-50%)}.fa2-tx-item[data-tx-type=income]:before{background:var(--income,#10b981)}.fa2-tx-item .ti-icon{background:var(--bg-2);width:40px;height:40px;color:var(--text-secondary);border-radius:12px;flex-shrink:0;place-items:center;font-size:16px;display:grid}.fa2-tx-item .ti-main{flex:1;min-width:0}.fa2-tx-item .ti-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:14.5px;font-weight:500;overflow:hidden}.fa2-tx-item .ti-meta{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;margin-top:3px;font-size:12px;overflow:hidden}.fa2-tx-item .ti-amt{font-variant-numeric:tabular-nums;white-space:nowrap;flex-shrink:0;font-size:15px;font-weight:600}.fa2-tx-item .ti-amt.out{color:var(--expense)}.fa2-tx-item .ti-amt.in{color:var(--income)}.fa2-tx-item .ti-date{color:var(--text-muted);text-align:right;white-space:nowrap;flex-shrink:0;min-width:50px;font-size:11.5px}.tx-date-group{margin-bottom:6px;padding-left:28px;position:relative}.tx-date-group:before{content:"";background:linear-gradient(to bottom, var(--border,#e5e7eb) 60%, transparent 100%);border-radius:1px;width:2px;position:absolute;top:10px;bottom:16px;left:9px}.tx-date-header{align-items:baseline;gap:6px;padding:8px 8px 4px;display:flex;position:relative}.tx-date-header:before{content:"";background:var(--text-muted,#94a3b8);border:2px solid var(--bg-1,#fff);width:10px;height:10px;box-shadow:0 0 0 2px var(--border,#e5e7eb);border-radius:50%;position:absolute;top:50%;left:-22px;transform:translateY(-50%)}.tx-date-label{color:var(--text-muted);letter-spacing:.01em;font-size:12px;font-weight:600}.tx-date-sep{color:var(--text-muted);opacity:.4;font-size:12px;font-weight:600}.tx-date-total{font-variant-numeric:tabular-nums;gap:6px;font-size:11.5px;font-weight:600;display:flex}.tx-date-total .in{color:var(--income)}.tx-date-total .out{color:var(--expense)}.tx-load-more{border:1.5px dashed var(--border);width:100%;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:10px;margin-top:10px;padding:13px;font-size:13.5px;font-weight:500;transition:background .15s,border-color .15s,color .15s}.tx-load-more:hover{background:var(--bg-2);border-color:var(--border-strong);color:var(--text-primary)}.acc-total-empty{color:var(--text-muted)!important;font-size:15px!important;font-weight:400!important}@media (width<=1100px){.grid-12>.col-7,.grid-12>.col-5,.grid-12>.col-4,.grid-12>.col-6,.grid-12>.col-8{grid-column:span 12}.fa2-card{padding:22px}.balance-hero{padding:32px 28px}.balance-hero .amount{font-size:38px}}@media (width<=768px){.monthly-grid{grid-template-columns:1fr 1fr;gap:12px 0}.balance-hero{border-radius:var(--radius-lg);padding:26px 22px}.balance-hero .amount{font-size:32px}.balance-hero .amount .won{font-size:18px}.fa2-card{border-radius:var(--radius);padding:18px}.fa2-goal-card{padding:18px}.fa2-chart-bars{gap:4px}.fa2-chart-col .bar{max-width:16px}.fa2-donut{width:160px;height:160px}}@media (width<=480px){.monthly-grid{grid-template-columns:1fr 1fr;gap:10px}.monthly-cell{border-left:none;border-top:3px solid var(--accent);border-bottom:none;border-radius:12px;padding:14px 16px;transition:transform .15s}.monthly-cell:active{transform:scale(.98)}.monthly-cell.income{background:linear-gradient(#10b98117,#10b98105);border-top-color:#10b981}.monthly-cell.expense{background:linear-gradient(#ef444414,#ef444405);border-top-color:#ef4444}.monthly-cell.available{background:linear-gradient(#3b82f614,#3b82f605);border-top-color:#3b82f6}.monthly-cell.savings{background:linear-gradient(#8b5cf617,#8b5cf605);border-top-color:#8b5cf6}.monthly-cell .ml{margin-bottom:4px;font-size:11px}.monthly-cell .mv{font-size:18px}.monthly-cell .mn{font-size:10.5px}.acc-total{font-size:17px}}.mth-modal-total{color:var(--text-muted);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:4px;padding:12px 24px;font-size:13px;display:flex}.mth-modal-total strong{font-size:15px;font-weight:700}.mth-modal-total.income strong{color:#059669}.mth-modal-total.expense strong{color:#dc2626}.mth-modal-total.savings strong{color:#2563eb}.mth-modal-total.invest strong{color:#4f46e5}.mth-modal-row{cursor:pointer;align-items:center;gap:10px;padding:11px 24px;transition:background .12s;display:flex}.mth-modal-row:hover{background:var(--bg)}.mth-modal-date{color:var(--text-muted);font-variant-numeric:tabular-nums;flex-shrink:0;min-width:28px;font-size:12px}.mth-modal-info{flex:1;min-width:0}.mth-modal-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:500;overflow:hidden}.mth-modal-sub{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:11.5px;overflow:hidden}.mth-modal-amt{font-variant-numeric:tabular-nums;flex-shrink:0;font-size:13.5px;font-weight:600}.mth-modal-amt.income{color:#059669}.mth-modal-amt.expense{color:#dc2626}.mth-modal-amt.savings{color:#2563eb}.mth-modal-amt.invest{color:#4f46e5}.pending-auto-debits-card{background:#fef3c7;border:1px solid #fbbf24;border-radius:12px;margin-bottom:16px;padding:16px}.pending-auto-debits-card header h3{margin:0 0 12px;font-size:1rem}.pending-auto-debits-card ul{margin:0 0 12px;padding:0;list-style:none}.pending-auto-debits-card li{border-bottom:1px dashed #fcd34d;grid-template-columns:1fr auto auto 1fr auto auto;align-items:center;gap:8px;padding:8px 0;display:grid}.pending-auto-debits-card li:last-child{border-bottom:none}.pad-amount{font-weight:600}.pad-from{color:#92400e;font-size:.85em}.pending-auto-debits-card footer{justify-content:flex-end;gap:8px;display:flex}@media (width<=640px){.pending-auto-debits-card li{grid-template-rows:auto auto auto;grid-template-columns:1fr 1fr}}.auto-debit-badge{cursor:pointer;color:#92400e;background:#fef3c7;border:1px solid #fbbf24;border-radius:999px;flex-shrink:0;align-items:center;gap:2px;padding:2px 8px;font-size:.75em;font-weight:600;line-height:1.4;display:inline-flex}.auto-debit-badge:hover{background:#fde68a}.stats-modal{max-width:640px!important}.stats-body{gap:24px!important}.stats-page-wrap{width:100%;max-width:600px;margin:0 auto;padding:8px 0 0}.stats-loading{justify-content:center;padding:40px 0;display:flex}.stats-compare-row{grid-template-columns:repeat(3,1fr);gap:12px;display:grid;overflow-x:auto}@media (width<=640px){.stats-compare-row{overflow-x:unset;grid-template-columns:1fr}.stats-cat-layout{flex-direction:column}.stats-cat-layout>div:first-child{width:100%!important}.fa2-chart-bars.cols-12 .month{font-size:9px}}.stats-compare-card{border:1px solid var(--border);background:#fff;border-radius:12px;flex-direction:column;gap:4px;padding:14px 16px;display:flex}.stats-compare-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);font-size:11.5px;font-weight:600}.stats-compare-amount{font-family:var(--font-mono);letter-spacing:-.4px;font-size:18px;font-weight:500}.stats-compare-amount.income{color:#059669}.stats-compare-amount.expense{color:#dc2626}.stats-compare-diff{font-size:11.5px;font-weight:500}.stats-compare-diff.up{color:#dc2626}.stats-compare-diff.down{color:#059669}.stats-compare-sub{color:var(--text-muted);margin-top:1px;font-size:11px}.stats-section{border:1px solid var(--border);background:#fff;border-radius:12px;flex-direction:column;gap:12px;padding:16px;display:flex}.stats-section-title{color:var(--text-primary);letter-spacing:-.1px;font-size:13px;font-weight:600}.stats-legend{justify-content:center;gap:16px;display:flex}.stats-legend-item{color:var(--text-muted);align-items:center;gap:6px;font-size:12px;display:flex}.stats-dot{border-radius:2px;flex-shrink:0;width:8px;height:8px}.income-dot{background:#34d399}.expense-dot{background:#fca5a5}.stats-cat-layout{align-items:center;gap:8px;display:flex}.stats-cat-list{flex-direction:column;flex:1;gap:8px;display:flex}.stats-cat-row{align-items:center;gap:8px;display:flex}.stats-cat-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.stats-cat-name{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;overflow:hidden}.stats-cat-pct{color:var(--text-muted);text-align:right;width:32px;font-size:12px}.stats-cat-amount{font-family:var(--font-mono);color:var(--text-primary);white-space:nowrap;font-size:12.5px;font-weight:500}.stats-saving-list{flex-direction:column;gap:10px;margin-bottom:14px;display:flex}.stats-saving-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.stats-saving-left{align-items:center;gap:8px;min-width:0;display:flex}.stats-saving-badge{border-radius:20px;flex-shrink:0;padding:2px 7px;font-size:10.5px;font-weight:600}.badge-saving{color:#2563eb;background:#dbeafe}.badge-investment{color:#ea580c;background:#ffedd5}.stats-saving-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.stats-saving-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.stats-saving-amount{color:var(--text-primary);font-size:13px;font-weight:600;font-family:var(--font-mono)}.stats-saving-pct{color:var(--text-muted);text-align:right;width:32px;font-size:11.5px}.stats-saving-bar-wrap{background:var(--border);border-radius:6px;gap:2px;height:8px;margin-bottom:8px;display:flex;overflow:hidden}.stats-saving-bar-seg{cursor:default;border-radius:2px;height:100%;transition:width .3s;position:relative}.stats-saving-bar-seg:hover{filter:brightness(1.12)}.stats-saving-bar-seg[data-tooltip]:after{content:attr(data-tooltip);color:#fff;white-space:nowrap;pointer-events:none;opacity:0;z-index:10;background:#1e293b;border-radius:5px;padding:4px 8px;font-size:12px;transition:opacity .15s;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%)}.stats-saving-bar-seg[data-tooltip]:hover:after{opacity:1}.stats-saving-total{color:var(--text-muted);text-align:right;font-size:12px}.setting-hint{color:var(--text-muted);margin-top:4px;font-size:12px;line-height:1.6}.cat-error-msg{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:10px 14px;font-size:13px;line-height:1.5}.cat-parent-group{margin-bottom:6px}.cat-parent-row,.cat-sortable-child{align-items:center;gap:4px;display:flex}.cat-drag-handle{color:#cbd5e1;cursor:grab;touch-action:none;border-radius:4px;flex-shrink:0;align-items:center;padding:4px 3px;display:flex}.cat-drag-handle:hover{color:#94a3b8;background:#f1f5f9}.cat-drag-handle:active{cursor:grabbing}.cat-parent-item{flex:1}.cat-parent-name{color:var(--text-primary);font-size:13px;font-weight:600}.cat-children{border-left:2px solid var(--border);margin-top:2px;margin-bottom:4px;margin-left:10px;padding-left:14px}.cat-child-item{color:var(--text-secondary);font-size:13px}.cat-add-child-btn{background:var(--accent-light);border:1px solid var(--accent-border);width:24px;height:24px;color:var(--accent);cursor:pointer;opacity:0;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:15px;line-height:1;transition:background .13s;display:flex}.cat-parent-row:hover .cat-add-child-btn{opacity:1}.cat-add-child-btn:hover{background:#d1fae5}.cat-parent-hint{border:1px solid var(--border);background:#f8fafc;border-radius:8px;align-items:center;gap:8px;padding:8px 12px;font-size:13px;display:flex}.cat-parent-hint-label{color:var(--text-muted);white-space:nowrap;font-size:12px;font-weight:500}.cat-parent-hint-name{color:var(--text-primary);font-weight:600}.fa2-stat-big{letter-spacing:-.02em;font-variant-numeric:tabular-nums;word-break:break-all;margin-bottom:4px;font-size:28px;font-weight:700}.fa2-stat-big.pos{color:var(--accent)}.fa2-stat-big.neg{color:var(--expense)}.fa2-stat-note{color:var(--text-muted);font-size:12.5px}.fa2-chart-wrap{padding:8px 0 4px}.fa2-chart-bars{border-bottom:1px solid var(--border);grid-template-columns:repeat(6,1fr);align-items:end;gap:6px;height:210px;padding:0 4px;display:grid;position:relative}.fa2-chart-bars.cols-3{grid-template-columns:repeat(3,1fr)}.fa2-chart-bars.cols-12{grid-template-columns:repeat(12,1fr);gap:3px}.fa2-chart-bars.cols-12 .bar{border-radius:3px 3px 0 0;min-width:4px;max-width:12px}.fa2-chart-bars.cols-12 .bars{gap:2px}.fa2-chart-col{flex-direction:column;align-items:center;gap:0;display:flex;position:relative}.fa2-chart-col .bars{justify-content:center;align-items:flex-end;gap:3px;width:100%;height:180px;display:flex}.fa2-chart-col .bar{border-radius:4px 4px 0 0;flex:1;min-width:6px;max-width:22px;min-height:2px;transition:transform .2s,opacity .2s}.fa2-chart-col .bar.income{background:#10b981}.fa2-chart-col .bar.expense{background:#f87171}.fa2-chart-col .bar.save{background:#60a5fa}.fa2-chart-col:hover .bar{opacity:.85}.fa2-chart-col{cursor:pointer}.chart-tooltip{background:var(--text);color:#fff;white-space:nowrap;z-index:100;pointer-events:none;border-radius:10px;min-width:130px;padding:10px 13px;font-size:12.5px;display:none;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 4px 16px #0000002e}.chart-tooltip:after{content:"";border:5px solid #0000;border-top-color:var(--text);position:absolute;top:100%;left:50%;transform:translate(-50%)}.fa2-chart-col:hover .chart-tooltip{display:block}.ct-label{color:#ffffffbf;margin-bottom:6px;font-size:13px;font-weight:700}.ct-row{align-items:center;gap:6px;padding:2px 0;font-size:12px;display:flex}.ct-val{font-variant-numeric:tabular-nums;margin-left:auto;font-weight:600}.ct-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.ct-dot.income{background:#10b981}.ct-dot.expense{background:#f87171}.ct-dot.save{background:#60a5fa}.fa2-chart-col .month{color:var(--text-muted);font-variant-numeric:tabular-nums;margin-top:8px;font-size:11px}.fa2-chart-legend{color:var(--text-secondary);flex-wrap:wrap;justify-content:center;gap:20px;margin-top:18px;font-size:12.5px;display:flex}.fa2-chart-legend .lg{align-items:center;gap:6px;display:inline-flex}.fa2-chart-legend .sw{border-radius:3px;width:10px;height:10px}.fa2-donut-wrap{justify-content:center;padding:10px 0;display:flex}.fa2-donut{border-radius:50%;width:200px;height:200px;position:relative;-webkit-mask-image:radial-gradient(circle,#0000 55px,#000 56px);mask-image:radial-gradient(circle,#0000 55px,#000 56px)}.fa2-donut-svg{width:200px;height:200px;overflow:visible}.fa2-cat-row{cursor:default;border-radius:8px;align-items:center;gap:12px;padding:6px 8px;transition:background .15s;display:flex;position:relative}.fa2-cat-row:hover{background:var(--bg-2)}.cat-tooltip{background:var(--text);color:#fff;white-space:nowrap;z-index:100;pointer-events:none;border-radius:10px;min-width:160px;padding:10px 13px;font-size:12.5px;display:none;position:absolute;bottom:calc(100% + 6px);right:0;box-shadow:0 4px 16px #0000002e}.cat-tooltip:after{content:"";border:5px solid #0000;border-top-color:var(--text);position:absolute;top:100%;right:20px}.fa2-cat-row:hover .cat-tooltip{display:block}.cat-tooltip .ct-label{margin-bottom:7px;font-size:13px;font-weight:700}.fa2-cat-row .dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.fa2-cat-row .nm{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:14px;font-weight:500;overflow:hidden}.fa2-cat-row .pct{color:var(--text-muted);text-align:right;width:36px;font-size:12.5px}.fa2-cat-row .amt{font-variant-numeric:tabular-nums;text-align:right;width:110px;font-size:14px;font-weight:600}.fa2-period-toggle{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;gap:4px;padding:4px;display:flex}.fa2-period-toggle button{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:6px 14px;font-size:12.5px;font-weight:500;transition:background .15s}.fa2-period-toggle button.on{background:var(--surface);color:var(--text-primary);box-shadow:var(--shadow-xs);font-weight:600}.fa2-sav-item{border-bottom:1px solid var(--border);align-items:center;gap:14px;padding:14px 0;display:flex}.fa2-sav-item:last-child{border-bottom:none}.fa2-sav-item .tp{border-radius:6px;flex-shrink:0;padding:3px 8px;font-size:11px;font-weight:600}.fa2-sav-item .tp.saving{background:var(--accent-light);color:var(--accent-ink)}.fa2-sav-item .tp.invest{color:#9a3412;background:#fff7ed}.fa2-sav-item .nm{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:14px;font-weight:500;overflow:hidden}.fa2-sav-item .amt{font-variant-numeric:tabular-nums;font-size:15px;font-weight:700}.fa2-sav-item .pct{color:var(--text-muted);text-align:right;width:40px;font-size:12px}.fa2-sav-progress{background:var(--bg-2);border-radius:99px;gap:2px;height:4px;margin-top:14px;display:flex;overflow:hidden}.fa2-sav-progress span{border-radius:2px;height:100%;display:block}.fa2-projection-summary{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;padding:16px 0 20px;display:flex}.fa2-projection-summary>div{text-align:center;flex:1;min-width:100px}.fa2-projection-arrow{color:var(--text-muted);font-size:20px;font-weight:300;flex:none!important}.fa2-projection-label{color:var(--text-muted);margin-bottom:4px;font-size:11px}.fa2-projection-num{color:var(--text-primary);letter-spacing:-.01em;font-variant-numeric:tabular-nums;font-family:JetBrains Mono,monospace;font-size:22px;font-weight:700}.fa2-projection-pos{color:var(--accent,#059669)}.fa2-projection-unit{color:var(--text-muted);margin-top:2px;font-size:11px}.fa2-projection-bars{align-items:flex-end;gap:6px;height:140px;margin-bottom:16px;padding:0 4px;display:flex}.fa2-projection-bar-wrap{cursor:help;flex-direction:column;flex:1;justify-content:flex-end;align-items:center;height:100%;display:flex}.fa2-projection-bar{background:0 0;border-radius:6px 6px 0 0;flex-direction:column-reverse;width:100%;max-width:40px;transition:opacity .15s;display:flex;overflow:hidden}.fa2-projection-bar-wrap:hover .fa2-projection-bar{opacity:.85}.fa2-projection-seg{width:100%;transition:height .25s}.fa2-projection-bar-val{color:var(--text-primary);margin-bottom:4px;font-family:JetBrains Mono,monospace;font-size:9.5px;font-weight:700}.fa2-projection-bar-label{color:var(--text-muted);margin-top:6px;font-size:10px}.fa2-projection-breakdown{border-top:1px solid var(--border);padding-top:12px}.fa2-projection-breakdown-title{color:var(--text-secondary);justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;font-size:12px;font-weight:600;display:flex}.fa2-projection-toggle-all{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:6px;padding:3px 10px;font-family:inherit;font-size:11px;font-weight:500;transition:background .12s,border-color .12s,color .12s}.fa2-projection-toggle-all:hover{color:var(--text-primary);background:#0f172a0a;border-color:#0f172a29}.fa2-projection-breakdown-row{border-bottom:1px solid var(--border);cursor:pointer;grid-template-columns:auto auto 1fr auto auto auto;align-items:center;gap:10px;padding:6px 0;font-size:12.5px;transition:opacity .14s;display:grid}.fa2-projection-breakdown-check{cursor:pointer;width:14px;height:14px;accent-color:var(--accent);margin:0}.fa2-projection-breakdown-row--off{opacity:.5}.fa2-projection-breakdown-row--off .fa2-projection-breakdown-name,.fa2-projection-breakdown-row--off .fa2-projection-breakdown-monthly,.fa2-projection-breakdown-row--off .fa2-projection-breakdown-rate,.fa2-projection-breakdown-row--off .fa2-projection-breakdown-total{-webkit-text-decoration:line-through #0f172a4d;text-decoration:line-through #0f172a4d}.fa2-projection-breakdown-row:last-of-type{border-bottom:none}.fa2-projection-breakdown-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;display:inline-block}.fa2-projection-breakdown-name{color:var(--text-primary);font-weight:500}.fa2-projection-breakdown-monthly,.fa2-projection-breakdown-rate{color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:11px}.fa2-projection-breakdown-total{color:var(--accent,#059669);font-family:JetBrains Mono,monospace;font-size:12px;font-weight:600}.proj-mini-card{color:inherit;cursor:pointer;text-decoration:none;transition:transform .12s,box-shadow .12s,border-color .12s;display:block}.proj-mini-card:hover{border-color:var(--accent,#059669);transform:translateY(-1px);box-shadow:0 4px 12px #05966914}.proj-mini-cta{color:var(--accent,#059669);font-size:12px;font-weight:600}.proj-detail-section{margin-bottom:20px}.proj-detail-section:last-child{margin-bottom:0}.proj-detail-heading{color:var(--text-primary);justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;font-size:13px;font-weight:600;display:flex}.proj-detail-table tbody tr.proj-detail-row-off td{opacity:.5}.proj-detail-table tbody tr.proj-detail-row-off td:nth-child(n+3){-webkit-text-decoration:line-through #0f172a4d;text-decoration:line-through #0f172a4d}.proj-detail-table tbody tr.proj-detail-row-off:hover{background:0 0}.proj-detail-table-wrap{border:1px solid var(--border);border-radius:8px;overflow-x:auto}.proj-detail-table{border-collapse:collapse;width:100%;font-size:12.5px}.proj-detail-table th,.proj-detail-table td{text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;padding:8px 10px}.proj-detail-table tbody tr:last-child td{border-bottom:none}.proj-detail-table thead th{color:var(--text-secondary);text-transform:none;background:#f8fafc;font-size:11.5px;font-weight:600}.proj-detail-table tbody tr:hover{background:#0596690a}.proj-detail-table .num{text-align:right;font-family:JetBrains Mono,monospace;font-size:12px}.proj-detail-table .strong{color:var(--accent,#059669);font-weight:700}.proj-detail-table .muted{color:var(--text-muted);white-space:normal}.proj-detail-dot{vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:6px;display:inline-block}.proj-detail-note{color:var(--text-muted);margin-top:8px;font-size:11px}.stl-list{flex-direction:column;gap:12px;display:flex}.stl-card{border:1px solid var(--border);background:var(--surface);border-radius:12px;padding:14px 16px 12px}.stl-pills{flex-wrap:wrap;gap:6px;margin-bottom:14px;display:flex}.stl-pill{border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;border-radius:999px;align-items:center;gap:5px;padding:5px 12px;font-size:13px;font-weight:500;transition:all .13s;display:inline-flex}.stl-pill:hover{color:#1d4ed8;background:#eff6ff;border-color:#93c5fd}.stl-pill--active{color:#fff;background:#3b82f6;border-color:#3b82f6}.stl-pill-pct{opacity:.8;font-size:11px}.stl-pill--active .stl-pill-pct{opacity:.85}.stl-header{justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;display:flex}.stl-name{color:var(--text-primary);font-size:14px;font-weight:700}.stl-chips{flex-wrap:wrap;gap:5px;display:flex}.stl-chip{background:var(--bg-2);border:1px solid var(--border);color:var(--text-muted);border-radius:999px;padding:2px 8px;font-size:11px;font-weight:500}.stl-chip--accent{color:#3b82f6;background:#eff6ff;border-color:#bfdbfe;font-weight:600}.stl-stats{border-top:1px solid var(--border);gap:0;margin-top:2px;padding:10px 0 8px;display:flex}.stl-stat{flex-direction:column;flex:1;gap:3px;display:flex}.stl-stat--center{border-left:1px solid var(--border);margin-left:14px;padding-left:14px}.stl-stat--right{border-left:1px solid var(--border);text-align:left;margin-left:14px;padding-left:14px}.stl-stat-label{color:var(--text-muted);font-size:10.5px}.stl-stat-val{color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:13.5px;font-weight:700}.stl-stat-val--blue{color:#3b82f6}.stl-progress{align-items:center;gap:10px;margin-top:8px;display:flex}.stl-track{background:var(--border);border-radius:999px;flex:1;height:4px;overflow:hidden}.stl-fill{background:#3b82f6;border-radius:999px;height:100%;transition:width .5s}.stl-progress-label{color:var(--text-muted);white-space:nowrap;flex-shrink:0;font-size:11px}.app-info-card{flex-wrap:wrap;align-items:center;gap:20px;display:flex}.app-info-left{flex:1;min-width:0}.app-info-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:12.5px;font-weight:600}.app-info-title{letter-spacing:-.01em;flex-wrap:wrap;align-items:center;gap:6px;margin-top:4px;font-size:18px;font-weight:700;display:flex}.app-info-build{color:var(--text-muted);font-size:12.5px;font-family:var(--font-mono);white-space:nowrap;margin-top:6px}.app-info-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}@media (width<=480px){.app-info-card{flex-direction:column;align-items:flex-start;gap:14px}.app-info-actions{width:100%}.app-info-actions .fa2-btn{flex:1;justify-content:center}}.settings-section-divider{background:var(--border);height:1px;margin:0 -24px}.settings-section{padding:16px 0 0}.settings-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;font-size:11.5px;font-weight:600}.settings-account-list{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.settings-account-item{cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;padding:10px;transition:background .12s;display:flex}.settings-account-name{color:var(--text-primary);font-size:13.5px;font-weight:500}.settings-account-meta{color:var(--text-muted);font-size:12px}.settings-account-right{flex-direction:column;align-items:flex-end;gap:2px;display:flex}.settings-account-opening{color:var(--text-muted);font-size:11px}.settings-account-balance{font-family:var(--font-mono);color:var(--text-primary);font-size:13px;font-weight:500}.settings-page{flex-direction:column;gap:16px;max-width:600px;margin:0 auto;padding:24px 24px 40px;display:flex}.settings-user-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;align-items:center;gap:14px;padding:20px;display:flex}.settings-user-avatar{background:var(--accent-light);border:1.5px solid var(--accent-border);width:48px;height:48px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;font-weight:700;display:flex}.settings-user-name{color:var(--text-primary);margin:0 0 2px;font-size:15px;font-weight:600}.settings-user-email{color:var(--text-muted);margin:0;font-size:12.5px}.settings-section-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;overflow:hidden}.settings-group-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin:0;padding:14px 18px 8px;font-size:11.5px;font-weight:600}.settings-menu-item{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:14px 18px;transition:background .12s;display:flex}.settings-menu-item:hover{background:var(--bg)}.settings-menu-left{align-items:center;gap:12px;display:flex}.settings-menu-icon{text-align:center;width:28px;font-size:18px}.settings-menu-title{color:var(--text-primary);font-size:14px;font-weight:500;display:block}.settings-menu-sub{color:var(--text-muted);margin-top:1px;font-size:12px;display:block}.settings-chevron{color:var(--text-muted);transition:transform .2s}.settings-chevron-open{transform:rotate(180deg)}.settings-divider{background:var(--border);height:1px;margin:0 18px}.settings-inline-form{border-top:1px solid var(--border);background:#fff;padding:16px 18px}.settings-account-list{margin:0;padding:0;list-style:none}.settings-account-item{cursor:pointer;background:#fff;align-items:center;gap:12px;padding:12px 18px;transition:background .12s;display:flex}.settings-account-item:hover{background:#f8fafc}.settings-account-item+.settings-account-item{border-top:1px solid var(--border)}.settings-account-icon{background:var(--accent-light);width:34px;height:34px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.settings-logout-btn{color:#ef4444;text-align:left;cursor:pointer;background:0 0;border:none;width:100%;padding:14px 18px;font-size:14px;font-weight:500;transition:background .12s}.settings-logout-btn:hover{background:#fef2f2}.settings-accounts-header{justify-content:space-between;align-items:center;padding:14px 18px 10px;display:flex}.settings-archived-hint{color:var(--text-muted);font-size:11.5px}.settings-acct-groups{flex-direction:column;display:flex}.settings-acct-group-header{cursor:pointer;justify-content:space-between;align-items:center;padding:12px 18px;transition:background .12s;display:flex}.settings-acct-group-header:hover{background:var(--bg)}.settings-acct-group-left{align-items:center;gap:8px;display:flex}.settings-acct-group-count{color:var(--text-muted);font-size:12px}.settings-acct-group-right{color:var(--text-secondary);align-items:center;gap:10px;display:flex}.settings-acct-group-total{font-size:13px;font-weight:600;font-family:var(--font-mono);color:var(--text-primary)}.settings-acct-group-body{border-top:1px solid var(--border);background:#fff}.settings-version-card{flex-direction:column;gap:6px;padding:14px 18px 16px;display:flex}.settings-version-row{justify-content:space-between;align-items:center;display:flex}.settings-version-left{align-items:center;gap:8px;display:flex}.settings-app-name{color:var(--text-primary);font-size:14px;font-weight:600}.settings-version-badge{color:var(--accent);background:var(--accent-light);font-size:11.5px;font-weight:600;font-family:var(--font-mono);border-radius:6px;padding:2px 8px}.settings-changelog-btn{color:var(--accent);border:1px solid var(--accent);cursor:pointer;background:0 0;border-radius:6px;padding:3px 10px;font-size:12px;transition:background .12s}.settings-changelog-btn:hover{background:var(--accent-light)}.settings-version-meta{color:var(--text-muted);align-items:center;gap:6px;font-size:11.5px;display:flex}.settings-version-dot{color:var(--border)}.settings-env-badge{color:#059669;background:#ecfdf5;border-radius:4px;padding:1px 6px;font-size:11px;font-weight:600}.settings-changelog{border-top:1px solid var(--border);flex-direction:column;gap:10px;margin-top:10px;padding-top:10px;display:flex}.settings-changelog-item{background:var(--bg);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:3px;padding:8px 10px;display:flex}.settings-changelog-item--latest{background:#f0fdf4;border-color:#a7f3d0}.settings-changelog-header{justify-content:space-between;align-items:center;display:flex}.settings-changelog-version{color:var(--accent);font-size:12.5px;font-weight:700;font-family:var(--font-mono)}.settings-changelog-date{color:var(--text-muted);font-size:11px}.settings-changelog-note{color:var(--text-secondary);margin:0;font-size:12px;line-height:1.5}.fa2-profile-card{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.fa2-profile-card .info{flex:1;min-width:0}.fa2-profile-card .avatar{background:var(--accent-light);width:56px;height:56px;color:var(--accent-ink);border:2px solid var(--accent-border);border-radius:50%;flex-shrink:0;place-items:center;font-size:22px;font-weight:700;display:grid;overflow:hidden}.fa2-profile-card .info .nm{flex-wrap:wrap;align-items:center;gap:8px;font-size:18px;font-weight:600;display:flex}.fa2-profile-card .info .em{color:var(--text-muted);margin-top:2px;font-size:13px}.role-badge{letter-spacing:.02em;border:1px solid #0000;border-radius:999px;align-items:center;height:20px;padding:0 9px;font-size:11px;font-weight:700;line-height:1;display:inline-flex}.role-badge.role-general{color:#5b6370;background:#eef1f5;border-color:#dde1e8}.role-badge.role-pro{color:#065f46;background:linear-gradient(135deg,#d1fae5 0%,#a7f3d0 100%);border-color:#6ee7b7}.role-badge.role-admin{color:#991b1b;background:linear-gradient(135deg,#fee2e2 0%,#fecaca 100%);border-color:#f87171}.fa2-setting-row{border-bottom:1px solid var(--border);cursor:pointer;align-items:center;gap:14px;padding:18px 0;display:flex}.fa2-toggle{background:#d4d0ca;border-radius:99px;flex-shrink:0;width:44px;height:24px;transition:background .2s;position:relative}.fa2-toggle.on{background:var(--accent,#059669)}.fa2-toggle-knob{background:#fff;border-radius:99px;width:20px;height:20px;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #1c191726}.fa2-toggle.on .fa2-toggle-knob{transform:translate(20px)}.fa2-setting-row:last-child{border-bottom:none}.fa2-setting-row:hover .nm{color:var(--accent)}.fa2-setting-row .ic{background:var(--bg-2);width:40px;height:40px;color:var(--text-secondary);border-radius:12px;flex-shrink:0;place-items:center;display:grid}.fa2-setting-row .main{flex:1;min-width:0}.fa2-setting-row .nm{font-size:15px;font-weight:600;transition:color .15s}.fa2-setting-row .sub{color:var(--text-muted);margin-top:2px;font-size:12.5px}.fa2-setting-row .chev{color:var(--text-muted);flex-shrink:0;transition:transform .2s}.fa2-setting-row .chev.open{transform:rotate(180deg)}.fa2-setting-row .amt-right{font-variant-numeric:tabular-nums;margin-right:14px;font-size:15px;font-weight:700}.fa2-version-chip{background:var(--accent-light);color:var(--accent-ink);font-size:11px;font-weight:600;font-family:var(--font-mono);border-radius:6px;margin-left:8px;padding:2px 8px;display:inline-flex}.fa2-prod-chip{color:#9a3412;background:#fff7ed;border-radius:6px;margin-left:8px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.fa2-acc-sub-list{padding:4px 0 8px 54px}@media (width<=600px){.fa2-acc-sub-list{padding-left:16px}}.fa2-acc-sub-item{border-bottom:1px dashed var(--border);align-items:center;gap:10px;padding:8px 0;font-size:13px;display:flex}.fa2-acc-sub-item:last-child{border-bottom:none}.fa2-acc-sub-item .nm{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.fa2-acc-sub-item .bank{color:var(--text-muted);font-size:11.5px}.fa2-acc-sub-item .amt{font-variant-numeric:tabular-nums;text-align:right;min-width:100px;font-weight:600}.fa2-page{padding:0}.budget-body{gap:16px!important}.budget-tip{color:var(--text-muted);cursor:default;vertical-align:middle;align-items:center;margin-left:2px;font-size:10px;display:inline-flex;position:relative}.budget-tip:after{content:attr(data-tip);color:#fff;white-space:pre-line;text-align:left;pointer-events:none;opacity:0;z-index:200;background:#1e293b;border-radius:6px;min-width:160px;max-width:220px;padding:6px 10px;font-size:11px;font-weight:400;transition:opacity .15s;position:absolute;bottom:calc(100% + 6px);left:0;transform:none;box-shadow:0 4px 12px #0003}.budget-tip:hover:after{opacity:1}.budget-tip.tip-right:after{left:auto;right:0}.budget-loading{color:var(--text-muted);justify-content:center;padding:60px 0;display:flex}.budget-hero-card{background:linear-gradient(135deg,#ecfdf5 0%,#f0fdf4 60%,#fff 100%);border:1.5px solid #a7f3d0;height:100%}.budget-hero-label{color:var(--accent-ink);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;font-size:12px;font-weight:600}.budget-hero-amount{color:var(--accent);letter-spacing:-.03em;margin-bottom:10px;font-size:36px;font-weight:800;line-height:1}.budget-hero-unit{margin-left:2px;font-size:18px;font-weight:700}.budget-hero-formula{flex-wrap:wrap;align-items:center;gap:8px;font-size:13px;display:flex}.budget-hero-income{color:var(--text-secondary)}.budget-hero-sep{color:var(--text-muted);font-weight:700}.budget-hero-saving{color:#6366f1}.budget-hero-period{color:var(--text-muted);font-size:12px;font-family:var(--font-mono);border-top:1px solid #d1fae5;margin-top:12px;padding-top:12px}.budget-hero-card{flex-direction:column;display:flex}.budget-hero-visual{flex:1;align-items:center;gap:20px;min-height:0;margin-top:16px;display:flex}.budget-hero-ring-wrap{flex-shrink:0;width:108px;height:108px;position:relative}.budget-hero-ring{filter:drop-shadow(0 2px 8px #10b98126);width:100%;height:100%}.budget-hero-ring-center{flex-direction:column;justify-content:center;align-items:center;gap:2px;display:flex;position:absolute;inset:0}.budget-hero-ring-pct{letter-spacing:-.02em;font-size:22px;font-weight:800;line-height:1}.budget-hero-ring-sub{color:var(--text-muted);font-size:10.5px;font-weight:500}.budget-hero-stat-list{flex-direction:column;flex:1;gap:10px;display:flex}.budget-hero-stat-item{background:#fff9;border:1px solid #d1fae5;border-radius:10px;flex-direction:column;gap:2px;padding:8px 12px;display:flex}.budget-hero-stat-label{color:var(--text-muted);letter-spacing:.02em;font-size:10.5px;font-weight:500}.budget-hero-stat-val{color:var(--text-primary);font-size:14px;font-weight:700;font-family:var(--font-mono);letter-spacing:-.01em}.budget-stats-card{flex-direction:column;gap:16px;height:100%;display:flex}.budget-stat-row{gap:0;display:flex}.budget-stat-item{flex-direction:column;flex:1;gap:4px;display:flex}.budget-stat-divider{background:var(--border);width:1px;margin:0 16px}.budget-stat-label{color:var(--text-muted);font-size:12px;font-weight:500}.budget-stat-value{letter-spacing:-.01em;font-size:18px;font-weight:700}.budget-stat-bar-wrap{flex-direction:column;gap:6px;display:flex}.budget-stat-bar-header{color:var(--text-secondary);justify-content:space-between;font-size:12.5px;display:flex}.budget-stat-track{background:var(--bg-2);border-radius:99px;height:8px;overflow:hidden}.budget-stat-fill{border-radius:99px;height:100%;transition:width .4s}.budget-stat-bar-sub{color:var(--text-muted);justify-content:space-between;font-size:11.5px;display:flex}.budget-stat-budget-vs-spent{background:#6366f10f;border-radius:8px;justify-content:space-between;align-items:center;margin-top:4px;padding:8px 12px;display:flex}.budget-stat-bvs-label{color:var(--text-secondary);font-size:12px;font-weight:500}.budget-stat-bvs-val{font-size:13px;font-weight:700}.budget-stat-actions{gap:8px;margin-top:auto;padding-top:4px;display:flex}.budget-stat-actions .fa2-btn{flex:1;justify-content:center}.bcat-donut-section{border-bottom:1.5px solid #e2e5e9;align-items:center;gap:28px;margin-bottom:14px;padding:4px 0 24px;display:flex}.bcat-donut-svg-wrap{flex-shrink:0;width:140px;height:140px;position:relative}.bcat-donut-svg{filter:drop-shadow(0 3px 10px #0000001a);width:100%;height:100%}.bcat-donut-svg path{transition:opacity .2s}.bcat-donut-hole{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;gap:2px;display:flex;position:absolute;inset:0}.bcat-donut-hole-label{color:var(--text-muted);letter-spacing:.02em;text-align:center;font-size:9.5px;font-weight:600}.bcat-donut-hole-val{color:var(--text-primary);font-size:12px;font-weight:800;font-family:var(--font-mono);letter-spacing:-.02em;text-align:center}.bcat-donut-hole-amt{color:var(--text-secondary);font-size:10px;font-weight:600;font-family:var(--font-mono);text-align:center}.bcat-donut-legend{flex:1;grid-template-columns:1fr 1fr;gap:7px 20px;min-width:0;display:grid}.bcat-donut-legend-item{cursor:pointer;border:1px solid #0000;border-radius:6px;align-items:center;gap:7px;min-width:0;padding:4px 6px;transition:background .15s,border-color .15s;display:flex}.bcat-donut-legend-item:hover{background:#f5f5f5}.bcat-donut-legend-item.selected{background:#f0fdf4;border-color:#a7f3d0}.bcat-donut-legend-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.bcat-donut-legend-name{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:12.5px;overflow:hidden}.bcat-donut-legend-pct{color:var(--text-primary);font-size:12px;font-weight:700;font-family:var(--font-mono);flex-shrink:0}.bcat-donut-legend-amt{color:var(--text-muted);font-size:11px;font-family:var(--font-mono);flex-shrink:0}@media (width<=768px){.budget-hero-visual{flex-direction:column;align-items:stretch;gap:12px}.budget-hero-ring-wrap{margin:0 auto}.budget-stats-card .budget-stat-row{display:none}}@media (width<=480px){.bcat-donut-section{flex-direction:row;align-items:center;gap:14px;padding-bottom:20px}.bcat-donut-svg-wrap{width:110px;height:110px}.bcat-donut-hole-label{font-size:9px}.bcat-donut-hole-val{font-size:11px}.bcat-donut-hole-amt{font-size:9.5px}.bcat-donut-legend{grid-template-columns:1fr;gap:4px}.bcat-donut-legend-amt{display:none}.bcat-donut-legend-name{font-size:12px}.bcat-donut-legend-pct{font-size:11.5px}}.bcat-header{color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;background:linear-gradient(90deg,#f8f9fa,#f3f4f6);border:1px solid #e5e7eb;border-radius:10px;grid-template-columns:1fr 200px 160px;gap:12px;margin-bottom:10px;padding:10px 16px;font-size:11px;font-weight:700;display:grid}.bcat-body{flex-direction:column;gap:8px;display:flex}.bcat-group{background:#fff;border:1.5px solid #e2e5e9;border-radius:12px;transition:box-shadow .15s;overflow:hidden}.bcat-group:hover{border-color:#d0d4d9;box-shadow:0 3px 12px #00000017}.bcat-row{grid-template-columns:1fr 200px 160px;align-items:center;gap:12px;padding:15px 18px;display:grid}.bcat-row.parent{background:#f7f8f9;border-bottom:1.5px solid #e2e5e9}.bcat-row.child{background:#fff;border-top:1px solid #eaecef;padding:11px 18px 11px 36px;transition:background .12s}.bcat-row.child:hover{background:#f4fdf9}.bcat-col-name{align-items:center;gap:8px;min-width:0;display:flex}.bcat-col-bar{align-items:center;display:flex}.bcat-col-input{justify-content:flex-end;display:flex}.bcat-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px;box-shadow:0 0 0 2px #fffc,0 0 0 3px}.bcat-parent-name{color:var(--text-primary);letter-spacing:-.01em;font-size:13.5px;font-weight:700}.bcat-child-indent{color:#ccc;flex-shrink:0;margin-right:-2px;font-size:11px}.bcat-child-name{color:var(--text-secondary);font-size:13px;font-weight:400}.bcat-child-name.clickable{cursor:pointer;align-items:center;gap:4px;display:inline-flex}.bcat-child-name.clickable:hover{color:var(--accent)}.bcat-child-arrow{color:var(--text-muted);font-size:9px}.bcat-row.child.open{background:#10b9810a}.bcat-child-wrap{display:contents}.bcat-tx-panel{border-left:2px solid var(--border);flex-direction:column;gap:4px;margin:0 0 4px 24px;padding:6px 0 6px 12px;display:flex}.bcat-tx-item{background:var(--bg-secondary,#f8fafc);border-radius:6px;align-items:center;gap:10px;padding:4px 8px;font-size:12px;display:flex}.bcat-tx-item.clickable{cursor:pointer;transition:background .15s}.bcat-tx-item.clickable:hover{background:#f0fdf4}.bcat-tx-date{color:var(--text-muted);font-family:var(--font-mono);white-space:nowrap;min-width:80px}.bcat-tx-title{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.bcat-tx-amt{color:#ef4444;white-space:nowrap;font-weight:600}.bcat-tx-empty{color:var(--text-muted);padding:4px 0;font-size:12px}.bcat-over-chip{color:#ef4444;white-space:nowrap;background:#fee2e2;border-radius:4px;flex-shrink:0;padding:1px 6px;font-size:11px;font-weight:700}.bcat-spent-chip{color:#6b7280;white-space:nowrap;letter-spacing:0;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:20px;padding:1px 8px;font-size:11px;font-weight:600}.bcat-spent-chip.muted{color:var(--text-muted);background:0 0;border-color:#0000;font-weight:400}.bcat-bar-wrap{align-items:center;gap:10px;width:100%;display:flex}.bcat-track{background:#f0f0f0;border-radius:99px;flex:1;height:7px;overflow:hidden}.bcat-fill{border-radius:99px;height:100%;transition:width .4s}.bcat-pct{white-space:nowrap;text-align:right;width:34px;font-size:12px;font-weight:700;font-family:var(--font-mono)}.bcat-no-plan{color:#d1d5db;font-size:11.5px}.bcat-input-wrap{background:#fafafa;border:1.5px solid #e5e7eb;border-radius:9px;align-items:center;gap:4px;padding:5px 10px;transition:border-color .15s,background .15s,box-shadow .15s;display:flex}.bcat-input-wrap:focus-within{border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px #10b9811a}.bcat-input{color:var(--text-primary);text-align:right;width:90px;font-size:14px;font-weight:700;font-family:var(--font-mono);letter-spacing:-.01em;background:0 0;border:none;outline:none}.bcat-input.sm{width:80px;font-size:13px}.bcat-input::placeholder{color:#d1d5db;font-weight:400}.bcat-unit{color:var(--text-muted);flex-shrink:0;font-size:12px}@media (width<=480px){.bcat-header,.bcat-row{grid-template-columns:1fr 130px;gap:8px}.bcat-col-bar{display:none}.bcat-col-name{flex-wrap:wrap;align-items:center;gap:6px}.bcat-spent-chip{flex-basis:100%;margin-left:17px;padding:1px 6px;font-size:10.5px}.bcat-input{width:80px;font-size:13px}.bcat-input.sm{width:72px}}.budget-total-card{background:linear-gradient(135deg,#ecfdf5,#f0fdf4);border:1.5px solid #a7f3d0;border-radius:14px;flex-direction:column;flex-shrink:0;gap:10px;padding:16px 20px;display:flex}.budget-total-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.budget-total-label{color:var(--accent);flex-shrink:0;font-size:13.5px;font-weight:600}.budget-total-meta{color:var(--text-secondary);justify-content:space-between;font-size:12px;display:flex}.budget-input-wrap{background:#fff;border:1.5px solid #a7f3d0;border-radius:8px;align-items:center;gap:4px;padding:0 10px;display:flex}.budget-input-wrap.small{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:0 8px}.budget-amount-input{color:var(--text-primary);text-align:right;background:0 0;border:none;outline:none;width:120px;padding:7px 0;font-family:JetBrains Mono,monospace;font-size:15px;font-weight:700}.budget-amount-input.small{width:100px;padding:5px 0;font-size:12.5px;font-weight:600}.budget-unit{color:var(--text-muted);white-space:nowrap;font-size:12px}.budget-bar-track{background:#e2e8f0;border-radius:999px;flex:1;min-width:0;height:5px;overflow:hidden}.budget-bar-track.total{background:#d1fae5;flex:none;height:8px}.budget-bar-fill{border-radius:999px;height:100%;transition:width .4s,background .3s}.budget-bar-row{align-items:center;gap:6px;width:100%;display:flex}.budget-pct{text-align:right;flex-shrink:0;min-width:28px;font-size:11px;font-weight:700}.budget-section-title{color:var(--text-muted);letter-spacing:.05em;flex-shrink:0;margin:0;font-size:11.5px;font-weight:700}.budget-cat-list{border:1px solid var(--border);background:#fff;border-radius:12px;flex-direction:column;gap:6px;padding:16px;display:flex}.budget-parent-group{flex-direction:column;gap:1px;display:flex}.budget-parent-row{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;justify-content:space-between;align-items:flex-start;gap:12px;padding:10px 12px;display:flex}.budget-child-row{border:1px solid #0000;border-radius:8px;justify-content:space-between;align-items:flex-start;gap:12px;padding:7px 12px 7px 28px;transition:background .12s;display:flex}.budget-child-row:hover{background:#f8fafc;border-color:#e2e8f0}.budget-cat-left{flex-direction:column;flex-shrink:0;gap:2px;min-width:64px;display:flex}.budget-parent-name{color:var(--text-primary);font-size:13.5px;font-weight:600}.budget-child-name{color:var(--text-secondary);font-size:12.5px;font-weight:400}.budget-cat-spent{color:var(--text-muted);font-size:11px}.budget-cat-right{flex-direction:column;flex:1;align-items:flex-end;gap:6px;min-width:0;display:flex}.budget-total-auto{color:var(--accent);font-size:20px;font-weight:700;font-family:var(--font-mono)}.budget-total-formula{color:var(--text-muted);align-items:center;gap:6px;margin-top:4px;font-size:12px;display:flex}.budget-formula-sep{color:var(--text-secondary);font-size:14px}.budget-alloc-bar{border-top:1px dashed var(--border);margin-top:12px;padding-top:10px}.budget-alloc-track{background:var(--border);border-radius:999px;height:6px;margin-bottom:6px;overflow:hidden}.budget-alloc-fill{border-radius:999px;height:100%;transition:width .3s}.budget-alloc-meta{color:var(--text-secondary);justify-content:space-between;font-size:12px;display:flex}.budget-btn-row{gap:8px;display:flex}.budget-reset-btn{border:1.5px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:10px;flex:none;padding:12px 16px;font-size:13.5px;font-weight:600;transition:background .12s,color .12s,border-color .12s}.budget-reset-btn:hover:not(:disabled){color:#ef4444;background:#fef2f2;border-color:#fca5a5}.budget-reset-btn:disabled{opacity:.5;cursor:not-allowed}.budget-save-btn{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;flex:1 0;padding:12px;font-size:14px;font-weight:600;transition:background .15s}.budget-save-btn:hover:not(:disabled){background:#047857}.budget-save-btn:disabled{opacity:.6;cursor:not-allowed}.budget-month-nav{justify-content:center;align-items:center;gap:12px;display:flex;padding:10px 16px!important}.budget-month-label{justify-content:center;align-items:center;gap:10px;min-width:140px;display:flex}.budget-month-text{font-variant-numeric:tabular-nums;color:var(--text-primary);font-size:18px;font-weight:700}.budget-month-today{border:1px solid var(--border,#e5e7eb);color:var(--text-secondary,#6b7280);cursor:pointer;background:0 0;border-radius:999px;padding:2px 10px;font-size:11px}.budget-month-today:hover{background:#f3f4f6}.budget-month-copy{margin-left:8px;font-size:12px}.budget-month-nav-inline{align-items:center;gap:6px;margin-top:2px;display:inline-flex}.budget-month-arrow{cursor:pointer;color:var(--text-secondary,#6b7280);background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:16px;line-height:1}.budget-month-arrow:hover:not(:disabled){color:var(--text-primary);background:#f3f4f6}.budget-month-arrow:disabled{opacity:.4;cursor:not-allowed}.budget-month-text-inline{font-variant-numeric:tabular-nums;color:var(--text-primary);text-align:center;min-width:60px;font-size:13px;font-weight:600}.budget-month-today-inline{border:1px solid var(--border,#e5e7eb);color:var(--text-secondary,#6b7280);cursor:pointer;background:0 0;border-radius:999px;margin-left:4px;padding:1px 8px;font-size:10px}.budget-month-today-inline:hover{background:#f3f4f6}.fa2-admin{flex-direction:column;gap:20px;display:flex}.fa2-admin-today{border:1px solid var(--accent-border,#a7f3d0);background:linear-gradient(135deg,#ecfdf5 0%,#f7f5f0 100%);border-radius:14px;flex-wrap:wrap;align-items:center;gap:14px;padding:14px 18px;display:flex}.fa2-admin-today-label{color:var(--accent-ink,#064e3b);white-space:nowrap;font-size:13px;font-weight:700}.fa2-admin-today-stats{flex-wrap:wrap;align-items:baseline;gap:10px;display:flex}.fa2-admin-today-stat{align-items:baseline;gap:6px;display:inline-flex}.fa2-admin-today-num{color:var(--text-primary,#1c1917);letter-spacing:-.01em;font-family:JetBrains Mono,monospace;font-size:22px;font-weight:700}.fa2-admin-today-unit{color:var(--text-secondary,#57534e);font-size:12px;font-weight:500}.fa2-admin-today-divider{color:var(--text-muted,#a8a29e);font-size:18px}.fa2-today-change{border-radius:99px;margin-left:2px;padding:2px 7px;font-size:12px;font-weight:700}.fa2-today-change-up{color:#047857;background:#ecfdf5}.fa2-today-change-down{color:#b91c1c;background:#fef2f2}.fa2-today-change-neutral{color:#64748b;background:#f1f5f9}.fa2-ai-usage-summary{border-bottom:1px solid #f1ede4;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:12px;padding:12px 0;display:grid}.fa2-ai-usage-summary>div{text-align:center}.fa2-ai-usage-label{color:var(--text-muted,#a8a29e);margin-bottom:4px;font-size:11px}.fa2-ai-usage-value{color:var(--text-primary,#1c1917);font-variant-numeric:tabular-nums;font-family:JetBrains Mono,monospace;font-size:16px;font-weight:700}.fa2-ai-usage-cost{color:var(--accent,#059669)}@media (width<=640px){.fa2-ai-usage-summary{grid-template-columns:repeat(2,1fr)}}.fa2-ai-usage-status{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.fa2-ai-status-chip{border-radius:99px;padding:3px 10px;font-size:12px;font-weight:600}.fa2-ai-status-success{color:#047857;background:#ecfdf5}.fa2-ai-status-rejected{color:#b45309;background:#fef3c7}.fa2-ai-status-error{color:#b91c1c;background:#fef2f2}.fa2-ai-usage-bars{align-items:flex-end;gap:4px;height:100px;padding-top:8px;display:flex}.fa2-ai-usage-bar-wrap{cursor:help;flex-direction:column;flex:1;align-items:center;height:100%;display:flex}.fa2-ai-usage-bar{background:linear-gradient(180deg, var(--accent,#059669) 0%, #34d399 100%);border-radius:4px 4px 0 0;width:100%;max-width:24px;transition:opacity .15s}.fa2-ai-usage-bar-wrap:hover .fa2-ai-usage-bar{opacity:.7}.fa2-ai-usage-bar-date{color:var(--text-muted,#a8a29e);white-space:nowrap;margin-top:4px;font-size:9px}.fa2-activity-label{vertical-align:middle;border-radius:99px;margin-left:6px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.fa2-activity-heavy{color:#047857;background:#ecfdf5}.fa2-activity-normal{color:#1d4ed8;background:#eff6ff}.fa2-activity-light{color:#b45309;background:#fef3c7}.fa2-activity-ghost{color:#64748b;background:#f1f5f9}.fa2-admin-cat-top{margin-top:8px}.fa2-admin-cat-top-label{color:var(--text-muted,#a8a29e);margin-bottom:6px;font-size:12px}.fa2-admin-cat-top-list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.fa2-admin-cat-top-list li{background:#faf8f3;border-radius:8px;grid-template-columns:22px 1fr auto auto;align-items:center;gap:10px;padding:6px 10px;font-size:13px;display:grid}.fa2-admin-cat-top-rank{color:var(--accent,#059669);text-align:center;font-size:12px;font-weight:700}.fa2-admin-cat-top-name{color:var(--text-primary,#1c1917);font-weight:500}.fa2-admin-cat-top-count{color:var(--text-muted,#a8a29e);font-size:11px}.fa2-admin-cat-top-amount{color:var(--text-secondary,#57534e);font-family:JetBrains Mono,monospace;font-size:12px;font-weight:600}.fa2-admin-tabs{background:var(--bg-2,#f1f5f9);border-radius:12px;align-self:flex-start;align-items:center;gap:2px;height:40px;padding:4px;display:inline-flex}.fa2-admin-tabs button{height:32px;color:var(--text-secondary,#64748b);cursor:pointer;background:0 0;border:none;border-radius:9px;padding:0 14px;font-size:13px;font-weight:500;transition:background .15s,color .15s}.fa2-admin-tabs button.on{background:var(--surface,#fff);color:var(--text-primary,#0f172a);box-shadow:var(--shadow-xs,0 1px 2px #0000000d);font-weight:600}.fa2-admin-engagement{flex-direction:column;gap:16px;display:flex}.fa2-admin-engagement-toolbar{justify-content:flex-end;display:flex}.fa2-admin-engagement-tabs{background:var(--bg-2,#f1f5f9);border-radius:10px;align-items:center;gap:2px;height:36px;padding:4px;display:inline-flex}.fa2-admin-engagement-tabs button{height:28px;color:var(--text-secondary,#64748b);cursor:pointer;background:0 0;border:none;border-radius:7px;padding:0 12px;font-size:12.5px;font-weight:500}.fa2-admin-engagement-tabs button.on{background:var(--surface,#fff);color:var(--text-primary,#0f172a);font-weight:600;box-shadow:0 1px 2px #0000000d}.fa2-admin-engagement-placeholder{border:1px dashed var(--border,#e2e8f0);background:#fff;border-radius:12px;padding:24px}.fa2-engagement-cards{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;display:grid}.fa2-engagement-card{border:1px solid var(--border,#e2e8f0);background:#fff;border-radius:12px;flex-direction:column;gap:4px;padding:14px 16px;display:flex}.fa2-engagement-card .label{color:var(--text-secondary,#64748b);font-size:12px;font-weight:500}.fa2-engagement-card .value{font-variant-numeric:tabular-nums;color:var(--text-primary,#0f172a);font-size:22px;font-weight:700}.fa2-engagement-card .sub{color:var(--text-muted,#94a3b8);font-size:11px}.fa2-chart-card{border:1px solid var(--border,#e2e8f0);background:#fff;border-radius:12px;padding:16px}.fa2-chart-title{color:var(--text-primary,#0f172a);margin-bottom:8px;font-size:13px;font-weight:600}.fa2-chart-svg{width:100%;height:auto;display:block}.fa2-funnel{flex-direction:column;gap:8px;padding-top:4px;display:flex}.fa2-funnel-row{grid-template-columns:100px 1fr auto;align-items:center;gap:12px;display:grid}.fa2-funnel-label{color:var(--text-secondary,#64748b);text-align:right;font-size:13px}.fa2-funnel-track{background:var(--bg-2,#f1f5f9);border-radius:6px;height:32px;position:relative;overflow:hidden}.fa2-funnel-fill{border-radius:6px;height:100%;transition:width .4s;position:absolute;top:0;left:0}.fa2-funnel-text{min-width:130px;color:var(--text-primary,#0f172a);font-variant-numeric:tabular-nums;white-space:nowrap;align-items:baseline;gap:8px;font-size:13px;display:flex}.fa2-funnel-text strong{font-weight:600}.fa2-funnel-pct{color:var(--text-secondary,#64748b)}.fa2-funnel-drop{color:#ef4444;font-size:11px;font-weight:500}.fa2-churn-table-wrap{overflow-x:auto}.fa2-churn-table{border-collapse:collapse;width:100%;font-size:13px}.fa2-churn-table th,.fa2-churn-table td{text-align:left;border-bottom:1px solid var(--border-light,#f1f5f9);padding:10px 14px}.fa2-churn-table thead th{color:var(--text-muted,#94a3b8);border-bottom:1px solid var(--border,#e2e8f0);font-size:12px;font-weight:500}.fa2-churn-table th.num,.fa2-churn-table td.num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.fa2-churn-table tbody tr{cursor:pointer;transition:background .12s}.fa2-churn-table tbody tr:hover{background:var(--bg-2,#f8fafc)}.fa2-churn-table tbody tr:last-child td{border-bottom:none}.fa2-visitors-table-wrap{overflow-x:auto}.fa2-visitors-table{border-collapse:collapse;width:100%;font-size:13px}.fa2-visitors-table th,.fa2-visitors-table td{text-align:left;border-bottom:1px solid var(--border-light,#f1f5f9);padding:10px 14px}.fa2-visitors-table thead th{color:var(--text-muted,#94a3b8);border-bottom:1px solid var(--border,#e2e8f0);font-size:12px;font-weight:500}.fa2-visitors-table th.num,.fa2-visitors-table td.num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.fa2-visitors-table tbody tr{cursor:pointer;transition:background .12s}.fa2-visitors-table tbody tr:hover{background:var(--bg-2,#f8fafc)}.fa2-visitors-table tbody tr:last-child td{border-bottom:none}.fa2-role-badge{text-transform:uppercase;letter-spacing:.4px;border-radius:6px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.fa2-nginx-log-wrap{border:1px solid var(--border-light,#f1f5f9);border-radius:8px;max-height:480px;overflow:auto}.fa2-nginx-log-table{border-collapse:collapse;width:100%;font-family:SF Mono,Consolas,monospace;font-size:11.5px}.fa2-nginx-log-table th,.fa2-nginx-log-table td{text-align:left;border-bottom:1px solid var(--border-light,#f1f5f9);white-space:nowrap;text-overflow:ellipsis;padding:6px 10px;overflow:hidden}.fa2-nginx-log-table thead th{background:var(--bg-2,#f8fafc);z-index:1;color:var(--text-muted,#94a3b8);font-family:inherit;font-size:11px;font-weight:500;position:sticky;top:0}.fa2-nginx-log-table th.num,.fa2-nginx-log-table td.num{text-align:right}.fa2-nginx-log-table .time-cell{color:var(--text-secondary,#64748b)}.fa2-nginx-log-table .ip-cell{color:var(--text-primary,#0f172a);font-weight:500}.fa2-nginx-log-table .path-cell{max-width:280px}.fa2-nginx-log-table .ua-cell{max-width:200px;color:var(--text-muted,#94a3b8)}.fa2-nginx-log-table tbody tr:hover{background:var(--bg-2,#f8fafc)}.fa2-method-badge{background:var(--bg-2,#f1f5f9);letter-spacing:.3px;border-radius:3px;padding:1px 6px;font-size:10px;font-weight:600;display:inline-block}.fa2-auth-events-wrap{border:1px solid var(--border-light,#f1f5f9);border-radius:8px;max-height:480px;overflow:auto}.fa2-auth-events-table{border-collapse:collapse;width:100%;font-size:12.5px}.fa2-auth-events-table th,.fa2-auth-events-table td{text-align:left;border-bottom:1px solid var(--border-light,#f1f5f9);padding:8px 12px}.fa2-auth-events-table thead th{background:var(--bg-2,#f8fafc);z-index:1;color:var(--text-muted,#94a3b8);font-size:11.5px;font-weight:500;position:sticky;top:0}.fa2-auth-events-table .time-cell{color:var(--text-secondary,#64748b);white-space:nowrap;font-family:SF Mono,Consolas,monospace;font-size:11.5px}.fa2-auth-events-table .ip-cell{font-family:SF Mono,Consolas,monospace;font-size:11.5px}.fa2-auth-events-table .ua-cell{text-overflow:ellipsis;white-space:nowrap;max-width:220px;color:var(--text-muted,#94a3b8);font-size:11.5px;overflow:hidden}.fa2-auth-events-table tbody tr:hover{background:var(--bg-2,#f8fafc)}.fa2-event-badge{white-space:nowrap;border-radius:5px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.fa2-admin-loading,.fa2-admin-error,.fa2-admin-empty{text-align:center;color:var(--text-secondary);padding:40px 20px}.fa2-admin-error{color:#b91c1c}.fa2-admin-stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.fa2-admin-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px}.fa2-admin-stat-label{color:var(--text-secondary);margin-bottom:6px;font-size:13px}.fa2-admin-stat-value{color:var(--text-primary);font-size:24px;font-weight:700}.fa2-admin-stat-roles{flex-wrap:wrap;gap:6px;display:flex}.fa2-admin-role-chip{vertical-align:middle;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.fa2-admin-role-general{color:#5b6370;background:#eef1f5}.fa2-admin-role-pro{color:#065f46;background:#d1fae5}.fa2-admin-role-admin{color:#991b1b;background:#fee2e2}.fa2-admin-toolbar{align-items:center;gap:10px;display:flex}.fa2-admin-search{border:1px solid var(--border);background:var(--surface);color:var(--text-primary);border-radius:8px;flex:1;padding:10px 12px;font-size:14px}.fa2-admin-filter{border:1px solid var(--border);background:var(--surface);color:var(--text-primary);border-radius:8px;padding:10px 12px;font-size:14px}.fa2-admin-table-wrapper{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}.fa2-admin-table{border-collapse:collapse;width:100%;font-size:14px}.fa2-admin-table thead th{text-align:left;background:var(--bg);color:var(--text-secondary);border-bottom:1px solid var(--border);padding:12px 16px;font-size:13px;font-weight:600}.fa2-admin-table tbody td{border-bottom:1px solid var(--border);color:var(--text-primary);padding:12px 16px}.fa2-admin-row{cursor:pointer;transition:background .1s}.fa2-admin-row:hover{background:var(--bg)}.fa2-admin-table tbody tr:last-child td{border-bottom:none}.fa2-admin-modal-backdrop{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.fa2-admin-modal{background:var(--surface);border-radius:14px;width:100%;max-width:520px;max-height:90vh;padding:24px;position:relative;overflow-y:auto}.fa2-admin-modal-close{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;padding:4px 8px;font-size:20px;position:absolute;top:12px;right:12px}.fa2-admin-modal-loading,.fa2-admin-modal-error{text-align:center;color:var(--text-secondary);padding:20px}.fa2-admin-modal-error{color:#b91c1c}.fa2-admin-modal-header{align-items:center;gap:14px;margin-bottom:20px;display:flex}.fa2-admin-modal-avatar,.fa2-admin-modal-avatar-placeholder{border-radius:50%;flex-shrink:0;width:56px;height:56px}.fa2-admin-modal-avatar-placeholder{background:var(--accent);color:#fff;justify-content:center;align-items:center;font-size:22px;font-weight:700;display:flex}.fa2-admin-modal-name{color:var(--text-primary);font-size:18px;font-weight:700}.fa2-admin-modal-email{color:var(--text-secondary);margin-top:2px;font-size:13px}.fa2-admin-modal-section{border-top:1px solid var(--border);padding:14px 0}.fa2-admin-modal-section h3{color:var(--text-secondary);margin:0 0 10px;font-size:14px;font-weight:600}.fa2-admin-modal-dl{grid-template-columns:120px 1fr;gap:6px 10px;margin:0;font-size:14px;display:grid}.fa2-admin-modal-dl dt{color:var(--text-secondary);margin:0}.fa2-admin-modal-dl dd{color:var(--text-primary);margin:0}.fa2-admin-modal-empty{color:var(--text-secondary);font-size:13px}.fa2-admin-modal-log{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.fa2-admin-modal-log li{flex-wrap:wrap;gap:8px;font-size:13px;display:flex}.fa2-admin-log-date{color:var(--text-secondary)}.fa2-admin-log-change{color:var(--text-primary);font-weight:600}.fa2-admin-log-admin{color:var(--text-secondary)}.fa2-admin-action-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.fa2-admin-action-label{color:var(--text-secondary);font-size:14px}.fa2-admin-action-select{border:1px solid var(--border);background:var(--surface);color:var(--text-primary);border-radius:6px;padding:8px 10px;font-size:14px}.fa2-admin-action-select:disabled{background:var(--bg);cursor:not-allowed;opacity:.6}.fa2-admin-action-save{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:8px 14px;font-size:14px;font-weight:600}.fa2-admin-action-save:disabled{cursor:not-allowed;background:#cbd5e1}.fa2-admin-action-hint{color:var(--text-secondary);flex-basis:100%;font-size:12px}.fa2-admin-action-impersonate{color:#fff;cursor:pointer;background:#0f172a;border:none;border-radius:6px;margin-left:auto;padding:8px 16px;font-size:13px;font-weight:500;transition:background .15s}.fa2-admin-action-impersonate:hover:not(:disabled){background:#1e293b}.fa2-admin-action-impersonate:disabled{opacity:.4;cursor:not-allowed}@media (width<=640px){.fa2-admin-modal-dl{grid-template-columns:1fr}.fa2-admin-modal-dl dt{font-size:12px}.fa2-admin-table thead{display:none}.fa2-admin-table tbody td{border:none;padding:6px 12px;display:block}.fa2-admin-table tbody tr{border-bottom:1px solid var(--border);padding:10px 0;display:block}.impersonation-banner{flex-direction:column;align-items:flex-start;gap:8px}}.impersonation-banner{color:#1c1917;box-sizing:border-box;background:#f59e0b;flex-shrink:0;justify-content:space-between;align-items:center;width:100%;padding:10px 20px;font-size:14px;font-weight:500;display:flex}.impersonation-banner strong{font-weight:700}.impersonation-banner button{color:#fef3c7;cursor:pointer;white-space:nowrap;background:#1c1917;border:none;border-radius:6px;padding:6px 14px;font-size:13px;font-weight:500}.impersonation-banner button:hover{background:#292524}.acct-accordion{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);margin-bottom:20px;overflow:hidden}.acct-accordion-header{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;transition:background .15s;display:flex}.acct-accordion-header:hover{background:var(--surface-hover)}.acct-accordion-header-left{flex-wrap:wrap;align-items:center;gap:12px;min-width:0;display:flex}.acct-accordion-title{color:var(--text-primary);white-space:nowrap;font-size:14px;font-weight:600}.acct-accordion-badges{flex-wrap:wrap;gap:6px;display:flex}.acct-accordion-empty-hint{color:var(--text-muted);font-size:12px}.acct-accordion-header-right{flex-shrink:0;align-items:center;gap:10px;display:flex}.acct-accordion-total{font-family:var(--font-mono);color:var(--text-primary);letter-spacing:-.3px;font-size:15px;font-weight:500}.acct-accordion-chevron{color:var(--text-muted);flex-shrink:0;transition:transform .3s cubic-bezier(.4,0,.2,1)}.acct-accordion--open .acct-accordion-chevron{transform:rotate(180deg)}.acct-accordion-body{max-height:0;transition:max-height .35s cubic-bezier(.4,0,.2,1);overflow:hidden}.acct-accordion-inner{border-top:1px solid var(--border);padding:16px 20px 20px}@media (width<=640px){.acct-accordion-header{flex-wrap:wrap;gap:8px 12px;padding:14px 16px}.acct-accordion-header-left{flex:0 0 100%;gap:8px}.acct-accordion-header-right{flex:0 0 100%;justify-content:flex-start;gap:10px}.acct-accordion-total{margin-right:auto}.acct-accordion-title{font-size:13px}}.section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:10px;font-size:11px;font-weight:600}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);margin-bottom:20px;padding:22px 24px}.card-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:14px;display:flex}.card-title{color:var(--text-primary);letter-spacing:-.2px;font-size:14.5px;font-weight:600}.btn-add{background:var(--accent-light);height:30px;color:var(--accent);border:1px solid var(--accent-border);cursor:pointer;border-radius:7px;padding:0 12px;font-size:12.5px;font-weight:600;transition:all .16s}.btn-add:hover{background:#d1fae5}.btn-delete{color:#dc2626!important;background:#fee2e2!important;border-color:#fca5a5!important}.btn-delete:hover{background:#fecaca!important}.acct-type-selector{gap:8px;display:flex}.acct-type-btn{border:1.5px solid var(--border);background:var(--surface);cursor:pointer;border-radius:10px;flex-direction:column;flex:1;align-items:center;gap:2px;padding:10px 8px;transition:border-color .15s,background .15s;display:flex}.acct-type-btn.active{border-color:var(--accent);background:#ecfdf5}.acct-type-btn.active .acct-type-label{color:var(--accent)}.acct-type-label{color:var(--text-primary);font-size:13px;font-weight:600}.acct-type-desc{color:var(--text-muted);font-size:11px}.account-name-row{align-items:center;gap:6px;display:flex}.acct-type-badge{border-radius:99px;padding:1px 6px;font-size:10px;font-weight:600;line-height:1.6}.acct-type-badge.type-checking{color:#64748b;background:#f1f5f9}.acct-type-badge.type-saving{color:#3b82f6;background:#eff6ff}.acct-type-badge.type-investment{color:#a855f7;background:#fdf4ff}.acct-groups{flex-direction:column;gap:0;display:flex}.acct-group{padding:12px 0 4px}.acct-group:first-child{padding-top:4px}.acct-group-header{justify-content:space-between;align-items:center;padding-bottom:14px;display:flex}.acct-group-label{letter-spacing:.03em;border-radius:99px;padding:3px 10px;font-size:11px;font-weight:700}.acct-group-label.type-checking{color:#64748b;background:#f1f5f9}.acct-group-label.type-saving{color:#3b82f6;background:#eff6ff}.acct-group-label.type-investment{color:#a855f7;background:#fdf4ff}.acct-group-sum{color:var(--text-primary);font-size:13px;font-weight:700;font-family:var(--font-mono)}.account-list{margin:0;padding:0;list-style:none}.account-item{justify-content:space-between;align-items:center;padding:7px 0;transition:opacity .15s;display:flex}.account-info{align-items:center;gap:11px;display:flex}.account-icon{color:#64748b;text-transform:uppercase;background:#f1f5f9;border-radius:9px;justify-content:center;align-items:center;width:34px;height:34px;font-size:12px;font-weight:700;display:flex}.account-name{color:var(--text-primary);font-size:13.5px;font-weight:500}.account-balance{font-family:var(--font-mono);color:var(--text-primary);letter-spacing:-.3px;font-size:14px;font-weight:500}.empty-state{text-align:center;color:var(--text-muted);padding:28px 0;font-size:13.5px;line-height:1.6}.account-bank{color:var(--text-muted);margin-top:1px;font-size:11.5px}.account-item-clickable{cursor:pointer;border-radius:10px;margin:0 -8px;padding-left:8px;padding-right:8px;transition:background .15s}.account-item-clickable:hover{background:#f8fafc}.account-item-clickable:hover .account-edit-hint{opacity:1}.account-meta{color:var(--text-muted);align-items:center;gap:4px;margin-top:2px;font-size:11.5px;display:flex}.account-meta-sep{color:var(--border-strong)}.account-right{flex-direction:column;align-items:flex-end;gap:3px;display:flex}.account-edit-hint{color:var(--accent);opacity:0;font-size:11px;font-weight:500;transition:opacity .15s}.account-opening-track{flex-direction:column;align-items:flex-end;gap:3px;width:100%;max-width:160px;display:flex}.account-opening-bar-wrap{background:#e2e8f0;border-radius:999px;width:100%;height:4px;overflow:hidden}.account-opening-bar-fill{background:var(--accent);border-radius:999px;height:100%;transition:width .3s}.account-opening-label{color:var(--text-muted);white-space:nowrap;font-size:11px}.form-hint{color:var(--text-muted);margin-top:5px;font-size:11.5px;line-height:1.5;display:block}.form-fieldset-projection{border:1px solid var(--accent-border,#a7f3d0);background:#ecfdf5;border-radius:12px;margin-top:4px;padding:12px 14px 10px}.form-fieldset-projection legend{color:var(--accent-ink,#064e3b);margin-left:-6px;padding:0 6px;font-size:12px;font-weight:700}.form-fieldset-projection .form-field{margin-bottom:8px}.form-fieldset-projection .form-field:last-of-type{margin-bottom:0}.archived-toggle-wrap{border-top:1px dashed var(--border);margin-top:8px;padding-top:12px}.archived-toggle-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;align-items:center;gap:5px;padding:0;font-size:12.5px;font-weight:500;transition:color .15s;display:flex}.archived-toggle-btn:before{content:"";background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none'%3E%3Cpath d='M2 4h12M4 4v9a1 1 0 001 1h6a1 1 0 001-1V4M6 4V3a1 1 0 011-1h2a1 1 0 011 1v1' stroke='%2394a3b8' stroke-width='1.4' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-size:contain;width:12px;height:12px;display:inline-block}.archived-toggle-btn:hover{color:var(--text-secondary)}.account-list-archived{margin-top:10px}.account-item-archived{opacity:.65}.account-item-archived:hover{opacity:.9}.account-icon-archived{color:#94a3b8;background:#f8fafc}.account-name-archived{color:var(--text-secondary);-webkit-text-decoration:line-through #cbd5e1;text-decoration:line-through #cbd5e1}.account-balance-archived{color:var(--text-muted)}.archived-badge{text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:4px;padding:1px 6px;font-size:10px;font-weight:600;display:inline-block}.account-edit-info-box{border:1px solid var(--border);background:#f8fafc;border-radius:10px;flex-direction:column;gap:6px;padding:12px 14px;display:flex}.account-edit-info-row{justify-content:space-between;align-items:center;display:flex}.account-edit-info-label{color:var(--text-muted);font-size:12px}.account-edit-info-value{font-family:var(--font-mono);color:var(--text-primary);font-size:13px;font-weight:500}.modal-subtitle{color:var(--text-muted);font-size:13px;font-weight:400}.acct-detail-info{border:1px solid var(--border);background:#f8fafc;border-radius:12px;flex-direction:column;gap:8px;margin-bottom:20px;padding:14px 16px;display:flex}.acct-detail-info-row{justify-content:space-between;align-items:center;display:flex}.acct-detail-label{color:var(--text-muted);font-size:12.5px}.acct-detail-value{font-family:var(--font-mono);color:var(--text-primary);font-size:13.5px;font-weight:500}.acct-detail-balance{color:var(--text-primary);font-size:16px;font-weight:700}.acct-detail-metric-pos{color:#059669}.acct-detail-metric-neg{color:#ef4444}.acct-detail-metric-zero{color:var(--text-muted)}.acct-detail-bar-wrap{background:#e2e8f0;border-radius:999px;width:100%;height:5px;margin-top:4px;overflow:hidden}.acct-detail-bar-fill{border-radius:999px;height:100%;transition:width .3s,background .2s}.acct-detail-bar-pos{background:#059669}.acct-detail-bar-neg{background:#ef4444}.acct-detail-bar-zero{background:#cbd5e1}.acct-detail-divider{background:#e2e8f0;height:1px;margin:10px 0 8px}.acct-detail-section-label{color:var(--text-muted);letter-spacing:.4px;justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px;font-size:11px;font-weight:700;display:flex}.acct-detail-warn-badge{color:#b45309;letter-spacing:0;background:#fef3c7;border:1px solid #fde68a;border-radius:999px;padding:2px 8px;font-size:10px;font-weight:600}.acct-detail-sub{color:var(--text-muted);font-size:12px;font-weight:500}.housing-check-row{color:var(--text-primary);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;padding:4px 0;font-size:13px;font-weight:500;display:flex}.housing-check-row input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--accent);flex-shrink:0;margin:0}.acct-detail-row-total{border-top:1px dashed #e2e8f0;margin-top:4px;padding-top:6px}.acct-detail-row-total .acct-detail-label{color:var(--text-primary);font-weight:600}.acct-detail-row-total .acct-detail-value{font-weight:700}.acct-detail-section-title{color:var(--text-muted);letter-spacing:.3px;border-top:1px solid var(--border);margin:16px 0 4px;padding-top:12px;font-size:11.5px;font-weight:600}.acct-detail-tx-list{max-height:280px;margin:0 -24px;padding:0 24px;overflow-y:auto}.acct-detail-tx-row{border-bottom:1px solid var(--border);cursor:pointer;border-radius:6px;justify-content:space-between;align-items:center;margin:0 -6px;padding:9px 6px;transition:background .1s;display:flex}.acct-detail-tx-row:last-child{border-bottom:none}.acct-detail-tx-row:hover{background:#f8fafc}.acct-detail-tx-left{align-items:center;gap:8px;min-width:0;display:flex}.acct-detail-tx-date{color:var(--text-muted);white-space:nowrap;flex-shrink:0;font-size:11.5px}.acct-detail-tx-title{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;max-width:120px;font-size:13px;font-weight:500;overflow:hidden}.acct-detail-tx-amount{font-family:var(--font-mono);white-space:nowrap;flex-shrink:0;font-size:13px;font-weight:600}.transfer-accounts-row{align-items:flex-end;gap:8px;display:flex}.transfer-arrow{color:var(--text-muted);flex-shrink:0;padding-bottom:10px;font-size:18px}.transfer-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;margin:0;padding:8px 12px;font-size:13px}.tx-delete-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border-radius:4px;padding:2px 8px;font-size:11px}.tx-delete-btn:hover{color:#dc2626;background:#fef2f2;border-color:#fecaca}.acct-detail-tabs{background:var(--bg-2,#f1f5f9);border-radius:10px;gap:2px;margin:14px 0 12px;padding:4px;display:flex}.acct-detail-tab{height:30px;color:var(--text-secondary,#64748b);cursor:pointer;background:0 0;border:none;border-radius:7px;flex:1;justify-content:center;align-items:center;gap:5px;font-size:12.5px;font-weight:500;transition:background .15s,color .15s;display:flex}.acct-detail-tab.on{color:var(--text-primary,#0f172a);background:#fff;font-weight:600;box-shadow:0 1px 2px #0000000f}.acct-detail-tab-count{background:var(--accent-light,#ecfdf5);color:var(--accent,#10b981);border-radius:10px;padding:0 5px;font-size:10.5px;font-weight:600;line-height:16px}.acct-detail-tab.on .acct-detail-tab-count{background:var(--accent,#10b981);color:#fff}.acct-timeline-list{flex-direction:column;padding:4px 0;display:flex}.acct-timeline-row{gap:12px;display:flex}.acct-timeline-axis{flex-direction:column;flex-shrink:0;align-items:center;width:14px;display:flex}.acct-timeline-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:14px}.acct-timeline-line{background:linear-gradient(#cbd5e1,#e2e8f0);flex:1;width:2px;min-height:8px;margin-top:4px}.acct-timeline-content{flex:1;min-width:0;padding-top:10px}.acct-timeline-header{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.acct-timeline-title{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:500;overflow:hidden}.acct-timeline-date{color:var(--text-muted);white-space:nowrap;flex-shrink:0;font-size:11px}.acct-timeline-meta{align-items:center;gap:8px;margin-top:2px;display:flex}.acct-timeline-sub{color:var(--text-muted);font-size:11.5px}.acct-detail-adj-list{flex-direction:column;margin:0 -24px;padding:0 24px;display:flex}.acct-detail-adj-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:8px;padding:10px 0;display:flex}.acct-detail-adj-row:last-child{border-bottom:none}.acct-detail-adj-left{flex-direction:column;gap:2px;min-width:0;display:flex}.acct-detail-adj-date{color:var(--text-muted);font-size:11px;font-family:var(--font-mono)}.acct-detail-adj-memo{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;max-width:200px;font-size:13px;overflow:hidden}.acct-detail-adj-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:2px;display:flex}.acct-detail-adj-diff{font-family:var(--font-mono);font-size:13px;font-weight:700}.acct-detail-adj-diff.adj-plus{color:var(--income)}.acct-detail-adj-diff.adj-minus{color:var(--expense)}.acct-detail-adj-balance{color:var(--text-muted);font-size:11px}.adj-diff-badge{font-size:12px;font-weight:600;font-family:var(--font-mono);border-radius:6px;margin-top:-4px;margin-bottom:4px;padding:6px 12px}.adj-diff-plus{color:var(--income);background:#10b9811a;border:1px solid #10b98140}.adj-diff-minus{color:var(--expense);background:#ef44441a;border:1px solid #ef444440}.form-label-optional{color:var(--text-muted);font-size:12px;font-weight:400}.auto-debit-section{margin-bottom:4px}.auto-debit-info{grid-template-columns:auto 1fr;gap:4px 12px;margin-bottom:10px;font-size:13px;display:grid}.auto-debit-info dt{color:var(--text-muted);font-weight:500}.auto-debit-info dd{color:var(--text-primary);margin:0;font-weight:500}.auto-debit-pending-inline{margin:0 0 8px;padding:0;list-style:none}.auto-debit-pending-inline li{align-items:center;gap:8px;padding:5px 0;font-size:13px;display:flex}.auto-debit-pending-inline li span{color:var(--text-primary);flex:1}.auto-debit-dismissed{margin-top:10px;font-size:13px}.auto-debit-dismissed summary{cursor:pointer;color:var(--text-muted);-webkit-user-select:none;user-select:none;font-size:12px;font-weight:600}.auto-debit-dismissed ul{margin:6px 0 0;padding:0;list-style:none}.auto-debit-dismissed li{align-items:center;gap:8px;padding:4px 0;display:flex}.auto-debit-dismissed li span{color:var(--text-muted);flex:1}.dash-form{flex-direction:column;gap:16px;display:flex}.type-toggle{border-radius:var(--radius);background:#f1f5f9;grid-template-columns:1fr 1fr;gap:3px;padding:3px;display:grid}.type-btn{height:38px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:9px;font-size:13.5px;font-weight:500;transition:all .16s}.type-btn.active-expense{background:var(--surface);color:var(--expense);font-weight:600;box-shadow:0 1px 3px #0f172a14}.type-btn.active-income{background:var(--surface);color:var(--income);font-weight:600;box-shadow:0 1px 3px #0f172a14}.record-tabs{background:#f1f5f9;border-radius:12px;flex-shrink:0;grid-template-columns:1fr 1fr 1fr;gap:3px;margin:16px 24px 0;padding:3px;display:grid}.record-tab{height:38px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:9px;font-size:13.5px;font-weight:500;transition:all .16s}.record-tab-active-expense{background:var(--surface);color:var(--expense);font-weight:700;box-shadow:0 1px 3px #0f172a14}.record-tab-active-income{background:var(--surface);color:var(--income);font-weight:700;box-shadow:0 1px 3px #0f172a14}.record-tab-active-transfer{background:var(--surface);color:var(--accent);font-weight:700;box-shadow:0 1px 3px #0f172a14}.btn-primary-income{background:var(--income)!important}.btn-primary-income:hover{filter:brightness(.92)}.btn-primary-transfer{background:var(--accent)!important}.form-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}@media (width<=560px){.form-grid{grid-template-columns:1fr}}.form-field{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-secondary);font-size:12.5px;font-weight:500}.form-input,.form-select{border-radius:var(--radius);height:42px;color:var(--text-primary);background:var(--surface);border:1.5px solid #e2e8f0;outline:none;width:100%;padding:0 12px;font-size:13.5px;transition:border-color .16s,box-shadow .16s,background-color .16s}.form-input:focus,.form-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0596691f}.form-input::placeholder{color:var(--text-muted)}input[inputmode=numeric]{text-align:right}.form-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10' fill='none'%3E%3Cpath d='M2 4l3 3 3-3' stroke='%2394a3b8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;background-size:11px;padding-right:36px}.form-select:hover:not(:disabled),.form-input:hover:not(:disabled){border-color:#cbd5e1}.form-select:hover:not(:disabled){background-color:#0f172a04}.form-select:focus{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10' fill='none'%3E%3Cpath d='M2 4l3 3 3-3' stroke='%23059669' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}.form-select:disabled,.form-input:disabled{color:var(--text-muted);cursor:not-allowed;opacity:.7;background-color:#f8fafc}.btn-submit{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;letter-spacing:-.1px;border:none;height:46px;font-size:14.5px;font-weight:600;transition:background .16s,transform .1s}.btn-submit:hover{background:var(--accent-hover)}.btn-submit:active{transform:scale(.98)}.tx-filter-bar{padding:0 0 12px}.tx-filter-select{border:1px solid var(--border);height:30px;color:var(--text-secondary);background:var(--surface);cursor:pointer;border-radius:7px;outline:none;min-width:160px;padding:0 10px;font-size:12.5px}.tx-filter-select:focus{border-color:var(--accent)}.history-table-wrap{-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--border) transparent;max-height:480px;overflow:auto}.history-table-wrap::-webkit-scrollbar{width:5px;height:5px}.history-table-wrap::-webkit-scrollbar-track{background:0 0}.history-table-wrap::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px}.history-table thead th{z-index:1;background:var(--surface);box-shadow:0 1px 0 var(--border);position:sticky;top:0}.history-table{border-collapse:collapse;width:100%;min-width:480px}@media (width<=640px){.history-table .col-date,.history-table .col-account,.history-table .col-merchant,.history-table .col-category,.tx-date,.tx-account,.tx-merchant{display:none}.history-table{min-width:unset}.amount-cell{min-width:72px}}.history-table thead th{text-align:left;text-transform:uppercase;letter-spacing:.09em;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap;padding:0 8px 12px 0;font-size:11px;font-weight:600}.history-table thead th:last-child{text-align:right;padding-right:0}.history-table tbody tr{border-bottom:1px solid var(--border);transition:background .13s}.history-table tbody tr:last-child{border-bottom:none}.history-table tbody tr:hover{background:#f8fafc}.history-table td{color:var(--text-secondary);vertical-align:middle;padding:13px 8px 13px 0;font-size:13.5px}.history-table td:last-child{padding-right:0}.cat-badge{color:#475569;white-space:nowrap;background:#f1f5f9;border-radius:6px;padding:3px 9px;font-size:12px;font-weight:500;display:inline-block}.amount-cell{font-family:var(--font-mono);text-align:right;white-space:nowrap;font-size:13px;font-weight:500}.amount-expense{color:#dc2626!important}.amount-income{color:#059669!important}.tx-date{color:var(--text-muted);white-space:nowrap;font-size:12.5px}.tx-merchant{color:var(--text-secondary);white-space:nowrap;font-size:12.5px}.tx-title{color:var(--text-primary);min-width:120px;font-weight:500}.tx-empty{color:var(--text-muted);font-size:12px}.tx-account{color:var(--text-muted);white-space:nowrap;font-size:12.5px}.tx-row{cursor:pointer}.tx-check-cell{text-align:center;width:36px;padding-left:4px!important;padding-right:8px!important}.tx-checkbox{appearance:none;border:1.5px solid var(--border);background:var(--surface);cursor:pointer;vertical-align:middle;border-radius:4px;flex-shrink:0;width:16px;height:16px;transition:background .15s,border-color .15s,box-shadow .15s;position:relative}.tx-checkbox:hover{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 15%, transparent)}.tx-checkbox:checked{background:var(--accent);border-color:var(--accent)}.tx-checkbox:checked:after{content:"";border:2px solid #fff;border-top:none;border-left:none;width:5px;height:9px;position:absolute;top:1.5px;left:4px;transform:rotate(45deg)}.tx-checkbox:indeterminate{background:var(--accent);border-color:var(--accent)}.tx-checkbox:indeterminate:after{content:"";background:#fff;border-radius:1px;width:8px;height:2px;position:absolute;top:6px;left:3px}.tx-drag-overlay-card{border:1px solid var(--border);cursor:grabbing;white-space:nowrap;pointer-events:none;background:#fff;border-radius:10px;align-items:center;gap:12px;padding:12px 16px;font-size:13.5px;display:flex;box-shadow:0 8px 28px #00000024,0 2px 8px #00000012}.tx-row:hover td{background:#f8fafc}.delete-confirm-msg{color:var(--text-secondary);padding:4px 0 8px;font-size:13.5px;line-height:1.6}.delete-account-warning{text-align:center;flex-direction:column;align-items:center;gap:8px;padding:20px 8px 12px;display:flex}.delete-account-warning-icon{font-size:28px;line-height:1}.delete-account-warning-title{color:var(--text-primary);margin:0;font-size:15px;font-weight:700}.delete-account-warning-desc{color:var(--text-secondary);margin:0;font-size:13px;line-height:1.6}.modal-actions-3{justify-content:space-between;align-items:center;gap:8px;margin-top:4px;display:flex}.modal-actions-right{gap:8px;display:flex}.modal-actions-right .btn-cancel,.modal-actions-right .btn-primary{min-width:72px;height:44px;margin-top:0;padding:0 20px}.btn-danger{color:#fff;border-radius:var(--radius);cursor:pointer;background:#dc2626;border:none;flex:1;height:44px;font-size:14px;font-weight:600;transition:background .15s}.btn-danger:hover{background:#b91c1c}.btn-danger-ghost{color:#dc2626;cursor:pointer;white-space:nowrap;background:0 0;border:1.5px solid #fca5a5;border-radius:8px;height:36px;padding:0 14px;font-size:13px;font-weight:500;transition:all .15s}.btn-danger-ghost:hover{background:#fef2f2;border-color:#dc2626}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0f172a66;justify-content:center;align-items:center;padding:24px;animation:.15s fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--surface);border-radius:20px;flex-direction:column;width:100%;max-width:480px;max-height:calc(100dvh - 48px);animation:.2s cubic-bezier(.16,1,.3,1) slide-up;display:flex;box-shadow:0 24px 48px #0f172a29,0 4px 12px #0f172a14}@keyframes slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.modal-title{color:var(--text-primary);letter-spacing:-.2px;font-size:15px;font-weight:600}.modal-close{width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:#f1f5f9;border:none;border-radius:7px;justify-content:center;align-items:center;transition:all .15s;display:flex}.modal-close:hover{color:var(--text-primary);background:#e2e8f0}.modal-form{flex-direction:column;flex:1;gap:16px;padding:20px 24px 24px;display:flex;overflow-y:auto}.modal-actions{grid-template-columns:1fr 1fr;gap:10px;margin-top:4px;display:grid}.btn-cancel{border:1.5px solid var(--border);height:36px;color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border-radius:8px;padding:0 16px;font-size:13px;font-weight:500;transition:all .15s}.btn-cancel:hover{background:#f1f5f9;border-color:#94a3b8}.modal-actions .btn-primary{flex:1;height:44px;margin-top:0}.form-input-suffix{align-items:center;display:flex;position:relative}.form-input-suffix .form-input{padding-right:36px}.form-suffix{color:var(--text-muted);pointer-events:none;white-space:nowrap;font-size:13px;position:absolute;right:12px}.form-error{color:#dc2626;background:#fff1f2;border:1px solid #fecdd3;border-radius:8px;padding:10px 12px;font-size:13px;line-height:1.4}.new-cat-trigger{color:var(--accent);cursor:pointer;opacity:.8;background:0 0;border:none;align-items:center;margin-top:6px;padding:0;font-size:12px;font-weight:500;display:inline-flex}.new-cat-trigger:hover{opacity:1;text-decoration:underline}.maturity-preview{background:#0596690f;border:1px solid #0596692e;border-radius:8px;margin-top:8px;padding:10px 12px}.maturity-preview-row{color:var(--text-primary);justify-content:space-between;align-items:baseline;gap:12px;font-size:13px;display:flex}.maturity-preview-row strong{color:var(--accent,#059669);font-family:JetBrains Mono,monospace;font-size:14px;font-weight:700}.maturity-preview-months{color:var(--text-muted);font-size:11.5px;font-weight:400}.maturity-preview-note{color:var(--text-muted);margin-top:6px;font-size:11px;line-height:1.5}.profile-avatar-wrap{flex-direction:column;align-items:center;gap:8px;display:flex;position:relative}.profile-avatar-btn{border:2.5px solid var(--accent-border);background:var(--accent-light);cursor:pointer;box-sizing:border-box;border-radius:50%;flex-shrink:0;width:80px;height:80px;padding:0;position:relative;overflow:hidden}.profile-avatar-btn:hover .profile-avatar-overlay{opacity:1}.profile-avatar-placeholder{width:100%;height:100%;color:var(--accent-ink);place-items:center;font-size:32px;font-weight:700;display:grid}.profile-avatar-img{object-fit:cover;border-radius:50%;width:100%;height:100%;display:block}.profile-avatar-overlay{color:#fff;opacity:0;background:#00000073;border-radius:50%;place-items:center;transition:opacity .15s;display:grid;position:absolute;inset:0}.profile-avatar-remove{color:#fff;border:2px solid var(--surface);cursor:pointer;background:#ef4444;border-radius:50%;place-items:center;width:22px;height:22px;font-size:11px;font-weight:700;display:grid;position:absolute;top:0;right:calc(50% - 52px)}.profile-email-text{color:var(--text-muted);font-size:12.5px}.profile-fixed-badge{color:var(--text-muted);background:var(--bg-2);border-radius:20px;margin-left:6px;padding:1px 6px;font-size:10.5px;font-weight:600;display:inline-block}.profile-edit-section{flex-direction:column;gap:10px;display:flex}.profile-edit-section-title{color:var(--text-secondary);font-size:13px;font-weight:600}.profile-edit-divider{background:var(--border);height:1px;margin:4px 0}.profile-edit-msg{border-radius:8px;margin:0;padding:8px 12px;font-size:12.5px}.profile-edit-msg.ok{color:#059669;background:#ecfdf5}.profile-edit-msg.err{color:#dc2626;background:#fff1f2}.avatar-action-sheet{background:var(--bg-card,#fff);border:1px solid var(--border);z-index:20;border-radius:12px;min-width:180px;position:absolute;top:calc(100% + 8px);left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 8px 24px #0000001f}.avatar-action-item{cursor:pointer;width:100%;color:var(--text-primary);text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:12px 16px;font-size:14px;transition:background .15s;display:flex}.avatar-action-item:hover{background:var(--bg-2,#f8fafc)}.avatar-action-item+.avatar-action-item{border-top:1px solid var(--border)}.avatar-action-item.danger{color:#dc2626}.avatar-action-item.danger:hover{background:#fff1f2}.avatar-action-icon{font-size:16px;line-height:1}.cd-meta{background:0 0;border-radius:0;flex-direction:column;gap:0;margin:0 0 4px;padding:0;display:flex;overflow:hidden}.cd-row{justify-content:space-between;align-items:center;gap:8px;padding:8px 2px;display:flex}.cd-row+.cd-row{border-top:1px dashed var(--border,#e5e7eb)}.cd-row-label{color:var(--text-muted);flex-shrink:0;font-size:12.5px}.cd-row-value{color:var(--text-primary);text-align:right;font-size:13px;font-weight:500}.cd-row-value.highlight{color:#2563eb;font-weight:600}.cd-field{flex-direction:column;gap:6px;display:flex}.cd-label{color:var(--text-secondary);font-size:12.5px;font-weight:600}.cd-hint{color:var(--text-muted);margin:0;font-size:11.5px;line-height:1.5}.cd-edit-section{background:0 0;border:none;flex-direction:column;gap:12px;padding:4px 2px;display:flex}.cd-save-dates{align-self:flex-end;padding:8px 16px;font-size:13px}.cd-actions-split{justify-content:flex-end;gap:10px;display:flex}.cd-actions-split>button{flex:1;max-width:200px}.cd-section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin:0 0 8px;font-size:12px;font-weight:600}.cd-charge-list{margin-top:4px}.cd-plan-charges{flex-direction:column;gap:0;max-height:240px;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.cd-plan-charge-item{background:0 0;align-items:center;gap:8px;padding:8px 2px;font-size:13px;display:flex}.cd-plan-charge-item+.cd-plan-charge-item{border-top:1px dashed var(--border,#e5e7eb)}.cd-plan-charge-item.pending{opacity:1}.cd-plan-charge-item.settled,.cd-plan-charge-item.prepaid{opacity:.55}.cd-seq{min-width:42px;color:var(--text-secondary);font-weight:600}.cd-due{color:var(--text-muted);flex:1}.cd-amount{color:var(--text-primary);font-weight:600}.cd-status-badge{border-radius:99px;padding:2px 7px;font-size:11px;font-weight:600}.cd-status-badge.pending{color:#92400e;background:#fef3c7}.cd-status-badge.prepaid{color:#1d4ed8;background:#dbeafe}.cd-status-badge.settled{color:#15803d;background:#dcfce7}.cd-actions{justify-content:flex-end;gap:8px;padding-top:4px;display:flex}.btn-ghost-danger{color:#dc2626;cursor:pointer;background:#fff1f2;border:1.5px solid #fca5a5;border-radius:10px;padding:8px 16px;font-size:13.5px;font-weight:600;transition:background .15s,border-color .15s}.btn-ghost-danger:hover{background:#ffe4e6;border-color:#f87171}.btn-ghost-danger:disabled{opacity:.5;cursor:not-allowed}.cd-actions .btn-ghost,.btn-ghost{color:#047857;cursor:pointer;background:#ecfdf5;border:1.5px solid #d1fae5;border-radius:10px;padding:8px 16px;font-size:13.5px;font-weight:600;transition:background .15s,border-color .15s}.cd-actions .btn-ghost:hover,.btn-ghost:hover{background:#d1fae5;border-color:#6ee7b7}.cd-actions .btn-ghost:disabled,.btn-ghost:disabled{opacity:.5;cursor:not-allowed}.modal-error{color:#dc2626;background:#fff1f2;border-radius:8px;margin:0;padding:10px 14px;font-size:13px}.cat-manage-grid{grid-template-columns:1fr 1fr;gap:0;min-height:0;display:grid}.cat-manage-col{padding:4px 0}.cat-manage-col:first-child{border-right:1px solid var(--border);padding-right:20px}.cat-manage-col:last-child{padding-left:20px}.cat-manage-type-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:10px;font-size:11px;font-weight:600}.cat-manage-item{width:100%;color:var(--text-primary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;justify-content:space-between;align-items:center;padding:9px 10px;font-size:13.5px;font-weight:400;transition:background .13s;display:flex}.cat-manage-item:hover{background:#f8fafc}.cat-manage-edit{color:var(--accent);opacity:0;font-size:11px;font-weight:500;transition:opacity .13s}.cat-manage-item:hover .cat-manage-edit{opacity:1}.cat-manage-empty{color:var(--text-muted);padding:6px 10px;font-size:12.5px}@media (width<=600px){.cat-manage-grid{grid-template-columns:1fr}.cat-manage-col:first-child{border-right:none;border-bottom:1px solid var(--border);margin-bottom:4px;padding-bottom:16px;padding-right:0}.cat-manage-col:last-child{padding-top:8px;padding-left:0}}.react-datepicker-wrapper,.react-datepicker__input-container{width:100%}.react-datepicker-popper{z-index:9999}.react-datepicker{background:#fff;border:1px solid #e2e8f0;border-radius:12px;font-family:Outfit,sans-serif;box-shadow:0 10px 28px #0f172a1a}.react-datepicker__header{border-bottom:1px solid #f1f5f9;border-top-left-radius:12px;border-top-right-radius:12px;padding:0;background:#fff!important}.react-datepicker__current-month,.react-datepicker__navigation,.react-datepicker__header__dropdown{display:none!important}.dp-header{justify-content:space-between;align-items:center;gap:6px;padding:10px 8px;display:flex}.dp-nav{color:#475569;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;transition:background .14s,color .14s;display:flex}.dp-nav:hover:not(:disabled){color:var(--accent);background:#0f172a0d}.dp-nav:disabled{opacity:.3;cursor:not-allowed}.dp-header-mid{color:var(--text-primary);align-items:center;gap:4px;font-weight:600;display:flex}.dp-sep{color:var(--text-muted);-webkit-user-select:none;user-select:none;font-size:13px;font-weight:500}.dp-cs{display:inline-flex;position:relative}.dp-cs-trigger{appearance:none;color:var(--text-primary);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;align-items:center;gap:6px;padding:4px 8px 4px 10px;font-family:inherit;font-size:13.5px;font-weight:600;transition:background .14s,border-color .14s;display:inline-flex}.dp-cs-trigger:hover{background:#0f172a0d;border-color:#0f172a14}.dp-cs-trigger--open{color:var(--accent);background:#10b9811a;border-color:#10b9814d}.dp-cs-trigger--open .dp-cs-caret{color:var(--accent);transform:rotate(180deg)}.dp-cs-label{letter-spacing:.2px}.dp-cs-caret{color:var(--text-muted);flex-shrink:0;transition:transform .16s,color .14s}.dp-cs-year .dp-cs-trigger,.dp-cs-month .dp-cs-trigger{justify-content:center;min-width:76px}.dp-cs-menu{overscroll-behavior:contain;z-index:50;background:#fff;border:1px solid #e2e8f0;border-radius:10px;min-width:88px;max-height:220px;margin:0;padding:4px;list-style:none;animation:.12s ease-out dpCsFadeIn;position:absolute;top:calc(100% + 4px);left:50%;overflow-y:auto;transform:translate(-50%);box-shadow:0 12px 32px #0f172a29}@keyframes dpCsFadeIn{0%{opacity:0;transform:translate(-50%,-4px)}to{opacity:1;transform:translate(-50%)}}.dp-cs-opt{color:var(--text-primary);cursor:pointer;text-align:center;-webkit-user-select:none;user-select:none;border-radius:6px;padding:6px 12px;font-size:13px;font-weight:500;transition:background .1s,color .1s}.dp-cs-opt:hover{color:var(--accent);background:#10b9811a}.dp-cs-opt--selected,.dp-cs-opt--selected:hover{background:var(--accent);color:#fff;font-weight:600}.dp-cs-menu::-webkit-scrollbar{width:6px}.dp-cs-menu::-webkit-scrollbar-thumb{background:#0f172a33;border-radius:3px}.dp-cs-menu::-webkit-scrollbar-thumb:hover{background:#0f172a52}.dp-cs-menu::-webkit-scrollbar-track{background:0 0}.react-datepicker__day-names{background:#fff;justify-content:space-around;margin:0;padding:4px 4px 8px;display:flex}.react-datepicker__day-name{color:var(--text-muted);width:36px;margin:0;font-size:11px;font-weight:600}.react-datepicker__month{margin:6px 6px 10px}.react-datepicker__week{justify-content:space-around;display:flex}.react-datepicker__day{width:36px;height:36px;color:var(--text-primary);border-radius:8px;margin:1px;font-size:13px;line-height:36px;transition:background .12s,color .12s}.react-datepicker__day:hover{color:var(--accent);background:#10b9811a}.react-datepicker__day--selected,.react-datepicker__day--keyboard-selected{font-weight:600;background:var(--accent)!important;color:#fff!important}.react-datepicker__day--today{color:var(--accent);font-weight:700}.react-datepicker__day--today.react-datepicker__day--selected{color:#fff}.react-datepicker__day--outside-month{color:var(--text-muted);opacity:.5}.react-datepicker__day--disabled{color:var(--text-muted);opacity:.4;cursor:not-allowed}.react-datepicker__day--disabled:hover{color:var(--text-muted);background:0 0}.react-datepicker__close-icon:after{background:#0f172a66;font-size:14px}.react-datepicker__close-icon:hover:after{background:#0f172ab3}.react-datepicker__triangle{display:none}.ai-fab{background:var(--color-primary,#6366f1);color:#fff;cursor:pointer;z-index:200;border:none;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;transition:transform .15s,box-shadow .15s;display:flex;position:fixed;bottom:80px;right:20px;box-shadow:0 4px 16px #0000002e}.ai-fab:hover{transform:scale(1.08);box-shadow:0 6px 20px #0000003d}.ai-panel{background:var(--color-surface,#fff);border:1px solid var(--color-border,#e5e7eb);z-index:200;border-radius:16px;flex-direction:column;width:340px;max-height:480px;display:flex;position:fixed;bottom:148px;right:20px;overflow:hidden;box-shadow:0 8px 32px #00000024}.ai-panel-header{border-bottom:1px solid var(--color-border,#e5e7eb);justify-content:space-between;align-items:center;padding:14px 16px;font-size:14px;font-weight:600;display:flex}.ai-panel-close{cursor:pointer;color:var(--color-text-secondary,#6b7280);background:0 0;border:none;align-items:center;padding:2px;display:flex}.ai-panel-close:hover{color:var(--color-text,#111827)}.ai-panel-messages{flex-direction:column;flex:1;gap:10px;padding:12px 14px;display:flex;overflow-y:auto}.ai-bubble{white-space:pre-wrap;word-break:break-word;border-radius:14px;max-width:85%;padding:9px 13px;font-size:13.5px;line-height:1.55}.ai-bubble-user{background:var(--color-primary,#6366f1);color:#fff;border-bottom-right-radius:4px;align-self:flex-end}.ai-bubble-model{background:var(--color-surface-2,#f3f4f6);color:var(--color-text,#111827);border-bottom-left-radius:4px;align-self:flex-start}.ai-bubble-loading{background:var(--color-surface-2,#f3f4f6);color:var(--color-text-secondary,#6b7280);border-bottom-left-radius:4px;align-self:flex-start;font-style:italic}.ai-panel-input-row{border-top:1px solid var(--color-border,#e5e7eb);gap:8px;padding:10px 12px;display:flex}.ai-panel-input{border:1px solid var(--color-border,#e5e7eb);background:var(--color-surface,#fff);color:var(--color-text,#111827);resize:none;border-radius:10px;outline:none;flex:1;height:38px;padding:8px 12px;font-size:13.5px;line-height:1.4}.ai-panel-input:focus{border-color:var(--color-primary,#6366f1)}.ai-panel-send{background:var(--color-primary,#6366f1);color:#fff;cursor:pointer;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;transition:opacity .15s;display:flex}.ai-panel-send:disabled{opacity:.45;cursor:not-allowed}.ai-suggestions{flex-direction:column;gap:6px;margin-top:2px;display:flex}.ai-suggestion-chip{background:var(--color-surface,#fff);border:1px solid var(--color-primary,#6366f1);color:var(--color-primary,#6366f1);cursor:pointer;text-align:left;border-radius:20px;align-self:flex-start;padding:5px 13px;font-size:12.5px;line-height:1.4;transition:background .13s,color .13s}.ai-suggestion-chip:hover{background:var(--color-primary,#6366f1);color:#fff}.ai-suggestion-chip:disabled{opacity:.4;cursor:not-allowed}.ai-bubble-md{white-space:normal}.ai-bubble-md p{margin:0 0 6px}.ai-bubble-md p:last-child{margin-bottom:0}.ai-bubble-md ul{margin:4px 0 6px;padding-left:18px;list-style-type:disc}.ai-bubble-md ol{margin:4px 0 6px;padding-left:18px;list-style-type:decimal}.ai-bubble-md li{margin-bottom:3px}.ai-bubble-md strong{font-weight:600}.ai-bubble-md h1,.ai-bubble-md h2,.ai-bubble-md h3{margin:6px 0 4px;font-size:13.5px;font-weight:700}@media (width<=768px){.ai-fab{transition:transform .22s,opacity .22s,box-shadow .15s;bottom:72px;right:16px}.ai-fab.is-hidden{opacity:0;pointer-events:none;transform:translateY(96px)scale(.6)}.ai-panel{width:calc(100vw - 20px);bottom:136px;right:10px}}.guest-upgrade-view{justify-content:center;align-items:center;min-height:60vh;padding:32px 16px;display:flex}.guest-upgrade-card{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:16px;width:100%;max-width:460px;padding:40px 32px;box-shadow:0 1px 2px #0f172a0a}.guest-upgrade-icon{width:72px;height:72px;color:var(--accent);background:#ecfdf5;border-radius:18px;justify-content:center;align-items:center;margin:0 auto 20px;display:flex}.guest-upgrade-title{letter-spacing:-.4px;color:var(--text-primary);margin:0 0 12px;font-size:20px;font-weight:700;line-height:1.35}.guest-upgrade-desc{color:var(--text-muted);margin:0 0 28px;font-size:14px;line-height:1.65}.guest-upgrade-actions{flex-direction:column;gap:10px;display:flex}.guest-upgrade-cta{width:100%;height:46px}.guest-upgrade-secondary{color:var(--text-muted);cursor:pointer;text-underline-offset:3px;background:0 0;border:none;padding:8px;font-size:13px;font-weight:500;text-decoration:underline}.guest-upgrade-secondary:hover{color:var(--text-primary)}.guest-banner{color:#78350f;z-index:30;background:#fef3c7;border-bottom:1px solid #fcd34d;font-size:13px;position:relative}.guest-banner-inner{flex-wrap:wrap;align-items:center;gap:10px;max-width:1280px;margin:0 auto;padding:9px 20px;display:flex}.guest-banner-icon{color:#92400e;flex-shrink:0;align-items:center;display:inline-flex}.guest-banner-text{letter-spacing:-.1px;flex:1;font-weight:500}.guest-banner-cta{color:#fff;cursor:pointer;white-space:nowrap;background:#92400e;border:none;border-radius:999px;padding:6px 14px;font-size:12.5px;font-weight:600;transition:background .15s}.guest-banner-cta:hover{background:#78350f}@media (width<=540px){.guest-banner-inner{gap:8px;padding:8px 14px}.guest-banner-text{font-size:12.5px}}.sub-cred-section{border-top:1px solid var(--border-light,#f1f5f9);margin-top:10px;padding-top:12px}.sub-cred-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted,#9ca3af);margin-bottom:8px;font-size:10.5px;font-weight:600}.sub-cred-field{background:var(--bg-2,#f8fafc);border-radius:9px;justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px;padding:9px 12px;display:flex}.sub-cred-field-left{flex:1;min-width:0}.sub-cred-field-key{color:var(--text-muted,#9ca3af);margin-bottom:2px;font-size:10.5px}.sub-cred-field-val{color:var(--text-primary,#0f172a);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.sub-cred-pw{letter-spacing:.1em;font-family:monospace;font-size:14px}.sub-cred-action{border:1px solid var(--border,#e5e7eb);background:var(--bg-1,#fff);color:var(--text-secondary,#6b7280);cursor:pointer;white-space:nowrap;border-radius:6px;flex-shrink:0;padding:4px 10px;font-size:11.5px;font-weight:500;transition:background .12s,color .12s}.sub-cred-action:hover{background:var(--bg-3,#f1f5f9)}.sub-cred-action.done{color:var(--accent,#10b981);border-color:var(--accent,#10b981)}.sub-cred-url-btn{color:var(--accent,#10b981);background:var(--bg-2,#f8fafc);border:1px solid var(--border,#e5e7eb);text-overflow:ellipsis;white-space:nowrap;border-radius:9px;align-items:center;gap:6px;padding:10px 12px;font-size:13px;text-decoration:none;transition:background .12s;display:flex;overflow:hidden}.sub-cred-url-btn:hover{background:var(--bg-3,#f1f5f9)}.sub-cred-type-row{gap:6px;margin-bottom:10px;display:flex}.sub-cred-type-btn{border:1px solid var(--border,#e5e7eb);background:var(--bg-1,#fff);color:var(--text-secondary,#6b7280);cursor:pointer;border-radius:7px;flex:1;padding:6px 0;font-size:12.5px;font-weight:500;transition:background .12s,color .12s}.sub-cred-type-btn.active{background:var(--accent,#10b981);border-color:var(--accent,#10b981);color:#fff}.sub-detail-actions{border-top:1px solid var(--border-light,#f1f5f9);justify-content:space-between;align-items:center;gap:8px;margin-top:16px;padding-top:14px;display:flex}.sub-detail-left,.sub-detail-right{align-items:center;gap:6px;display:flex}.sda-ghost{border:1px solid var(--border,#e5e7eb);color:var(--text-secondary,#6b7280);cursor:pointer;background:0 0;border-radius:8px;padding:7px 13px;font-size:13px;font-weight:500;transition:background .12s,border-color .12s}.sda-ghost:hover{background:var(--bg-2,#f8fafc)}.sda-ghost:disabled{opacity:.45;cursor:default}.sda-ghost.danger{color:#dc2626;border-color:#fca5a5}.sda-ghost.danger:hover{background:#fef2f2}.sub-modal-card{max-width:480px}.sub-modal-card .sub-row{gap:8px;display:flex}.sub-modal-card .sub-row .form-field{flex:1;min-width:0}.subscriptions-page{flex-direction:column;gap:16px;display:flex}.sub-summary-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.sub-summary-grid .sub-summary-card{border:1px solid var(--border);background:#fff;border-radius:12px;flex-direction:column;gap:4px;padding:14px 16px;display:flex}.sub-summary-grid .sub-summary-card .label{color:var(--muted);font-size:.85em}.sub-summary-grid .sub-summary-card .value{font-size:1.25em;font-weight:600}.sub-upcoming-list{border:1px solid var(--border);background:#fff;border-radius:12px;padding:16px}.sub-upcoming-list h3{align-items:center;gap:6px;margin:0 0 8px;font-size:1em;display:flex}.sub-upcoming-list .sub-upcoming-row{border-top:1px solid var(--border-light,#f1f5f9);justify-content:space-between;align-items:center;padding:8px 0;display:flex}.sub-upcoming-list .sub-upcoming-row:first-of-type{border-top:none}.sub-upcoming-list .sub-upcoming-row .meta{color:var(--muted);font-size:.85em}.sub-list-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin:8px 0;display:flex}.sub-list-header h3{margin:0;font-size:1em}.sub-list-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.sub-view-tabs{background:var(--bg-2,#f1f5f9);border-radius:10px;align-items:center;gap:2px;height:36px;padding:4px;display:inline-flex}.sub-view-tabs button{height:28px;color:var(--text-secondary,#64748b);cursor:pointer;background:0 0;border:none;border-radius:7px;padding:0 12px;font-size:12.5px;font-weight:500;transition:background .15s,color .15s}.sub-view-tabs button.on{background:var(--surface,#fff);color:var(--text-primary,#0f172a);font-weight:600;box-shadow:0 1px 2px #0000000d}.sub-table-wrap{border:1px solid var(--border);background:#fff;border-radius:12px;overflow-x:auto}.sub-table{border-collapse:collapse;width:100%;font-size:14px}.sub-table th,.sub-table td{text-align:left;border-bottom:1px solid var(--border-light,#f1f5f9);padding:10px 14px}.sub-table thead th{background:var(--bg-2,#f8fafc);color:var(--muted);border-bottom:1px solid var(--border);font-size:12.5px;font-weight:500}.sub-table th.num,.sub-table td.num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.sub-table tbody tr{cursor:pointer;transition:background .12s}.sub-table tbody tr:hover{background:var(--bg-2,#f8fafc)}.sub-table tbody tr:last-child td{border-bottom:none}.sub-table tbody tr.upcoming{background:#fef3c7}.sub-table tbody tr.upcoming:hover{background:#fde68a}.sub-table tbody tr.paused td,.sub-table tbody tr.ended td{opacity:.55}.sub-table .name-cell{font-weight:500}.sub-table .memo-cell{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;max-width:240px;font-size:12.5px;overflow:hidden}.sub-card-memo{background:var(--bg-2,#f8fafc);white-space:nowrap;text-overflow:ellipsis;border-radius:6px;margin-top:6px;padding:4px 8px;font-size:.85em;overflow:hidden}.sub-card-remaining{color:var(--muted)}.sub-card-remaining.urgent{color:#d97706;font-weight:600}.sub-card-remaining.expired{color:#dc2626}.sub-remaining-urgent{color:#d97706;font-weight:600}.sub-remaining-expired{color:#dc2626}.sub-card-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;display:grid}.sub-card{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:12px;padding:16px;transition:transform .12s,box-shadow .12s}.sub-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000000f}.sub-card .name{margin-bottom:4px;font-weight:600}.sub-card .amount{margin:4px 0;font-size:1.4em;font-weight:600}.sub-card .meta{color:var(--muted);font-size:.85em}.sub-card.upcoming{border-color:#f59e0b;box-shadow:inset 0 0 0 1px #fde68a}.sub-card.paused,.sub-card.ended{opacity:.6}.sub-empty-state{text-align:center;border:1px dashed var(--border);color:var(--muted);background:#fff;border-radius:12px;padding:48px 16px}.sub-detail-card .detail-row{border-top:1px solid var(--border-light,#f1f5f9);justify-content:space-between;padding:6px 0;display:flex}.sub-detail-card .detail-row:first-of-type{border-top:none}.sub-detail-card .detail-row .label{color:var(--muted)}.sub-detail-card .detail-amount{margin:8px 0;font-size:1.6em;font-weight:600}.cal-sub-marker{background:#8b5cf6;border-radius:50%;width:6px;height:6px;margin-right:2px;display:inline-block}.nav-badge{color:#fff;background:#ef4444;border-radius:10px;margin-left:auto;padding:1px 6px;font-size:.75em}@media (width<=640px){.sub-summary-grid{grid-template-columns:1fr}.sub-modal-card .sub-row{flex-wrap:wrap}}.cc-page{flex-direction:column;gap:20px;display:flex}.cc-stat-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.cc-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-xs);flex-direction:column;gap:4px;padding:16px 18px;display:flex}.cc-stat-card .cc-stat-label{color:var(--text-muted);letter-spacing:.03em;font-size:12px;font-weight:500}.cc-stat-card .cc-stat-value{color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:1.35em;font-weight:700}.cc-stat-card .cc-stat-value.danger{color:var(--expense)}.cc-stat-card .cc-stat-sub{color:var(--text-muted);font-size:12px}.cc-card-pills{flex-wrap:wrap;gap:8px;display:flex}.cc-card-pill{border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;border-radius:999px;align-items:center;gap:6px;padding:7px 14px;font-size:13.5px;font-weight:500;transition:all .15s;display:flex}.cc-card-pill:hover{border-color:var(--accent-border);color:var(--text-primary);background:var(--accent-light)}.cc-card-pill.active{border-color:var(--accent);background:var(--accent);color:#fff}.cc-card-pill .cc-pill-amount{opacity:.75;font-size:12px}.cc-hero{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px 22px 16px}.cc-hero-top{justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:14px;display:flex}.cc-hero-left{flex-direction:column;flex:1;justify-content:space-between;align-self:stretch;gap:14px;min-width:0;display:flex}.cc-hero-name{color:var(--text-primary);align-items:center;gap:8px;font-size:1.1em;font-weight:700;display:flex}.cc-hero-insights{flex-direction:column;gap:12px;width:100%;display:flex}.cc-hero-insight-chip{background:var(--accent-soft,#ecfdf5);border:1px solid var(--accent-soft,#d1fae5);border-radius:999px;align-items:baseline;gap:8px;width:fit-content;padding:8px 14px;display:inline-flex}.cc-hero-chip-label{color:var(--text-secondary,#6b7280);font-size:11.5px;font-weight:500}.cc-hero-chip-value{color:var(--accent-ink,#047857);font-variant-numeric:tabular-nums;font-size:15px;font-weight:700}.cc-hero-usage{flex-direction:column;gap:6px;display:flex}.cc-hero-usage-header{justify-content:space-between;align-items:baseline;display:flex}.cc-hero-usage-label{color:var(--text-secondary,#6b7280);font-size:13px;font-weight:500}.cc-hero-usage-pct{font-variant-numeric:tabular-nums;font-size:16px;font-weight:700}.cc-hero-usage-track{background:var(--bg-2,#f3f4f6);border-radius:999px;height:10px;overflow:hidden}.cc-hero-usage-fill{border-radius:999px;height:100%;transition:width .4s,background .2s}.cc-hero-usage-sub{color:var(--text-muted,#9ca3af);font-variant-numeric:tabular-nums;font-size:11.5px}.cc-hero-badge{background:var(--accent-soft);color:var(--accent-ink);border-radius:999px;padding:2px 8px;font-size:11px;font-weight:600}.cc-hero-top-right{flex-direction:column;align-items:flex-end;gap:6px;display:flex}.cc-hero-edit-btn{border:1.5px solid var(--border);background:var(--surface);height:26px;color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:6px;align-items:center;padding:0 10px;font-size:12px;font-weight:600;transition:all .15s;display:inline-flex}.cc-hero-edit-btn:hover{border-color:var(--accent-border);background:var(--accent-light);color:var(--accent)}.cc-hero-balances{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.cc-hero-balance{text-align:right}.cc-hero-balance-label{color:var(--text-muted);margin-bottom:2px;font-size:11.5px}.cc-hero-balance-value{color:var(--expense);font-variant-numeric:tabular-nums;font-size:1.5em;font-weight:700}.cc-hero-balance-sub{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:12px}.cc-hero-balance-sub strong{color:var(--text-primary);font-weight:600}.cc-hero-balance-sub.is-zero strong{color:var(--text-muted);font-weight:500}.cc-hero-meta{border-top:1px solid var(--border);flex-wrap:wrap;gap:20px;padding-top:12px;display:flex}.cc-hero-meta-item{flex-direction:column;gap:2px;display:flex}.cc-hero-meta-item .meta-label{color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase;font-size:11px;font-weight:500}.cc-hero-meta-item .meta-value{color:var(--text-secondary);font-size:13px;font-weight:600}.cc-inner-tabs{background:var(--bg-2);border-radius:12px;align-self:flex-start;align-items:center;gap:2px;padding:4px;display:inline-flex}.cc-inner-tab{height:30px;color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:9px;padding:0 14px;font-size:13px;font-weight:500;transition:background .15s,color .15s}.cc-inner-tab.active{background:var(--surface);color:var(--text-primary);box-shadow:var(--shadow-xs);font-weight:600}.cc-content-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-xs);overflow:hidden}.cc-charge-list{list-style:none}.cc-charge-item{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:13px 18px;transition:background .1s;display:flex}.cc-charge-item:last-child{border-bottom:none}.cc-charge-item:hover{background:var(--bg-2)}.cc-charge-item.settled{opacity:.7}.cc-clickable{cursor:pointer}.cc-clickable:active{opacity:.85}.cc-charge-date{color:var(--text-muted);font-variant-numeric:tabular-nums;min-width:68px;font-size:12px}.cc-charge-info{flex:1;min-width:0}.cc-charge-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.cc-charge-sub{color:var(--text-muted);margin-top:1px;font-size:12px}.cc-charge-seq{background:var(--bg-2);color:var(--text-secondary);white-space:nowrap;border-radius:999px;padding:2px 8px;font-size:11.5px;font-weight:600}.cc-charge-amount{color:var(--expense);font-variant-numeric:tabular-nums;white-space:nowrap;text-align:right;min-width:80px;font-size:14px;font-weight:700}.cc-charge-item.settled .cc-charge-amount{color:var(--text-muted)}.cc-status-badge{white-space:nowrap;border-radius:999px;padding:3px 9px;font-size:11.5px;font-weight:600}.cc-status-badge.prepaid{background:var(--accent-soft);color:var(--accent-ink)}.cc-status-badge.settled{background:var(--bg-2);color:var(--text-muted)}.btn-prepay{border:1.5px solid var(--accent-border);background:var(--accent-light);color:var(--accent);cursor:pointer;white-space:nowrap;border-radius:8px;flex-shrink:0;padding:5px 12px;font-size:12px;font-weight:600;transition:background .12s,border-color .12s}.btn-prepay:hover{background:var(--accent-soft);border-color:var(--accent)}.cc-plan-list{list-style:none}.cc-plan-item{border-bottom:1px solid var(--border);padding:14px 18px}.cc-plan-item:last-child{border-bottom:none}.cc-plan-item:hover{background:var(--bg-2)}.cc-plan-top{justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:8px;display:flex}.cc-plan-title{color:var(--text-primary);font-size:14px;font-weight:600}.cc-plan-total{color:var(--text-primary);white-space:nowrap;font-variant-numeric:tabular-nums;font-size:14px;font-weight:700}.cc-plan-progress-row{align-items:center;gap:10px;margin-bottom:8px;display:flex}.cc-plan-bar-wrap{background:var(--bg-2);border-radius:999px;flex:1;height:5px;overflow:hidden}.cc-plan-bar-fill{background:var(--accent);border-radius:999px;height:100%;transition:width .3s}.cc-plan-progress-text{color:var(--text-muted);white-space:nowrap;font-size:12px}.cc-plan-next{color:var(--text-secondary);justify-content:space-between;align-items:center;gap:8px;font-size:12px;display:flex}.cc-plan-bottom{justify-content:flex-end;margin-top:10px;display:flex}.cc-empty-page{text-align:center;background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius-sm);color:var(--text-muted);padding:64px 16px}.cc-empty-page .cc-empty-icon{opacity:.35;margin-bottom:10px;font-size:2.6em}.cc-empty-page p{font-size:14px}.cc-empty-hint{color:var(--text-muted);margin-top:6px;font-size:13px}.cc-list-empty{text-align:center;color:var(--text-muted);padding:32px 18px;font-size:13.5px}.cc-import-preview{background:var(--bg-2);border-radius:10px;flex-direction:column;gap:6px;margin-top:4px;padding:12px 14px;display:flex}.cc-import-preview-row{color:var(--text-secondary);justify-content:space-between;font-size:13px;display:flex}.cc-import-preview-row span:first-child{color:var(--text-muted)}.cc-tab-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.cc-tab-header-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.btn-import-lumpsum{border:1.5px solid var(--accent);color:var(--accent);cursor:pointer;white-space:nowrap;background:0 0;border-radius:8px;align-items:center;gap:5px;padding:7px 14px;font-size:13px;font-weight:600;transition:background .15s,color .15s,transform .1s;display:inline-flex}.btn-import-lumpsum:hover{background:var(--accent-light);transform:translateY(-1px)}.btn-import-lumpsum:active{transform:translateY(0)}.btn-import-installment{border:1.5px solid var(--accent);background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border-radius:8px;flex-shrink:0;align-items:center;gap:5px;padding:7px 14px;font-size:13px;font-weight:700;transition:background .12s,border-color .12s,transform .1s;display:inline-flex}.btn-import-installment:hover{background:color-mix(in srgb, var(--accent) 85%, #000);border-color:color-mix(in srgb, var(--accent) 85%, #000);transform:translateY(-1px)}.btn-import-installment:active{transform:translateY(0)}@media (width<=640px){.cc-stat-grid{grid-template-columns:1fr 1fr}.cc-stat-grid .cc-stat-card:first-child{grid-column:1/-1}.cc-charge-date{display:none}.cc-hero-balance-value{font-size:1.3em}}
