@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Noto+Sans+TC:wght@300;400;500;700&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--color-stone-50:#f8fafc;--color-stone-100:#f1f5f9;--color-stone-150:#e2e8f0;--color-stone-200:#cbd5e1;--color-stone-300:#94a3b8;--color-stone-400:#64748b;--color-stone-500:#475569;--color-stone-600:#334155;--color-stone-700:#1e293b;--color-stone-800:#0f172a;--color-stone-900:#020617;--color-income:#0d9488;--color-expense:#e11d48;--color-asset:#0284c7;--color-liability:#475569;--color-warning:#d97706;--color-danger:#f43f5e;--color-safe:#059669;--color-income-light:#0d948814;--color-expense-light:#e11d4814;--color-asset-light:#0284c714;--color-liability-light:#47556914;--color-warning-light:#d9770614;--color-danger-light:#f43f5e14;--color-safe-light:#05966914;--glass-bg:#f8fafc40;--glass-bg-strong:#fff6;--glass-bg-subtle:#f1f5f926;--glass-blur:40px;--glass-blur-strong:48px;--glass-border:#ffffff40;--glass-border-strong:#ffffff59;--glass-shadow:0 12px 40px #0f172a14;--glass-shadow-elevated:0 24px 64px #0f172a29;--glass-shadow-subtle:0 6px 20px #0f172a0a;--glass-inner-shadow:inset 0 1px 1px #ffffff4d;--glass-saturate:180%;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--radius-xs:6px;--radius-sm:10px;--radius-md:16px;--radius-lg:24px;--radius-xl:32px;--radius-full:9999px;--focus-scale:1.02;--font-sans:-apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Icons", "Helvetica Neue", "Noto Sans TC", sans-serif;--font-mono:"SF Mono", "JetBrains Mono", Menlo, monospace;--text-xs:.6875rem;--text-sm:.8125rem;--text-md:.875rem;--text-base:.9375rem;--text-lg:1.0625rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--leading-tight:1.25;--leading-normal:1.5;--leading-relaxed:1.625;--tracking-tight:-.02em;--tracking-normal:0;--tracking-wide:.025em;--transition-fast:.15s ease-out;--transition-base:.25s ease-out;--transition-slow:.4s ease-out;--transition-spring:.5s cubic-bezier(.34, 1.56, .64, 1);--z-base:0;--z-elevated:10;--z-dropdown:100;--z-sticky:200;--z-modal:300;--z-toast:400;--z-max:999;--safe-area-top:env(safe-area-inset-top,0px);--safe-area-bottom:env(safe-area-inset-bottom,0px);--safe-area-left:env(safe-area-inset-left,0px);--safe-area-right:env(safe-area-inset-right,0px);--tab-bar-height:64px;--header-height:56px;--max-content-width:430px;--focus-ring:0 0 0 3px #0284c759;--focus-ring-accent:0 0 0 3px #0d948859}html[data-theme=dark]{--color-stone-50:#020617;--color-stone-100:#0f172a;--color-stone-150:#1e293b;--color-stone-200:#334155;--color-stone-300:#475569;--color-stone-400:#64748b;--color-stone-500:#94a3b8;--color-stone-600:#cbd5e1;--color-stone-700:#e2e8f0;--color-stone-800:#f1f5f9;--color-stone-900:#f8fafc;--color-income:#2dd4bf;--color-expense:#fda4af;--color-asset:#38bdf8;--color-liability:#94a3b8;--color-warning:#fbbf24;--color-danger:#f43f5e;--color-safe:#34d399;--color-income-light:#2dd4bf1f;--color-expense-light:#fda4af1f;--color-asset-light:#38bdf81f;--color-liability-light:#94a3b81f;--color-warning-light:#fbbf241f;--color-danger-light:#f43f5e1f;--color-safe-light:#34d3991f;--glass-bg:#0f172a73;--glass-bg-strong:#080c1899;--glass-bg-subtle:#0f172a4d;--glass-border:#ffffff26;--glass-border-strong:#ffffff40;--glass-shadow:0 16px 48px #0006;--glass-shadow-elevated:0 32px 80px #0009;--glass-shadow-subtle:0 8px 24px #00000040;--glass-inner-shadow:inset 0 1px 1px #fff3;--focus-ring:0 0 0 3px #38bdf859}html[data-theme=dark] body{background-image:radial-gradient(at 20% 0,#38bdf814 0%,#0000 50%),radial-gradient(at 80% 100%,#2dd4bf0f 0%,#0000 50%),radial-gradient(#fda4af0a 0%,#0000 60%)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;scroll-behavior:smooth;height:100%}body{height:100%;min-height:100%;font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-stone-800);background-color:var(--color-stone-100);-webkit-tap-highlight-color:transparent;background-image:radial-gradient(at 20% 0,#6b8cae0f 0%,#0000 50%),radial-gradient(at 80% 100%,#5b8a720d 0%,#0000 50%),radial-gradient(#c2785c08 0%,#0000 60%);background-attachment:fixed;overflow-x:hidden}#root{isolation:isolate;height:100%}.app{width:100%;height:100dvh;max-width:var(--max-content-width);flex-direction:column;margin:0 auto;display:flex;position:relative;overflow:hidden;transform:translate(0,0)}.app__content{-webkit-overflow-scrolling:touch;flex:1;width:100%;overflow:hidden auto}img,picture,video,canvas,svg{max-width:100%;display:block}input,button,textarea,select{font:inherit;color:inherit}button{cursor:pointer;background:0 0;border:none}a{color:inherit;text-decoration:none}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{font-family:var(--font-sans);color:var(--color-stone-800);font-weight:600;line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);overflow-wrap:break-word}h1{font-size:var(--text-2xl);font-weight:700}h2{font-size:var(--text-xl)}h3{font-size:var(--text-lg)}h4{font-size:var(--text-base)}h5{font-size:var(--text-sm)}h6{font-size:var(--text-xs);color:var(--color-stone-500)}html[data-theme=dark] h1,html[data-theme=dark] h2,html[data-theme=dark] h3,html[data-theme=dark] h4,html[data-theme=dark] h5,html[data-theme=dark] h6{color:var(--color-stone-800)}p{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-relaxed);color:var(--color-stone-600);overflow-wrap:break-word}html[data-theme=dark] p{color:var(--color-stone-600)}table{border-collapse:collapse}input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-stone-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-stone-400)}*{scrollbar-width:thin;scrollbar-color:var(--color-stone-300) transparent}::selection{color:var(--color-stone-900);background-color:#6b8cae33}::selection{color:var(--color-stone-900);background-color:#6b8cae33}:focus-visible{outline:3px solid var(--color-asset);outline-offset:3px;border-radius:var(--radius-sm)}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.text-income{color:var(--color-income)}.text-expense{color:var(--color-expense)}.text-asset{color:var(--color-asset)}.text-liability{color:var(--color-liability)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.text-safe{color:var(--color-safe)}.bg-income{background-color:var(--color-income-light)}.bg-expense{background-color:var(--color-expense-light)}.bg-asset{background-color:var(--color-asset-light)}.bg-liability{background-color:var(--color-liability-light)}.bg-warning{background-color:var(--color-warning-light)}.bg-danger{background-color:var(--color-danger-light)}.bg-safe{background-color:var(--color-safe-light)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-3xl{font-size:var(--text-3xl)}.text-4xl{font-size:var(--text-4xl)}.text-light{font-weight:300}.text-normal{font-weight:400}.text-medium{font-weight:500}.text-semibold{font-weight:600}.text-bold{font-weight:700}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--color-stone-500)}.text-subtle{color:var(--color-stone-400)}.font-mono{font-family:var(--font-mono)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.gap-xl{gap:var(--space-xl)}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.mt-xs{margin-top:var(--space-xs)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mt-xl{margin-top:var(--space-xl)}.mb-xs{margin-bottom:var(--space-xs)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.mb-xl{margin-bottom:var(--space-xl)}.p-xs{padding:var(--space-xs)}.p-sm{padding:var(--space-sm)}.p-md{padding:var(--space-md)}.p-lg{padding:var(--space-lg)}.p-xl{padding:var(--space-xl)}.w-full{width:100%}@media print{.tab-bar,.btn,.plan-dropdown-select,.header-plan-selector-row,.swipeable-months,.month-picker,.timeline-slider,.stress-test-controller,.settings-section,.overview-view-selector,.page__header,.header-plan-selector{display:none!important}body,.app,.page,.page__content{color:#000!important;width:100%!important;max-width:100%!important;box-shadow:none!important;background:#fff!important;margin:0!important;padding:0!important}.glass-card,.dimension-card,.rec-card,.alert-card,.app-info-card,.flow-rating-summary-card,.monthly-flow-card{page-break-inside:avoid;break-inside:avoid;-webkit-backdrop-filter:none!important;box-shadow:none!important;background:#fff!important;border:1px solid #d6d3d1!important;margin-bottom:20px!important}h1,h2,h3,h4,h5,h6,p,span,strong,li,td,th{color:#000!important}.text-income{color:#2e624a!important}.text-expense{color:#9a4d2e!important}.text-muted{color:#57534e!important}.progress-bar{-webkit-print-color-adjust:exact;print-color-adjust:exact;background:#eeeeec!important}.progress-bar__fill{-webkit-print-color-adjust:exact;print-color-adjust:exact}.overview-page__chart-section,.rating-recs-section,.rating-dimensions-section{page-break-inside:avoid;break-inside:avoid}@page{size:A4 portrait;margin:15mm}}@media (prefers-reduced-motion:reduce){*,:before,:after{background-attachment:initial!important;scroll-behavior:auto!important;transition-duration:0s!important;transition-delay:0s!important;animation-duration:1ms!important;animation-iteration-count:1!important;animation-delay:-1ms!important}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-24px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes breathe{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}@keyframes modalEnter{0%{opacity:0;transform:scale(.95)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes toastEnter{0%{opacity:0;transform:translateY(-100%)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes progressFill{0%{transform:scaleX(0)}to{transform:scaleX(1)}}@keyframes ripple{to{opacity:0;transform:scale(2.5)}}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(var(--glass-saturate));border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow), var(--glass-inner-shadow);padding:var(--space-lg);transition:transform var(--transition-base), background-color var(--transition-base), border-color var(--transition-base), box-shadow var(--transition-base);will-change:transform, box-shadow}.glass-card:hover{transform:scale(var(--focus-scale)) translate3d(0, -3px, 0);background:var(--glass-bg-strong);border-color:var(--glass-border-strong);box-shadow:var(--glass-shadow-elevated), var(--glass-inner-shadow)}.glass-card--elevated{background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(var(--glass-blur-strong)) saturate(var(--glass-saturate));border-color:var(--glass-border-strong);box-shadow:var(--glass-shadow-elevated), var(--glass-inner-shadow)}.glass-card--flat{background:var(--glass-bg-subtle);box-shadow:var(--glass-shadow-subtle)}.glass-card--flat:hover{box-shadow:var(--glass-shadow-subtle);transform:none}.glass-card--compact{padding:var(--space-md);border-radius:var(--radius-md)}.glass-card--interactive{cursor:pointer}.glass-card--interactive:active{transform:scale(.97)translateY(-1px)}.tab-bar{z-index:var(--z-sticky);height:calc(var(--tab-bar-height) + var(--safe-area-bottom));padding:0 var(--space-xs) var(--safe-area-bottom);border-radius:var(--radius-lg) var(--radius-lg) 0 0;-webkit-backdrop-filter:blur(var(--glass-blur-strong)) saturate(180%);background:#ffffff2e;border:1px solid #ffffff40;border-bottom:none;flex-shrink:0;justify-content:space-around;align-items:center;width:100%;display:flex;position:relative;box-shadow:0 -8px 32px #0000000d,inset 0 1px 1px #fff3}html[data-theme=dark] .tab-bar{background:#0f172a73;border-color:#ffffff1f #ffffff1f currentColor;border-bottom-style:none;border-bottom-width:medium;box-shadow:0 -8px 32px #00000059,inset 0 1px 1px #ffffff1a}.tab-bar__item{height:calc(var(--tab-bar-height) - 12px);border-radius:var(--radius-full);color:var(--color-stone-400);font-size:var(--text-xs);letter-spacing:var(--tracking-wide);transition:color var(--transition-base), background-color var(--transition-base), transform var(--transition-fast);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;margin:6px 3px;font-weight:500;display:flex;position:relative}.tab-bar__item:active{transform:scale(.92)}.tab-bar__item-icon{width:20px;height:20px;transition:transform var(--transition-base);justify-content:center;align-items:center;display:flex}.tab-bar__item-icon svg{stroke-width:1.8px;width:18px;height:18px}.tab-bar__item-label{letter-spacing:.02em;font-size:9px;font-weight:600}.tab-bar__item--active{background:#fff6;box-shadow:0 4px 12px #0f172a0d,inset 0 1px #fff6;color:var(--color-stone-900)!important}html[data-theme=dark] .tab-bar__item--active{background:#ffffff1f;box-shadow:0 4px 12px #00000040,inset 0 1px #ffffff1a}.tab-bar__item--active .tab-bar__item-icon{transform:translateY(-.5px)}.btn{justify-content:center;align-items:center;gap:var(--space-sm);font-size:var(--text-sm);letter-spacing:var(--tracking-wide);border-radius:var(--radius-full);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:background-color var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);-webkit-tap-highlight-color:transparent;will-change:transform, box-shadow;border:1.5px solid #0000;padding:10px 24px;font-weight:600;line-height:1;display:inline-flex;position:relative;overflow:hidden}.btn:hover:not(:disabled){transform:scale(1.03)translateY(-1px)}.btn:active:not(:disabled){transform:scale(.96)translate(0,0)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn--primary{background-color:var(--color-stone-900);color:var(--color-stone-50);border-color:var(--color-stone-900);box-shadow:0 4px 12px #0f172a1f,inset 0 1px 1px #ffffff40}html[data-theme=dark] .btn--primary{color:#020617;background-color:#fff;border-color:#fff;box-shadow:0 4px 16px #00000059,inset 0 1px 1px #fff6}.btn--primary:hover:not(:disabled){background-color:var(--color-stone-850);border-color:var(--color-stone-850);box-shadow:0 6px 18px #0f172a2e,inset 0 1px 1px #ffffff4d}html[data-theme=dark] .btn--primary:hover:not(:disabled){background-color:#ffffffe6;border-color:#ffffffe6;box-shadow:0 8px 24px #00000080,inset 0 1px 1px #ffffff80}.btn--secondary{color:var(--color-stone-700);border-color:var(--color-stone-300);-webkit-backdrop-filter:blur(8px);background-color:#0000}html[data-theme=dark] .btn--secondary{border-color:#ffffff26}.btn--secondary:hover:not(:disabled){border-color:var(--color-stone-400);background-color:#0f172a0d}html[data-theme=dark] .btn--secondary:hover:not(:disabled){background-color:#ffffff14;border-color:#ffffff4d}.btn--ghost{color:var(--color-stone-600);background-color:#0000;border-color:#0000}.btn--ghost:hover:not(:disabled){background-color:#0f172a0a}html[data-theme=dark] .btn--ghost:hover:not(:disabled){background-color:#ffffff0a}.btn--danger{background-color:var(--color-danger);color:#fff;border-color:var(--color-danger);box-shadow:0 4px 12px #e11d4826,inset 0 1px 1px #fff3}.btn--danger:hover:not(:disabled){background-color:#c21a48;border-color:#c21a48;box-shadow:0 6px 16px #e11d4840}.btn--sm{font-size:var(--text-xs);padding:6px 16px}.btn--lg{font-size:var(--text-base);padding:14px 32px}.btn--icon{border-radius:var(--radius-full);flex-shrink:0;width:40px;height:40px;padding:0}.btn--icon.btn--sm{width:32px;height:32px}.btn--icon.btn--lg{width:48px;height:48px}.btn--glass{background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);border-color:var(--glass-border);color:var(--color-stone-700)}.btn--glass:hover:not(:disabled){background:var(--glass-bg-strong)}.segment-control{border-radius:var(--radius-full);background:#0f172a0d;align-items:center;gap:2px;padding:3px;display:flex;position:relative}html[data-theme=dark] .segment-control{background:#ffffff0f}.segment-control__btn{font-size:var(--text-sm);color:var(--color-stone-500);border-radius:var(--radius-full);cursor:pointer;-webkit-user-select:none;user-select:none;transition:color var(--transition-base);z-index:2;white-space:nowrap;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex:1;justify-content:center;align-items:center;padding:8px 16px;font-weight:500;display:flex;position:relative}.segment-control__btn:hover{color:var(--color-stone-800)}.segment-control__btn--active{font-weight:600;color:var(--color-stone-900)!important}.segment-control__indicator{z-index:1;background:var(--glass-bg-strong);border-radius:var(--radius-full);transition:transform .25s cubic-bezier(.34,1.56,.64,1),width .25s;position:absolute;top:3px;bottom:3px;left:0;box-shadow:0 1px 3px #0f172a14,0 1px 2px #0f172a0a}html[data-theme=dark] .segment-control__indicator{background:#ffffff14;box-shadow:0 1px 3px #0003,inset 0 1px #ffffff0d}.form-field{gap:var(--space-xs);margin-bottom:var(--space-md);flex-direction:column;width:100%;display:flex}.form-field__label{font-size:var(--text-sm);color:var(--color-stone-600);transition:color var(--transition-fast);align-items:center;font-weight:600;display:inline-flex}.form-field--focused .form-field__label{color:var(--color-stone-900)}.form-field__required{color:var(--color-danger);margin-left:2px}.form-field__input-container{align-items:center;width:100%;display:flex;position:relative}.form-field__input,.form-field__select,.form-field__textarea{width:100%;font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-stone-900);background:var(--color-stone-50);border:1.5px solid var(--color-stone-200);border-radius:var(--radius-md);transition:border-color var(--transition-base), background-color var(--transition-base), box-shadow var(--transition-base);appearance:none;outline:none;padding:12px 16px}@media (width<=768px){.form-field__input,.form-field__select,.form-field__textarea{font-size:16px!important}}html[data-theme=dark] .form-field__input,html[data-theme=dark] .form-field__select,html[data-theme=dark] .form-field__textarea{border-color:var(--color-stone-300);background:#0f172a73}.form-field__input::placeholder,.form-field__textarea::placeholder{color:var(--color-stone-400)}.form-field__input:focus,.form-field__select:focus,.form-field__textarea:focus{border-color:var(--color-stone-700);box-shadow:var(--focus-ring);background:#fff;outline:none}html[data-theme=dark] .form-field__input:focus,html[data-theme=dark] .form-field__select:focus,html[data-theme=dark] .form-field__textarea:focus{border-color:var(--color-stone-500);background:var(--color-stone-900);box-shadow:var(--focus-ring)}.form-field--error .form-field__input,.form-field--error .form-field__select,.form-field--error .form-field__textarea{border-color:var(--color-danger)!important;box-shadow:0 0 0 3px #f43f5e33!important}.form-field--error .form-field__label{color:var(--color-danger)!important}.form-field__error{font-size:var(--text-xs);color:var(--color-danger);margin-top:4px;font-weight:500}.form-field__hint{font-size:var(--text-xs);color:var(--color-stone-400);margin-top:4px}.form-field__prefix,.form-field__suffix{color:var(--color-stone-500);font-size:var(--text-base);pointer-events:none;z-index:5;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.form-field__prefix{left:14px}.form-field__suffix{right:14px}.form-field__input-container:has(.form-field__prefix) .form-field__input{padding-left:38px}.form-field__input-container:has(.form-field__suffix) .form-field__input{padding-right:38px}.form-field__select-chevron{width:18px;height:18px;color:var(--color-stone-400);pointer-events:none;z-index:5;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.form-field__select-chevron svg{stroke:currentColor;width:16px;height:16px}.form-field__select{cursor:pointer;padding-right:40px}.form-field__textarea{resize:vertical;min-height:90px;line-height:var(--leading-relaxed)}.form-field--disabled{opacity:.6}.form-field--disabled .form-field__input,.form-field--disabled .form-field__select,.form-field--disabled .form-field__textarea{cursor:not-allowed;background:var(--color-stone-100)}.badge{font-size:var(--text-xs);border-radius:var(--radius-full);white-space:nowrap;color:var(--color-stone-600);background:#0000000d;align-items:center;gap:4px;padding:3px 10px;font-weight:500;line-height:1.4;display:inline-flex}.badge--income{background:var(--color-income-light);color:var(--color-income)}.badge--expense{background:var(--color-expense-light);color:var(--color-expense)}.badge--essential{color:var(--color-asset);background:#6b8cae1f}.badge--optional{color:var(--color-stone-500);background:#a8a29e26}.badge--asset{background:var(--color-asset-light);color:var(--color-asset)}.badge--liability{background:var(--color-liability-light);color:var(--color-liability)}.badge--warning{background:var(--color-warning-light);color:var(--color-warning)}.rating-badge{border-radius:var(--radius-full);width:36px;height:36px;font-size:var(--text-base);font-weight:700;font-family:var(--font-mono);color:#fff;background:var(--color-stone-400);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex;box-shadow:0 2px 8px #0000001a}.rating-badge--S{background:var(--color-safe);box-shadow:0 2px 12px #7a9e7e59}.rating-badge--A{background:var(--color-asset);box-shadow:0 2px 12px #6b8cae59}.rating-badge--B{background:var(--color-warning);box-shadow:0 2px 12px #d4a04a59}.rating-badge--C{background:var(--color-expense);box-shadow:0 2px 12px #c2785c59}.rating-badge--D{background:var(--color-danger);box-shadow:0 2px 12px #c45c5c59}.rating-badge--sm{width:28px;height:28px;font-size:var(--text-sm)}.rating-badge--lg{width:52px;height:52px;font-size:var(--text-2xl)}.amount{font-family:var(--font-mono);font-variant-numeric:tabular-nums;letter-spacing:-.01em;color:var(--color-stone-800);font-weight:500}.amount--positive{color:var(--color-income)}.amount--negative{color:var(--color-expense)}.amount--large{font-size:var(--text-2xl);font-weight:600}.amount--xl{font-size:var(--text-3xl);font-weight:700}.amount__currency{opacity:.6;margin-right:2px;font-size:.7em;font-weight:400}.progress-bar{border-radius:var(--radius-full);background:#0000000f;width:100%;height:6px;position:relative;overflow:hidden}.progress-bar__fill{border-radius:var(--radius-full);background:var(--color-stone-600);height:100%;transition:width var(--transition-slow);transform-origin:0;position:relative}.progress-bar__fill:after{content:"";border-radius:inherit;background:linear-gradient(90deg,#0000,#ffffff40,#0000);position:absolute;inset:0}.progress-bar--income .progress-bar__fill{background:var(--color-income)}.progress-bar--expense .progress-bar__fill{background:var(--color-expense)}.progress-bar--asset .progress-bar__fill{background:var(--color-asset)}.progress-bar--warning .progress-bar__fill{background:var(--color-warning)}.progress-bar--danger .progress-bar__fill{background:var(--color-danger)}.progress-bar--safe .progress-bar__fill{background:var(--color-safe)}.progress-bar--thick{height:10px}.progress-bar--thin{height:3px}.modal-overlay{z-index:var(--z-modal);-webkit-backdrop-filter:blur(12px);animation:fadeIn var(--transition-base) ease-out;padding:var(--space-md);padding-bottom:calc(var(--space-md) + var(--safe-area-bottom));overscroll-behavior:contain;background:#0a0b0ec7;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.modal-overlay--center{align-items:center}@media (width<=480px){.modal-overlay--center{padding-bottom:calc(var(--space-md) + var(--safe-area-bottom));align-items:flex-end}}.modal{width:100%;max-width:var(--max-content-width);overscroll-behavior:contain;background:var(--glass-bg-strong);max-height:85dvh;-webkit-backdrop-filter:blur(var(--glass-blur-strong));border:1px solid var(--glass-border-strong);border-radius:var(--radius-xl);box-shadow:0 24px 80px #0f172a26, 0 8px 24px #0f172a14, var(--glass-inner-shadow);flex-direction:column;animation:.35s cubic-bezier(.34,1.56,.64,1) modalEnter;display:flex;overflow:hidden}@media (width<=480px){.modal{max-height:calc(100dvh - var(--space-md) * 2 - var(--safe-area-bottom));border-radius:var(--radius-xl) var(--radius-xl) 0 0}}.modal__header{padding:var(--space-lg) var(--space-lg) var(--space-md);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.modal__title{font-size:var(--text-lg);color:var(--color-stone-900);font-weight:600}.modal__close{border-radius:var(--radius-full);width:32px;height:32px;color:var(--color-stone-500);transition:background-color var(--transition-fast);justify-content:center;align-items:center;display:flex}.modal__close:hover{background-color:#0f172a0f}.modal__body{padding:0 var(--space-lg);-webkit-overflow-scrolling:touch;flex:auto;min-height:0;max-height:none;overflow-y:auto}.modal__footer{justify-content:space-between;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg) var(--space-lg);border-top:1px solid var(--color-stone-150);flex-shrink:0;display:flex}.modal__footer .btn{flex:1}.modal__actions{justify-content:space-between;align-items:center;gap:var(--space-md);margin-top:var(--space-xl);padding-top:var(--space-md);border-top:1px solid var(--color-stone-150);display:flex}.modal__actions .btn{flex:1}.modal__handle{background:var(--color-stone-300);border-radius:var(--radius-full);width:36px;height:4px;margin:var(--space-sm) auto 0}.month-picker__year-select{justify-content:center;align-items:center;gap:var(--space-lg);margin-bottom:var(--space-lg);margin-top:var(--space-sm);display:flex}.month-picker__year-btn{border-radius:var(--radius-full);background:var(--color-stone-150);width:36px;height:36px;color:var(--color-stone-800);transition:background-color var(--transition-fast), transform var(--transition-fast);justify-content:center;align-items:center;display:inline-flex}.month-picker__year-btn:hover{background:var(--color-stone-200);color:var(--color-stone-900)}.month-picker__year-btn:active{transform:scale(.9)}.month-picker__year-btn svg{width:18px;height:18px}.month-picker__year-display{font-size:var(--text-lg);color:var(--color-stone-900);text-align:center;min-width:80px;letter-spacing:var(--tracking-tight);font-weight:600}.month-picker__grid{gap:var(--space-sm);margin-bottom:var(--space-md);grid-template-columns:repeat(4,1fr);display:grid}.month-picker__month-btn{border-radius:var(--radius-md);background:var(--color-stone-100);font-size:var(--text-sm);color:var(--color-stone-700);text-align:center;transition:background-color var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);padding:12px 0;font-weight:500}.month-picker__month-btn:hover{background:var(--color-stone-150);color:var(--color-stone-900)}.month-picker__month-btn:active{transform:scale(.95)}.month-picker__month-btn--selected{font-weight:600;background:var(--color-stone-900)!important;color:var(--color-stone-50)!important}.empty-state{padding:var(--space-3xl) var(--space-xl);text-align:center;animation:fadeIn var(--transition-slow) ease-out;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state__icon{width:64px;height:64px;margin-bottom:var(--space-lg);color:var(--color-stone-300);opacity:.7}.empty-state__icon svg{stroke-width:1px;width:100%;height:100%}.empty-state__title{font-size:var(--text-lg);color:var(--color-stone-700);margin-bottom:var(--space-sm);font-weight:600}.empty-state__description{font-size:var(--text-sm);color:var(--color-stone-400);max-width:260px;line-height:var(--leading-relaxed)}.empty-state__action{margin-top:var(--space-xl)}.divider{background:var(--color-stone-200);width:100%;height:1px;margin:var(--space-md) 0;opacity:.6;border:none}.divider--subtle{opacity:.3}.divider--spaced{margin:var(--space-lg) 0}.divider--inset{margin-left:var(--space-md);width:calc(100% - var(--space-md))}.chip{font-size:var(--text-sm);color:var(--color-stone-600);border-radius:var(--radius-full);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:background-color var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);-webkit-tap-highlight-color:transparent;background:#0000000a;border:1.5px solid #0000;justify-content:center;align-items:center;padding:6px 14px;font-weight:500;display:inline-flex}.chip:hover{background:#00000012}.chip--selected{background:var(--color-stone-900);color:var(--color-stone-50);border-color:var(--color-stone-900)}.chip--selected:hover{background:var(--color-stone-800)}.chip--sm{font-size:var(--text-xs);padding:4px 10px}.chip--income.chip--selected{background:var(--color-income);border-color:var(--color-income)}.chip--expense.chip--selected{background:var(--color-expense);border-color:var(--color-expense)}.list-item{align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-md);margin-bottom:var(--space-sm);transition:transform var(--transition-fast), box-shadow var(--transition-fast);cursor:pointer;-webkit-tap-highlight-color:transparent;animation:.3s ease-out backwards slideUp;display:flex;position:relative;overflow:hidden}.list-item:active{transform:scale(.98)}.list-item__icon{border-radius:var(--radius-md);width:36px;height:36px;font-size:var(--text-lg);background:#0000000a;flex-shrink:0;justify-content:center;align-items:center;display:flex}.list-item__content{flex:1;min-width:0}.list-item__title{font-size:var(--text-base);color:var(--color-stone-800);font-weight:500;line-height:var(--leading-tight)}.list-item__subtitle{font-size:var(--text-xs);color:var(--color-stone-400);margin-top:2px}.list-item__trailing{flex-direction:column;flex-shrink:0;align-items:flex-end;display:flex}.list-item__actions{transition:transform var(--transition-base);align-items:stretch;display:flex;position:absolute;top:0;bottom:0;right:0;transform:translate(100%)}.list-item--swiped .list-item__actions{transform:translate(0)}.list-item__action-btn{padding:0 var(--space-lg);font-size:var(--text-sm);color:#fff;cursor:pointer;border:none;justify-content:center;align-items:center;font-weight:500;display:flex}.list-item__action-btn--edit{background:var(--color-asset)}.list-item__action-btn--delete{background:var(--color-danger)}.list-item:first-child{animation-delay:0s}.list-item:nth-child(2){animation-delay:40ms}.list-item:nth-child(3){animation-delay:80ms}.list-item:nth-child(4){animation-delay:.12s}.list-item:nth-child(5){animation-delay:.16s}.list-item:nth-child(6){animation-delay:.2s}.list-item:nth-child(7){animation-delay:.24s}.list-item:nth-child(8){animation-delay:.28s}.list-item:nth-child(9){animation-delay:.32s}.list-item:nth-child(10){animation-delay:.36s}.toast{top:calc(var(--space-md) + var(--safe-area-top));z-index:var(--z-toast);align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);min-width:200px;max-width:calc(100vw - var(--space-xl));background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(var(--glass-blur-strong));border:1px solid var(--glass-border);border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--color-stone-800);pointer-events:auto;font-weight:500;animation:.4s cubic-bezier(.34,1.56,.64,1) toastEnter;display:flex;position:fixed;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #1f26231a,0 2px 8px #1f26230a}.toast--success{border-color:#5b8a724d}.toast--success .toast__icon{color:var(--color-income)}.toast--error{border-color:#c45c5c4d}.toast--error .toast__icon{color:var(--color-danger)}.toast--warning{border-color:#d4a04a4d}.toast--warning .toast__icon{color:var(--color-warning)}.toast__icon{flex-shrink:0;width:18px;height:18px}.toast__message{flex:1}.toast__dismiss{border-radius:var(--radius-full);width:20px;height:20px;color:var(--color-stone-400);cursor:pointer;transition:color var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.toast__dismiss:hover{color:var(--color-stone-600)}.skeleton{background:linear-gradient(90deg, var(--color-stone-200) 25%, var(--color-stone-150) 50%, var(--color-stone-200) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.8s ease-in-out infinite shimmer}.skeleton--text{width:100%;height:14px;margin-bottom:var(--space-sm)}.skeleton--heading{width:60%;height:22px;margin-bottom:var(--space-md)}.skeleton--card{border-radius:var(--radius-lg);height:120px}.skeleton--circle{border-radius:var(--radius-full)}.toggle{flex-shrink:0;width:44px;height:26px;position:relative}.toggle__input{opacity:0;width:0;height:0;position:absolute}.toggle__slider{background:var(--color-stone-300);border-radius:var(--radius-full);cursor:pointer;transition:background-color var(--transition-base);position:absolute;inset:0}.toggle__slider:before{content:"";border-radius:var(--radius-full);width:20px;height:20px;transition:transform var(--transition-base);background:#fff;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0000001f}.toggle__input:checked+.toggle__slider{background:var(--color-stone-800)}.toggle__input:checked+.toggle__slider:before{transform:translate(18px)}.toggle__input:focus-visible+.toggle__slider{box-shadow:var(--focus-ring)}.number-ticker{font-family:var(--font-mono);font-variant-numeric:tabular-nums;display:inline-flex;overflow:hidden}.number-ticker__digit{transition:transform var(--transition-slow);display:inline-block}.modal__form,.modal-form--scrollable{max-height:calc(85vh - 75px);padding:0 var(--space-lg) var(--space-lg);-webkit-overflow-scrolling:touch;overflow-y:auto}.sticky-actions{background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(12px);padding:var(--space-md) 0 0 0;margin-top:var(--space-lg);border-top:1px solid var(--color-stone-200);justify-content:flex-end;gap:var(--space-sm);z-index:10;display:flex;position:sticky;bottom:0}.amount--blurred{transition:filter var(--transition-fast) ease}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-8px)}40%,80%{transform:translate(8px)}}.shake-animation{animation:.3s ease-in-out shake}.pin-lock-screen{z-index:9999;-webkit-backdrop-filter:blur(24px);color:var(--color-stone-800);background:#1c191766;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.pin-lock-card{width:100%;max-width:320px;padding:var(--space-xl);text-align:center;box-shadow:none;background:0 0;border:none}.pin-lock-title{font-size:var(--text-lg);color:var(--color-stone-800);margin-bottom:var(--space-xs);justify-content:center;align-items:center;gap:8px;font-weight:600;display:flex}.pin-lock-subtitle{font-size:var(--text-xs);color:var(--color-stone-500);margin-bottom:var(--space-xl)}.pin-dots{justify-content:center;gap:var(--space-md);margin-bottom:var(--space-2xl);display:flex}.pin-dot{border-radius:var(--radius-full);border:1.5px solid var(--color-stone-400);width:14px;height:14px;transition:all var(--transition-fast) ease}.pin-dot--filled{background:var(--color-stone-800);border-color:var(--color-stone-800);transform:scale(1.15)}.pin-keypad{gap:var(--space-md);grid-template-columns:repeat(3,1fr);justify-items:center;display:grid}.pin-key{border-radius:var(--radius-full);border:1px solid var(--glass-border);width:68px;height:68px;font-size:24px;font-family:var(--font-sans);color:var(--color-stone-800);cursor:pointer;-webkit-user-select:none;user-select:none;transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent;background:#ffffff59;justify-content:center;align-items:center;font-weight:400;display:flex}html[data-theme=dark] .pin-key{background:#ffffff14;border-color:#ffffff26}.pin-key:active{background:#00000014;transform:scale(.92)}.pin-key--action{color:var(--color-stone-500);background:0 0;border-color:#0000;font-size:14px;font-weight:500}.pin-key--action:active{color:var(--color-stone-800);background:0 0}.template-list{gap:var(--space-md);margin-top:var(--space-sm);flex-direction:column;display:flex}.template-item{padding:var(--space-md);gap:var(--space-sm);transition:all var(--transition-base);flex-direction:column;display:flex;position:relative}.template-item--inactive{opacity:.65}.template-item__main{justify-content:space-between;align-items:flex-start;gap:var(--space-md);width:100%;display:flex}.template-item__left-col{align-items:flex-start;gap:var(--space-sm);flex:1;min-width:0;display:flex}.template-item__icon{border-radius:var(--radius-md);background:#0f172a0a;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;margin-top:2px;display:flex}html[data-theme=dark] .template-item__icon{background:#ffffff0f}.template-item__icon-svg{color:var(--color-stone-600)}.template-item__info{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.template-item__name{font-size:var(--text-base);color:var(--color-stone-800);flex-wrap:wrap;align-items:center;gap:6px;font-weight:600;line-height:1.35;display:flex}.loan-badge{background:var(--color-warning-light);color:var(--color-warning);border-radius:var(--radius-xs);padding:1px 5px;font-size:9px;font-weight:600}.template-item__freq{font-size:var(--text-xs);color:var(--color-stone-400)}.template-item__right-col{text-align:right;flex-direction:column;flex-shrink:0;align-items:flex-end;gap:8px;display:flex}.template-item__amount{font-family:var(--font-mono);font-size:var(--text-base);font-variant-numeric:tabular-nums;flex-shrink:0;font-weight:700;line-height:1.2}.template-item__meta{align-items:center;gap:var(--space-xs);display:flex}.template-item__actions{align-items:center;gap:var(--space-xs);flex-shrink:0;display:flex}.btn-loan-config{border-radius:var(--radius-sm);padding:4px 10px;font-size:10px}.template-item__note{font-size:var(--text-xs);color:var(--color-stone-400);line-height:var(--leading-normal);border-radius:var(--radius-xs);margin-top:var(--space-xs);background:#0f172a05;padding:6px 10px}html[data-theme=dark] .template-item__note{background:#ffffff05}@media (width<=359px){.template-item__main{align-items:stretch;gap:var(--space-sm);flex-direction:column}.template-item__left-col{width:100%}.template-item__right-col{text-align:left;align-items:flex-start;width:100%}.template-item__amount{text-align:left}.template-item__actions{justify-content:flex-start;width:100%}}.settings-group-card{margin-bottom:var(--space-md);flex-direction:column;display:flex;overflow:hidden;border:1px solid var(--glass-border-strong)!important;background:var(--glass-bg-strong)!important;padding:0!important}.settings-row{justify-content:space-between;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-stone-150);transition:background-color var(--transition-fast);display:flex}html[data-theme=dark] .settings-row{border-bottom-color:var(--color-stone-200)}.settings-row:last-child{border-bottom:none}.settings-row__left{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.settings-row__title{font-size:var(--text-base);color:var(--color-stone-800);font-weight:500}.settings-row__desc{font-size:var(--text-xs);color:var(--color-stone-400);line-height:var(--leading-normal)}.settings-row__right{align-items:center;gap:var(--space-sm);flex-shrink:0;display:flex}.settings-group-footer{font-size:var(--text-xs);color:var(--color-stone-400);line-height:var(--leading-normal);padding:0 var(--space-lg) var(--space-lg);margin-top:calc(-1 * var(--space-xs))}.swipeable-months{box-sizing:border-box;background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:var(--radius-full);align-items:center;gap:var(--space-xs);height:40px;box-shadow:var(--glass-shadow-subtle);flex-shrink:0;margin:0;padding:4px;display:inline-flex}html[data-theme=dark] .swipeable-months{background:#ffffff14}.swipeable-months__arrow{border-radius:var(--radius-full);width:30px;height:30px;color:var(--color-stone-600);transition:all var(--transition-fast);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;font-size:18px;font-weight:500;display:flex}.swipeable-months__arrow:hover{color:var(--color-stone-900);background:#0f172a0f}html[data-theme=dark] .swipeable-months__arrow:hover{background:#ffffff14}.swipeable-months__arrow:active{transform:scale(.9)}.swipeable-months__current{box-sizing:border-box;justify-content:center;align-items:center;gap:var(--space-xs);border-radius:var(--radius-full);min-width:110px;height:30px;transition:all var(--transition-fast);cursor:pointer;background:0 0;border:none;padding:0 10px;display:flex}.swipeable-months__current:hover{background:#0f172a0a}html[data-theme=dark] .swipeable-months__current:hover{background:#ffffff0a}.swipeable-months__label{font-size:var(--text-sm);color:var(--color-stone-800);letter-spacing:var(--tracking-tight);font-weight:600}.swipeable-months__picker-hint{color:var(--color-stone-400);font-size:10px}.plan-dropdown-select{appearance:none;background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-full);box-sizing:border-box;height:40px;font-size:var(--text-sm);color:var(--color-stone-800);cursor:pointer;text-overflow:ellipsis;white-space:nowrap;max-width:140px;transition:all var(--transition-fast);box-shadow:var(--glass-shadow-subtle);background-image:url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:11px;outline:none;padding:0 32px 0 12px;font-weight:600}@media (width<=375px){.plan-dropdown-select{max-width:105px}}html[data-theme=dark] .plan-dropdown-select{background:#ffffff14 url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23cbd5e1' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E")}.plan-dropdown-select:hover{background-color:var(--glass-bg-strong)}.plan-dropdown-select:focus{border-color:var(--color-stone-400);box-shadow:0 0 0 3px #0f172a0d}.page{min-height:100%;padding-bottom:var(--space-xl);padding-left:var(--safe-area-left);padding-right:var(--safe-area-right);max-width:var(--max-content-width);flex-direction:column;width:100%;margin:0 auto;display:flex}.page__header{z-index:var(--z-sticky);padding:calc(var(--safe-area-top) + var(--space-md)) var(--space-md) var(--space-md);background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(var(--glass-blur-strong)) saturate(var(--glass-saturate));border-bottom:1px solid var(--glass-border);justify-content:space-between;align-items:center;gap:12px;display:flex;position:sticky;top:0}.page__header-left{align-items:center;gap:var(--space-sm);display:flex}.page__header-right{align-items:center;gap:var(--space-xs);display:flex}.page__title{font-size:var(--text-xl);color:var(--color-stone-900);letter-spacing:var(--tracking-tight);font-weight:700;line-height:var(--leading-tight)}.page__subtitle{font-size:var(--text-sm);color:var(--color-stone-400);font-weight:400;line-height:var(--leading-normal);margin-top:4px}.page__content{padding:var(--space-sm) var(--space-md) var(--space-md);scrollbar-gutter:stable;-webkit-overflow-scrolling:touch;flex:1;overflow:hidden auto}.page__content--flush{padding-left:0;padding-right:0}.page__section{margin-bottom:var(--space-xl)}.page__section-title{font-size:var(--text-sm);color:var(--color-stone-500);text-transform:uppercase;letter-spacing:var(--tracking-wide);margin-bottom:var(--space-md);padding:0 var(--space-xs);font-weight:600}.plan-selector{align-items:center;gap:var(--space-sm);background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);border:1px solid var(--glass-border);border-radius:var(--radius-full);cursor:pointer;transition:background-color var(--transition-fast);-webkit-tap-highlight-color:transparent;padding:6px 14px 6px 12px;display:flex}.plan-selector:hover{background:var(--glass-bg-strong)}.plan-selector:active{transform:scale(.97)}.plan-selector__name{font-size:var(--text-sm);color:var(--color-stone-800);text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-weight:600;overflow:hidden}.plan-selector__arrow{width:14px;height:14px;color:var(--color-stone-400);transition:transform var(--transition-fast)}.plan-selector--open .plan-selector__arrow{transform:rotate(180deg)}.plan-selector__dropdown{top:calc(100% + var(--space-xs));left:var(--space-lg);right:var(--space-lg);z-index:var(--z-dropdown);background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(var(--glass-blur-strong));border:1px solid var(--glass-border-strong);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow-elevated);padding:var(--space-sm);animation:.2s ease-out scaleIn;position:absolute;overflow:hidden}.plan-selector__option{align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-stone-700);cursor:pointer;transition:background-color var(--transition-fast);font-weight:500;display:flex}.plan-selector__option:hover{background:#0000000a}.plan-selector__option--active{color:var(--color-stone-900);background:#0000000f;font-weight:600}.month-navigator{justify-content:center;align-items:center;gap:var(--space-lg);padding:var(--space-sm) 0;-webkit-user-select:none;user-select:none;display:flex}.month-navigator__btn{border-radius:var(--radius-full);width:36px;height:36px;color:var(--color-stone-500);transition:background-color var(--transition-fast), color var(--transition-fast);-webkit-tap-highlight-color:transparent;justify-content:center;align-items:center;display:flex}.month-navigator__btn:hover{color:var(--color-stone-700);background:#0000000a}.month-navigator__btn:active{transform:scale(.9)}.month-navigator__btn:disabled{opacity:.3;cursor:not-allowed}.month-navigator__btn svg{width:20px;height:20px}.month-navigator__label{font-size:var(--text-base);color:var(--color-stone-800);text-align:center;min-width:120px;letter-spacing:var(--tracking-tight);font-weight:600}.month-navigator__sub{font-size:var(--text-xs);color:var(--color-stone-400);text-align:center;font-weight:400;display:block}.timeline-slider{padding:var(--space-sm) var(--space-xs);position:relative}.timeline-slider__track{align-items:center;height:40px;display:flex;position:relative}.timeline-slider__input{appearance:none;background:linear-gradient(to right, var(--color-stone-600) var(--timeline-progress,0%), var(--color-stone-200) var(--timeline-progress,0%));border-radius:var(--radius-full);cursor:pointer;outline:none;width:100%;height:4px}.timeline-slider__input::-webkit-slider-thumb{-webkit-appearance:none;border-radius:var(--radius-full);border:2px solid var(--color-stone-600);cursor:grab;width:20px;height:20px;transition:transform var(--transition-fast);background:#fff;box-shadow:0 2px 6px #0000001a}.timeline-slider__input::-webkit-slider-thumb:hover{transform:scale(1.15)}.timeline-slider__input::-webkit-slider-thumb:active{cursor:grabbing;border-color:var(--color-stone-800);transform:scale(1.1)}.timeline-slider__input::-moz-range-thumb{border-radius:var(--radius-full);border:2px solid var(--color-stone-600);cursor:grab;background:#fff;width:20px;height:20px;box-shadow:0 2px 6px #0000001a}.timeline-slider__labels{margin-top:var(--space-xs);justify-content:space-between;padding:0 2px;display:flex}.timeline-slider__label{font-size:var(--text-xs);color:var(--color-stone-400);font-variant-numeric:tabular-nums}.timeline-slider__current{top:-8px;left:var(--timeline-progress,0%);font-size:var(--text-xs);color:var(--color-stone-800);background:var(--glass-bg-strong);border-radius:var(--radius-full);white-space:nowrap;pointer-events:none;padding:2px 8px;font-weight:600;position:absolute;transform:translate(-50%);box-shadow:0 1px 4px #00000014}.cashflow-page .page__content{padding-top:var(--space-md)}.cashflow-page__summary{gap:var(--space-sm);margin-bottom:var(--space-lg);display:flex}.cashflow-page__summary-card{padding:var(--space-md);text-align:center;flex:1}.cashflow-page__summary-label{font-size:var(--text-xs);color:var(--color-stone-500);margin-bottom:var(--space-xs);font-weight:500}.cashflow-page__summary-value{font-family:var(--font-mono);font-size:var(--text-lg);font-variant-numeric:tabular-nums;font-weight:600}.cashflow-page__add-btn{bottom:calc(var(--tab-bar-height) + var(--safe-area-bottom) + var(--space-lg));right:var(--space-lg);border-radius:var(--radius-full);background:var(--color-stone-900);color:#fff;width:52px;height:52px;z-index:var(--z-elevated);transition:transform var(--transition-fast), box-shadow var(--transition-fast);justify-content:center;align-items:center;display:flex;position:fixed;box-shadow:0 4px 16px #1c191733,0 2px 4px #1c191714}.cashflow-page__add-btn:hover{transform:scale(1.05);box-shadow:0 6px 24px #1c191740,0 3px 6px #1c19171a}.cashflow-page__add-btn:active{transform:scale(.95)}.cashflow-page__add-btn svg{stroke-width:2px;width:24px;height:24px}.cashflow-group{margin-bottom:var(--space-lg)}.cashflow-group__header{padding:var(--space-sm) var(--space-xs);margin-bottom:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.cashflow-group__title{font-size:var(--text-sm);color:var(--color-stone-600);font-weight:600}.cashflow-group__total{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-stone-500);font-variant-numeric:tabular-nums;font-weight:500}.simulation-page__controls{align-items:center;gap:var(--space-sm);padding:var(--space-sm) 0;margin-bottom:var(--space-md);scrollbar-width:none;-ms-overflow-style:none;display:flex;overflow-x:auto}.simulation-page__controls::-webkit-scrollbar{display:none}.simulation-page__timeline{margin-bottom:var(--space-lg)}.simulation-page__results{gap:var(--space-md);flex-direction:column;display:flex}.simulation-page__month-card{animation:.3s ease-out backwards slideUp}.simulation-page__month-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.simulation-page__month-title{font-size:var(--text-base);color:var(--color-stone-800);font-weight:600}.simulation-page__month-balance{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-weight:600}.simulation-page__row{padding:var(--space-xs) 0;justify-content:space-between;align-items:center;display:flex}.simulation-page__row-label{font-size:var(--text-sm);color:var(--color-stone-600)}.simulation-page__row-value{font-family:var(--font-mono);font-size:var(--text-sm);font-variant-numeric:tabular-nums}.overview-page__hero{text-align:center;padding:var(--space-xl) 0 var(--space-lg);animation:.5s ease-out fadeIn}.overview-page__hero-label{font-size:var(--text-sm);color:var(--color-stone-400);margin-bottom:var(--space-xs);font-weight:500}.overview-page__hero-amount{font-family:var(--font-mono);font-size:var(--text-4xl);color:var(--color-stone-900);letter-spacing:var(--tracking-tight);font-variant-numeric:tabular-nums;margin-bottom:var(--space-sm);font-weight:700;line-height:1}.overview-page__hero-change{font-size:var(--text-sm);border-radius:var(--radius-full);align-items:center;gap:4px;padding:3px 10px;font-weight:500;display:inline-flex}.overview-page__hero-change--up{color:var(--color-income);background:var(--color-income-light)}.overview-page__hero-change--down{color:var(--color-expense);background:var(--color-expense-light)}.overview-page__grid{gap:var(--space-sm);margin-bottom:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}.overview-page__grid-card{padding:var(--space-md)}.overview-page__grid-card-label{font-size:var(--text-xs);color:var(--color-stone-500);margin-bottom:var(--space-xs);align-items:center;gap:4px;font-weight:500;display:flex}.overview-page__grid-card-label .dot{border-radius:var(--radius-full);flex-shrink:0;width:6px;height:6px}.overview-page__grid-card-value{font-family:var(--font-mono);font-size:var(--text-lg);font-variant-numeric:tabular-nums;color:var(--color-stone-800);font-weight:600}.overview-page__chart-section{margin-bottom:var(--space-xl)}.overview-page__chart-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.overview-page__chart-title{font-size:var(--text-base);color:var(--color-stone-800);font-weight:600}.overview-page__chart-container{padding:var(--space-md);justify-content:center;align-items:center;min-height:200px;display:flex}.rating-page__score{text-align:center;padding:var(--space-xl) 0;animation:.5s cubic-bezier(.34,1.56,.64,1) scaleIn}.rating-page__score-badge{margin:0 auto var(--space-md)}.rating-page__score-label{font-size:var(--text-sm);color:var(--color-stone-500);font-weight:500}.rating-page__score-value{font-family:var(--font-mono);font-size:var(--text-3xl);color:var(--color-stone-900);margin-top:var(--space-xs);font-weight:700}.rating-page__score-desc{font-size:var(--text-sm);color:var(--color-stone-400);margin-top:var(--space-xs);max-width:240px;margin-left:auto;margin-right:auto}.rating-page__radar{padding:var(--space-md);margin-bottom:var(--space-lg);justify-content:center;align-items:center;min-height:260px;display:flex}.rating-page__dimensions{gap:var(--space-sm);grid-template-columns:1fr 1fr;display:grid}.rating-page__dimension-card{padding:var(--space-md);animation:.3s ease-out backwards slideUp}.rating-page__dimension-header{margin-bottom:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.rating-page__dimension-name{font-size:var(--text-sm);color:var(--color-stone-700);font-weight:600}.rating-page__dimension-score{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-stone-500);font-weight:600}.rating-page__dimension-bar{margin-top:var(--space-sm)}.rating-page__dimension-card:first-child{animation-delay:0s}.rating-page__dimension-card:nth-child(2){animation-delay:60ms}.rating-page__dimension-card:nth-child(3){animation-delay:.12s}.rating-page__dimension-card:nth-child(4){animation-delay:.18s}.rating-page__dimension-card:nth-child(5){animation-delay:.24s}.rating-page__dimension-card:nth-child(6){animation-delay:.3s}.settings-page .page__content{padding-top:var(--space-md)}.settings-section{background:var(--glass-bg);-webkit-backdrop-filter:blur(24px);border:1px solid var(--glass-border);border-radius:var(--radius-md);margin-bottom:var(--space-md);box-shadow:var(--glass-shadow-subtle);transition:all var(--transition-base);overflow:hidden}.settings-section:hover{border-color:var(--glass-border-strong);box-shadow:var(--glass-shadow);transform:translateY(-1px)}.settings-section .section-header-row{padding:14px var(--space-md);transition:background-color var(--transition-fast);background:#0f172a05;justify-content:space-between;align-items:center;margin-bottom:0;display:flex}html[data-theme=dark] .settings-section .section-header-row{background:#ffffff05}.settings-section .section-header-row:hover{background:#0f172a0a}html[data-theme=dark] .settings-section .section-header-row:hover{background:#ffffff0a}.settings-section .section-title{font-size:var(--text-base);color:var(--color-stone-800);flex:1;align-items:center;gap:10px;margin:0;font-weight:600;display:flex}.settings-section .section-title-icon{color:var(--color-stone-600);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.settings-section .collapse-arrow{color:var(--color-stone-400);transition:transform var(--transition-base);cursor:pointer;-webkit-user-select:none;user-select:none;font-size:10px}.settings-section .collapse-arrow--expanded{transform:rotate(180deg)}.settings-section__content{padding:var(--space-md);border-top:1px solid var(--glass-border);background:0 0}.settings-page__group{margin-bottom:var(--space-xl)}.settings-page__group-header{font-size:var(--text-xs);color:var(--color-stone-400);text-transform:uppercase;letter-spacing:.08em;padding:0 var(--space-xs);margin-bottom:var(--space-sm);font-weight:600}.settings-page__card{overflow:hidden}.settings-page__row{padding:var(--space-md) 0;border-bottom:1px solid #0000000a;justify-content:space-between;align-items:center;min-height:48px;display:flex}.settings-page__row:last-child{border-bottom:none}.settings-page__row-left{align-items:center;gap:var(--space-md);flex:1;min-width:0;display:flex}.settings-page__row-icon{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--color-stone-500);background:#0000000a;flex-shrink:0;justify-content:center;align-items:center;display:flex}.settings-page__row-icon svg{width:18px;height:18px}.settings-page__row-content{flex:1;min-width:0}.settings-page__row-title{font-size:var(--text-base);color:var(--color-stone-800);font-weight:500}.settings-page__row-subtitle{font-size:var(--text-xs);color:var(--color-stone-400);margin-top:1px}.settings-page__row-right{align-items:center;gap:var(--space-sm);color:var(--color-stone-400);flex-shrink:0;display:flex}.settings-page__row-value{font-size:var(--text-sm);color:var(--color-stone-500)}.settings-page__row-arrow{width:16px;height:16px}.settings-page__footer{text-align:center;padding:var(--space-xl) 0}.settings-page__footer-text{font-size:var(--text-xs);color:var(--color-stone-400)}.settings-page__footer-version{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-stone-300);margin-top:var(--space-xs)}.simulation-actions-row{align-items:center;gap:var(--space-md);margin-top:var(--space-md);margin-bottom:var(--space-lg);display:flex}.simulation-actions-row .btn{flex:1;justify-content:center;align-items:center;gap:6px;padding:12px 16px;display:inline-flex}.cashflow-actions{margin-top:var(--space-lg);margin-bottom:var(--space-md)}.cashflow-actions .btn{padding:14px 20px}@media (width<=374px){:root{--text-4xl:1.875rem;--text-3xl:1.5rem;--space-lg:20px;--space-xl:28px}.page__content{padding-left:var(--space-md);padding-right:var(--space-md)}.page__title{font-size:var(--text-xl)}.overview-page__hero-amount{font-size:var(--text-3xl)}.overview-page__grid{gap:var(--space-xs)}}@media (width>=431px){.page{padding-left:var(--space-md);padding-right:var(--space-md)}.overview-page__grid,.rating-page__dimensions{gap:var(--space-md)}}@media (width>=768px){.page{max-width:480px;margin:0 auto}.modal{max-width:420px}.modal-overlay{align-items:center}.toast{max-width:360px}}@media (width>=1024px){body{background-image:radial-gradient(at 20% 0,#6b8cae0f 0%,#0000 50%),radial-gradient(at 80% 100%,#5b8a720d 0%,#0000 50%)}.page{max-width:430px;box-shadow:-1px 0 0 var(--color-stone-200), 1px 0 0 var(--color-stone-200)}.tab-bar{border-radius:var(--radius-lg) var(--radius-lg) 0 0;border-left:1px solid var(--glass-border);border-right:1px solid var(--glass-border);max-width:430px}.cashflow-page__add-btn{right:calc(50% - 215px + var(--space-lg))}}@media (display-mode:standalone){.page__header{padding-top:calc(var(--space-md) + var(--safe-area-top))}.page{padding-top:0}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.glass-card:hover{transform:none}.list-item{animation:none}}.overview-section{margin-bottom:var(--space-lg);animation:.3s ease-out backwards slideUp}.section-title{font-size:var(--text-base);color:var(--color-stone-700);margin-bottom:var(--space-md);padding-left:var(--space-xs);align-items:center;gap:8px;font-weight:600;display:flex}.overview-grid{gap:var(--space-md);flex-direction:column;display:flex}.overview-card{padding:var(--space-md);flex-direction:column;justify-content:center;min-height:80px;display:flex}.overview-card--large{padding:var(--space-lg);background:var(--glass-bg-strong);border-color:var(--glass-border-strong);min-height:100px}.card-label{font-size:var(--text-xs);color:var(--color-stone-500);text-transform:uppercase;letter-spacing:.02em;margin-bottom:6px;font-weight:500}.overview-sub-grid{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}@media (width<=374px){.overview-sub-grid{gap:var(--space-sm);grid-template-columns:1fr}}.breakdown-grid{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}@media (width<=374px){.breakdown-grid{gap:var(--space-sm);grid-template-columns:1fr}}.breakdown-card{padding:var(--space-md);gap:var(--space-sm);flex-direction:column;display:flex}.breakdown-item{flex-direction:column;gap:4px;display:flex}.breakdown-label{font-size:var(--text-xs);color:var(--color-stone-500);font-weight:500}.csm-display{font-family:var(--font-sans);font-size:var(--text-base);letter-spacing:var(--tracking-tight);font-weight:600}.csm--safe{color:var(--color-safe)}.csm--warning{color:var(--color-warning)}.csm--danger{color:var(--color-danger)}.stat-ratio{font-family:var(--font-mono);font-size:var(--text-base);color:var(--color-stone-800);font-weight:600}.monthly-flow-grid{gap:var(--space-md);flex-direction:column;display:flex}.monthly-flow-card{padding:var(--space-lg);gap:var(--space-md);flex-direction:column;display:flex}.flow-primary{gap:var(--space-sm);flex-direction:column;display:flex}.flow-primary__item{padding:var(--space-xs) 0;justify-content:space-between;align-items:center;display:flex}.flow-primary__item--balance{padding-top:var(--space-sm);border-top:1px dashed var(--color-stone-200);margin-top:4px}html[data-theme=dark] .flow-primary__item--balance{border-top-color:var(--color-stone-300)}.flow-label{font-size:var(--text-sm);color:var(--color-stone-600);font-weight:500}.flow-divider{background:var(--color-stone-200);opacity:.6;height:1px;margin:var(--space-xs) 0}html[data-theme=dark] .flow-divider{background:var(--color-stone-300)}.flow-secondary{gap:var(--space-sm);flex-direction:column;display:flex}.flow-secondary__item{font-size:var(--text-sm);justify-content:space-between;align-items:center;display:flex}.flow-sec-label{font-size:var(--text-xs);color:var(--color-stone-500);align-items:center;gap:6px;display:flex}html[data-theme=dark] .flow-sec-label{color:var(--color-stone-400)}.flow-rating-summary-card{padding:var(--space-md);gap:var(--space-md);background:var(--glass-bg-strong);border-color:var(--glass-border-strong);flex-direction:column;display:flex}.rating-summary-header{border-bottom:1px solid var(--color-stone-150);padding-bottom:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.summary-label{font-size:var(--text-sm);color:var(--color-stone-800);font-weight:600}.rating-summary-body{gap:var(--space-sm);flex-direction:column;display:flex}.rating-summary-body .score-label{font-size:var(--text-sm);color:var(--color-stone-600)}.rating-summary-body .score-label strong{font-size:var(--text-lg);font-family:var(--font-mono);color:var(--color-stone-800)}.rating-tagline{font-size:var(--text-sm);color:var(--color-stone-700);font-weight:500;line-height:var(--leading-relaxed)}.prohib-box{padding:var(--space-sm) var(--space-md);background:var(--color-danger-light);border-radius:var(--radius-sm);flex-direction:column;gap:4px;display:flex}.prohib-title{font-size:var(--text-xs);font-weight:600}.prohib-text{font-size:var(--text-xs);color:var(--color-stone-700);line-height:var(--leading-normal)}.rating-score-card{align-items:center;gap:var(--space-lg);padding:var(--space-lg);background:var(--glass-bg-strong);border-color:var(--glass-border-strong);margin-bottom:var(--space-lg);animation:.4s cubic-bezier(.34,1.56,.64,1) scaleIn;display:flex}.score-card-badge-container{flex-shrink:0;justify-content:center;align-items:center;display:flex}.score-card-details{flex-direction:column;flex:1;gap:4px;display:flex}.score-card-title{font-size:var(--text-sm);color:var(--color-stone-500);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.score-card-number{font-size:var(--text-base);color:var(--color-stone-500);align-items:baseline;gap:var(--space-xs);display:flex}.score-card-number strong{font-size:var(--text-3xl);font-family:var(--font-mono);color:var(--color-stone-900);font-weight:700}.score-total{font-size:var(--text-xs);color:var(--color-stone-400)}.score-card-label{font-size:var(--text-base);color:var(--color-stone-800);font-weight:600}.rating-dimensions-section{margin-top:var(--space-lg);margin-bottom:var(--space-xl)}.dimensions-list{gap:var(--space-md);flex-direction:column;display:flex}.dimension-card{padding:var(--space-md);gap:var(--space-sm);flex-direction:column;display:flex}.dimension-header{justify-content:space-between;align-items:center;display:flex}.dimension-name{font-size:var(--text-sm);color:var(--color-stone-800);font-weight:600}.dimension-score{font-size:var(--text-xs);color:var(--color-stone-500)}.dimension-score strong{font-size:var(--text-base);font-family:var(--font-mono);color:var(--color-stone-800)}.dimension-detail-text{font-size:var(--text-xs);color:var(--color-stone-500);line-height:var(--leading-relaxed);margin-top:2px}.rating-recs-section{margin-top:var(--space-lg);margin-bottom:var(--space-xl)}.recs-grid{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:1fr;display:grid}.rec-card{padding:var(--space-md);gap:var(--space-sm);flex-direction:column;display:flex}.rec-card-title{font-size:var(--text-sm);color:var(--color-stone-800);margin-bottom:var(--space-xs);font-weight:600}.rec-list{gap:var(--space-sm);flex-direction:column;display:flex}.rec-list-item{align-items:flex-start;gap:var(--space-sm);display:flex}.rec-bullet{background:var(--color-stone-150);width:20px;height:20px;color:var(--color-stone-700);font-size:var(--text-xs);font-family:var(--font-mono);border-radius:var(--radius-full);flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;font-weight:600;display:flex}.rec-bullet--action{background:var(--color-safe-light);color:var(--color-safe)}.rec-text{font-size:var(--text-sm);color:var(--color-stone-600);line-height:var(--leading-normal);flex:1}.danger-zone-grid{gap:var(--space-md);flex-direction:column;display:flex}.alert-card{padding:var(--space-md);gap:var(--space-xs);flex-direction:column;display:flex}.alert-card--danger{background:#f43f5e0a}.alert-card--warning{background:#d977060a}.alert-card-title{font-size:var(--text-sm);font-weight:600}.alert-card-text{font-size:var(--text-xs);color:var(--color-stone-700);line-height:var(--leading-relaxed)}.scenario-comparison-view{gap:var(--space-md);flex-direction:column;display:flex}.comparison-selectors-card{padding:var(--space-md)}.selectors-grid{gap:var(--space-md);flex-wrap:wrap;display:flex}.checkbox-label{align-items:center;gap:var(--space-sm);font-size:var(--text-sm);color:var(--color-stone-700);cursor:pointer;-webkit-user-select:none;user-select:none;font-weight:500;display:inline-flex}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-stone-800);cursor:pointer}.comparison-chart-card{padding:var(--space-md)}.comparison-table-card{padding:var(--space-md);overflow-x:auto}.comparison-table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.comparison-table th,.comparison-table td{padding:12px var(--space-sm);text-align:left;border-bottom:1px solid var(--color-stone-150)}.comparison-table th{color:var(--color-stone-700);background:var(--color-stone-100);font-weight:600}html[data-theme=dark] .comparison-table th{background:#0f172a99}.comparison-table td{color:var(--color-stone-800)}.comparison-table tr:hover{background:#0f172a05}html[data-theme=dark] .comparison-table tr:hover{background:#ffffff05}.empty-list-msg{text-align:center;color:var(--color-stone-400);font-size:var(--text-sm);padding:var(--space-xl) 0}.overview-loading{text-align:center;color:var(--color-stone-500);font-size:var(--text-sm);padding:var(--space-xl) 0}.plans-list{gap:var(--space-md);margin-top:var(--space-sm);flex-direction:column;display:flex}.plan-manager-card{padding:var(--space-md);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);gap:var(--space-sm);transition:all var(--transition-base);flex-direction:column;display:flex}.plan-manager-card:hover{box-shadow:var(--glass-shadow-elevated);transform:translateY(-2px)}.plan-manager-card--active{border-color:var(--color-stone-600);background:var(--glass-bg-strong)}.plan-manager-header{justify-content:space-between;align-items:flex-start;gap:var(--space-sm);display:flex}.plan-name{font-size:var(--text-base);color:var(--color-stone-900);align-items:center;gap:6px;font-weight:600;display:flex}.active-tag{background:var(--color-safe-light);color:var(--color-safe);border-radius:var(--radius-full);padding:2px 6px;font-size:10px;font-weight:600}.plan-time{font-size:var(--text-xs);color:var(--color-stone-400);margin-top:2px}.plan-networth{text-align:right;flex-direction:column;flex-shrink:0;gap:2px;display:flex}.net-label{color:var(--color-stone-400);text-transform:uppercase;font-size:10px}.net-val{font-family:var(--font-mono);font-size:var(--text-base);color:var(--color-stone-800);font-weight:600}.plan-desc{font-size:var(--text-sm);color:var(--color-stone-500);line-height:var(--leading-normal);border-top:1px solid var(--color-stone-150);padding-top:var(--space-sm);margin-top:2px}.plan-card-actions{justify-content:flex-end;align-items:center;gap:var(--space-sm);margin-top:var(--space-xs);display:flex}.form-group-section{border:1px solid var(--color-stone-150);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-md);gap:var(--space-sm);background:#0f172a05;flex-direction:column;display:flex}html[data-theme=dark] .form-group-section{border-color:var(--color-stone-200);background:#ffffff05}.form-group-section-title{font-size:var(--text-sm);color:var(--color-stone-800);margin-bottom:var(--space-xs);border-left:3px solid var(--color-stone-600);padding-left:var(--space-xs);font-weight:600}html[data-theme=dark] .form-group-section-title{border-left-color:var(--color-stone-400)}.form-row{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}@media (width<=374px){.form-row{gap:var(--space-xs);grid-template-columns:1fr}}.dynamic-list-row{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xs);display:flex}.dynamic-list-row .form-field__input{flex:1}.modal-overlay--plan{padding:10px;padding-bottom:calc(10px + var(--safe-area-bottom));align-items:center}.modal--plan{border-radius:var(--radius-lg);flex-direction:column;width:min(920px,100vw - 20px);max-height:min(92dvh,840px);display:flex}.modal--plan .modal__header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-stone-150);flex:none}.modal--plan .modal__title{font-size:var(--text-lg);margin:0;line-height:1.25}.modal--plan .plan-form{min-height:0;max-height:none;padding:var(--space-md);gap:var(--space-md);flex:auto;grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.modal--plan .modal__error,.modal--plan .sticky-actions{grid-column:1/-1}.modal--plan .form-group-section{min-width:0;padding:var(--space-md);border-radius:var(--radius-md);margin:0}.modal--plan .form-group-section:first-of-type,.modal--plan .form-group-section:last-of-type{grid-column:1/-1}.modal--plan .form-group-section h4{margin:0 0 var(--space-sm);font-size:var(--text-sm);line-height:1.3}.modal--plan .form-row{gap:var(--space-sm)}.modal--plan .form-field{margin-bottom:var(--space-sm)}.modal--plan textarea.form-field__input{min-height:72px}.modal--plan .form-field__input,.modal--plan .form-field__select,.modal--plan input.form-field__input,.modal--plan select.form-field__select{min-height:42px;font-size:var(--text-sm);padding-top:10px;padding-bottom:10px}.modal--plan .dynamic-list-row{width:100%;margin-bottom:var(--space-sm)}.modal--plan .dynamic-list-row[style]{grid-template-columns:minmax(150px,2fr) minmax(72px,.8fr) minmax(120px,1.5fr) auto!important}.modal--plan .sticky-actions{margin:var(--space-xs) calc(var(--space-md) * -1) calc(var(--space-md) * -1);padding:var(--space-md);background:var(--glass-bg-strong)}@media (width<=720px){.modal-overlay--plan{padding:8px;padding-bottom:calc(8px + var(--safe-area-bottom));align-items:flex-end}.modal--plan{width:100%;max-height:calc(100dvh - 16px - var(--safe-area-bottom));border-radius:var(--radius-lg) var(--radius-lg) 0 0}.modal--plan .modal__header{padding:var(--space-sm) var(--space-md)}.modal--plan .plan-form{gap:var(--space-sm);padding:var(--space-sm);-webkit-overflow-scrolling:touch;grid-template-columns:1fr;overflow-y:auto}.modal--plan .form-group-section,.modal--plan .form-group-section:first-of-type,.modal--plan .form-group-section:last-of-type{padding:var(--space-sm);grid-column:auto}.modal--plan .form-row{grid-template-columns:1fr}.modal--plan .dynamic-list-row[style]{grid-template-columns:inherit!important;gap:var(--space-xs)!important;display:grid!important}.modal--plan .dynamic-list-row input:first-of-type{grid-column:auto}.modal--plan .dynamic-list-row button{min-height:42px}.modal--plan .sticky-actions{margin:var(--space-xs) calc(var(--space-sm) * -1) calc(var(--space-sm) * -1);padding:var(--space-sm);z-index:10;position:sticky;bottom:0}}.section-header-row{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.modal__error{background:var(--color-danger-light);color:var(--color-danger);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:var(--text-xs);margin-bottom:var(--space-md);font-weight:500}.simulation-totals-card{padding:var(--space-md);margin-bottom:var(--space-md);background:var(--glass-bg-strong);border-color:var(--glass-border-strong)}.totals-row{justify-content:space-between;align-items:center;display:flex}.total-item{flex-direction:column;flex:1;align-items:center;gap:4px;display:flex}.total-item__label{font-size:var(--text-xs);color:var(--color-stone-400);font-weight:500}.total-item--balance{border-left:1px solid var(--color-stone-150)}.simulation-controls{margin-bottom:var(--space-md)}.simulation-list{gap:var(--space-sm);margin-top:var(--space-sm);flex-direction:column;display:flex}.simulation-record-card{padding:var(--space-md);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);gap:var(--space-xs);transition:all var(--transition-fast);flex-direction:column;display:flex}.simulation-record-card:hover{box-shadow:var(--glass-shadow-subtle);transform:translateY(-1px)}.record-header{align-items:center;gap:var(--space-sm);display:flex}.record-icon{border-radius:var(--radius-sm);background:#0f172a0a;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.record-icon-svg{color:var(--color-stone-500)}.record-info{align-items:center;gap:var(--space-sm);flex:1;min-width:0;display:flex}.record-name{font-size:var(--text-sm);color:var(--color-stone-800);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.source-tag{color:var(--color-stone-500);border-radius:var(--radius-xs);background:#0f172a0d;padding:1px 4px;font-size:9px;font-weight:500}.record-amount{font-family:var(--font-mono);font-size:var(--text-sm);flex-shrink:0;font-weight:600}.record-note{font-size:var(--text-xs);color:var(--color-stone-400);line-height:var(--leading-normal);margin-left:40px}.record-card-actions{justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-xs);padding-top:var(--space-xs);border-top:1px solid #00000008;display:flex}.radio-group{gap:var(--space-md);grid-template-columns:1fr 1fr;margin-top:4px;display:grid}.radio-option{justify-content:center;align-items:center;gap:var(--space-sm);border:1.5px solid var(--color-stone-200);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-stone-600);cursor:pointer;transition:all var(--transition-fast);background:var(--color-stone-50);padding:12px;font-weight:500;display:flex}.radio-option:hover{border-color:var(--color-stone-400);background:#fff}.radio-option input[type=radio]{display:none}.radio-option:has(input[type=radio]:checked){box-shadow:var(--focus-ring);font-weight:600;border-color:var(--color-stone-800)!important;color:var(--color-stone-900)!important;background:#fff!important}html[data-theme=dark] .radio-option:has(input[type=radio]:checked){border-color:var(--color-stone-400)!important;color:var(--color-stone-50)!important;background:var(--color-stone-900)!important}.form-field--toggle{padding:var(--space-sm) 0;border-bottom:1px solid var(--color-stone-150);justify-content:space-between;align-items:center;display:flex;flex-direction:row!important}.form-field--toggle .form-field__label{margin-bottom:0}.preview-import-content{gap:var(--space-md);max-height:65dvh;padding:0 var(--space-lg) var(--space-lg);-webkit-overflow-scrolling:touch;overscroll-behavior:contain;flex-direction:column;display:flex;overflow-y:auto}.modal--large{max-width:900px}.loan-form-container{gap:var(--space-lg);max-height:calc(85dvh - 80px);padding:0 var(--space-lg) var(--space-lg);-webkit-overflow-scrolling:touch;overscroll-behavior:contain;flex-direction:column;display:flex;overflow-y:auto}.loan-form-inputs{max-height:none!important;padding:0!important;overflow:visible!important}.loan-form-preview{border-radius:var(--radius-lg);padding:var(--space-lg);border:1px dashed var(--color-stone-200);background:#0f172a08}html[data-theme=dark] .loan-form-preview{border-color:var(--color-stone-700);background:#ffffff08}.loan-preview-stats{gap:var(--space-md);margin-top:var(--space-md);flex-direction:column;display:flex}.preview-stat-card{background:var(--glass-bg-subtle);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:var(--space-md);gap:var(--space-xs);flex-direction:column;display:flex}.preview-schedule-notes{font-size:var(--text-xs);color:var(--color-stone-500);margin-top:var(--space-sm);line-height:1.5}.preview-placeholder{color:var(--color-stone-400);font-size:var(--text-sm);text-align:center;padding:var(--space-xl) 0}@media (width>=769px){.loan-form-container{height:60vh;max-height:500px;padding:0 var(--space-lg) var(--space-lg);flex-direction:row;align-items:stretch;overflow:hidden}.loan-form-inputs{flex:1.2;max-height:100%!important;padding-right:var(--space-md)!important;overflow-y:auto!important}.loan-form-preview{flex:1;height:100%;margin:0;overflow-y:auto}}.overview-charts-section{margin-top:var(--space-xl)}.charts-grid{gap:var(--space-md);flex-direction:column;display:flex}.chart-card{padding:var(--space-md)}.chart-card h4{margin-top:0;margin-bottom:var(--space-md);font-size:var(--text-sm);color:var(--color-stone-800);font-weight:600}.chart-container{width:100%;height:260px;position:relative}.pie-chart-container{height:200px}.empty-chart-placeholder{height:100%;color:var(--color-stone-400);font-size:var(--text-sm);border-radius:var(--radius-md);background:#00000005;justify-content:center;align-items:center;font-style:italic;display:flex}@media (width>=768px){.charts-grid{gap:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}}.warning-banner{background:var(--color-warning-light);color:var(--color-warning);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:500}.import-summary-bar{font-size:var(--text-xs);color:var(--color-stone-500);padding:var(--space-xs) 0;border-bottom:1px solid var(--color-stone-150);justify-content:space-between;align-items:center;display:flex}.preview-sections{gap:var(--space-lg);flex-direction:column;display:flex}.preview-section{gap:var(--space-xs);flex-direction:column;display:flex}.preview-section-title{font-size:var(--text-xs);color:var(--color-stone-500);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.preview-list{border-radius:var(--radius-sm);padding:var(--space-xs);background:#0f172a05;flex-direction:column;gap:2px;display:flex}.preview-row{padding:8px var(--space-xs);font-size:var(--text-sm);border-bottom:1px solid #00000005;justify-content:space-between;align-items:center;display:flex}.preview-row:last-child{border-bottom:none}.preview-row__name{color:var(--color-stone-700)}.preview-row__amount{font-family:var(--font-mono);font-weight:500}.preview-row--diff{background:#0f172a03}.preview-row__diff-vals{align-items:center;gap:var(--space-xs);font-family:var(--font-mono);font-size:var(--text-xs);display:flex}.old-val{color:var(--color-stone-400);text-decoration:line-through}.new-val{font-weight:600}.preview-row--skipped{opacity:.6}.preview-placeholder-msg{text-align:center;color:var(--color-stone-400);padding:var(--space-lg) 0;font-size:var(--text-sm)}@media print{.tab-bar,.cashflow-page__add-btn,.plan-selector,.toast{display:none!important}.page{max-width:100%;padding-bottom:0}.glass-card{-webkit-backdrop-filter:none;backdrop-filter:none;background:#fff;border:1px solid #e0e0e0;box-shadow:0 0 1px #0000001a}.page__header{-webkit-backdrop-filter:none;backdrop-filter:none;background:#fff;position:static}}
