*,: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:100vh;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;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 .sidebar-spacer{flex:1}aside.sidebar .user-chip{background:var(--bg);border:1px solid var(--border);border-radius:14px;align-items:center;gap:10px;padding:12px;display:flex}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;text-overflow:ellipsis;font-size:13.5px;font-weight:600;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{display:none}main.content{padding:28px 28px 80px}}@media (width<=768px){.app-shell{grid-template-columns:1fr}aside.sidebar{z-index:300;width:260px;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}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;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}.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}.quick-actions-grid{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.quick-action{background:var(--bg-2);color:var(--text-secondary);cursor:pointer;border:none;border-radius:14px;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;font-size:12px;font-weight:600;transition:background .15s,color .15s;display:flex}.quick-action:hover{background:var(--accent-light);color:var(--accent-ink)}.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(4,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}.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-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 h4{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;justify-content:space-between;align-items:center;margin:0 0 10px;font-size:12.5px;font-weight:600;display:flex}.fa2-acc-group h4 .gtot{color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:14px}.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;flex:1;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;padding:2px 8px;font-size:10.5px;font-weight:600}.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:wrap;align-items:center;gap:12px;margin-bottom:18px;display:flex}.fa2-tx-head .sel{background:var(--bg-2);border:1px solid var(--border);cursor:pointer;color:var(--text-secondary);border-radius:10px;align-items:center;gap:6px;padding:8px 12px;font-size:13px;font-weight:500;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}.fa2-tx-list{flex-direction:column;gap:2px;display:flex}.fa2-tx-item{cursor:pointer;border-radius:12px;align-items:center;gap:14px;padding:14px 12px;transition:background .15s,transform .15s;display:flex}.fa2-tx-item:hover{background:var(--bg-2);transform:translate(3px)}.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:2px}.tx-date-header{justify-content:space-between;align-items:center;padding:10px 8px 5px;display:flex}.tx-date-label{color:var(--text-muted);letter-spacing:.01em;font-size:12px;font-weight:600}.tx-date-total{font-variant-numeric:tabular-nums;gap:8px;font-size:12px;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)}@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:10px}.fa2-chart-col .bar{width:8px}.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);background:var(--bg-2);border-bottom:none;border-radius:10px;padding:12px 14px}.monthly-cell.income{border-top-color:#10b981}.monthly-cell.expense{border-top-color:#ef4444}.monthly-cell.available{border-top-color:#3b82f6}.monthly-cell.savings{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-head-wrap{flex-direction:column;align-items:flex-start!important;gap:8px!important}.acc-head-wrap .acc-total{align-self:flex-end;margin-left:0!important}.acc-head-pills{flex-wrap:wrap;gap:6px;display:flex}}.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}}.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:18px;height:210px;padding:0 8px;display:grid;position:relative}.fa2-chart-bars.cols-3{grid-template-columns:repeat(3,1fr)}.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:4px;width:100%;height:180px;display:flex}.fa2-chart-col .bar{border-radius:4px 4px 0 0;width:10px;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}.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{align-items:center;gap:16px;display:flex}.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-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}.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-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-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<=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-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}.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}.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-used{color:#ef4444}.acct-detail-bar-wrap{background:#e2e8f0;border-radius:999px;width:100%;height:5px;margin-top:4px;overflow:hidden}.acct-detail-bar-fill{background:var(--accent);border-radius:999px;height:100%;transition:width .3s}.acct-detail-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:12px;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-adj-list{border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:0;margin-bottom:4px;display:flex;overflow:hidden}.acct-detail-adj-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:8px;padding:10px 14px;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-secondary);white-space:nowrap;text-overflow:ellipsis;max-width:160px;font-size:12px;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}.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}.form-input:focus,.form-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0596691a}.form-input::placeholder{color:var(--text-muted)}.form-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.5l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:12px;padding-right:34px}.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}.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}.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}.react-datepicker-wrapper,.react-datepicker__input-container{width:100%}.react-datepicker-popper{z-index:9999}.react-datepicker{border-radius:var(--radius);border:1.5px solid #e2e8f0;font-family:Outfit,sans-serif;overflow:hidden;box-shadow:0 8px 24px #0000001f}.react-datepicker__header{background:var(--accent);border-bottom:none;padding:12px 0 8px}.react-datepicker__current-month,.react-datepicker__day-name{color:#fff}.react-datepicker__current-month{margin-bottom:6px;font-size:13.5px;font-weight:600}.react-datepicker__day-name{width:32px;font-size:11.5px;font-weight:500}.react-datepicker__navigation-icon:before{border-color:#fff}.react-datepicker__navigation:hover .react-datepicker__navigation-icon:before{border-color:#ffffffb3}.react-datepicker__day{width:32px;color:var(--text-primary);border-radius:6px;font-size:12.5px;line-height:32px;transition:background .12s}.react-datepicker__day:hover{color:var(--accent);background:#0596691f}.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)}
