*,:before,:after{box-sizing:border-box}:root{color:#374151;-webkit-font-smoothing:antialiased;background-color:#f9fafb;font-family:system-ui,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.5}body{min-height:100vh;margin:0;overflow-x:clip}#root{min-height:100vh}button,input{font-family:inherit}.app{max-width:780px;margin:0 auto;padding:0 16px 64px}.app-header{justify-content:space-between;align-items:flex-start;gap:16px;padding:40px 0 8px;display:flex}.header-titles{text-align:left}.app-header h1{color:#5b21b6;letter-spacing:-1px;margin:0 0 4px;font-size:2.4rem;font-weight:700}.app-header p{color:#6b7280;margin:0;font-size:1rem}.header-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:6px;display:flex}.today-date{color:#6b7280;white-space:nowrap;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:8px;margin-top:6px;padding:6px 12px;font-size:.85rem}.quote-badge{white-space:nowrap;background:#ede9fe;border:1px solid #c4b5fd;border-radius:8px;align-items:center;gap:6px;padding:5px 12px;display:flex}.quote-badge--stale{background:#fef3c7;border-color:#fcd34d}.quote-badge-ticker{color:#5b21b6;letter-spacing:.03em;text-transform:uppercase;font-size:.78rem;font-weight:600}.quote-badge--stale .quote-badge-ticker{color:#92400e}.quote-badge-price{color:#4c1d95;font-variant-numeric:tabular-nums;font-size:.9rem;font-weight:700}.quote-badge--stale .quote-badge-price{color:#78350f}.quote-badge-time{color:#7c3aed;border-left:1px solid #c4b5fd;padding-left:6px;font-size:.75rem}.quote-badge--stale .quote-badge-time{color:#b45309;border-color:#fcd34d}.quote-badge-refresh{cursor:pointer;color:#7c3aed;opacity:.6;background:0 0;border:none;align-items:center;padding:0 0 0 4px;font-size:.85rem;line-height:1;transition:opacity .15s;display:flex}.quote-badge-refresh:hover{opacity:1}.quote-badge--stale .quote-badge-refresh{color:#b45309}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.quote-badge-refresh--spinning{opacity:1;animation:.6s linear spin}.app-main{flex-direction:column;gap:24px;margin-top:24px;display:flex}.app-nav{border-bottom:2px solid #e5e7eb;gap:4px;margin-top:24px;display:flex}.nav-link{color:#6b7280;border-bottom:2px solid #0000;border-radius:6px 6px 0 0;margin-bottom:-2px;padding:10px 20px;font-size:.95rem;font-weight:600;text-decoration:none;transition:color .15s,border-color .15s}.nav-link:hover{color:#5b21b6}.nav-link--active{color:#5b21b6;border-bottom-color:#7c3aed}.planner-table-wrapper{margin:0 -4px;overflow-x:auto}.planner-table{border-collapse:collapse;width:100%;font-size:.875rem}.planner-table thead th{color:#6b7280;text-align:right;white-space:nowrap;border-bottom:2px solid #e5e7eb;padding:0 16px 12px;font-size:.8rem;font-weight:600}.planner-col-month{min-width:90px;text-align:left!important;padding-left:4px!important}.planner-col-income{min-width:160px}.planner-col-expenses,.planner-col-pct,.planner-col-balance{min-width:120px}.planner-col-pac{white-space:nowrap;min-width:140px}.planner-col-savings{min-width:140px}.planner-row:nth-child(2n){background:#f9fafb}.planner-row--current,.planner-row--current:nth-child(2n){outline-offset:-1px;background:#fefce8;outline:1px solid #fde047}.planner-row--year-end td{border-bottom:2px solid #6b7280}.planner-month-label{color:#374151;white-space:nowrap;padding:10px 16px 10px 4px;font-weight:600}.planner-income-cell{padding:6px 12px}.planner-input-wrap{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;align-items:center;gap:4px;padding:0 10px;transition:border-color .2s;display:flex}.planner-input-wrap:focus-within{border-color:#7c3aed}.planner-currency{color:#9ca3af;-webkit-user-select:none;user-select:none;font-size:.9rem}.planner-income-input{color:#111827;text-align:right;background:0 0;border:none;outline:none;width:100%;padding:7px 0;font-size:.9rem}.planner-income-input--saving{opacity:.5}.planner-income-input::-webkit-outer-spin-button{-webkit-appearance:none}.planner-income-input::-webkit-inner-spin-button{-webkit-appearance:none}.planner-income-input[type=number]{-moz-appearance:textfield}.planner-cell{text-align:right;white-space:nowrap;border-left:1px solid #f3f4f6;padding:10px 16px}.planner-cell--zero{color:#9ca3af}.planner-cell--expense{color:#5b21b6;font-weight:600}.planner-cell--positive{color:#16a34a;font-weight:600}.planner-cell--negative{color:#dc2626;font-weight:600}.planner-cell--warning{color:#d97706;font-weight:600}.planner-cell--pac{font-size:.82rem}.planner-quote-badge{color:#5b21b6;vertical-align:middle;letter-spacing:.01em;background:#ede9fe;border-radius:999px;margin-left:6px;padding:2px 7px;font-size:.72rem;font-weight:700;display:inline-block}.planner-quote-badge--stale{color:#92400e;background:#fef3c7}.planner-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.planner-header h2{margin:0}.planner-toggle-btn{color:#374151;cursor:pointer;background:#f9fafb;border:1px solid #d1d5db;border-radius:6px;padding:.375rem .875rem;font-size:.85rem;transition:background .15s,border-color .15s}.planner-toggle-btn:hover{background:#f3f4f6;border-color:#9ca3af}.planner-toggle-btn--active{color:#1d4ed8;background:#eff6ff;border-color:#3b82f6}.card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:28px 28px 24px;box-shadow:0 1px 6px #0000000d}.card h2{color:#111827;margin:0 0 20px;font-size:1.1rem;font-weight:600}.expense-form{flex-direction:column;gap:18px;display:flex}.form-row{flex-wrap:wrap;gap:16px;display:flex}.field{flex-direction:column;flex:240px;gap:6px;display:flex}.field-amount{flex:0 160px}.field label{color:#374151;font-size:.85rem;font-weight:500}.field input{color:#111827;background:#fff;border:1.5px solid #d1d5db;border-radius:8px;outline:none;padding:10px 12px;font-size:1rem;transition:border-color .2s}.field input:focus{border-color:#7c3aed}.estimated-toggle{color:#374151;cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;font-size:.875rem;font-weight:500;display:flex}.estimated-toggle input[type=checkbox]{accent-color:#7c3aed;cursor:pointer;width:16px;height:16px}.year-section{flex-direction:column;gap:10px;display:flex}.section-label{color:#374151;font-size:.85rem;font-weight:500}.year-chips{flex-wrap:wrap;gap:8px;display:flex}.year-chip{color:#374151;cursor:pointer;background:#fff;border:1.5px solid #d1d5db;border-radius:999px;align-items:center;gap:6px;padding:8px 16px;font-size:.9rem;font-weight:600;transition:all .15s;display:flex}.year-chip:hover{color:#7c3aed;border-color:#7c3aed}.year-chip--open{color:#fff;background:#7c3aed;border-color:#7c3aed}.year-chip--has-months:not(.year-chip--open){color:#5b21b6;background:#faf5ff;border-color:#c4b5fd}.year-chip-badge{color:#5b21b6;background:#c4b5fd;border-radius:999px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:.7rem;font-weight:700;line-height:1;display:inline-flex}.year-chip--open .year-chip-badge{color:#fff;background:#ffffff4d}.month-panel{background:#faf5ff;border:1.5px solid #c4b5fd;border-radius:10px;padding:14px}.month-panel-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.month-panel-year{color:#5b21b6;font-size:.95rem;font-weight:700}.months-actions{align-items:center;gap:6px;display:flex}.btn-link{color:#7c3aed;cursor:pointer;background:0 0;border:none;padding:0;font-size:.8rem;font-weight:500;text-decoration:underline}.sep{color:#d1d5db;font-size:.8rem}.months-grid{grid-template-columns:repeat(6,1fr);gap:7px;display:grid}.month-btn{color:#374151;cursor:pointer;background:#fff;border:1.5px solid #d1d5db;border-radius:8px;padding:8px 0;font-size:.85rem;font-weight:500;transition:all .15s}.month-btn:hover{color:#7c3aed;border-color:#7c3aed}.month-btn.selected{color:#fff;background:#7c3aed;border-color:#7c3aed}.form-error{color:#dc2626;margin:0;font-size:.875rem}.btn-primary{color:#fff;cursor:pointer;background:#7c3aed;border:none;border-radius:8px;align-self:flex-start;padding:11px 24px;font-size:1rem;font-weight:600;transition:background .2s}.btn-primary:hover{background:#6d28d9}.expense-table-wrapper{margin:0 -4px;overflow-x:auto}.expense-table{border-collapse:collapse;width:100%;font-size:.875rem}.expense-table thead th{white-space:nowrap;border-bottom:2px solid #e5e7eb;padding:0 12px 12px}.expense-table-month-col{text-align:left;color:#6b7280;min-width:80px;font-size:.8rem;font-weight:600;padding-left:4px!important}.expense-table-expense-col{text-align:center;min-width:110px}.expense-table-header-cell{flex-direction:column;align-items:center;gap:2px;display:flex}.expense-table-header-name{color:#111827;font-weight:600}.expense-table-header-amount{color:#5b21b6;font-size:.8rem;font-weight:700}.expense-table-row:nth-child(2n){background:#f9fafb}.expense-table-row--current,.expense-table-row--current:nth-child(2n){outline-offset:-1px;background:#fefce8;outline:1px solid #fde047}.expense-table-row--year-end td{border-bottom:2px solid #6b7280}.expense-table-month-label{color:#374151;white-space:nowrap;padding:9px 12px 9px 4px;font-weight:500}.expense-table-cell{text-align:center;color:#9ca3af;border-left:1px solid #f3f4f6;padding:9px 12px}.expense-table-cell--active{color:#5b21b6;font-weight:600}.expense-table-toggle{color:#6b7280;cursor:pointer;background:0 0;border:1.5px dashed #d1d5db;border-radius:8px;width:100%;margin-top:12px;padding:8px;font-size:.82rem;font-weight:500;transition:color .15s,border-color .15s;display:block}.expense-table-toggle:hover{color:#7c3aed;border-color:#c4b5fd}.btn-remove{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 6px;font-size:.9rem;line-height:1;transition:color .15s,background .15s}.btn-remove:hover{color:#dc2626;background:#fef2f2}.card--wide{width:calc(100vw - 32px);max-width:calc(100vw - 32px);margin-left:calc(50% - 50vw + 16px);margin-right:calc(50% - 50vw + 16px)}.chart-card{padding-bottom:32px}.chart-wrapper{height:420px;position:relative}.breakdown-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.breakdown-header h2{margin:0}.breakdown-select{color:#374151;cursor:pointer;background:#f9fafb;border:1px solid #d1d5db;border-radius:6px;padding:.375rem .75rem;font-size:.9rem}.breakdown-select:focus{outline-offset:1px;outline:2px solid #6366f1}.breakdown-empty{color:#6b7280;text-align:center;padding:1rem 0}.breakdown-body{align-items:flex-start;gap:32px;display:flex}.breakdown-chart{flex:0 0 240px;height:240px}.breakdown-list{flex:1;min-width:0}.breakdown-table{border-collapse:collapse;width:100%;font-size:.9rem}.breakdown-table thead th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid #e5e7eb;padding:0 8px 10px;font-size:.78rem;font-weight:600}.breakdown-table tbody tr:nth-child(2n){background:#f9fafb}.breakdown-table tbody td{color:#111827;border-bottom:1px solid #f3f4f6;padding:9px 8px}.breakdown-col-amount,.breakdown-col-pct,.breakdown-table thead th.breakdown-col-amount,.breakdown-table thead th.breakdown-col-pct{text-align:right;white-space:nowrap}.breakdown-col-amount{font-variant-numeric:tabular-nums;font-weight:500}.breakdown-col-pct{color:#6b7280;font-size:.85rem}.breakdown-dot{vertical-align:middle;border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-right:8px;display:inline-block}.breakdown-total-row td{color:#111827;border-top:2px solid #e5e7eb;padding:10px 8px;font-weight:600}.planner-table-wrapper,.expense-table-wrapper{-webkit-overflow-scrolling:touch;scrollbar-width:thin}@media (width<=768px){.app-header{padding:28px 0 8px}.app-header h1{font-size:2rem}.chart-wrapper{height:320px}}@media (width<=640px){.app-header{flex-direction:column;align-items:flex-start;gap:10px;padding:20px 0 8px}.app-header h1{font-size:1.8rem}.header-right{flex-flow:wrap;align-items:center;gap:8px;width:100%}.today-date{margin-top:0}.app-main{gap:16px;margin-top:16px}.card{padding:20px 16px}.card h2{margin-bottom:16px;font-size:1rem}.chart-wrapper{height:260px}.nav-link{padding:10px 16px}.field,.field-amount{flex:100%}.btn-primary{text-align:center;width:100%}.months-grid{grid-template-columns:repeat(4,1fr)}.month-btn{min-height:44px;padding:10px 0}.year-chip{min-height:44px}.breakdown-body{flex-direction:column;align-items:center}.breakdown-chart{flex:0 0 200px;width:200px;height:200px}.breakdown-list{width:100%}.planner-header{flex-direction:column;align-items:flex-start;gap:10px}.planner-toggle-btn{text-align:center;width:100%;min-height:44px;padding:10px}}@media (width<=480px){.app{padding:0 10px 40px}.card--wide{width:calc(100vw - 20px);max-width:calc(100vw - 20px);margin-left:calc(50% - 50vw + 10px);margin-right:calc(50% - 50vw + 10px)}.app-header h1{font-size:1.6rem}.app-header p{font-size:.9rem}.card{border-radius:10px;padding:16px 12px}.nav-link{padding:10px 12px;font-size:.88rem}.chart-wrapper{height:220px}.months-grid{grid-template-columns:repeat(3,1fr)}.breakdown-chart{flex:0 0 170px;width:170px;height:170px}.today-date{padding:5px 10px;font-size:.78rem}.quote-badge{padding:4px 10px;font-size:.85rem}}@media (width<=360px){.app{padding:0 8px 32px}.card--wide{width:calc(100vw - 16px);max-width:calc(100vw - 16px);margin-left:calc(50% - 50vw + 8px);margin-right:calc(50% - 50vw + 8px)}.app-header h1{font-size:1.4rem}.months-grid{grid-template-columns:repeat(3,1fr);gap:5px}.month-btn{font-size:.78rem}.nav-link{padding:10px;font-size:.82rem}.breakdown-chart{flex:0 0 150px;width:150px;height:150px}}
