:root{color-scheme:light;--mft-font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", sans-serif;--mft-radius-sm: 10px;--mft-radius-md: 14px;--mft-radius-lg: 18px;--mft-radius-xl: 22px;--mft-radius-pill-md: 16px;--mft-radius-pill-lg: 18px;--mft-space-xxxs: 2px;--mft-space-xxs: 4px;--mft-space-xs: 8px;--mft-space-sm: 8px;--mft-space-md: 12px;--mft-space-lg: 16px;--mft-space-xl: 20px;--mft-space-xxl: 24px;--mft-space-xxxl: 32px;--mft-font-page-title-size: 24px;--mft-font-section-title-size: 24px;--mft-font-widget-heading-size: 18px;--mft-font-body-size: 14px;--mft-font-data-size: 12px;--mft-font-metric-size: 28px;--mft-font-card-metric-size: 24px;--mft-brand-teal: #008fa6;--mft-brand-blue: #0f4fd6;--mft-brand-green: #45b061;--mft-brand-red: #e33d38;--mft-color-page: #f2f5f7;--mft-color-card: #ffffff;--mft-color-subtle: #ebf0f5;--mft-color-border: rgba(0, 0, 0, .06);--mft-color-text: #242e38;--mft-color-text-secondary: #757f8c;--mft-color-primary: #0f4fd6;--mft-color-info: #008fa6;--mft-color-success: #45b061;--mft-color-danger: #e33d38;--mft-color-warning: #f7a056;--mft-gradient-surface: linear-gradient(180deg, #f7fafe 0%, #f0f5fa 100%);--mft-gradient-overview: linear-gradient(135deg, #008fa6 0%, #0f4fd6 100%);--mft-shadow-card: 0 2px 8px rgba(0, 0, 0, .06);--mft-shadow-floating: 0 8px 14px rgba(0, 0, 0, .1);--mft-sidebar-width: 220px;--mft-filter-rail-width: 320px;--mft-utility-column-width: 300px;--mft-shell-gap: 16px;--mft-hero-sticky-height: 240px;--mft-sidebar-bg: #1c1d21;--mft-sidebar-bg-bottom: #1c1d21;--mft-sidebar-text: rgba(245, 247, 250, .96);--mft-sidebar-text-secondary: rgba(245, 247, 250, .72);--mft-sidebar-divider: rgba(255, 255, 255, .12);--mft-sidebar-selected-bg: #ffffff;--mft-sidebar-selected-fg: #0f4fd6;--mft-scroll-pane-height: calc(100vh - var(--mft-hero-sticky-height) - 7rem);--bg-start: #f7fafe;--bg-end: #f0f5fa;--surface: rgba(255, 255, 255, .9);--surface-strong: var(--mft-color-card);--surface-elevated: rgba(255, 255, 255, .96);--surface-muted: var(--mft-color-subtle);--border: var(--mft-color-border);--border-strong: rgba(0, 0, 0, .08);--text: var(--mft-color-text);--muted: var(--mft-color-text-secondary);--primary: var(--mft-color-primary);--primary-strong: var(--mft-brand-teal);--danger: var(--mft-color-danger);--success: var(--mft-color-success);--warning: var(--mft-color-warning);--shadow: var(--mft-shadow-card);--shadow-soft: var(--mft-shadow-floating);--radius: var(--mft-radius-xl);--radius-sm: var(--mft-radius-lg);--radius-xs: var(--mft-radius-md)}:root[data-theme-mode=dark]{color-scheme:dark;--mft-color-page: #14171c;--mft-color-card: #1f2129;--mft-color-subtle: #2b2e38;--mft-color-border: rgba(255, 255, 255, .09);--mft-color-text: #ebf0f7;--mft-color-text-secondary: #a8b3c2;--mft-color-primary: #5994fa;--mft-color-info: #45c2d1;--mft-color-success: #61d185;--mft-color-danger: #f56b61;--mft-gradient-surface: linear-gradient(180deg, #1a1c24 0%, #0d0f14 100%);--mft-gradient-overview: linear-gradient(135deg, #15576b 0%, #1a3875 100%);--mft-shadow-card: 0 2px 8px rgba(0, 0, 0, .28);--mft-shadow-floating: 0 8px 14px rgba(0, 0, 0, .32);--bg-start: #1a1c24;--bg-end: #0d0f14;--surface: rgba(31, 33, 41, .92);--surface-strong: var(--mft-color-card);--surface-elevated: rgba(31, 33, 41, .96);--surface-muted: var(--mft-color-subtle);--border: var(--mft-color-border);--border-strong: rgba(255, 255, 255, .12);--text: var(--mft-color-text);--muted: var(--mft-color-text-secondary);--primary: var(--mft-color-primary);--primary-strong: var(--mft-color-info);--danger: var(--mft-color-danger);--success: var(--mft-color-success);--warning: #f0a84f;--shadow: var(--mft-shadow-card);--shadow-soft: var(--mft-shadow-floating)}:root[data-theme-mode=color-blind]{--primary: #0057b8;--primary-strong: #008fa6;--success: #0057b8;--danger: #f7a056;--warning: #a86200}:root[data-theme-mode=monochrome]{--bg-start: #f7f7f7;--bg-end: #ececec;--surface: rgba(255, 255, 255, .92);--surface-strong: #ffffff;--surface-elevated: rgba(255, 255, 255, .95);--surface-muted: rgba(239, 239, 239, .9);--border: rgba(0, 0, 0, .1);--border-strong: rgba(0, 0, 0, .16);--text: #111111;--muted: #555555;--primary: #343434;--primary-strong: #131313;--danger: #525252;--success: #2f2f2f;--warning: #444444}*{box-sizing:border-box}html,body{min-height:100%}body{margin:0;font-family:var(--mft-font-family);font-size:var(--mft-font-body-size);line-height:1.4;background:var(--mft-color-page);background-attachment:fixed;color:var(--text)}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}input,select,textarea{width:100%;margin-top:var(--mft-space-xxs);border:1px solid var(--border);border-radius:var(--radius-xs);background:var(--surface-strong);color:var(--text);padding:var(--mft-space-sm) var(--mft-space-md)}textarea{min-height:110px;resize:vertical}label{display:block;font-size:var(--mft-font-body-size);color:var(--muted)}.card{background:var(--surface-strong);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.glass-card{background:#ffffffd6}:root[data-theme-mode=dark] .glass-card{background:#1f2129f0}.btn{border:0;border-radius:var(--mft-radius-pill-lg);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-weight:700;letter-spacing:.01em;padding:var(--mft-space-sm) var(--mft-space-lg);transition:transform .2s ease,opacity .2s ease,background .2s ease}.btn:hover{transform:translateY(-1px)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn.primary{background:var(--mft-gradient-overview);box-shadow:var(--mft-shadow-floating);color:#fff}.btn.secondary{background:var(--surface-muted);border:1px solid var(--border);color:var(--primary)}.btn.ghost{background:var(--surface-muted);border:1px solid var(--border);color:var(--text)}.btn.danger{background:#e4574d1f;color:var(--danger)}.btn.success{background:var(--success);box-shadow:var(--mft-shadow-floating);color:#fff}.btn.expense{background:var(--danger);box-shadow:var(--mft-shadow-floating);color:#fff}.full-width{width:100%}.small-btn{padding:.55rem .8rem;font-size:.85rem}.brand-tile{align-items:center;background:var(--mft-gradient-overview);border-radius:var(--mft-radius-xl);box-shadow:var(--mft-shadow-floating);color:#fff;display:inline-flex;font-size:1.15rem;font-weight:800;height:70px;justify-content:center;letter-spacing:.08em;width:70px}.brand-tile.small{border-radius:var(--mft-radius-lg);font-size:.9rem;height:52px;width:52px}.splash-screen,.loading-screen{align-items:center;display:flex;flex-direction:column;gap:.75rem;justify-content:center;margin:0 auto;min-height:100vh;padding:2rem;text-align:center}.loading-screen{margin-top:6rem;max-width:560px;min-height:auto;padding:3rem}.splash-tile{height:88px;width:88px}.auth-screen{align-items:center;display:grid;min-height:100vh;overflow:hidden;padding:2rem;position:relative}.auth-ornament{border-radius:999px;filter:blur(2px);position:absolute}.auth-ornament-left{background:#1d4ed81f;height:320px;left:-70px;top:80px;width:320px}.auth-ornament-right{background:#0f9b7224;bottom:-60px;height:380px;right:-80px;width:380px}.auth-panel{margin:0 auto;max-width:520px;padding:2rem;position:relative;width:100%;z-index:1}.auth-brand{align-items:center;display:flex;gap:1rem;margin-bottom:1.5rem}.auth-brand h1,.sidebar-brand h2,.page-toolbar h1,.card h2,.card h3{margin:0}.segmented-control{background:var(--surface-muted);border:1px solid var(--border);border-radius:var(--mft-radius-pill-md);display:grid;gap:.4rem;grid-template-columns:repeat(2,1fr);margin-bottom:var(--mft-space-lg);padding:var(--mft-space-xxs)}.segmented-control.compact{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:0}.segment{background:transparent;border:0;border-radius:var(--mft-radius-pill-md);color:var(--muted);cursor:pointer;font-size:var(--mft-font-body-size);font-weight:500;padding:var(--mft-space-sm) var(--mft-space-md)}.segmented-control.compact .segment{flex:1 1 0;min-width:0;padding:.72rem .88rem}.segmented-control.two-up .segment{min-width:calc(50% - .35rem)}.segmented-control.three-up .segment{min-width:calc(33.333% - .35rem)}.segmented-control.four-up .segment{min-width:calc(25% - .35rem)}.segment.active{background:var(--surface-strong);box-shadow:var(--mft-shadow-card);color:var(--text)}.stack-form{display:grid;gap:1rem}.toggle-field{align-items:center;display:flex;gap:.75rem}.toggle-field input{margin:0;width:auto}.inline-message{color:var(--danger);margin-bottom:0}.auth-footnote,.muted,.label,.small-text{color:var(--muted)}.app-shell{display:grid;gap:0;grid-template-columns:var(--mft-sidebar-width) minmax(0,1fr);min-height:100vh;padding:0}.sidebar,.content-shell,.page-toolbar,.page-body,.settings-panel{padding:1.25rem}.sidebar{display:flex;flex-direction:column;gap:.9rem;justify-content:space-between;padding:.9rem .75rem .7rem;position:sticky;top:0;height:100vh;border:0;border-radius:0;box-shadow:none;background:linear-gradient(180deg,var(--mft-sidebar-bg) 0%,var(--mft-sidebar-bg-bottom) 100%);color:var(--mft-sidebar-text)}.sidebar .muted,.sidebar .small-text,.sidebar .label,.sidebar .sidebar-brand p{color:var(--mft-sidebar-text-secondary)}.sidebar .toolbar-icon{background:transparent;border:0;color:var(--mft-sidebar-text);box-shadow:none}.sidebar .toolbar-icon.is-accent{background:#ffffff14;color:var(--mft-sidebar-text)}.sidebar-topbar{align-items:flex-start;display:flex;gap:.9rem;justify-content:space-between;padding:.1rem .15rem .35rem}.sidebar-brand{align-items:center;display:flex;gap:1rem}.sidebar-brand p{margin-top:.15rem}.sidebar-nav{display:grid;gap:.25rem;margin-top:.35rem}.nav-link,.bottom-nav a{align-items:center;border-radius:22px;color:var(--mft-sidebar-text-secondary);display:flex;font-size:.95rem;gap:.8rem;padding:.82rem .95rem}.nav-link{background:transparent;border:1px solid transparent;cursor:pointer}.nav-link:hover:not(.active){background:#ffffff0f;color:var(--mft-sidebar-text);cursor:pointer}.nav-link.active,.bottom-nav a.active{background:var(--mft-sidebar-selected-bg);border-color:transparent;box-shadow:none;color:var(--mft-sidebar-selected-fg);font-weight:700}.bottom-nav a{color:var(--text)}.bottom-nav a.active{background:var(--surface-strong);color:var(--primary)}.nav-link-icon{width:18px}.sidebar-footer{display:grid;gap:.55rem;margin-top:auto;padding:.65rem .25rem 0;border-top:1px solid var(--mft-sidebar-divider)}.sidebar-footer-actions{display:grid;gap:.35rem}.sidebar-action-link{background:transparent;border:1px solid transparent;color:var(--mft-sidebar-text-secondary);cursor:pointer;justify-content:flex-start;width:100%}.sidebar-action-link:hover{background:#ffffff0f;color:var(--mft-sidebar-text);cursor:pointer}.sidebar-user{display:grid;gap:.15rem}.sidebar-user strong{font-size:.9rem}.content-shell{display:grid;gap:1.15rem;grid-template-rows:auto minmax(0,1fr);height:100vh;min-width:0;overflow:hidden;padding:var(--mft-space-lg)}.page-toolbar{align-items:center;background:transparent;border:0;border-radius:0;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;display:flex;justify-content:center;padding:var(--mft-space-sm) var(--mft-space-md);position:sticky;top:0;z-index:5}.toolbar-side{align-items:center;display:flex;flex:1;gap:.75rem}.toolbar-leading{min-width:0}.toolbar-actions{flex:0 0 auto;justify-content:flex-end}.page-title-cluster{flex:1;text-align:center}.page-title-cluster h1{font-size:var(--mft-font-page-title-size);font-weight:700}.toolbar-group-label{background:var(--surface-muted);border:1px solid var(--border);border-radius:999px;display:inline-flex;min-height:40px;align-items:center;padding:0 .9rem;white-space:nowrap}.toolbar-actions,.inline-actions,.row-actions,.quick-actions{display:flex;flex-wrap:wrap;gap:.75rem}.toolbar-icon{align-items:center;background:var(--surface-strong);border:1px solid var(--border);border-radius:50%;color:var(--text);cursor:pointer;display:inline-flex;box-shadow:none;font-size:18px;height:36px;justify-content:center;width:36px}.toolbar-icon.is-muted{background:#ffffffb3;color:#4d5a70}.toolbar-icon.is-accent{background:#1673f21f;color:var(--primary)}.page-body{min-height:0;overflow:hidden;padding:0}.page-body>section{height:100%;overflow-y:auto;padding-right:.25rem}.page-body .hero-card.full-span{position:sticky;top:0;z-index:4}.page-grid{display:grid;align-items:start;gap:var(--mft-shell-gap);grid-template-columns:minmax(0,1.28fr) minmax(var(--mft-filter-rail-width),.52fr)}.dashboard-grid{display:grid;gap:var(--mft-shell-gap);grid-template-columns:minmax(var(--mft-filter-rail-width),.52fr) minmax(0,1.28fr)}.dashboard-hero-slot{display:block;min-width:0}.dashboard-main-column{display:flex;flex-direction:column;gap:var(--mft-shell-gap);min-width:0}.transactions-layout{align-items:start;display:grid;gap:var(--mft-shell-gap);grid-template-columns:minmax(0,1.28fr) minmax(var(--mft-filter-rail-width),.52fr)}.transactions-main-column{display:grid;gap:var(--mft-shell-gap)}.full-span{grid-column:1 / -1}.page-grid>.filter-panel,.transactions-layout>.filter-panel{align-self:start;grid-column:2;height:var(--mft-scroll-pane-height);max-height:var(--mft-scroll-pane-height);min-height:0;overflow-y:auto;position:static;top:auto;scrollbar-width:none;-ms-overflow-style:none}.page-grid>.filter-panel::-webkit-scrollbar,.transactions-layout>.filter-panel::-webkit-scrollbar{display:none;width:0;height:0}.page-grid>.content-column{grid-column:1}.dashboard-screen,.transactions-screen,.budget-screen{overflow:hidden}.dashboard-screen{grid-template-rows:auto minmax(0,1fr)}.dashboard-screen .dashboard-actions-column,.dashboard-screen .dashboard-main-column{height:var(--mft-scroll-pane-height);max-height:var(--mft-scroll-pane-height);min-height:0;overflow-y:auto;padding-right:.2rem;scrollbar-width:none;-ms-overflow-style:none}.dashboard-screen .dashboard-actions-column::-webkit-scrollbar,.dashboard-screen .dashboard-main-column::-webkit-scrollbar{display:none;width:0;height:0}.transactions-screen{grid-template-rows:auto minmax(0,1fr)}.transactions-screen .transactions-main-column{min-height:0;overflow:hidden}.transactions-screen .transactions-list-card,.budget-screen .budget-list-column{height:var(--mft-scroll-pane-height);max-height:var(--mft-scroll-pane-height);min-height:0;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.transactions-screen .transactions-list-card::-webkit-scrollbar,.budget-screen .budget-list-column::-webkit-scrollbar{display:none;width:0;height:0}.budget-screen{grid-template-rows:auto minmax(0,1fr)}.hero-card{background:linear-gradient(135deg,#008fa614,#0f4fd60f),var(--surface-strong);border-color:var(--border);display:grid;gap:var(--mft-space-lg);grid-template-columns:minmax(0,1fr) auto;padding:var(--mft-space-xl)}.hero-card-dashboard{background:radial-gradient(circle at 82% 86%,#0a1b59e6,#0a1b5900 48%),linear-gradient(138deg,#15a7c4,#1e6fe8 52%,#2c3db8);border:0;box-shadow:0 10px 22px #0f4fd640;color:#fff;gap:var(--mft-space-sm);grid-template-columns:repeat(3,minmax(0,1fr));isolation:isolate;overflow:hidden;padding:var(--mft-space-xl);position:relative}.hero-card-dashboard:before{background:radial-gradient(circle at 20% 20%,rgba(255,255,255,.26),transparent 46%),repeating-linear-gradient(-35deg,rgba(255,255,255,.09) 0,rgba(255,255,255,.09) 1px,transparent 1px,transparent 6px);content:"";inset:0;opacity:.4;pointer-events:none;position:absolute;z-index:-1}.hero-card-dashboard:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 28%,rgba(255,255,255,.1),transparent 38%),radial-gradient(circle at 30% 74%,rgba(9,16,46,.2),transparent 42%);pointer-events:none;mix-blend-mode:soft-light;z-index:-1}.hero-card-title{font-size:var(--mft-font-widget-heading-size);font-weight:500;grid-column:1 / -1;letter-spacing:.01em;margin-bottom:.25rem}.hero-summary-metric{display:grid;gap:.2rem}.hero-summary-metric .label,.hero-card-dashboard .label{color:#ffffffc2}.hero-summary-metric strong{font-size:var(--mft-font-metric-size);font-weight:700;line-height:1.05}.hero-card-divider{background:#ffffff3d;grid-column:1 / -1;height:1px;margin:var(--mft-space-xxs) 0}.hero-bottom-row{align-items:center;display:flex;gap:var(--mft-space-md);grid-column:1 / -1;justify-content:space-between;padding-top:var(--mft-space-xs)}.hero-bottom-row .label{color:#ffffffc7}.hero-bottom-row strong{color:#fffffff5;font-size:var(--mft-font-body-size);font-weight:500}.hero-summary-metric.bottom-left strong,.hero-summary-metric.bottom-center strong,.hero-summary-metric.bottom-right strong{font-size:var(--mft-font-card-metric-size)}.align-right{text-align:right}.bottom-center{text-align:center}.hero-metrics,.stat-grid{display:grid;gap:.9rem}.hero-metrics{grid-template-columns:repeat(3,minmax(110px,1fr))}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));padding:1.5rem}.stat-grid.two-column{grid-template-columns:repeat(4,minmax(0,1fr))}.stat-grid.three-column{grid-template-columns:repeat(3,minmax(0,1fr))}.metric-tile{background:var(--surface-strong);border:1px solid var(--border);border-radius:var(--mft-radius-lg);display:grid;gap:var(--mft-space-xxs);padding:var(--mft-space-lg);position:relative}.metric-tile:before{background:var(--mft-color-info);border-radius:3px;content:"";height:4px;left:var(--mft-space-lg);position:absolute;top:var(--mft-space-md);width:28px}.metric-tile strong,.hero-metrics strong{font-size:var(--mft-font-widget-heading-size)}.compact-metric-tile{min-height:0;padding:var(--mft-space-md) var(--mft-space-lg) var(--mft-space-md)}.compact-metric-tile strong{font-size:var(--mft-font-section-title-size)}.dashboard-actions-column,.dashboard-side-column{display:grid;gap:1rem;align-content:start}.dashboard-actions-column{min-width:0}.dashboard-side-column{align-content:start}.dashboard-actions-row{display:grid;gap:.85rem;grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-action-strip{margin-top:-.1rem}.large-action{border-radius:20px;box-shadow:var(--mft-shadow-floating);font-size:1rem;justify-content:center;min-height:54px}.dashboard-panel{border-radius:var(--mft-radius-xl);min-height:142px;padding:var(--mft-space-lg)}.quick-actions-panel,.widget-card{background:var(--surface-strong)}.dashboard-overview-card{background:var(--surface-strong);display:grid;gap:var(--mft-space-md);min-height:150px;padding:var(--mft-space-lg)}.dashboard-overview-header{align-items:center;display:flex;justify-content:space-between}.dashboard-overview-title{align-items:center;color:var(--text);display:inline-flex;gap:var(--mft-space-sm)}.dashboard-overview-title i{color:var(--primary);font-size:.95rem}.dashboard-overview-title h3{font-size:var(--mft-font-widget-heading-size);font-weight:500}.dashboard-overview-body{align-content:center;display:grid;gap:var(--mft-space-xs);min-height:84px}.dashboard-overview-body strong{font-size:var(--mft-font-card-metric-size);line-height:1.05}.dashboard-overview-empty{align-content:center;color:color-mix(in srgb,var(--muted) 78%,white 22%);display:grid;justify-items:center;min-height:84px;text-align:center}.widget-detail-card,.widget-list{display:grid;gap:var(--mft-space-md)}.widget-detail-grid{display:grid;gap:var(--mft-space-sm)}.widget-detail-grid.two-up{grid-template-columns:repeat(2,minmax(0,1fr))}.widget-list-row{align-items:center;display:flex;gap:var(--mft-space-md);justify-content:space-between;padding-top:var(--mft-space-sm)}.widget-list-row+.widget-list-row{border-top:1px solid var(--border)}.compact-header{align-items:center;margin-bottom:.9rem}.transaction-card-header{margin-bottom:var(--mft-space-md)}.segmented-tabs{background:var(--surface-muted);border:1px solid var(--border);border-radius:999px;display:inline-flex;gap:.2rem;padding:.2rem}.mini-segment{background:transparent;border:0;border-radius:999px;color:var(--muted);cursor:pointer;font-size:.8rem;font-weight:600;padding:.45rem .8rem}.mini-segment.active{background:var(--surface-strong);box-shadow:var(--mft-shadow-card);color:var(--text)}.dashboard-list{display:grid;gap:.75rem;min-height:190px}.ipad-list-panel{padding:var(--mft-space-lg)}.transaction-list{display:grid}.dashboard-list-row{align-items:center;background:linear-gradient(180deg,var(--surface-muted),var(--surface));border:1px solid var(--border);border-radius:var(--mft-radius-lg);box-shadow:var(--mft-shadow-card);display:flex;gap:1rem;justify-content:space-between;padding:.85rem .95rem}.ipad-transaction-row,.transaction-list-row{align-items:center;background:transparent;border:0;border-bottom:1px solid rgba(36,46,56,.07);border-radius:0;box-shadow:none;display:flex;gap:var(--mft-space-md);justify-content:space-between;padding:.8rem 0}.ipad-transaction-row:last-child,.transaction-list-row:last-child{border-bottom:0;padding-bottom:0}.dashboard-list-row:first-child{padding-top:.85rem}.dashboard-list-row:last-child{padding-bottom:.85rem}.dashboard-row-main{align-items:center;display:flex;gap:.85rem;min-width:0}.transaction-row-main{align-items:center;display:flex;gap:var(--mft-space-md);min-width:0}.dashboard-row-icon{align-items:center;background:#e33d381f;border-radius:var(--mft-radius-md);color:var(--danger);display:inline-flex;flex:0 0 auto;height:40px;justify-content:center;width:40px}.dashboard-row-icon.is-income{background:#45b06124;color:var(--success)}.dashboard-row-icon.is-warning,.transaction-row-icon.is-warning{background:#f7a05629;color:var(--mft-color-warning)}.dashboard-row-icon.is-info,.transaction-row-icon.is-info{background:#008fa61f;color:var(--mft-color-info)}.transaction-row-icon{align-items:center;background:#e33d381f;border-radius:var(--mft-radius-md);color:var(--danger);display:inline-flex;flex:0 0 auto;font-size:.95rem;height:40px;justify-content:center;width:40px}.transaction-row-icon.is-income{background:#45b06124;color:var(--success)}.dashboard-row-meta{display:grid;gap:.4rem;justify-items:end}.transaction-row-meta{display:grid;gap:.15rem;justify-items:end;text-align:right}.dashboard-row-actions{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-end}.dashboard-row-select,.inline-select{margin-top:0;min-width:130px;padding:.5rem .7rem}.transaction-status-label{font-size:var(--mft-font-data-size);font-weight:600}.transaction-status-label.is-income{color:var(--success)}.transaction-status-label.is-warning{color:var(--mft-color-warning)}.transaction-status-label.is-overdue{color:var(--danger)}.transaction-status-date{color:var(--muted);font-size:var(--mft-font-data-size)}.dashboard-row-button,.list-row-button{border:0;color:inherit;cursor:pointer;font:inherit;text-align:left;width:100%}.status-chip{background:#008fa61f;border:1px solid rgba(0,143,166,.14);border-radius:999px;color:var(--mft-color-info);display:inline-flex;font-size:.72rem;font-weight:700;letter-spacing:.04em;padding:.28rem .6rem;text-transform:uppercase}.status-chip.is-income{background:#1ea9711f;border-color:#1ea97124;color:var(--success)}.status-chip.is-overdue{background:#e4574d1f;border-color:#e4574d24;color:var(--danger)}.dashboard-empty-state{align-content:center;color:var(--muted);display:grid;gap:.9rem;justify-items:center;min-height:180px;text-align:center}.empty-icon{align-items:center;background:#18a0cb1f;border-radius:20px;color:#1895bd;display:inline-flex;font-size:1.5rem;height:60px;justify-content:center;width:60px}.compact-summary-card{min-height:112px}.compact-summary-header{align-items:center;display:flex;margin-bottom:var(--mft-space-lg)}.compact-summary-body{text-align:left}.compact-select{margin-top:0;max-width:220px;padding:.7rem .95rem}.section-header{align-items:center;display:flex;gap:var(--mft-space-md);justify-content:space-between;margin-bottom:var(--mft-space-lg)}.section-header h3{color:var(--text);font-size:var(--mft-font-widget-heading-size);font-weight:500}.section-header p{font-size:var(--mft-font-data-size)}.control-card{padding:1.1rem}.filters-rail{display:grid;gap:var(--mft-space-lg);position:sticky}.control-stack{display:grid;gap:.95rem;margin-bottom:1.2rem}.filters-stack{margin-bottom:0}.control-group{display:grid;gap:var(--mft-space-sm)}.control-label{color:var(--muted);font-size:var(--mft-font-data-size);font-weight:500}.soft-select{background:var(--surface-strong);border:1px solid rgba(36,46,56,.07);border-radius:var(--mft-radius-pill-lg);box-shadow:inset 0 1px #ffffff73;min-height:46px;padding:.8rem 1rem}.amount-inputs{display:grid;gap:var(--mft-space-md)}.soft-field{display:grid;gap:var(--mft-space-xs)}.soft-field span{color:var(--muted);font-size:var(--mft-font-data-size)}.soft-input{background:linear-gradient(180deg,#f4f7fbfa,#ecf1f6fa);border:1px solid rgba(36,46,56,.05);border-radius:var(--mft-radius-pill-lg);min-height:44px;padding:.8rem 1rem}.transactions-summary-card{padding-bottom:var(--mft-space-lg)}.transactions-list-card{display:grid;min-height:520px}.progress-panel{display:grid;gap:var(--mft-space-sm)}.progress-track.tall{height:12px;position:relative}.progress-track.compact{height:8px;margin-top:var(--mft-space-xs)}.budget-progress-fill{background:linear-gradient(135deg,var(--primary),var(--mft-color-info))}.projected-progress-fill{background:linear-gradient(135deg,#308fed5c,#45b0616b);opacity:.75}.progress-legend{display:flex;flex-wrap:wrap;gap:var(--mft-space-md);justify-content:space-between}.period-nav{align-items:center;background:var(--surface-muted);border:1px solid var(--border);border-radius:22px;display:grid;gap:.6rem;grid-template-columns:38px minmax(0,1fr) 38px;padding:.35rem}.period-nav-label{font-size:.95rem;font-weight:700;text-align:center}.filter-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));margin-top:1rem}.filter-grid.compact{grid-template-columns:repeat(auto-fit,minmax(150px,220px))}.list-table{display:grid;gap:.75rem}.compact-list{gap:.6rem}.list-row{align-items:center;background:var(--surface-strong);border:1px solid var(--border);border-radius:var(--mft-radius-lg);display:flex;gap:1rem;justify-content:space-between;padding:1rem 1.1rem}.compact-row{padding:.8rem .9rem}.list-row.with-actions{align-items:flex-start}.metric-list-row{background:linear-gradient(180deg,var(--surface-strong),var(--surface));box-shadow:var(--mft-shadow-card);padding:.95rem 1rem}.dashboard-screen .dashboard-actions-column,.dashboard-screen .dashboard-side-column,.dashboard-screen .dashboard-main-column{gap:var(--mft-space-lg)}.dashboard-screen .dashboard-panel{border-radius:var(--mft-radius-lg);min-height:132px}.dashboard-screen .dashboard-overview-card{min-height:138px}.transactions-screen .transactions-list-card{padding:var(--mft-space-lg)}.transactions-screen .transaction-list{border-top:1px solid rgba(36,46,56,.08)}.transactions-screen .filters-rail{top:5.2rem}.budget-screen .list-table,.credit-screen .list-table,.reports-screen .list-table,.insights-screen .list-table{gap:0}.budget-screen .budget-row-card,.credit-screen .metric-list-row,.reports-screen .metric-list-row,.insights-screen .metric-list-row{background:transparent;border:0;border-bottom:1px solid rgba(36,46,56,.08);border-radius:0;box-shadow:none;padding:.9rem .1rem}.budget-screen .budget-row-card:last-child,.credit-screen .metric-list-row:last-child,.reports-screen .metric-list-row:last-child,.insights-screen .metric-list-row:last-child{border-bottom:0}.goals-screen .goal-grid{grid-template-columns:1fr;gap:0}.goals-screen .goal-card{background:transparent;border:0;border-bottom:1px solid rgba(36,46,56,.08);border-radius:0;box-shadow:none;gap:.55rem;padding:.9rem .1rem}.goals-screen .goal-card:last-child{border-bottom:0}.goals-screen .goal-card:before{left:.1rem;top:.6rem}.goals-screen .full-span>h3,.credit-screen .full-span>h3,.reports-screen .card>h3{font-size:var(--mft-font-widget-heading-size);font-weight:500}.goal-detail-screen .list-row.metric-list-row,.credit-detail-screen .list-row.metric-list-row{background:transparent;border:0;border-bottom:1px solid rgba(36,46,56,.08);border-radius:0;box-shadow:none;padding:.9rem .1rem}.goal-detail-screen .list-row.metric-list-row:last-child,.credit-detail-screen .list-row.metric-list-row:last-child{border-bottom:0}.negative{color:var(--danger)}.positive{color:var(--success)}.goal-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.goal-card{background:var(--surface-strong);border:1px solid var(--border);border-radius:var(--mft-radius-xl);box-shadow:var(--mft-shadow-card);display:grid;gap:.8rem;overflow:hidden;padding:1rem;position:relative}.goal-card:before{background:var(--mft-color-info);border-radius:999px;content:"";height:4px;left:1rem;position:absolute;top:.95rem;width:28px}.goal-card-header{align-items:center;display:flex;justify-content:space-between;padding-top:.45rem}.goal-card-metrics{display:grid;gap:var(--mft-space-md);grid-template-columns:repeat(2,minmax(0,1fr))}.goal-card-metrics strong{display:block;margin-top:.25rem}.credit-line-meta{align-items:flex-end;display:grid;justify-items:end}.progress-track{background:#94a3b833;border-radius:999px;height:10px;overflow:hidden}.progress-fill{background:linear-gradient(135deg,var(--primary),var(--success));height:100%}.settings-drawer{inset:0;position:fixed;z-index:20}.settings-backdrop{background:#0f172a57;inset:0;position:absolute}.settings-panel{display:grid;gap:1rem;max-width:420px;height:100vh;position:absolute;right:0;top:0;width:100%;border-radius:var(--mft-radius-xl) 0 0 var(--mft-radius-xl);overflow-y:auto;overscroll-behavior:contain;padding-bottom:calc(1.25rem + env(safe-area-inset-bottom,0px))}.settings-header{align-items:flex-start;display:flex;justify-content:space-between;position:sticky;top:0;background:var(--surface);padding-bottom:.6rem;z-index:1}.settings-block{border-top:1px solid var(--border);padding-top:1rem}.settings-list{display:grid;gap:.75rem;margin:.9rem 0 1rem}.settings-inline-form{margin:var(--mft-space-lg) 0}.settings-inline-form .btn{width:100%}.settings-list-row{align-items:center;background:var(--surface-muted);border:1px solid var(--border);border-radius:20px;display:flex;gap:.9rem;justify-content:space-between;padding:.9rem 1rem}.settings-list-row.is-compact{padding-block:.8rem}.settings-link{align-items:center;background:var(--surface-muted);border:1px solid var(--border);border-radius:18px;color:var(--text);cursor:pointer;display:flex;font:inherit;justify-content:space-between;padding:.9rem 1rem;text-align:left;width:100%}.settings-link-danger{color:var(--danger)}.dashboard-widget-grid{grid-column:2}.widget-metric-stack{display:grid;gap:.45rem}.widget-metric-grid{display:grid;gap:.85rem;grid-template-columns:repeat(2,minmax(0,1fr))}.transaction-editor-drawer{z-index:30}.transaction-editor-panel{max-width:520px;border-radius:var(--mft-radius-xl) 0 0 var(--mft-radius-xl)}.bottom-nav{display:none}.eyebrow{color:var(--primary);font-size:.82rem;font-weight:700;letter-spacing:.08em;margin:0 0 .4rem;text-transform:uppercase}@media(max-width:1100px){.app-shell{grid-template-columns:1fr;padding-bottom:7.5rem}.sidebar{display:none}.bottom-nav{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);bottom:1rem;display:grid;gap:.3rem;grid-template-columns:repeat(6,minmax(0,1fr));left:1rem;padding:.5rem;position:fixed;right:1rem;z-index:10}.bottom-nav a{flex-direction:column;font-size:.78rem;gap:.35rem;justify-content:center;padding:.65rem .4rem;text-align:center}.page-toolbar{padding-inline:.75rem}.dashboard-grid,.transactions-layout{grid-template-columns:1fr}.dashboard-widget-grid,.dashboard-main-column{grid-column:auto}.toolbar-group-label{display:none}.content-shell{height:auto;overflow:visible}.page-body{overflow:visible}.page-body>section{height:auto;overflow:visible;padding-right:0}.page-body .hero-card.full-span,.page-grid>.filter-panel,.transactions-layout>.filter-panel{max-height:none;overflow:visible;position:static}.dashboard-screen,.transactions-screen,.budget-screen,.insights-screen{overflow:visible}.dashboard-screen .dashboard-actions-column,.dashboard-screen .dashboard-widget-grid,.dashboard-screen .dashboard-main-column,.transactions-screen .transactions-list-card,.budget-screen .budget-list-column,.insights-screen .insights-widget-grid{height:auto;max-height:none;overflow:visible;padding-right:0}}@media(max-width:820px){.page-grid,.transactions-layout,.dashboard-actions-row,.hero-card,.hero-metrics,.stat-grid.two-column,.stat-grid.three-column{grid-template-columns:1fr}.page-grid>.filter-panel,.transactions-layout>.filter-panel{grid-column:1}.page-toolbar,.section-header,.list-row,.dashboard-list-row,.transaction-list-row,.ipad-transaction-row{align-items:flex-start;flex-direction:column}.toolbar-side{width:100%}.page-title-cluster{order:-1;text-align:left}.hero-card-dashboard{grid-template-columns:1fr}.align-right,.bottom-center{text-align:left}.hero-bottom-row{align-items:flex-start;flex-direction:column}.segmented-tabs{flex-wrap:wrap}.settings-list-row{align-items:flex-start;flex-direction:column}.widget-metric-grid,.goal-card-metrics{grid-template-columns:1fr}.transaction-row-meta{justify-items:start;text-align:left}.segmented-control.compact .segment{min-width:calc(50% - .35rem)}.period-nav{grid-template-columns:38px minmax(0,1fr) 38px}}.widget-surface{--mft-chart-height-sm: 180px;--mft-chart-height-md: 220px;--mft-chart-height-lg: 260px;--mft-chart-height-xl: 300px}.widget-chrome-header{align-items:flex-start;display:flex;gap:var(--mft-space-md);justify-content:space-between;margin-bottom:var(--mft-space-md)}.widget-chrome-title{align-items:center;display:inline-flex;gap:var(--mft-space-sm)}.widget-chrome-title i{color:var(--primary);font-size:.95rem}.widget-chrome-title h3{font-size:var(--mft-font-widget-heading-size);font-weight:500;margin:0}.widget-chrome-title p{margin:.1rem 0 0}.widget-chrome-body{display:grid;gap:var(--mft-space-md)}.widget-chart-canvas{display:block;width:100%}.widget-chart-canvas apx-chart,.widget-chart-canvas .apexcharts-canvas{width:100%!important}.widget-chart-sm{height:var(--mft-chart-height-sm)}.widget-chart-md{height:var(--mft-chart-height-md)}.widget-chart-lg{height:var(--mft-chart-height-lg)}.widget-chart-xl{height:var(--mft-chart-height-xl)}.widget-stat-row{align-items:center;display:flex;gap:var(--mft-space-md);justify-content:space-between}.widget-stat-row strong{font-size:var(--mft-font-card-metric-size);line-height:1.05}.insights-widget-grid{display:grid;gap:var(--mft-space-lg);grid-template-columns:1fr}.insights-widget-grid>*{min-width:0;width:100%}.insights-screen .insights-widget-grid{height:var(--mft-scroll-pane-height);max-height:var(--mft-scroll-pane-height);min-height:0;overflow-y:auto;padding-right:.2rem;align-content:start;scrollbar-width:none;-ms-overflow-style:none}.insights-screen .insights-widget-grid::-webkit-scrollbar{display:none;width:0;height:0}.insights-screen{grid-template-rows:auto minmax(0,1fr);overflow:hidden}.insights-category-filter{display:grid;gap:var(--mft-space-sm)}.insights-category-filter-header{align-items:center;display:flex;justify-content:space-between}.chip-row{display:flex;flex-wrap:wrap;gap:.35rem}.category-chip{background:var(--surface-muted);border:1px solid var(--border);border-radius:999px;color:var(--text);cursor:pointer;font-size:.78rem;padding:.3rem .7rem;transition:background .15s ease,border-color .15s ease,color .15s ease}.category-chip:hover{background:color-mix(in srgb,var(--surface-muted) 70%,var(--primary) 30%)}.category-chip.active{background:var(--primary);border-color:var(--primary);color:#fff}.sync-result-modal{position:fixed;inset:0;z-index:1200;display:grid;place-items:center;padding:1.25rem}.sync-result-backdrop{position:absolute;inset:0;background:#0c111873;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.sync-result-panel{position:relative;display:grid;gap:var(--mft-space-md);justify-items:center;max-width:380px;padding:var(--mft-space-lg) var(--mft-space-lg) var(--mft-space-md);text-align:center;width:100%;animation:sync-result-pop .18s ease-out}@keyframes sync-result-pop{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.sync-result-icon{align-items:center;border-radius:999px;display:inline-flex;font-size:1.75rem;height:56px;justify-content:center;width:56px}.sync-result-panel.is-success .sync-result-icon{background:color-mix(in srgb,var(--income, #2ecc71) 18%,transparent);color:var(--income, #2ecc71)}.sync-result-panel.is-error .sync-result-icon{background:color-mix(in srgb,var(--expense, #e74c3c) 18%,transparent);color:var(--expense, #e74c3c)}.sync-result-title{font-size:1.2rem;font-weight:700;margin:0}.sync-result-message{margin:0;max-width:30ch}.sync-result-actions{display:flex;gap:.5rem;justify-content:center;margin-top:.25rem;width:100%}.sync-result-actions .btn{min-width:110px}.apexcharts-canvas{font-family:inherit!important}.apexcharts-tooltip,.apexcharts-xaxistooltip,.apexcharts-yaxistooltip{background:var(--surface-strong)!important;border:1px solid var(--border)!important;box-shadow:var(--mft-shadow-card)!important;color:var(--text)!important}.apexcharts-tooltip .apexcharts-tooltip-title{background:transparent!important;border-bottom:1px solid var(--border)!important;color:var(--text)!important}.apexcharts-legend-text{color:var(--text)!important}@media(max-width:960px){.insights-widget-grid{grid-template-columns:1fr}}
