html,body{margin:0;padding:0}#root{width:100%;margin:0 auto}.spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}:root{--color-primary: #FD5E4B;--color-primary-light: #FD8391;--color-primary-bg: #FFF5F2;--color-primary-bg-2: #FFEBE5;--color-primary-border: #FFD9CC;--color-primary-text: #8A4F3F;--color-bg: #FAF8F5;--color-surface: #FFFFFF;--color-surface-2: #F4EFE6;--color-border: #EDE8DF;--color-divider: #F4EFE6;--color-text: #1F1B16;--color-text-secondary: #5F5A52;--color-text-muted: #8A8478;--color-success: #4A7C59;--color-success-bg: rgba(74, 124, 89, .12);--color-danger: #C95B47;--color-danger-bg: rgba(201, 91, 71, .1);--color-warning: #B88649;--cat-1: #4A7C59;--cat-2: #B88649;--cat-3: #FD5E4B;--cat-4: #7A6D9A;--cat-5: #C99940;--cat-6: #5C7A91;--cat-7: #D45F75;--cat-8: #8A8478;--color-sun: #FFD58A;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-pill: 999px;--shadow-sm: 0 1px 2px rgba(31, 27, 22, .04);--shadow-md: 0 4px 12px rgba(31, 27, 22, .06);--shadow-lg: 0 8px 24px rgba(31, 27, 22, .08)}[data-theme=dark]{--color-primary: #FD5E4B;--color-primary-light: #FD8391;--color-primary-bg: rgba(253, 94, 75, .15);--color-primary-bg-2: rgba(253, 94, 75, .18);--color-primary-border: rgba(253, 94, 75, .35);--color-primary-text: #FFB89E;--color-bg: #14110E;--color-surface: #1E1A15;--color-surface-2: #2A2520;--color-border: #2A2520;--color-divider: #2A2520;--color-text: #F5EFE2;--color-text-secondary: #A89F8E;--color-text-muted: #8A8478;--color-success: #7EB28A;--color-success-bg: rgba(126, 178, 138, .15);--color-danger: #E27867;--color-danger-bg: rgba(226, 120, 103, .15);--color-warning: #D4A96E;--cat-1: #7EB28A;--cat-2: #D4A96E;--cat-3: #FD8391;--cat-4: #A898C4;--cat-5: #E8C078;--cat-6: #8FA6B8;--cat-7: #E88A9D;--cat-8: #A89F8E;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5)}*{margin:0;padding:0;box-sizing:border-box}html,body{font-family:-apple-system,system-ui,Segoe UI,Helvetica Neue,sans-serif;background:var(--color-bg);color:var(--color-text);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button,input,select{font-family:inherit}.app{min-height:100vh;display:flex;flex-direction:column}.amount,.stat-value,.balance-value,.budget-amount,.expense-card-amount,.detail-item-total,.detail-group-total,.detail-summary-total,.detail-total-badge,.dash-stat-value,.dash-budget-form input,input[type=number]{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.app-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:50}.header-left,.header-right{display:flex;align-items:center;gap:8px}.brand{display:inline-flex;align-items:center;gap:10px}.brand-mark{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;letter-spacing:0;flex-shrink:0}.brand-text{display:flex;flex-direction:column;line-height:1.15}.brand-name{font-size:16px;font-weight:600;color:var(--color-text)}.brand-sub{font-size:11px;color:var(--color-text-muted);font-weight:400}.user-pill{display:inline-flex;align-items:center;gap:8px;padding:4px 12px 4px 4px;border-radius:var(--radius-pill);background:var(--color-primary-bg);color:var(--color-primary-text);font-size:13px;font-weight:500}.user-pill-name{line-height:22px}.icon-btn{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.icon-btn:hover{background:var(--color-surface-2);color:var(--color-text)}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;color:#fff;font-weight:600;flex-shrink:0;line-height:1}.cat-icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.app-nav{display:flex;gap:4px;padding:8px 16px;background:var(--color-bg);border-bottom:1px solid var(--color-border);overflow-x:auto}.nav-tab{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:none;background:transparent;font-size:13px;font-weight:500;color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-pill);transition:background .15s,color .15s;white-space:nowrap}.nav-tab:hover:not(.active){background:var(--color-surface-2);color:var(--color-text)}.nav-tab.active{background:var(--color-text);color:var(--color-bg)}.app-main{max-width:980px;width:100%;margin:0 auto;padding:20px;display:flex;flex-direction:column;gap:16px;flex:1}.toolbar{display:flex;gap:8px;flex-wrap:wrap}.filter-input-wrap{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color .15s;min-width:0;flex:0 1 auto}.filter-input-wrap:focus-within{border-color:var(--color-primary)}.filter-input-wrap.filter-search{flex:1 1 200px}.filter-icon{color:var(--color-text-muted);flex-shrink:0}.filter-input-wrap .filter-input{border:none;background:transparent;padding:0;font-size:13px;color:var(--color-text);outline:none;min-width:0;flex:1}.filter-input-wrap select.filter-input{-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='none' stroke='%238A8478' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' d='M1 1l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 4px center;padding-right:18px;cursor:pointer}.card,.expense-form,.dash-stat,.dash-budget,.dash-chart-card,.detail-summary,.detail-group,.auth-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.expense-form{padding:20px}.form-title{font-size:14px;font-weight:600;color:var(--color-text);margin-bottom:14px;display:inline-flex;align-items:center;gap:8px}.form-edit-banner{display:flex;align-items:center;justify-content:space-between;background:var(--color-primary-bg);color:var(--color-primary-text);font-weight:500;font-size:13px;padding:8px 12px;border-radius:var(--radius-md);margin-bottom:12px;border:1px solid var(--color-primary-border)}.form-edit-banner span{display:inline-flex;align-items:center;gap:6px}.btn-cancel-inline{background:transparent;border:none;color:var(--color-primary);font-weight:600;font-size:12px;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);display:inline-flex;align-items:center;gap:4px}.btn-cancel-inline:hover{background:var(--color-primary-bg-2)}.form-grid{display:grid;grid-template-columns:1fr 140px;gap:10px}.form-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.form-field{display:flex;flex-direction:column;gap:4px;min-width:0}.form-field-full{grid-column:1 / -1}.form-input{width:100%;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:13px;background:var(--color-bg);color:var(--color-text);transition:border-color .15s,box-shadow .15s;min-width:0}.form-input::placeholder{color:var(--color-text-muted)}.form-input:focus{outline:none;border-color:var(--color-primary);background:var(--color-surface);box-shadow:0 0 0 3px var(--color-primary-bg-2)}select.form-input{-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='none' stroke='%238A8478' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' d='M1 1l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:28px}.input-with-suffix{position:relative;display:flex;align-items:center}.input-with-suffix .form-input{padding-right:32px}.input-suffix{position:absolute;right:12px;font-size:12px;font-weight:500;color:var(--color-text-muted);pointer-events:none}.has-error .form-input{border-color:var(--color-danger)}.form-error-msg{font-size:12px;font-weight:500;color:var(--color-danger);display:inline-flex;align-items:center;gap:4px}.form-shake{animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-5px)}40%{transform:translate(5px)}60%{transform:translate(-3px)}80%{transform:translate(3px)}}.btn-primary{width:100%;padding:11px 16px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:background .15s,transform .05s}.btn-primary:hover{background:#e54e3c}.btn-primary:active{transform:translateY(1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-ghost{background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary);padding:8px 12px;border-radius:var(--radius-md);font-size:13px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:background .15s,color .15s}.btn-ghost:hover{background:var(--color-surface-2);color:var(--color-text)}.expense-cards{display:flex;flex-direction:column;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.expense-row{display:flex;align-items:center;gap:14px;padding:14px 18px;border-bottom:1px solid var(--color-divider);transition:background .15s}.expense-row:last-child{border-bottom:none}.expense-row:hover{background:var(--color-surface-2)}.expense-row-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.expense-row-title{font-size:14px;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.expense-row-meta{font-size:12px;color:var(--color-text-muted);display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap}.meta-sep{opacity:.5}.meta-member{display:inline-flex;align-items:center;gap:4px}.expense-row-amount{font-size:14px;font-weight:600;color:var(--color-text);white-space:nowrap}.expense-row-amount.is-revenue{color:var(--color-success)}.row-actions{display:inline-flex;align-items:center;gap:2px}.btn-action{width:28px;height:28px;border:none;background:transparent;border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text-muted);display:inline-flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.btn-action:hover{background:var(--color-surface-2);color:var(--color-text)}.btn-action-delete:hover{background:var(--color-danger-bg);color:var(--color-danger)}.tab-content{display:flex;flex-direction:column;gap:16px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.empty-state{text-align:center;padding:48px 16px;color:var(--color-text-muted);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.empty-icon{display:flex;justify-content:center;margin-bottom:12px;color:var(--color-text-muted)}.empty-state-title{font-size:14px;font-weight:500;color:var(--color-text);margin-bottom:4px}.empty-state-hint{font-size:12px;color:var(--color-text-muted)}.dashboard{display:flex;flex-direction:column;gap:16px}.dash-welcome{position:relative;display:flex;align-items:center;gap:22px;padding:28px;background:linear-gradient(135deg,var(--color-primary-bg),var(--color-primary-bg-2));border:1px solid var(--color-primary-border);border-radius:16px;overflow:hidden}.dash-welcome-decor{position:absolute;border-radius:50%;pointer-events:none}.dash-welcome-decor.decor-1{width:140px;height:140px;top:-40px;right:-30px;background:radial-gradient(circle,rgba(253,94,75,.12),transparent 70%)}.dash-welcome-decor.decor-2{width:100px;height:100px;bottom:-30px;left:40%;background:radial-gradient(circle,rgba(253,131,145,.1),transparent 70%)}.dash-welcome-icon{position:relative;width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 6px 16px #fd5e4b40}.dash-welcome-content{position:relative;flex:1;min-width:0}.dash-welcome-label{display:block;font-size:11px;font-weight:600;color:#c95b47;text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px}[data-theme=dark] .dash-welcome-label{color:var(--color-primary-text)}.dash-welcome-title{font-size:22px;font-weight:600;color:var(--color-text);margin:0 0 8px;letter-spacing:-.2px}.dash-welcome-text{font-size:14px;color:var(--color-text-secondary);line-height:1.5;margin:0;max-width:460px}.dash-welcome-cta{position:relative;display:inline-flex;align-items:center;gap:8px;padding:12px 18px;background:var(--color-text);color:var(--color-bg);border:none;border-radius:10px;font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;flex-shrink:0;transition:transform .1s,opacity .15s}.dash-welcome-cta:hover{opacity:.9}.dash-welcome-cta:active{transform:translateY(1px)}.dash-stat.is-zero .dash-stat-value{color:#c8c2b5}[data-theme=dark] .dash-stat.is-zero .dash-stat-value{color:var(--color-text-muted)}.dash-stat-icon-zero{background:var(--color-surface-2);color:var(--color-text-muted)}.dash-onboarding{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:24px;box-shadow:var(--shadow-sm)}.dash-onboarding-title{font-size:14px;font-weight:600;color:var(--color-text);margin:0 0 16px}.dash-onboarding-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.dash-step{display:flex;flex-direction:column;gap:8px;padding:16px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:10px;text-align:left;cursor:pointer;font-family:inherit;color:var(--color-text);transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.dash-step:hover{transform:translateY(-2px);border-color:var(--color-primary-border);box-shadow:var(--shadow-md)}.dash-step-head{display:flex;align-items:center;gap:10px}.dash-step-num{width:24px;height:24px;border-radius:50%;background:var(--color-primary);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.dash-step-title{font-size:13px;font-weight:600;color:var(--color-text);margin:0}.dash-step-desc{font-size:12px;color:var(--color-text-muted);line-height:1.4;margin:0}.dash-step-featured{background:linear-gradient(135deg,var(--color-primary-bg),var(--color-primary-bg-2));border-color:var(--color-primary-border)}.dash-step-featured .dash-step-desc{color:var(--color-primary-text)}.dash-step-featured:hover{border-color:var(--color-primary)}@media (max-width: 768px){.dash-onboarding-grid{grid-template-columns:1fr}.dash-welcome{flex-direction:column;align-items:stretch;text-align:center;gap:16px}.dash-welcome-icon{margin:0 auto}.dash-welcome-text{max-width:none}.dash-welcome-cta{width:100%;justify-content:center}}.dash-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.dash-stat{padding:16px 18px;display:flex;align-items:center;gap:14px}.dash-stat-balance{background:linear-gradient(135deg,var(--color-primary-bg),var(--color-primary-bg-2));border-color:var(--color-primary-border)}.dash-stat-icon-wrap{width:40px;height:40px;border-radius:var(--radius-md);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.dash-stat-icon-success{background:var(--color-success-bg);color:var(--color-success)}.dash-stat-icon-expense{background:#fd839126;color:var(--color-primary-light)}.dash-stat-icon-balance{background:#fd5e4b26;color:var(--color-primary)}.dash-stat-icon-danger{background:var(--color-danger-bg);color:var(--color-danger)}.dash-stat-label{font-size:11px;font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.dash-stat-value{font-size:22px;font-weight:600;color:var(--color-text);line-height:1.1}.dash-stat-currency{font-weight:400;color:var(--color-text-muted);margin-left:2px}.dash-budget{padding:18px 20px}.dash-budget-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.dash-budget-title{font-size:14px;font-weight:600;color:var(--color-text);display:inline-flex;align-items:center;gap:8px}.dash-budget-edit{background:transparent;border:none;color:var(--color-primary);font-size:13px;font-weight:500;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm)}.dash-budget-edit:hover{background:var(--color-primary-bg)}.dash-budget-form{display:inline-flex;gap:6px;align-items:center}.dash-budget-form input{width:110px;padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:13px;background:var(--color-bg);color:var(--color-text)}.dash-budget-save{background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);padding:6px 12px;font-size:12px;font-weight:600;cursor:pointer}.dash-budget-cancel{background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;padding:4px;display:inline-flex;align-items:center}.dash-gauge-track{height:6px;background:var(--color-surface-2);border-radius:999px;overflow:hidden}.dash-gauge-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-primary-light));border-radius:999px;transition:width .6s ease}.dash-gauge-fill.over{background:var(--color-danger)}.dash-gauge-info{display:flex;justify-content:space-between;font-size:12px;color:var(--color-text-secondary);margin-top:8px}.dash-gauge-info .remain{color:var(--color-success);font-weight:500}.dash-gauge-info .remain.over{color:var(--color-danger)}.dash-charts{display:grid;grid-template-columns:1fr 1fr;gap:12px}.dash-chart-card{padding:18px 20px}.dash-chart-title{font-size:14px;font-weight:600;color:var(--color-text);margin-bottom:14px}.dash-pie-wrap{display:flex;align-items:center;gap:14px}.dash-pie{width:130px;height:130px;flex-shrink:0}.dash-pie-legend{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}.dash-legend-item{display:flex;align-items:center;gap:8px;font-size:12px}.dash-legend-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}.dash-legend-name{flex:1;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-legend-val{font-weight:600;color:var(--color-text);font-variant-numeric:tabular-nums}.dash-empty{text-align:center;color:var(--color-text-muted);font-size:13px;padding:24px}.dash-trend{display:flex;gap:4px;height:130px;align-items:flex-end}.dash-trend-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%}.dash-trend-bars{flex:1;display:flex;gap:2px;align-items:flex-end;width:100%}.dash-trend-bar{flex:1;border-radius:3px 3px 0 0;min-height:2px;transition:height .5s ease}.dash-trend-rev{background:var(--color-success);opacity:.85}.dash-trend-exp{background:var(--color-primary-light)}.dash-trend-label{font-size:10px;color:var(--color-text-muted)}.dash-trend-legend{display:flex;gap:16px;justify-content:center;font-size:12px;color:var(--color-text-secondary);margin-top:10px}.dash-trend-legend span{display:inline-flex;align-items:center;gap:6px}.detail-intro{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:var(--color-primary-bg);border:1px solid var(--color-primary-border);border-radius:var(--radius-lg)}.detail-intro-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--color-surface);color:var(--color-primary);flex-shrink:0}.detail-intro-text{flex:1;min-width:0;font-size:12.5px;line-height:1.5;color:var(--color-primary-text)}.detail-intro-text strong{display:block;font-size:13px;font-weight:600;color:var(--color-text);margin-bottom:2px}.detail-intro-text p{margin:0}.detail-intro-text em{font-style:normal;font-weight:600;color:var(--color-primary)}.detail-form-grid{display:grid;grid-template-columns:2fr 70px 1fr;gap:10px}.detail-form-row2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}.detail-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:4px 2px}.detail-pills{display:flex;gap:6px;flex-wrap:wrap}.detail-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--color-border);background:var(--color-surface);border-radius:var(--radius-pill);font-size:12px;font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.detail-pill:hover{background:var(--color-surface-2)}.detail-pill.active{background:var(--color-text);color:var(--color-bg);border-color:var(--color-text)}.detail-pill-dot{width:8px;height:8px;border-radius:50%;background:var(--color-text-muted)}.detail-total{font-size:13px;color:var(--color-text-secondary);white-space:nowrap}.detail-total strong{color:var(--color-text);font-weight:600;font-variant-numeric:tabular-nums;margin-left:4px}.detail-summary{padding:14px 16px;display:flex;flex-wrap:wrap;gap:10px}.detail-summary-item{display:inline-flex;align-items:center;gap:8px;background:var(--color-surface-2);padding:6px 12px;border-radius:var(--radius-md);font-size:12px}.detail-summary-name{font-weight:500;color:var(--color-text)}.detail-summary-count{color:var(--color-text-muted)}.detail-summary-total{font-weight:600;color:var(--color-text);font-variant-numeric:tabular-nums}.detail-group{overflow:hidden}.detail-group-header{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:var(--color-surface-2);font-size:13px;font-weight:500;color:var(--color-text-secondary)}.detail-group-date{display:inline-flex;align-items:center;gap:6px}.detail-group-total{color:var(--color-text);font-weight:600;font-variant-numeric:tabular-nums}.detail-items{display:flex;flex-direction:column}.detail-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid var(--color-divider);transition:background .15s}.detail-item:hover{background:var(--color-surface-2)}.detail-item-info{display:inline-flex;align-items:center;gap:10px;flex:1;min-width:0}.detail-item-name{font-size:13px;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.detail-item-tag{font-size:11px;color:var(--color-text-muted);padding:2px 8px;background:var(--color-surface-2);border-radius:var(--radius-sm);white-space:nowrap}.detail-item:hover .detail-item-tag{background:var(--color-surface)}.detail-item-right{display:inline-flex;align-items:center;gap:14px;flex-shrink:0}.detail-item-qty{font-size:12px;color:var(--color-text-muted);font-variant-numeric:tabular-nums}.detail-item-total{font-size:13px;font-weight:600;color:var(--color-text);min-width:70px;text-align:right;font-variant-numeric:tabular-nums}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s}.modal-box{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px;text-align:center;max-width:360px;width:90%;box-shadow:var(--shadow-lg)}.modal-icon{display:flex;justify-content:center;margin-bottom:12px;color:var(--color-danger)}.modal-msg{font-size:14px;font-weight:500;color:var(--color-text);margin-bottom:20px}.modal-actions{display:flex;gap:8px;justify-content:center}.modal-btn{padding:10px 18px;border:none;border-radius:var(--radius-md);font-weight:500;font-size:13px;cursor:pointer;transition:background .15s,color .15s}.modal-btn-cancel{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border)}.modal-btn-cancel:hover{background:var(--color-surface-2);color:var(--color-text)}.modal-btn-confirm{background:var(--color-danger);color:#fff}.modal-btn-confirm:hover{background:#b04e3d}.settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;justify-content:flex-end;animation:fadeIn .15s}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.settings-panel{width:400px;max-width:92vw;background:var(--color-surface);height:100%;display:flex;flex-direction:column;animation:slideIn .25s cubic-bezier(.16,1,.3,1);box-shadow:var(--shadow-lg)}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--color-border)}.settings-header h2{font-size:16px;font-weight:600;color:var(--color-text)}.settings-close{width:32px;height:32px;border:1px solid var(--color-border);background:transparent;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary)}.settings-close:hover{background:var(--color-surface-2);color:var(--color-text)}.settings-tabs{display:flex;border-bottom:1px solid var(--color-border)}.settings-tab{flex:1;padding:12px;border:none;background:transparent;font-size:13px;font-weight:500;color:var(--color-text-secondary);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:color .15s,border-color .15s}.settings-tab.active{color:var(--color-text);border-bottom-color:var(--color-primary)}.settings-body{flex:1;overflow-y:auto;padding:20px}.settings-section{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.settings-label{font-size:11px;font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.settings-add-form{display:flex;flex-direction:column;gap:10px;padding-bottom:18px;margin-bottom:18px;border-bottom:1px solid var(--color-border)}.picker-row{display:flex;gap:8px;flex-wrap:wrap}.color-dot{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .15s,border-color .15s;padding:0}.color-dot:hover{transform:scale(1.1)}.color-dot.selected{border-color:var(--color-text)}.icon-pick{width:36px;height:36px;border:1px solid var(--color-border);background:var(--color-surface);border-radius:var(--radius-md);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:var(--color-text-secondary);transition:all .15s}.icon-pick:hover{background:var(--color-surface-2);color:var(--color-text)}.icon-pick.selected{background:var(--color-primary-bg);border-color:var(--color-primary);color:var(--color-primary)}.settings-list{display:flex;flex-direction:column;gap:4px}.settings-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-radius:var(--radius-md);transition:background .15s}.settings-item:hover{background:var(--color-surface-2)}.settings-item-main{display:inline-flex;align-items:center;gap:10px;min-width:0;flex:1}.settings-item-name{font-size:13px;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.settings-item-actions{display:inline-flex;gap:2px}.settings-empty{text-align:center;color:var(--color-text-muted);font-size:13px;padding:24px}.settings-hint{font-size:12px;color:var(--color-text-muted);line-height:1.5;margin:-2px 0 4px}.select{position:relative}.select-trigger{display:flex;align-items:center;gap:12px;width:100%;padding:8px 10px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;font-family:inherit;color:var(--color-text);text-align:left;transition:border-color .15s,box-shadow .15s,background .15s}.select-trigger:hover{background:var(--color-surface-2)}.select.is-open .select-trigger,.select-trigger:focus-visible{outline:none;border-color:var(--color-primary);background:var(--color-surface);box-shadow:0 0 0 3px var(--color-primary-bg-2)}.select-symbol{width:32px;height:32px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:var(--color-surface-2);color:var(--color-text);font-size:13px;font-weight:600;font-variant-numeric:tabular-nums}.select-main{display:flex;flex-direction:column;flex:1;min-width:0;line-height:1.25}.select-name{font-size:13px;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.select-code{font-size:11px;color:var(--color-text-muted);letter-spacing:.5px}.select-chev{color:var(--color-text-muted);flex-shrink:0;transition:transform .2s}.select.is-open .select-chev{transform:rotate(180deg);color:var(--color-primary)}.select-menu{position:absolute;top:calc(100% + 6px);left:0;right:0;margin:0;padding:6px;list-style:none;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:110;max-height:280px;overflow-y:auto;animation:selectMenuIn .12s ease-out}@keyframes selectMenuIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.select-option{display:flex;align-items:center;gap:12px;width:100%;padding:8px 10px;background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;color:var(--color-text);text-align:left;transition:background .1s}.select-option:hover{background:var(--color-surface-2)}.select-option.active{background:var(--color-primary-bg)}.select-option.active .select-symbol{background:var(--color-primary);color:#fff}.select-option.active .select-name{color:var(--color-primary-text)}.select-check{color:var(--color-primary);flex-shrink:0}.theme-toggle{display:grid;grid-template-columns:1fr 1fr;gap:8px}.theme-option{position:relative;display:inline-flex;align-items:center;gap:10px;padding:12px 14px;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;font-family:inherit;font-size:13px;font-weight:500;color:var(--color-text);transition:background .15s,border-color .15s}.theme-option:hover{background:var(--color-surface-2)}.theme-option.active{background:var(--color-primary-bg);border-color:var(--color-primary);color:var(--color-primary-text)}.theme-option-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);background:var(--color-surface-2);color:var(--color-text-secondary)}.theme-option.active .theme-option-icon{background:var(--color-primary);color:#fff}.theme-option-label{flex:1;text-align:left}.theme-option-check{color:var(--color-primary);flex-shrink:0}.auth-screen{position:relative;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 16px;background:var(--color-bg);overflow:hidden}.auth-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(circle at 18% 22%,color-mix(in srgb,var(--color-primary) 18%,transparent),transparent 45%),radial-gradient(circle at 82% 78%,color-mix(in srgb,var(--color-primary-light) 14%,transparent),transparent 50%)}[data-theme=dark] .auth-bg{background:radial-gradient(circle at 18% 22%,color-mix(in srgb,var(--color-primary) 22%,transparent),transparent 45%),radial-gradient(circle at 82% 78%,color-mix(in srgb,var(--color-primary-light) 12%,transparent),transparent 50%)}.auth-card{position:relative;padding:32px 28px 28px;width:100%;max-width:400px;text-align:left;box-shadow:var(--shadow-lg);border-radius:16px;z-index:1}.auth-head{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--color-divider)}.auth-slogan{font-size:13px;font-style:italic;color:var(--color-primary);letter-spacing:.2px;margin:0;text-align:center}.auth-title-block{text-align:center;margin-bottom:22px}.auth-title{font-size:20px;font-weight:600;color:var(--color-text);margin:0 0 6px;letter-spacing:-.2px}.auth-subtitle{font-size:13px;color:var(--color-text-muted);line-height:1.5;margin:0}.auth-form{display:flex;flex-direction:column;gap:10px}.auth-field{position:relative;display:flex;align-items:center;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color .15s,box-shadow .15s,background .15s}.auth-field:focus-within{border-color:var(--color-primary);background:var(--color-surface);box-shadow:0 0 0 3px var(--color-primary-bg-2)}.auth-field-icon{display:inline-flex;align-items:center;justify-content:center;padding:0 12px;color:var(--color-text-muted);flex-shrink:0}.auth-field:focus-within .auth-field-icon{color:var(--color-primary)}.auth-field input{flex:1;min-width:0;padding:11px 12px 11px 0;border:none;background:transparent;font-size:14px;font-family:inherit;color:var(--color-text);outline:none}.auth-field input::placeholder{color:var(--color-text-muted)}.auth-field input:-webkit-autofill,.auth-field input:-webkit-autofill:hover,.auth-field input:-webkit-autofill:focus{-webkit-text-fill-color:var(--color-text);-webkit-box-shadow:0 0 0 1000px var(--color-bg) inset;caret-color:var(--color-text)}.auth-error{background:var(--color-danger-bg);color:var(--color-danger);font-size:13px;font-weight:500;padding:10px 12px;border-radius:var(--radius-md);text-align:left}.auth-submit{margin-top:4px;padding:12px 16px}.auth-switch{margin:18px 0 0;text-align:center;font-size:13px;color:var(--color-text-secondary)}.auth-switch button{background:none;border:none;color:var(--color-primary);font-weight:600;font-size:13px;cursor:pointer;font-family:inherit;padding:0;margin-left:4px}.auth-switch button:hover{text-decoration:underline}.auth-foot{position:relative;margin-top:20px;font-size:11px;color:var(--color-text-muted);letter-spacing:.3px}.loading-bar{height:2px;background:var(--color-surface-2);border-radius:2px;overflow:hidden}.loading-bar-fill{height:100%;width:40%;background:linear-gradient(90deg,var(--color-primary-light),var(--color-primary));border-radius:2px;animation:loadingSlide 1.2s ease-in-out infinite}@keyframes loadingSlide{0%{transform:translate(-100%)}to{transform:translate(350%)}}.toast-container{position:fixed;bottom:20px;right:20px;z-index:300;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{display:inline-flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius-md);font-size:13px;font-weight:500;background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);box-shadow:var(--shadow-md);pointer-events:auto;animation:toastIn .25s cubic-bezier(.16,1,.3,1);min-width:240px}.toast-exit{animation:toastOut .3s ease forwards}.toast-success .toast-icon-wrap{color:var(--color-success)}.toast-error .toast-icon-wrap{color:var(--color-danger)}.toast-info .toast-icon-wrap{color:var(--color-primary)}.toast-icon-wrap{display:inline-flex;align-items:center;flex-shrink:0}.toast-msg{flex:1}@keyframes toastIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes toastOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(20px)}}@media (max-width: 768px){.dash-stats,.dash-charts{grid-template-columns:1fr}.dash-pie-wrap{flex-direction:column;align-items:center}.form-row{grid-template-columns:1fr}}@media (max-width: 600px){.app-header{padding:10px 14px}.brand-sub,.user-pill-name{display:none}.user-pill{padding:4px}.app-nav{padding:6px 10px}.nav-tab{font-size:12px;padding:6px 10px}.nav-tab span{display:none}.app-main{padding:14px;gap:12px}.toolbar{flex-direction:column;align-items:stretch}.filter-input-wrap,.filter-input-wrap.filter-search{width:100%;flex:0 0 auto}.form-grid{grid-template-columns:1fr}.detail-form-grid{grid-template-columns:1fr 70px}.detail-item-qty{display:none}.expense-row{padding:12px 14px}.settings-panel{width:100%;max-width:100%}.toast-container{bottom:14px;right:14px;left:14px}.toast{min-width:0;width:100%}}@media (max-width: 480px){.nav-tab span{display:none}.detail-toolbar{flex-direction:column;align-items:stretch}}@media (max-width: 768px){.form-input,.filter-input,.filter-input-wrap .filter-input,.auth-field input,.dash-budget-form input,.settings-add-form input,.select-trigger,input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],input[type=month],input[type=search],select,textarea{font-size:16px}}
