:root{--bg-primary: #f8f9fc;--bg-secondary: #ffffff;--bg-tertiary: #f1f3f9;--bg-card: #ffffff;--bg-input: #f1f3f9;--bg-nav: rgba(255, 255, 255, .92);--bg-overlay: rgba(0, 0, 0, .4);--bg-toast: #1e293b;--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #94a3b8;--text-inverse: #ffffff;--text-link: #6366f1;--accent: #6366f1;--accent-hover: #4f46e5;--accent-light: #e0e7ff;--accent-glow: rgba(99, 102, 241, .15);--success: #22c55e;--success-light: #dcfce7;--warning: #f59e0b;--warning-light: #fef3c7;--danger: #ef4444;--danger-light: #fee2e2;--info: #3b82f6;--info-light: #dbeafe;--border: #e2e8f0;--border-focus: #6366f1;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .06);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .08);--shadow-card: 0 2px 8px rgba(0, 0, 0, .04), 0 0 0 1px rgba(0, 0, 0, .02);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .8125rem;--font-size-base: .9375rem;--font-size-lg: 1.0625rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--nav-height: 64px;--header-height: 56px;--safe-bottom: env(safe-area-inset-bottom, 0px);--content-max-width: 480px}[data-theme=dark]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #1e293b;--bg-card: #1e293b;--bg-input: #334155;--bg-nav: rgba(15, 23, 42, .95);--bg-toast: #334155;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-tertiary: #64748b;--text-link: #818cf8;--accent: #818cf8;--accent-hover: #6366f1;--accent-light: rgba(99, 102, 241, .15);--accent-glow: rgba(129, 140, 248, .15);--success-light: rgba(34, 197, 94, .15);--warning-light: rgba(245, 158, 11, .15);--danger-light: rgba(239, 68, 68, .15);--info-light: rgba(59, 130, 246, .15);--border: #334155;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .4);--shadow-card: 0 2px 8px rgba(0, 0, 0, .2), 0 0 0 1px rgba(255, 255, 255, .03)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--text-primary);background-color:var(--bg-primary);line-height:1.5;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100dvh;display:flex;flex-direction:column}a{color:var(--text-link);text-decoration:none}img{max-width:100%;display:block}.app-layout{display:flex;flex-direction:column;min-height:100dvh}.app-header{position:sticky;top:0;z-index:100;height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-md);background:var(--bg-nav);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.app-header h1{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary)}.app-content{flex:1;padding:var(--space-md);padding-bottom:calc(var(--nav-height) + var(--safe-bottom) + var(--space-xl) + 56px);max-width:var(--content-max-width);margin:0 auto;width:100%}.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:200;height:calc(var(--nav-height) + var(--safe-bottom));padding-bottom:var(--safe-bottom);display:flex;align-items:center;justify-content:space-around;background:var(--bg-nav);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--border)}.nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);color:var(--text-tertiary);font-size:var(--font-size-xs);font-weight:500;border:none;background:none;cursor:pointer;transition:color .2s;min-width:56px;-webkit-tap-highlight-color:transparent}.nav-item.active{color:var(--accent)}.nav-item svg,.nav-item .nav-icon{font-size:1.25rem;width:24px;height:24px}.fab{position:fixed;bottom:calc(var(--nav-height) + var(--safe-bottom) + var(--space-md));right:var(--space-md);z-index:150;width:56px;height:56px;border-radius:var(--radius-full);background:var(--accent);color:#fff;border:none;font-size:1.75rem;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #6366f159;cursor:pointer;transition:transform .2s,box-shadow .2s;-webkit-tap-highlight-color:transparent}.fab:active{transform:scale(.93)}.card{background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:var(--space-md);transition:box-shadow .2s}.card-row{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-card);margin-bottom:var(--space-sm)}.summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm);margin-bottom:var(--space-md)}.summary-card{background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-xs)}.summary-card .label{font-size:var(--font-size-xs);font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.summary-card .value{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary)}.summary-card.income .value{color:var(--success)}.summary-card.expense .value{color:var(--danger)}.summary-card.balance .value{color:var(--accent)}.summary-card.alert .value{color:var(--warning)}.summary-card .summary-icon{font-size:1.5rem;margin-bottom:var(--space-xs)}.summary-card--full{grid-column:1 / -1}.tx-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-card);margin-bottom:var(--space-sm);cursor:pointer;transition:transform .15s;-webkit-tap-highlight-color:transparent}.tx-card:active{transform:scale(.98)}.tx-icon{width:42px;height:42px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.tx-details{flex:1;min-width:0}.tx-title{font-size:var(--font-size-base);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tx-category{font-size:var(--font-size-xs);color:var(--text-tertiary)}.tx-amount{font-size:var(--font-size-base);font-weight:700;text-align:right;white-space:nowrap}.tx-amount.income{color:var(--success)}.tx-amount.expense{color:var(--danger)}.tx-date{font-size:var(--font-size-xs);color:var(--text-tertiary);text-align:right}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;letter-spacing:.02em}.badge.paid{background:var(--success-light);color:var(--success)}.badge.unpaid{background:var(--warning-light);color:var(--warning)}.badge.pending{background:var(--info-light);color:var(--info)}.badge.overdue{background:var(--danger-light);color:var(--danger)}.form-group{margin-bottom:var(--space-md)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-xs)}.form-input,.form-select,.form-textarea{width:100%;padding:12px var(--space-md);font-size:var(--font-size-base);font-family:var(--font-family);color:var(--text-primary);background:var(--bg-input);border:2px solid transparent;border-radius:var(--radius-md);outline:none;transition:border-color .2s,box-shadow .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-glow)}.form-textarea{min-height:80px;resize:vertical}.form-select{padding-right:40px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}.form-error{font-size:var(--font-size-xs);color:var(--danger);margin-top:var(--space-xs)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:12px var(--space-lg);font-size:var(--font-size-base);font-weight:600;font-family:var(--font-family);border-radius:var(--radius-md);border:none;cursor:pointer;transition:background .2s,transform .15s,box-shadow .2s;-webkit-tap-highlight-color:transparent;min-height:48px}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 2px 8px #6366f140}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary)}.btn-danger{background:var(--danger);color:#fff}.btn-ghost{background:transparent;color:var(--text-secondary);padding:var(--space-sm) var(--space-md);min-height:40px}.btn-block{width:100%}.btn-sm{padding:8px var(--space-md);font-size:var(--font-size-sm);min-height:36px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.section-title{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary)}.section-action{font-size:var(--font-size-sm);font-weight:600;color:var(--accent);background:none;border:none;cursor:pointer;padding:var(--space-xs) var(--space-sm)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl) var(--space-md);text-align:center}.empty-state .empty-icon{font-size:3rem;margin-bottom:var(--space-md)}.empty-state .empty-text{font-size:var(--font-size-base);color:var(--text-tertiary)}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:var(--space-2xl)}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top:3px solid var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast-container{position:fixed;top:var(--space-md);left:var(--space-md);right:var(--space-md);z-index:1000;display:flex;flex-direction:column;gap:var(--space-sm);pointer-events:none}.toast{padding:var(--space-md);background:var(--bg-toast);color:var(--text-inverse);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);font-size:var(--font-size-sm);font-weight:500;animation:slideDown .3s ease-out;pointer-events:auto}.toast.success{border-left:4px solid var(--success)}.toast.error{border-left:4px solid var(--danger)}.toast.info{border-left:4px solid var(--info)}@keyframes slideDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:var(--bg-overlay);display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s}.modal-content{background:var(--bg-secondary);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:var(--space-lg);padding-bottom:calc(var(--space-lg) + var(--safe-bottom));width:100%;max-width:var(--content-max-width);max-height:80dvh;overflow-y:auto;animation:slideUp .3s ease-out}.modal-handle{width:40px;height:4px;background:var(--border);border-radius:var(--radius-full);margin:0 auto var(--space-md)}.modal-title{font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--space-md)}.modal-actions{display:flex;gap:var(--space-sm);margin-top:var(--space-lg)}.modal-actions .btn{flex:1}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.login-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;padding:var(--space-lg);background:var(--bg-primary)}.login-card{width:100%;max-width:360px}.login-logo{font-size:3rem;text-align:center;margin-bottom:var(--space-sm)}.login-title{font-size:var(--font-size-2xl);font-weight:700;text-align:center;color:var(--text-primary);margin-bottom:var(--space-xs)}.login-subtitle{font-size:var(--font-size-sm);text-align:center;color:var(--text-tertiary);margin-bottom:var(--space-xl)}.filter-bar{display:flex;gap:var(--space-sm);margin-bottom:var(--space-md);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:var(--space-xs)}.filter-bar::-webkit-scrollbar{display:none}.filter-chip{display:inline-flex;align-items:center;padding:8px 14px;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:500;white-space:nowrap;border:1.5px solid var(--border);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}.filter-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}.search-input{flex:1;min-width:120px}.chart-wrapper{background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:var(--space-md);margin-bottom:var(--space-md)}.chart-title{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-md)}.setting-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-card);margin-bottom:var(--space-sm)}.setting-label{font-size:var(--font-size-base);font-weight:500;color:var(--text-primary)}.setting-desc{font-size:var(--font-size-xs);color:var(--text-tertiary)}.toggle{position:relative;width:52px;height:30px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--border);border-radius:var(--radius-full);cursor:pointer;transition:background .3s}.toggle-slider:before{content:"";position:absolute;width:24px;height:24px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform .3s;box-shadow:0 1px 3px #00000026}.toggle input:checked+.toggle-slider{background:var(--accent)}.toggle input:checked+.toggle-slider:before{transform:translate(22px)}.page-enter{animation:pageIn .25s ease-out}@keyframes pageIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(min-width:640px){:root{--content-max-width: 540px}.summary-grid{grid-template-columns:repeat(3,1fr)}.modal-content{border-radius:var(--radius-xl);margin-bottom:var(--space-lg)}}@media(min-width:768px){:root{--content-max-width: 640px}}.text-center{text-align:center}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.gap-sm{gap:var(--space-sm)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.w-full{width:100%}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
