:root{--bg:#f3f6fb;--ink:#142132;--muted:#5f6f84;--panel:rgba(255,255,255,0.96);--line:rgba(148,163,184,0.18);--accent:#0f766e;--accent-soft:#d8fbf4;--gold:#d4a017;--danger:#c62828;--success:#166534;--shadow:0 20px 45px rgba(15,23,42,0.08)}*{box-sizing:border-box}body,html{margin:0;padding:0;background:radial-gradient(circle at top left,rgba(15,118,110,.1),transparent 24%),radial-gradient(circle at top right,rgba(20,33,50,.06),transparent 20%),linear-gradient(180deg,#f6f8fb,#eef4f8);color:var(--ink);font-family:Satoshi,Avenir Next,Segoe UI,sans-serif}a{color:inherit;text-decoration:none}button{font:inherit}.page-shell{min-height:100vh;padding:28px 20px 64px}.container{width:min(1200px,100%);margin:0 auto}.app-container{display:grid;grid-gap:18px;gap:18px}.hero{display:grid;grid-template-columns:minmax(0,1.18fr) minmax(280px,.82fr);grid-gap:20px;gap:20px;margin-bottom:28px}.hero-card,.panel{background:var(--panel);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow)}.hero-card{padding:28px}.app-header{padding:22px}.app-header-top{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:16px}.app-title{margin:14px 0 8px;font-size:clamp(1.8rem,3vw,2.4rem);line-height:1}.app-description{max-width:72ch}.eyebrow{display:inline-flex;padding:8px 14px;border-radius:999px;background:var(--accent-soft);color:var(--accent);font-size:12px;letter-spacing:.08em;text-transform:uppercase}.hero h1{font-size:clamp(2.5rem,6vw,5rem);line-height:.95;margin:16px 0 12px;max-width:10ch}.hero p{color:var(--muted);font-size:1.05rem;max-width:68ch;line-height:1.6}.landing-home .hero-card,.landing-home .panel{background:rgba(255,255,255,.88);border-color:rgba(148,163,184,.2);box-shadow:0 24px 60px rgba(15,23,42,.08)}.landing-home .hero h1,.landing-home .metric-value{font-family:Georgia,Times New Roman,serif}.landing-home .hero h1{font-size:clamp(2.15rem,4.8vw,4rem);max-width:13ch}.hero-mascot-card{padding:18px;display:grid;grid-gap:16px;gap:16px;align-content:start;min-height:100%}.hero-mascot-fallback,.hero-mascot-image{width:100%;aspect-ratio:1/1;border-radius:24px;border:1px solid var(--line);object-fit:cover;object-position:center 18%;display:block;background:radial-gradient(circle at top left,rgba(255,255,255,.8),transparent 35%),linear-gradient(160deg,rgba(15,118,110,.12),rgba(20,33,50,.08))}.hero-mascot-fallback{display:grid;place-items:center}.hero-mascot-emoji{font-size:clamp(4rem,10vw,6rem)}.hero-mascot-copy{display:grid;grid-gap:8px;gap:8px}.hero-mascot-copy strong{font-size:1.4rem;letter-spacing:-.03em}.hero-mascot-copy p{margin:0;color:var(--muted);font-size:.98rem;line-height:1.6}.landing-home .hero p,.landing-home .muted{color:#475569}.landing-home .eyebrow{background:#ccfbf1;color:#0f766e}.landing-home .primary-btn{background:#0f172a}.landing-home .secondary-btn{background:white}.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:20px}.primary-btn,.secondary-btn{border:1px solid transparent;border-radius:999px;padding:14px 22px;cursor:pointer;transition:transform .16s ease,background .16s ease,border-color .16s ease}.primary-btn{background:var(--ink);color:white}.secondary-btn{background:white;color:var(--ink);border:1px solid var(--line)}.icon-text-btn:hover,.nav-chip:hover,.pill-tab:hover,.primary-btn:hover,.secondary-btn:hover{transform:translateY(-1px)}.disabled-link{opacity:.48;cursor:not-allowed;pointer-events:none}.categories-stack,.grid{display:grid;grid-gap:18px;gap:18px}.categories-toolbar{padding:18px 20px;display:flex;justify-content:space-between;align-items:center;gap:16px;background:linear-gradient(180deg,rgba(245,248,252,.98),rgba(255,255,255,.88))}.categories-filter{display:flex;flex-wrap:wrap;gap:12px}.categories-filter-select{min-width:220px}.pill-tab{border:1px solid var(--line);background:rgba(255,255,255,.94);color:var(--ink);padding:12px 18px;border-radius:999px;cursor:pointer;font-weight:600}.pill-tab.active.expense{background:#dc2626;color:white}.pill-tab.active.income{background:#166534;color:white}.round-icon-btn{width:48px;background:white;font-size:1.8rem;line-height:1}.round-icon-btn,.toolbar-import-btn{height:48px;border-radius:999px;border:1px solid var(--line);box-shadow:0 12px 26px rgba(15,23,42,.08);cursor:pointer;color:var(--ink)}.toolbar-import-btn{background:rgba(255,255,255,.96);padding:0 16px;display:inline-flex;align-items:center;gap:8px;font-weight:700}.warning-badge{background:rgba(180,83,9,.12);color:#9a6700}.toolbar-primary-btn{height:48px;border-radius:999px;border:1px solid #0f766e;background:linear-gradient(135deg,#0f766e,#115e59);box-shadow:0 12px 26px rgba(15,118,110,.2);padding:0 18px;display:inline-flex;align-items:center;gap:8px;font-weight:800;color:white;cursor:pointer}.categories-layout{display:grid;grid-template-columns:1.45fr .75fr;grid-gap:18px;gap:18px}.categories-layout.single{grid-template-columns:1fr}.categories-editor-card,.categories-table-card{overflow:hidden}.category-block{border-bottom:1px solid var(--line)}.category-block:last-child{border-bottom:none}.categories-header-row,.categories-row{display:grid;grid-template-columns:1.7fr .55fr .5fr .7fr .9fr;grid-gap:16px;gap:16px;align-items:center}.categories-header-row{padding:16px 24px;font-weight:700;font-size:.92rem;color:var(--muted);background:rgba(248,250,252,.92);border-bottom:1px solid var(--line)}.categories-row{padding:18px 24px;border-bottom:1px solid var(--line)}.categories-row.dragging{opacity:.5}.categories-row:last-child{border-bottom:none}.category-name-cell{display:grid;grid-gap:4px;gap:4px}.category-name-topline{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.subcount-badge{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;background:rgba(15,118,110,.08);color:var(--accent);font-size:.78rem;font-weight:700}.category-icon-cell{font-size:1.6rem}.category-color-cell,.category-icon-cell{display:flex;align-items:center}.category-color-dot{width:18px;height:18px;border-radius:999px;display:inline-block}.category-actions{display:flex;gap:8px;flex-wrap:nowrap}.icon-text-btn{border:1px solid var(--line);background:rgba(255,255,255,.96);color:var(--ink);border-radius:999px;padding:9px 12px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;min-width:42px}.icon-text-btn.danger{color:var(--danger)}.icon-text-btn:disabled{opacity:.45;cursor:not-allowed}.add-subcategory-btn{color:var(--success);border-color:rgba(22,101,52,.18)}.subtle-label{font-size:.8rem}.categories-editor-card{padding:22px}.categories-flyout-card{padding:24px;border-radius:28px}.modal-scrim{position:fixed;inset:0;background:rgba(20,33,50,.28);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:grid;place-items:center;padding:20px;z-index:40;animation:modalFadeIn .18s ease}.modal-card{width:min(720px,100%);max-height:calc(100vh - 40px);overflow:auto;animation:modalLiftIn .22s ease}.color-palette{display:flex;flex-wrap:wrap;gap:10px}.color-swatch{width:28px;height:28px;border-radius:999px;border:2px solid transparent;cursor:pointer}.color-swatch.active{outline:2px solid var(--ink);outline-offset:2px}.toggle-field{display:flex;gap:12px;align-items:flex-start;color:var(--ink)}.toggle-field input{margin-top:4px}.toggle-field span{display:grid;grid-gap:4px;gap:4px}.toggle-field small{color:var(--muted);font-size:.85rem}.editor-actions{display:flex;gap:12px;flex-wrap:wrap}.categories-empty{padding:24px;color:var(--muted)}.settings-link-card{display:grid;grid-gap:8px;gap:8px}.toolbar-actions{display:flex;align-items:center;gap:10px}.toolbar-badge{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:#fff7e6;color:#9a6700;font-size:.82rem;font-weight:600}.categories-search input{min-width:260px;border:1px solid var(--line);border-radius:999px;padding:12px 16px;background:rgba(255,255,255,.96);color:var(--ink);font:inherit}.categories-search input:focus{outline:none;border-color:rgba(15,118,110,.45);box-shadow:0 0 0 4px rgba(15,118,110,.08)}.transactions-stack{gap:16px}.transactions-metrics{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));grid-gap:16px;gap:16px}.transactions-period-filters{display:flex;align-items:flex-end;gap:12px}.compact-field{min-width:92px}.transaction-metric-card{padding:18px 20px;display:grid;grid-gap:8px;gap:8px}.transaction-metric-label{font-size:.84rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.transaction-metric-value{font-size:1.45rem;line-height:1}.import-modal-card{width:min(1220px,calc(100vw - 32px))}.import-toolbar{display:grid;grid-template-columns:minmax(220px,.9fr) minmax(280px,1fr) auto;grid-gap:16px;gap:16px;align-items:end;margin-bottom:16px}.import-file-field small{display:block;margin-top:6px;color:var(--muted)}.import-review-stack{display:grid;grid-gap:18px;gap:18px}.import-metrics{grid-template-columns:repeat(3,minmax(0,1fr))}.transaction-amount.income,.transaction-metric-value.income{color:var(--success)}.transaction-amount.expense,.transaction-metric-value.expense{color:var(--danger)}.transaction-metric-value.neutral{color:var(--ink)}.transactions-header-row,.transactions-row{display:grid;grid-template-columns:.8fr 1.7fr .9fr 1fr 1fr .9fr .9fr .8fr;grid-gap:16px;gap:16px;align-items:center}.import-header-row,.import-row{display:grid;grid-template-columns:44px 110px minmax(220px,1.4fr) 1fr 1fr 140px 130px 1.2fr;grid-gap:14px;gap:14px;align-items:center}.cards-header-row,.cards-row{display:grid;grid-template-columns:1.2fr .9fr 1fr 1fr .8fr;grid-gap:16px;gap:16px;align-items:center}.cards-header-row{padding:16px 24px;font-weight:700;font-size:.92rem;color:var(--muted);background:rgba(248,250,252,.92)}.cards-header-row,.cards-row{border-bottom:1px solid var(--line)}.cards-row{padding:18px 24px}.cards-row:last-child{border-bottom:none}.card-name-cell{display:grid;grid-gap:4px;gap:4px}.card-brand-pill,.card-due-pill{display:inline-flex;align-items:center;justify-content:center;padding:7px 11px;border-radius:999px;font-size:.78rem;font-weight:700;border:1px solid var(--line);background:rgba(255,255,255,.95)}.card-brand-pill{color:var(--ink)}.card-due-pill{color:var(--accent);background:rgba(15,118,110,.08);border-color:rgba(15,118,110,.18)}.cards-editor-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:16px;gap:16px}.accounts-metrics,.budget-metrics,.reports-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:16px;gap:16px}.account-metric-card,.budget-metric-card,.report-metric-card{padding:18px 20px;display:grid;grid-gap:8px;gap:8px}.accounts-header-row,.accounts-row,.budgets-header-row,.budgets-row{display:grid;grid-gap:16px;gap:16px;align-items:center}.accounts-header-row,.budgets-header-row{padding:16px 24px;font-weight:700;font-size:.92rem;color:var(--muted);background:rgba(248,250,252,.92);border-bottom:1px solid var(--line)}.accounts-header-row,.accounts-row{grid-template-columns:1.2fr 1fr 1fr .9fr .8fr}.budgets-header-row,.budgets-row{grid-template-columns:1fr 1fr 1fr 1fr}.accounts-row,.budgets-row{padding:18px 24px;border-bottom:1px solid var(--line)}.accounts-row:last-child,.budgets-row:last-child{border-bottom:none}.account-name-cell{display:grid;grid-gap:4px;gap:4px}.account-type-pill{display:inline-flex;align-items:center;justify-content:center;padding:7px 11px;border-radius:999px;font-size:.78rem;font-weight:700;border:1px solid rgba(15,118,110,.18);color:var(--accent);background:rgba(15,118,110,.08)}.accounts-editor-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:16px;gap:16px}.import-header-row,.transactions-header-row{padding:16px 24px;font-weight:700;font-size:.92rem;color:var(--muted);background:rgba(248,250,252,.92);border-bottom:1px solid var(--line)}.import-row,.transactions-row{padding:18px 24px;border-bottom:1px solid var(--line)}.import-row:last-child,.transactions-row:last-child{border-bottom:none}.transaction-description-cell{display:grid;grid-gap:4px;gap:4px}.transaction-description-strong{display:inline-flex;align-items:center;gap:8px}.credit-card-mark{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:999px;background:rgba(15,23,42,.08);font-size:.85rem}.transaction-inline-meta{color:var(--muted);font-size:.84rem}.import-alerts-cell{display:flex;flex-wrap:wrap;gap:8px}.transaction-status-pill,.transaction-type-pill{display:inline-flex;align-items:center;justify-content:center;padding:7px 11px;border-radius:999px;font-size:.78rem;font-weight:700;border:1px solid var(--line);background:rgba(255,255,255,.95)}.transaction-type-pill.expense{background:rgba(220,38,38,.08);color:var(--danger);border-color:rgba(220,38,38,.18)}.transaction-type-pill.income{background:rgba(22,101,52,.08);color:var(--success);border-color:rgba(22,101,52,.18)}.transaction-type-pill.transfer{background:rgba(15,118,110,.08);color:var(--accent);border-color:rgba(15,118,110,.18)}.transaction-status-pill{text-transform:capitalize}.transaction-amount{font-weight:700}.transaction-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:16px;gap:16px}.transaction-editor-layout{display:grid;grid-gap:18px;gap:18px}.transaction-editor-layout.with-details{grid-template-columns:minmax(0,1.35fr) minmax(280px,.75fr);align-items:start}.transaction-primary-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:16px;gap:16px}.transaction-top-controls{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-gap:10px;gap:10px}.switch-field{display:inline-flex;align-items:center;gap:10px;min-height:48px;padding:0 6px;cursor:pointer}.switch-field input{display:none}.switch-track{position:relative;width:50px;height:30px;border-radius:999px;background:rgba(148,163,184,.35);transition:background .16s ease}.switch-thumb{position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:999px;background:white;box-shadow:0 4px 10px rgba(15,23,42,.18);transition:transform .16s ease}.switch-field.active .switch-track{background:rgba(22,101,52,.5)}.switch-field:not(.active) .switch-track{background:rgba(198,40,40,.34)}.switch-field.active .switch-thumb{transform:translateX(20px)}.switch-label{font-weight:700;white-space:nowrap}.transaction-span-2{grid-column:span 2}.transaction-field-break{grid-column:1}.transaction-placeholder-cell{min-height:1px}.recurrence-mini-card{border:1px solid var(--line);border-radius:20px;padding:14px 16px;background:rgba(248,250,252,.7);display:grid;grid-gap:12px;gap:12px}.recurrence-mini-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.field-caption{display:block;margin-top:4px;color:var(--muted);font-size:.8rem;font-weight:500}.transaction-status-pill.pending{color:#9a6700;background:#fff7e6;border-color:rgba(154,103,0,.18)}.transaction-status-pill.paid{color:var(--success);background:rgba(22,101,52,.08);border-color:rgba(22,101,52,.18)}.transaction-details-panel{border:1px solid var(--line);border-radius:22px;padding:18px;background:rgba(248,250,252,.7);display:grid;grid-gap:14px;gap:14px}.transaction-details-header{display:grid;grid-gap:4px;gap:4px}.transaction-editor-actions{grid-column:1/-1}.active-detail{color:var(--accent);border-color:rgba(15,118,110,.18);background:rgba(15,118,110,.08)}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalLiftIn{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.category-image-preview{object-fit:cover}.category-fallback-icon,.category-image-preview{width:42px;height:42px;border-radius:12px;border:1px solid var(--line)}.category-fallback-icon{display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.9);font-size:1.2rem;font-weight:700}.icon-upload-preview{padding:12px;border-radius:20px;border:1px dashed var(--line);display:flex;justify-content:center;background:rgba(248,250,252,.7)}.icon-picker-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));grid-gap:10px;gap:10px}.icon-picker-option{border:1px solid var(--line);background:rgba(255,255,255,.96);border-radius:18px;padding:12px;display:grid;grid-gap:8px;gap:8px;justify-items:center;cursor:pointer;color:var(--ink)}.icon-picker-option.active{border-color:rgba(15,118,110,.45);box-shadow:0 0 0 4px rgba(15,118,110,.08)}.icon-picker-symbol{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border-radius:12px;background:rgba(248,250,252,.92);font-size:1.2rem;border:1px solid var(--line)}.subcategory-strip-title{color:var(--muted);font-size:.9rem;font-weight:600}.subcategories-panel{display:grid;grid-gap:12px;gap:12px;padding:8px 0}.subcategory-list{display:flex;flex-wrap:wrap;gap:10px}.subcategory-chip{display:inline-flex;align-items:center;gap:8px;padding:9px 12px;border-radius:999px;background:rgba(248,250,252,.95);border:1px solid var(--line)}.confirm-card{width:min(460px,100%);padding:28px;text-align:center}.confirm-icon{width:56px;height:56px;margin:0 auto 14px;border-radius:999px;display:grid;place-items:center;background:rgba(198,40,40,.08);font-size:1.5rem}.confirm-actions{justify-content:center}.danger-btn{background:var(--danger)}.subcategory-chip small{color:var(--muted)}.subcategory-chip button{border:none;background:transparent;color:var(--ink);cursor:pointer;padding:0;display:inline-flex;align-items:center;justify-content:center;min-width:20px}.subcategory-chip button.danger{color:var(--danger)}.subcategory-chip button:disabled{opacity:.45;cursor:not-allowed}.auth-layout{display:grid;grid-gap:18px;gap:18px;grid-template-columns:minmax(320px,460px) 1fr}.auth-card{padding:28px}.entity-grid{grid-template-columns:1.1fr .9fr}.form-stack{display:grid;grid-gap:14px;gap:14px}.field{display:grid;grid-gap:8px;gap:8px;color:var(--muted);font-size:.95rem}.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);border-radius:16px;padding:14px 16px;background:rgba(255,255,255,.96);color:var(--ink);font:inherit}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:rgba(15,118,110,.45);box-shadow:0 0 0 4px rgba(15,118,110,.08)}.form-error,.form-success{border-radius:16px;padding:12px 14px;font-size:.95rem}.form-error{background:rgba(185,28,28,.08);color:var(--danger)}.form-success{background:rgba(22,101,52,.08);color:var(--success)}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:18px}.chart-card,.insight-card,.list-card,.metric-card{padding:22px}.metric-value{font-size:2rem;margin:8px 0}.muted{color:var(--muted)}.dashboard-grid{grid-template-columns:1.2fr .8fr;align-items:start}.stack{display:grid;grid-gap:18px;gap:18px}.mini-bar{display:grid;grid-gap:8px;gap:8px;margin-top:18px}.mini-bar-row{display:grid;grid-template-columns:120px 1fr 72px;grid-gap:12px;gap:12px;align-items:center;font-size:.95rem}.mini-bar-fill{height:10px;border-radius:999px;background:linear-gradient(90deg,var(--accent),var(--gold))}.section-title{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.list{display:grid;grid-gap:14px;gap:14px}.list-row{display:flex;justify-content:space-between;gap:12px;padding-bottom:14px;border-bottom:1px solid var(--line)}.list-row:last-child{border-bottom:0;padding-bottom:0}.nav-strip{display:flex;justify-content:center;flex-wrap:nowrap;gap:10px;padding-bottom:6px;margin-bottom:18px}.nav-chip{gap:8px;padding:9px 12px;border-radius:999px;background:rgba(255,255,255,.82);border:1px solid var(--line);white-space:nowrap;font-size:.92rem}.nav-chip,.nav-chip-icon{display:inline-flex;align-items:center}.nav-chip-icon{justify-content:center;width:20px;height:20px;font-size:.95rem}@media (max-width:960px){.nav-strip{justify-content:flex-start;flex-wrap:nowrap;overflow-x:auto}.transactions-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.transactions-period-filters{width:100%}.auth-layout,.categories-layout,.dashboard-grid,.entity-grid,.hero{grid-template-columns:1fr}.accounts-header-row,.budgets-header-row,.cards-header-row,.categories-header-row,.import-header-row,.transactions-header-row{display:none}.accounts-row,.budgets-row,.cards-row,.categories-row,.import-row,.transactions-row{grid-template-columns:1fr;gap:10px}.subcategory-strip{padding-top:10px}.categories-search input{min-width:100%}}@media (max-width:720px){.accounts-editor-grid,.accounts-metrics,.budget-metrics,.cards-editor-grid,.import-metrics,.import-toolbar,.reports-metrics,.transaction-editor-layout.with-details,.transaction-form-grid,.transaction-inline-option-row,.transaction-primary-fields,.transaction-top-controls,.transactions-metrics{grid-template-columns:1fr}.transactions-period-filters{flex-direction:column;align-items:stretch}.transaction-span-2{grid-column:span 1}}