:root{color-scheme:light;--bg: #f4f6f8;--surface: #ffffff;--surface-muted: #eef3f7;--line: #d8e0e7;--line-strong: #b7c4cf;--text: #17212b;--muted: #687684;--blue: #2f6f9f;--blue-dark: #21587d;--green: #287a4d;--green-bg: #e6f4ec;--amber: #9a6500;--amber-bg: #fff1d6;--red: #b33232;--red-bg: #fde8e8;--shadow: 0 18px 45px rgb(27 48 66 / .08)}*{box-sizing:border-box}html,body{min-height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,select,textarea{font:inherit}a{color:inherit;text-decoration:none}.app-shell{min-height:100vh;display:grid;grid-template-columns:228px minmax(0,1fr)}.sidebar{position:sticky;top:0;height:100vh;padding:20px 14px;background:#203748;color:#dce8ef}.brand-mark{width:42px;height:42px;display:grid;place-items:center;border-radius:8px;background:#d9efe3;color:#174a31;font-weight:800;margin:0 0 28px 6px}.nav-list{display:grid;gap:6px}.nav-item{min-height:40px;display:flex;align-items:center;gap:10px;padding:0 10px;border-radius:7px;color:#bfd0dc;font-size:14px;font-weight:600}.nav-item.active,.nav-item:hover{background:#2f4f64;color:#fff}.budget-page{min-width:0;padding:28px}.budget-header{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:18px}.eyebrow{margin:0 0 4px;color:var(--muted);font-size:13px;font-weight:700;text-transform:uppercase}h1,h2,p{margin-top:0}h1{margin-bottom:0;font-size:30px;line-height:1.1}h2{margin-bottom:0;font-size:15px}.primary-action{height:40px;display:inline-flex;align-items:center;gap:8px;border:0;border-radius:7px;padding:0 14px;background:var(--blue);color:#fff;font-weight:700;cursor:pointer}.header-actions{display:inline-flex;align-items:center;gap:10px}.primary-action:hover{background:var(--blue-dark)}.summary-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1px;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:var(--line);box-shadow:var(--shadow)}.summary-metric{min-width:0;padding:16px;background:var(--surface)}.summary-metric span{display:block;margin-bottom:7px;color:var(--muted);font-size:12px;font-weight:700}.summary-metric strong{display:block;overflow-wrap:anywhere;font-size:22px;line-height:1.1}.positive{color:var(--green)}.negative{color:var(--red)}.work-area{display:grid;grid-template-columns:minmax(0,1fr) 310px;gap:18px;margin-top:18px}.budget-table-wrap,.rail-section{border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow)}.section-heading{min-height:54px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 16px;border-bottom:1px solid var(--line)}.pending-pill{min-height:28px;display:inline-flex;align-items:center;gap:7px;border-radius:999px;padding:0 10px;background:var(--amber-bg);color:var(--amber);font-size:13px;font-weight:700;white-space:nowrap}.budget-table{width:100%;border-collapse:collapse;font-size:14px}.budget-table th,.budget-table td{height:42px;border-bottom:1px solid var(--line);padding:0 14px;text-align:right;white-space:nowrap}.budget-table thead th{height:36px;background:var(--surface-muted);color:var(--muted);font-size:12px;font-weight:800}.budget-table th:first-child,.budget-table td:first-child{text-align:left}.budget-table tbody th{font-weight:600}.budget-table tbody th span{display:inline-block;max-width:28ch;overflow:hidden;text-overflow:ellipsis;vertical-align:middle}.budget-table tbody small{margin-left:8px;color:var(--muted);font-size:11px;font-weight:700}.group-row th,.group-row td{height:38px;background:#e8eef3;color:#29485f;font-weight:800}.side-rail{display:grid;align-content:start;gap:18px}.rail-section{padding:16px}.account-list{display:grid;gap:10px;margin-top:14px}.account-row{display:flex;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid var(--line);padding-bottom:10px;font-size:14px}.account-row:last-child{border-bottom:0;padding-bottom:0}.account-row span{color:var(--muted)}.import-state{display:grid;grid-template-columns:38px 1fr;gap:12px;background:var(--amber-bg);color:#4a3210}.import-state p{margin:6px 0 0;color:#6b4b17;font-size:13px;line-height:1.4}.import-icon{width:38px;height:38px;display:grid;place-items:center;border-radius:8px;background:#fff;color:var(--amber)}.mobile-category-list,.bottom-nav{display:none}.error-shell{max-width:680px;margin:80px auto;padding:24px}.setup-page{min-height:100vh;padding:32px 18px 48px;background:var(--bg)}.setup-hero,.setup-layout{width:min(980px,100%);margin:0 auto}.setup-hero{margin-bottom:18px}.setup-hero h1{max-width:760px;font-size:32px}.setup-hero p{max-width:720px;margin:10px 0 0;color:var(--muted);line-height:1.55}.setup-layout{display:grid;gap:16px}.setup-section{border:1px solid var(--line);border-radius:8px;padding:16px;background:var(--surface);box-shadow:var(--shadow)}.section-title{display:flex;align-items:center;gap:9px;margin-bottom:14px;color:#29485f}.field{display:grid;gap:6px}.field span{color:var(--muted);font-size:12px;font-weight:800}.field input,.field select{width:100%;height:38px;border:1px solid var(--line-strong);border-radius:7px;padding:0 10px;background:#fff;color:var(--text)}.field input:focus,.field select:focus{border-color:var(--blue);outline:3px solid rgb(47 111 159 / .16)}.account-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.account-fieldset{display:grid;gap:10px;margin:0;border:1px solid var(--line);border-radius:8px;padding:12px}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.template-preview{display:grid;gap:10px}.template-group{display:grid;gap:4px;border-bottom:1px solid var(--line);padding-bottom:10px}.template-group:last-child{border-bottom:0;padding-bottom:0}.template-group span{color:var(--muted);font-size:13px;line-height:1.45}.setup-actions{display:flex;align-items:center;justify-content:flex-end;gap:12px}.secondary-link{min-height:38px;display:inline-flex;align-items:center;border:1px solid var(--line-strong);border-radius:7px;padding:0 12px;background:var(--surface);color:var(--blue-dark);font-weight:700}.form-error{margin:0;border:1px solid #f0b9b9;border-radius:8px;padding:12px;background:var(--red-bg);color:var(--red);font-weight:700}.auth-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:var(--bg)}.auth-panel{width:min(440px,100%);border:1px solid var(--line);border-radius:8px;padding:24px;background:var(--surface);box-shadow:var(--shadow)}.auth-icon{width:44px;height:44px;display:grid;place-items:center;border-radius:8px;margin-bottom:16px;background:var(--surface-muted);color:var(--blue-dark)}.auth-panel h1{margin-bottom:8px}.auth-copy{color:var(--muted);line-height:1.5}.auth-form{display:grid;gap:12px;margin-top:18px}.auth-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.secondary-button{min-height:40px;border:1px solid var(--line-strong);border-radius:7px;padding:0 14px;background:var(--surface);color:var(--blue-dark);font-weight:800;cursor:pointer}.auth-link{width:100%;justify-content:center;margin-top:12px}.quick-form{display:grid;gap:10px;margin-top:14px}.full-width{width:100%;justify-content:center}.form-error.compact,.form-success{margin-top:12px;font-size:13px}.form-success{border:1px solid #b9dfc8;border-radius:8px;padding:10px;background:var(--green-bg);color:var(--green);font-weight:800}.account-row small,.recent-row small{display:block;margin-top:2px;color:var(--muted);font-size:11px;font-weight:700}.recent-list{display:grid;gap:10px;margin-top:10px}.recent-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;border-top:1px solid rgb(74 50 16 / .15);padding-top:10px;font-size:13px}@media(max-width:980px){.app-shell{display:block;padding-bottom:76px}.sidebar{display:none}.budget-page{padding:18px 14px}.budget-header{align-items:flex-start}.primary-action{width:40px;padding:0;justify-content:center}.primary-action span,.header-actions .secondary-link{display:none}h1{font-size:25px}.summary-strip{grid-template-columns:1fr 1fr}.summary-metric{padding:13px}.summary-metric strong{font-size:18px}.work-area{display:block}.side-rail{margin-top:14px}.budget-table{display:none}.mobile-category-list{display:grid}.section-heading{min-height:50px;padding:0 12px}.pending-pill{max-width:52%;justify-content:center;overflow:hidden;text-overflow:ellipsis}.category-panel{border-bottom:1px solid var(--line)}.category-panel:last-child{border-bottom:0}.category-panel summary{min-height:48px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 12px;color:#29485f;font-weight:800;cursor:pointer}.category-panel summary strong{color:var(--text);font-size:14px}.mobile-category-row{min-height:58px;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;border-top:1px solid var(--line);padding:10px 12px}.mobile-category-row span,.mobile-category-row small{display:block;min-width:0}.mobile-category-row span{font-weight:700}.mobile-category-row small{margin-top:4px;color:var(--muted);font-size:12px;line-height:1.35}.mobile-category-row strong{font-size:17px}.bottom-nav{position:fixed;right:0;bottom:0;left:0;z-index:20;height:64px;display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);background:#fffffff5;box-shadow:0 -10px 30px #1b30421a}.bottom-nav a{display:grid;place-items:center;align-content:center;gap:3px;color:var(--muted);font-size:11px;font-weight:700}.bottom-nav a.active{color:var(--blue)}.bottom-nav .add-tab{width:46px;height:46px;place-self:center;border-radius:999px;background:var(--blue);color:#fff}}@media(max-width:520px){.summary-strip{grid-template-columns:1fr}.side-rail{margin-top:14px}.setup-page{padding:22px 12px 36px}.setup-hero h1{font-size:26px}.account-form-grid,.field-row{grid-template-columns:1fr}.setup-actions{align-items:stretch;flex-direction:column-reverse}.setup-actions .primary-action,.auth-actions .primary-action,.secondary-link{width:100%;justify-content:center}.auth-actions{grid-template-columns:1fr}}
