*{box-sizing:border-box}:root{--grid-label-col-width: 300px;--grid-month-col-width: 65px;--grid-month-count: 12}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:#f4f7fb;color:#1f2937}.portal-shell{display:grid;grid-template-columns:220px 1fr;height:100vh;overflow:hidden}.portal-shell.nav-collapsed{grid-template-columns:72px 1fr}.left-portal-nav{background:#1e293b;color:#e2e8f0;padding:14px 10px;display:flex;flex-direction:column;gap:8px;height:100vh;overflow-y:auto}.left-portal-nav.collapsed{padding:14px 8px}.nav-collapse-btn{border:1px solid #334155;background:#0f172a;color:#e2e8f0;font-weight:700}.left-nav-title{font-size:18px;font-weight:700;padding:8px 10px}.left-portal-nav.collapsed .left-nav-title{display:none}.nav-item{display:flex;align-items:center;gap:8px;text-align:left;border:1px solid #334155;background:#0f172a;color:#e2e8f0}.nav-icon{width:18px;text-align:center}.left-portal-nav.collapsed .nav-item{justify-content:center;padding-left:8px;padding-right:8px}.left-portal-nav.collapsed .nav-label{display:none}.nav-spacer{flex:1}.nav-item.active{background:#312e81;border-color:#4338ca}.top-utility-bar{display:flex;justify-content:flex-end;align-items:center;margin-bottom:12px}.top-utility-actions{display:flex;align-items:center;gap:8px}.api-notification-menu{position:relative}.api-notification-badge{margin-left:6px;display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#dc2626;color:#fff;font-size:10px;font-weight:700}.api-notification-panel{position:absolute;right:0;top:calc(100% + 6px);width:360px;max-height:320px;overflow-y:auto;background:#fff;border:1px solid #d1d5db;border-radius:10px;box-shadow:0 12px 20px #0f172a26;padding:10px;z-index:50}.api-notification-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.api-notification-list{display:grid;gap:8px}.api-notification-item{border:1px solid #e5e7eb;border-radius:8px;padding:8px;background:#f8fafc}.api-notification-item-title{font-size:12px;font-weight:700;color:#111827;margin-bottom:4px}.api-notification-item-message{font-size:11px;color:#334155;line-height:1.3;word-break:break-word}.api-toast-stack{position:fixed;right:16px;bottom:16px;z-index:60;display:grid;gap:8px;width:min(380px,calc(100vw - 24px));pointer-events:none}.api-toast-card{border:1px solid #cbd5e1;border-left:4px solid #ef4444;background:#fff;border-radius:10px;box-shadow:0 8px 18px #0f172a26;padding:10px 12px}.api-toast-title{font-size:12px;font-weight:700;color:#7f1d1d;margin-bottom:4px}.api-toast-message{font-size:11px;color:#334155;line-height:1.35;word-break:break-word}.queue-progress-banner{position:sticky;top:0;z-index:20;margin-bottom:12px;padding:8px 10px;border:1px solid #bfdbfe;border-radius:10px;background:#eff6ff}.queue-progress-banner-text{color:#1e3a8a;font-size:12px;font-weight:700;margin-bottom:6px}.queue-progress-track{height:8px;border-radius:999px;background:#dbeafe;overflow:hidden}.queue-progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#3b82f6,#2563eb);transition:width .18s ease}.utility-pill{border:1px solid transparent;background:#f8fafc}.utility-pill.active{border-color:#bfdbfe;background:#eff6ff;color:#1d4ed8}.portal-content{padding:16px;height:100vh;overflow-y:auto}button,input,select,textarea{padding:8px 10px;border-radius:8px;border:1px solid #d1d5db;background:#fff}button{cursor:pointer}button:hover{background:#f9fafb}textarea{width:100%}.button-danger{color:#991b1b;border-color:#fecaca;background:#fff5f5}.panel{background:#fff;border-radius:12px;padding:12px;box-shadow:0 1px 2px #00000014}.section-title{font-size:16px;margin:0 0 8px}.controls{display:flex;justify-content:space-between;flex-wrap:wrap}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}.form-grid form{display:grid;gap:8px}.compact-forms{display:grid;gap:10px}.compact-forms form{display:grid;gap:8px}.compact-forms h3{margin:0;font-size:14px}.version-stack{display:grid;gap:8px}.version-chip{display:inline-flex;align-items:center;width:fit-content;padding:6px 10px;border-radius:999px;border:1px solid #cbd5e1;background:#f8fafc;color:#0f172a;font-size:12px;font-weight:600}.grid-wrapper{overflow-x:auto}.expand-btn{width:100%;text-align:left;border:0;background:transparent;font-weight:600;padding:4px}.category-row{background:#e0e7ff}.category-cell{background:#eef2ff}.expense-row{background:#fff}.expense-row-label{padding-left:26px;color:#334155;background:#f8fafc}.row-sync-indicator{display:inline-flex;align-items:center;gap:6px;margin-left:8px;color:#475569;font-size:11px;font-weight:600}.row-sync-spinner{width:10px;height:10px;border-radius:50%;border:2px solid #cbd5e1;border-top-color:#2563eb;animation:cell-sync-spin .8s linear infinite}.total-col{background:#f8fafc}.total-row{background:#dbeafe;font-weight:700}.total-cell{background:#eff6ff}table{width:max-content;border-collapse:collapse;min-width:calc(var(--grid-label-col-width) + (13 * var(--grid-month-col-width)));table-layout:fixed}th,td{box-sizing:content-box;border:1px solid #e5e7eb;padding:6px;vertical-align:top;font-size:13px}.current-month-col{box-shadow:inset 0 0 0 2px #5c5e61}th:first-child,td:first-child{width:var(--grid-label-col-width)}th:not(:first-child),td:not(:first-child){width:var(--grid-month-col-width)}.summary-grid-table{width:max-content;min-width:calc(var(--grid-label-col-width) + (var(--grid-month-count) * var(--grid-month-col-width)));table-layout:fixed}.summary-grid-table th,.summary-grid-table td{box-sizing:content-box}.summary-grid-table th:first-child,.summary-grid-table td:first-child{width:var(--grid-label-col-width)}.summary-grid-table th:not(:first-child),.summary-grid-table td:not(:first-child){width:var(--grid-month-col-width)}.cell{min-width:0}.cell.selected{background:#eff6ff}.cell-value{font-weight:600;font-size:13px}.cell-delta{font-size:10px;line-height:1.1;margin-top:2px;font-weight:600;opacity:.8}.cell-delta.positive{color:#166534}.cell-delta.negative{color:#991b1b}.value-state-estimate{background:#fff7ed;color:#9a3412}.value-state-actual{background:#ecfdf5;color:#065f46}.value-state-mixed{background:#f3e8ff;color:#6b21a8}.cell-actual{font-weight:600}.cell-estimate{font-size:12px;color:#4b5563}.pill{display:inline-block;margin-top:4px;padding:2px 6px;border-radius:999px;font-size:11px}.pill.paid{background:#dcfce7;color:#166534}.pill.unpaid{background:#fee2e2;color:#991b1b}.inline-actions{display:flex;align-items:center;gap:8px}.checkbox-row{display:flex;align-items:center;gap:8px;margin:8px 0}.grid-settings-wrap{position:relative;display:inline-block}.grid-settings-btn{font-size:16px;padding:4px 8px;border-radius:6px;border:1px solid #d1d5db;background:#fff;cursor:pointer;line-height:1;color:#475569}.grid-settings-btn:hover{background:#f1f5f9;color:#1e293b}.grid-settings-flyout{position:absolute;top:calc(100% + 6px);right:0;background:#fff;border:1px solid #cbd5e1;border-radius:10px;box-shadow:0 8px 24px #0f172a1f;padding:10px 14px;min-width:200px;z-index:20}.grid-settings-flyout .checkbox-row{margin:4px 0;font-size:13px}.grid-settings-section-title{font-size:11px;font-weight:700;text-transform:uppercase;color:#94a3b8;letter-spacing:.06em;margin:8px 0 2px}.grid-settings-section-title:first-child{margin-top:0}.error-banner{background:#fee2e2;border:1px solid #fecaca;color:#7f1d1d;border-radius:8px;padding:8px}.charts-grid{display:grid;gap:16px;grid-template-columns:repeat(2,minmax(0,1fr))}@media(max-width:1100px){.charts-grid{grid-template-columns:1fr}}.chart-panel{display:grid;gap:10px}.chart-panel-header{display:flex;justify-content:space-between;align-items:center;gap:10px}.chart-panel-header h2{margin:0}.chart-table-wrap{margin-top:6px}.net-grid{display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(110px,1fr))}.net-card{border:1px solid #e5e7eb;border-radius:10px;padding:8px;background:#f8fafc}.net-month{font-size:12px;color:#475569}.net-value{margin-top:4px;font-size:15px;font-weight:700}.net-value.positive{color:#166534}.net-value.negative{color:#991b1b}.bank-balance-cell{cursor:pointer;-webkit-user-select:none;user-select:none;background:#f8fafc;color:#0f172a}.bank-balance-cell.bank-balance-actual{border-left:3px solid #0f766e}.bank-balance-cell.bank-balance-forecast{border-left:3px solid #94a3b8}.net-summary-cell{background:#f8fafc}.net-summary-positive{border-left:3px solid #16a34a}.net-summary-negative{border-left:3px solid #dc2626}.summary-value-positive{color:#166534}.summary-value-negative{color:#991b1b}.summary-cell-button{width:100%;border:0;background:transparent;padding:0;margin:0;text-align:inherit;font:inherit;color:inherit;cursor:pointer}.projection-list{display:grid;gap:8px}.projection-item{border:1px solid #e5e7eb;border-radius:10px;padding:8px}.project-card{border:1px solid #e5e7eb;border-radius:10px;padding:8px;margin-top:8px}.project-accordion{border-color:#c7d2fe;background:#fff;padding:0;overflow:hidden}.projection-accordion{margin-top:6px;border-color:#cbd5e1;background:#f8fafc;padding:0;overflow:hidden}.project-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.accordion-header{background:#eef2ff;border-bottom:1px solid #c7d2fe;padding:6px 8px}.projection-accordion .accordion-header{background:#f1f5f9;border-bottom-color:#cbd5e1}.project-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:8px;margin-top:6px}.field-group{display:grid;gap:4px}.inherit-toggle{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:#475569}.field-inherited{background:#f8fafc;border-color:#cbd5e1;color:#64748b}.field-overridden{background:#fff7ed;border-color:#fb923c;color:#9a3412}.inherited-from-badge{grid-column:1 / -1;margin:-2px 0 2px;padding:6px 8px;border:1px solid #cbd5e1;border-radius:8px;background:#f8fafc;color:#475569;font-size:12px;font-weight:600}.inherited-from-warning{border-color:#f59e0b;background:#fef3c7;color:#92400e}.field-group>span{font-size:12px;color:#475569;font-weight:600}.milestone-grid{display:grid;grid-template-columns:96px 120px 120px minmax(120px,1fr) 96px minmax(120px,1fr) minmax(120px,1fr) 92px 104px 90px;gap:8px;margin-top:8px;align-items:center}.milestone-grid-income{grid-template-columns:96px 120px 120px minmax(120px,1fr) 96px minmax(120px,1fr) minmax(120px,1fr) 92px 104px 90px}.milestone-grid-expense{grid-template-columns:96px 120px minmax(120px,1fr) 120px minmax(120px,1fr) minmax(120px,1fr) 92px 104px 90px}.milestone-grid input,.milestone-grid select{min-width:0;width:100%}.milestone-grid-header{margin-top:10px}.milestone-grid-header>span{font-size:12px;color:#475569;font-weight:600}.stream-line-items-grid{margin-top:8px;display:grid;gap:6px;overflow-x:auto}.stream-line-item-row{display:grid;grid-template-columns:44px minmax(160px,1.4fr) 96px 132px 96px minmax(140px,1fr) minmax(140px,1fr) 104px 96px 56px;gap:8px;align-items:center;min-width:1040px}.stream-line-item-row-disabled{opacity:.72}.stream-line-item-header{padding-bottom:4px;border-bottom:1px solid #e2e8f0}.stream-line-item-header>span{font-size:12px;color:#475569;font-weight:600}.stream-line-item-row input,.stream-line-item-row select{min-width:0;width:100%}.stream-line-item-row .icon-action{justify-self:end}.stream-accordion{margin-bottom:12px}.stream-line-item-row[draggable=true]{cursor:grab}.stream-line-item-row[draggable=true]:active{cursor:grabbing}.compact-grid{grid-template-columns:1fr}.editor-form{display:grid;gap:8px}.list-row{display:flex;justify-content:space-between;align-items:center;gap:6px;border:1px solid #e5e7eb;border-radius:8px;padding:6px;margin-bottom:6px}.list-row input,.list-row select{min-width:0;font-size:13px}.list-actions{display:flex;gap:4px}.compact-actions{align-items:center}.icon-action{min-width:26px;height:26px;padding:3px 5px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;font-size:12px}.project-accordion>:not(.accordion-header),.projection-accordion>:not(.accordion-header){padding:8px}.project-name-input{min-width:160px;max-width:260px;height:28px;font-weight:700;font-size:14px;padding:4px 8px}.projection-schedule-drawer{position:fixed;top:56px;right:0;width:min(460px,100vw);height:calc(100vh - 56px);padding:12px;background:#f8fafc;border-left:1px solid #e5e7eb;overflow-y:auto;transform:translate(100%);transition:transform .2s ease;z-index:25}.projection-schedule-drawer.open{transform:translate(0)}.schedule-card{margin-top:10px;background:#fff}.schedule-drawer-actions{margin-top:8px;margin-bottom:8px}.schedule-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:8px;align-items:center;font-size:12px;padding:4px 0;border-bottom:1px solid #f1f5f9}.schedule-grid-header{font-weight:700;color:#334155;border-bottom:1px solid #cbd5e1}.schedule-grid-payment{grid-template-columns:1fr 1fr}.row-kind-label{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#475569;min-width:68px}.category-edit-row{border-width:2px;background:#eff6ff}.category-edit-row.expense{border-color:#93c5fd}.category-edit-row.income{border-color:#6ee7b7;background:#ecfdf5}.type-edit-row{background:#f8fafc}.type-group{margin-top:2px}.type-group>summary{list-style:none;cursor:pointer;font-weight:600;font-size:13px;color:#1e293b;background:#f1f5f9;border:1px solid #cbd5e1;border-radius:8px;padding:7px 10px}.type-group[open]>summary{border-bottom-left-radius:0;border-bottom-right-radius:0}.type-group>.inline-actions,.type-group>.type-edit-row{border-left:1px solid #cbd5e1;border-right:1px solid #cbd5e1;padding-left:8px;padding-right:8px}.type-group>.inline-actions{background:#f8fafc;margin:0;padding-top:8px}.type-group>.type-edit-row:last-of-type{border-bottom:1px solid #cbd5e1;border-bottom-left-radius:8px;border-bottom-right-radius:8px}.management-list{display:grid;gap:8px}.management-row{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;border:1px solid #e5e7eb;border-radius:8px;padding:8px}.user-search-item{display:flex;flex-direction:column;align-items:flex-start;gap:2px;text-align:left;border:1px solid #e5e7eb;border-radius:8px;background:#fff;color:#0f172a}.user-search-item span{font-size:12px;color:#64748b}.operation-progress{margin-top:8px;border:1px solid #cbd5e1;border-radius:8px;padding:8px;background:#f8fafc;display:grid;gap:6px}.operation-progress-header{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#0f172a}.operation-progress-track{width:100%;height:10px;border-radius:999px;background:#e2e8f0;overflow:hidden}.operation-progress-fill{height:100%;background:linear-gradient(90deg,#0ea5e9,#22c55e);transition:width .25s ease}.operation-progress-meta{display:flex;justify-content:space-between;gap:8px;font-size:12px;color:#334155}.operation-progress-counts{border-top:1px dashed #cbd5e1;padding-top:6px;display:grid;gap:4px}.operation-progress-count-row{display:flex;justify-content:space-between;gap:8px;font-size:12px}.operation-progress-modal{border:none;background:transparent;padding:0;width:min(520px,92vw)}.operation-progress-modal::backdrop{background:#0f172a80}.operation-progress-modal-body{border:1px solid #cbd5e1;border-radius:10px;padding:12px;background:#fff;box-shadow:0 14px 28px #0f172a38}.operation-progress-modal-body .operation-progress{margin-top:0}.notice-dialog{border:1px solid #cbd5e1;border-radius:12px;padding:14px;width:min(460px,90vw);box-shadow:0 14px 30px #0f172a33}.notice-dialog::backdrop{background:#0f172a73}.layout-shell{display:block}.main-content{display:grid;gap:16px;padding-right:0;transition:padding-right .2s ease}.main-content.with-whatif-drawer{padding-right:min(320px,36vw)}.whatif-drawer{position:fixed;top:0;right:0;width:min(320px,100vw);height:100vh;padding:12px;background:#f8fafc;border-left:1px solid #e5e7eb;overflow-y:auto;transform:translate(100%);transition:transform .2s ease;z-index:20}.whatif-drawer.open{transform:translate(0)}.config-drawer{position:fixed;top:0;right:0;width:min(380px,100vw);height:100vh;padding:12px;background:#f8fafc;border-left:1px solid #e5e7eb;overflow-y:auto;transform:translate(100%);transition:transform .2s ease;z-index:20}.config-drawer.open{transform:translate(0)}.drawer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.drawer-block{margin-bottom:10px}.drawer-block>summary{list-style:none;cursor:pointer;background:#eef2ff;border:1px solid #c7d2fe;padding:8px 10px;border-radius:8px;font-weight:600}.drawer-block[open]>summary{border-bottom-left-radius:0;border-bottom-right-radius:0}.drawer-block>.panel{border-top-left-radius:0;border-top-right-radius:0}.budget-dialog{border:1px solid #cbd5e1;border-radius:10px;padding:12px;width:min(420px,90vw)}.budget-dialog::backdrop{background:#0f172a59}.dialog-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.dialog-note{margin:0 0 8px;color:#475569;font-size:12px}.whatif-snapshot-actions{margin-top:6px;gap:6px}.whatif-project-tile{position:relative;padding:8px;margin-top:8px}.whatif-project-tile h3{margin:0 0 6px;font-size:14px}.whatif-project-tile-overridden{border-color:#f59e0b;background:linear-gradient(180deg,#fffbeb,#fff 68%);box-shadow:inset 0 0 0 1px #fde68a}.whatif-project-tile-overridden h3:after{content:"  • What-if";color:#92400e;font-size:11px;font-weight:700}.whatif-snapshot-card{padding:8px;margin-top:0}.whatif-snapshot-card h3{margin:0 0 6px;font-size:14px}.cell.has-budget-hover{position:relative;overflow:visible}.cell.cell-pending{opacity:.5;filter:grayscale(.7);cursor:not-allowed;pointer-events:none}.cell-sync-spinner{position:absolute;top:4px;right:4px;width:10px;height:10px;border-radius:50%;border:2px solid #cbd5e1;border-top-color:#2563eb;animation:cell-sync-spin .8s linear infinite}.app-busy-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a59;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1400;display:flex;align-items:center;justify-content:center;pointer-events:all}.app-busy-card{min-width:240px;max-width:88vw;padding:16px 18px;border-radius:12px;border:1px solid #cbd5e1;background:#fff;color:#0f172a;box-shadow:0 14px 30px #0f172a2e;display:inline-flex;align-items:center;gap:10px;font-weight:600}.app-busy-spinner{width:18px;height:18px;border-radius:50%;border:2px solid #cbd5e1;border-top-color:#2563eb;animation:cell-sync-spin .8s linear infinite}@keyframes cell-sync-spin{to{transform:rotate(360deg)}}.budget-projection-flyout{position:absolute;left:50%;top:calc(100% - 8px);width:min(340px,42vw);background:#fff;border:1px solid #cbd5e1;border-radius:10px;box-shadow:0 8px 24px #0f172a1f;padding:8px;z-index:12;font-size:11px;display:none;pointer-events:none;opacity:0;transform:translate(-50%) translateY(6px);transition:opacity .15s ease,transform .15s ease}.cell.has-budget-hover:hover .budget-projection-flyout,.cell.has-budget-hover:focus-within .budget-projection-flyout{display:block;pointer-events:auto;opacity:1;transform:translate(-50%) translateY(0)}.budget-projection-section-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.budget-projection-open-icon{width:24px;height:24px;min-width:24px;border-radius:6px;border:1px solid #c7d2fe;background:#eef2ff;color:#312e81;display:inline-flex;align-items:center;justify-content:center;padding:0;font-size:13px;line-height:1}.budget-projection-open-icon:hover{background:#e0e7ff}.whatif-projection-flyout{position:absolute;left:12px;right:12px;top:calc(100% - 8px);background:#fff;border:1px solid #cbd5e1;border-radius:10px;box-shadow:0 8px 24px #0f172a1f;padding:6px;z-index:5;font-size:10px;opacity:0;transform:translateY(6px);pointer-events:none;transition:opacity .15s ease,transform .15s ease}.whatif-project-tile:hover .whatif-projection-flyout,.whatif-project-tile:focus-within .whatif-projection-flyout{opacity:1;transform:translateY(0)}.whatif-projection-flyout-title{font-weight:700;margin-bottom:4px;color:#1e293b;font-size:11px}.whatif-projection-flyout-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px;margin-bottom:4px}.whatif-projection-flyout-grid>div{display:grid;gap:1px}.whatif-projection-flyout-grid span{color:#64748b}.whatif-projection-flyout-grid strong{color:#0f172a;font-weight:600}.whatif-projection-section{border-top:1px solid #e2e8f0;padding-top:3px;margin-top:3px}.whatif-projection-section-title{color:#334155;font-weight:600;margin-bottom:1px}.whatif-projection-line{display:flex;justify-content:space-between;gap:8px;color:#475569}.whatif-projection-line strong{color:#0f172a}.whatif-projection-more{color:#64748b;margin-top:2px}.bank-grid{display:grid;gap:8px}.bank-row{display:grid;grid-template-columns:1fr 140px 100px;gap:8px;align-items:center}@media(min-width:1024px){.main-content{padding-right:390px}}@media(max-width:768px){.portal-shell{grid-template-columns:1fr;height:auto;overflow:visible}.left-portal-nav{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;height:auto;overflow:visible}.portal-content{height:auto;overflow:visible}.left-nav-title{grid-column:1 / -1}}.grid-settings-select{width:100%;font-size:13px;padding:5px 8px;border-radius:6px;border:1px solid #d1d5db;background:#fff;margin-bottom:2px}
