:root{--font-family: "Inter", "Geist", -apple-system, BlinkMacSystemFont, sans-serif;--font-feature-tabular: "tnum" on, "lnum" on;--tracking-tight: -.01em;--bg-base: #0d121a;--bg-surface: #111826;--bg-card: #121826;--bg-elevated: #1a2035;--bg-hover: #1e2642;--border: #1e293b;--border-hover: #2e3a54;--border-active: #3e4a64;--ring: rgba(255, 255, 255, .05);--text-primary: #E6EAF5;--text-secondary: #9AA4BF;--text-muted: #6B7280;--text-inverse: #0d121a;--accent-green: #21d4a3;--accent-green-light: #34E7B9;--accent-green-dark: #1AB892;--accent-blue: #7aa2ff;--accent-blue-light: #93C5FD;--accent-pink: #D946EF;--accent-pink-light: #E879F9;--accent-amber: #F59E0B;--accent-amber-light: #FBBF24;--accent-red: #ff5e73;--accent-red-light: #FB7185;--success: #21d4a3;--success-bg: rgba(33, 212, 163, .1);--success-border: rgba(33, 212, 163, .25);--danger: #ff5e73;--danger-bg: rgba(255, 94, 115, .1);--danger-border: rgba(255, 94, 115, .25);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .1);--warning-border: rgba(245, 158, 11, .25);--info: #7aa2ff;--info-bg: rgba(122, 162, 255, .1);--info-border: rgba(122, 162, 255, .25);--bg-primary: var(--bg-base);--bg-secondary: var(--bg-card);--bg-tertiary: var(--bg-surface);--text-primary-legacy: var(--text-primary);--border-color: var(--border);--primary: var(--accent-blue);--accent: var(--accent-green);--accent-teal: var(--accent-green);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 24px;--spacing-2xl: 32px;--spacing-3xl: 48px;--radius-sm: 8px;--radius-md: 12px;--radius-card: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-xl: 0 12px 48px rgba(0, 0, 0, .6);--shadow-glow-green: 0 0 20px rgba(33, 212, 163, .3);--shadow-glow-blue: 0 0 20px rgba(122, 162, 255, .3);--shadow-glow-pink: 0 0 20px rgba(217, 70, 239, .3);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--transition-bounce: .3s cubic-bezier(.68, -.55, .265, 1.55);--sidebar-collapsed: 72px;--sidebar-expanded: 256px;--header-height: 64px;--content-max-width: 1600px;--gap-desktop: 16px;--gap-md: 12px;--gap-sm: 8px;--z-dropdown: 100;--z-sticky: 200;--z-modal-backdrop: 900;--z-modal: 1000;--z-toast: 1100;--txn-bg-base: #0f1623;--txn-bg-panel: #101826;--txn-bg-card: #121c2b;--txn-border: #233044;--txn-text-primary: #E6ECF5;--txn-text-secondary: #9FB0C7;--txn-text-muted: #6E7F97;--txn-success: #22d3a6;--txn-danger: #ef4444;--txn-info: #60a5fa;--txn-positive: #2DD4BF;--txn-negative: #F87171;--txn-recurring: #a855f7;--txn-row-height: 48px;--txn-row-height-compact: 40px;--txn-drawer-width: 420px;--rec-bg-base: var(--txn-bg-base);--rec-bg-panel: var(--txn-bg-panel);--rec-bg-card: var(--txn-bg-card);--rec-border: var(--txn-border);--rec-text-primary: var(--txn-text-primary);--rec-text-secondary: var(--txn-text-secondary);--rec-text-muted: var(--txn-text-muted);--rec-success: var(--txn-success);--rec-danger: var(--txn-danger);--rec-info: var(--txn-info);--rec-row-height: 56px;--rec-drawer-width: 440px;--rec-calendar-dot: 6px;--rec-toggle-width: 44px;--rec-toggle-height: 22px;--rec-badge-bg: rgba(122, 162, 255, .12);--rec-badge-text: #93b4ff;--rec-increase-bg: rgba(255, 94, 115, .12);--rec-increase-text: #ff8a9b;--goal-bg-base: var(--txn-bg-base);--goal-bg-panel: var(--txn-bg-panel);--goal-bg-card: var(--txn-bg-card);--goal-border: var(--txn-border);--goal-text-primary: var(--txn-text-primary);--goal-text-secondary: var(--txn-text-secondary);--goal-text-muted: var(--txn-text-muted);--goal-success: var(--txn-success);--goal-danger: var(--txn-danger);--goal-info: var(--txn-info);--goal-warning: #f59e0b;--goal-card-min: 320px;--goal-row-height: 72px;--goal-drawer-width: 440px;--goal-progress-height: 10px;--goal-progress-height-lg: 14px;--mobile-topbar-height: 56px;--mobile-bottomtab-height: 64px;--mobile-fab-size: 56px;--mobile-card-radius: 16px;--mobile-safe-bottom: env(safe-area-inset-bottom, 0px);--mobile-safe-top: env(safe-area-inset-top, 0px)}.gradient-green{background:linear-gradient(135deg,var(--accent-green) 0%,var(--accent-green-light) 100%)}.gradient-blue{background:linear-gradient(135deg,var(--accent-blue) 0%,var(--accent-blue-light) 100%)}.gradient-pink{background:linear-gradient(135deg,var(--accent-pink) 0%,var(--accent-pink-light) 100%)}.gradient-card{background:linear-gradient(135deg,var(--bg-card) 0%,var(--bg-elevated) 100%)}.glass{background:#121826cc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.text-gradient-green{background:linear-gradient(135deg,var(--accent-green) 0%,var(--accent-green-light) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.text-gradient-blue{background:linear-gradient(135deg,var(--accent-blue) 0%,var(--accent-blue-light) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.mobile-shell{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;width:100%;background:var(--bg-base);overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.mobile-content{flex:1;padding-bottom:calc(var(--mobile-bottomtab-height) + var(--mobile-safe-bottom) + 8px)}.mobile-content>.container{padding:var(--spacing-md) var(--spacing-lg)}.is-mobile .sidebar,.is-mobile .sidebar-overlay,.is-mobile .app-header,.is-mobile .dashboard-footer{display:none!important}.is-mobile .app-main{margin-left:0!important}.mobile-topbar-wrapper{position:sticky;top:0;left:0;right:0;z-index:500}.mobile-topbar{height:var(--mobile-topbar-height);padding-top:var(--mobile-safe-top);display:flex;align-items:center;justify-content:space-between;padding-left:var(--spacing-lg);padding-right:var(--spacing-lg);background:#0d121aeb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}.mobile-topbar-left{flex-shrink:0;display:flex;align-items:center}.mobile-topbar-logo{font-size:1.25rem}.mobile-topbar-title{flex:1;font-size:1.0625rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:var(--tracking-tight);text-align:center}.mobile-topbar-right{flex-shrink:0;display:flex;align-items:center;gap:var(--spacing-sm);min-width:28px}.mobile-month-bar{display:flex;flex-direction:column;align-items:center;padding:8px var(--spacing-lg);background:#0d121aeb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}.mobile-month-bar .month-selector-container{display:flex;flex-direction:column;align-items:center;gap:6px;width:100%}.mobile-month-bar .month-selector{display:flex;align-items:center;gap:4px}.mobile-month-bar .current-month-chip{font-size:.75rem;padding:4px 12px}.mobile-bottom-tabs{position:fixed;bottom:0;left:0;right:0;height:calc(var(--mobile-bottomtab-height) + var(--mobile-safe-bottom));padding-bottom:var(--mobile-safe-bottom);display:flex;align-items:flex-start;justify-content:space-around;background:#0d121aeb;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid var(--border);z-index:500}.mobile-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:8px 0 4px;background:none;border:none;color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);-webkit-tap-highlight-color:transparent;position:relative}.mobile-tab.active{color:var(--accent-green)}.mobile-tab-icon-wrap{position:relative;display:flex;align-items:center;justify-content:center;width:28px;height:28px}.mobile-tab-indicator{position:absolute;bottom:-4px;left:50%;transform:translate(-50%);width:4px;height:4px;border-radius:50%;background:var(--accent-green)}.mobile-tab-label{font-size:.625rem;font-weight:500;letter-spacing:.02em}.mobile-fab-container{position:fixed;bottom:calc(var(--mobile-bottomtab-height) + var(--mobile-safe-bottom) + 16px);right:16px;z-index:600;display:flex;flex-direction:column;align-items:flex-end;gap:12px}.mobile-fab-btn{width:var(--mobile-fab-size);height:var(--mobile-fab-size);border-radius:50%;border:none;background:linear-gradient(135deg,var(--accent-green) 0%,var(--accent-green-light) 100%);color:var(--bg-base);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 20px #21d4a366;transition:transform var(--transition-fast),box-shadow var(--transition-fast);-webkit-tap-highlight-color:transparent}.mobile-fab-btn:active{transform:scale(.92)}.mobile-fab-btn.active{background:var(--bg-elevated);color:var(--text-primary);box-shadow:var(--shadow-lg);transform:rotate(45deg)}.mobile-fab-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:550;animation:mobileOverlayIn .2s ease}.mobile-fab-actions{display:flex;flex-direction:column;align-items:flex-end;gap:10px}.mobile-fab-action{display:flex;align-items:center;gap:10px;background:none;border:none;cursor:pointer;animation:mobileFabSlideUp .25s ease forwards;opacity:0;-webkit-tap-highlight-color:transparent}.mobile-fab-action-label{background:var(--bg-elevated);color:var(--text-primary);padding:8px 14px;border-radius:var(--radius-sm);font-size:.8125rem;font-weight:500;white-space:nowrap;box-shadow:var(--shadow-md)}.mobile-fab-action-icon{width:44px;height:44px;border-radius:50%;background:var(--bg-elevated);border:1px solid var(--border);color:var(--accent-green);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}@keyframes mobileFabSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes mobileOverlayIn{0%{opacity:0}to{opacity:1}}.mobile-bs-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:700;display:flex;align-items:flex-end;animation:mobileOverlayIn .2s ease}.mobile-bs-sheet{width:100%;max-height:85vh;background:var(--bg-surface);border-radius:20px 20px 0 0;overflow:hidden;display:flex;flex-direction:column;animation:mobileBsSlideUp .3s cubic-bezier(.32,.72,0,1);will-change:transform}.mobile-bs-half{max-height:50vh}.mobile-bs-full{max-height:92vh}.mobile-bs-handle-area{display:flex;justify-content:center;padding:10px 0 6px;cursor:grab;flex-shrink:0}.mobile-bs-handle{width:36px;height:4px;border-radius:2px;background:var(--text-muted);opacity:.4}.mobile-bs-title{font-size:1.0625rem;font-weight:600;color:var(--text-primary);padding:0 20px 12px;border-bottom:1px solid var(--border);flex-shrink:0}.mobile-bs-content{flex:1;overflow-y:auto;padding:12px 20px 20px;-webkit-overflow-scrolling:touch}@keyframes mobileBsSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mobile-more-menu{display:flex;flex-direction:column;gap:4px}.mobile-more-item{display:flex;align-items:center;gap:14px;padding:14px 8px;border:none;background:none;color:var(--text-primary);font-size:.9375rem;font-weight:500;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast);-webkit-tap-highlight-color:transparent}.mobile-more-item:active{background:var(--bg-hover)}.mobile-more-item svg{color:var(--text-secondary);flex-shrink:0}.mobile-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--mobile-card-radius);padding:var(--spacing-lg) var(--spacing-xl);transition:border-color var(--transition-fast)}.mobile-card[role=button]{cursor:pointer;-webkit-tap-highlight-color:transparent}.mobile-card[role=button]:active{background:var(--bg-elevated)}.mobile-card-kpi{padding:var(--spacing-xl)}.mobile-card-accent{border-left-width:3px}.mobile-swipe-item{position:relative;overflow:hidden;border-radius:var(--radius-sm)}.mobile-swipe-actions{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;justify-content:space-between;align-items:stretch}.mobile-swipe-action{display:flex;align-items:center;justify-content:center;width:80px;color:#fff}.mobile-swipe-edit{background:var(--accent-blue)}.mobile-swipe-delete{background:var(--danger);margin-left:auto}.mobile-swipe-content{position:relative;background:var(--bg-card);z-index:1;will-change:transform}.is-mobile .dashboard-kpis{display:flex;overflow-x:auto;gap:var(--spacing-md);padding-bottom:var(--spacing-sm);scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.is-mobile .dashboard-kpis::-webkit-scrollbar{display:none}.is-mobile .dashboard-kpis>*{flex:0 0 75vw;max-width:280px;scroll-snap-align:start}.is-mobile .stats-grid,.is-mobile .dashboard-row,.is-mobile .dashboard-row-equal,.is-mobile .dashboard-grid{grid-template-columns:1fr!important}.mobile-content .container{padding:var(--spacing-md) var(--spacing-lg);max-width:100%}.is-mobile .stat-card{min-height:100px;padding:var(--spacing-lg);border-radius:var(--mobile-card-radius)}.is-mobile .goals-grid{display:flex;overflow-x:auto;gap:var(--spacing-md);padding-bottom:var(--spacing-sm);scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.is-mobile .goals-grid::-webkit-scrollbar{display:none}.is-mobile .goals-grid>*{flex:0 0 80vw;max-width:300px;scroll-snap-align:start}.is-mobile .budgets-grid{display:flex;overflow-x:auto;gap:var(--spacing-md);padding-bottom:var(--spacing-sm);scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.is-mobile .budgets-grid::-webkit-scrollbar{display:none}.is-mobile .budgets-grid>*{flex:0 0 80vw;max-width:300px;scroll-snap-align:start}.is-mobile .txn-row,.is-mobile .rec-row{min-height:56px;padding:var(--spacing-md) var(--spacing-lg)}.is-mobile .filter-bar,.is-mobile .txn-filters,.is-mobile .rec-search-bar{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:var(--spacing-sm)}.is-mobile .filter-bar::-webkit-scrollbar,.is-mobile .txn-filters::-webkit-scrollbar,.is-mobile .rec-search-bar::-webkit-scrollbar{display:none}.is-mobile .txn-drawer,.is-mobile .rec-drawer,.is-mobile .goal-drawer{width:100%!important;max-width:100%!important;border-radius:20px 20px 0 0!important;bottom:0!important;top:auto!important;max-height:90vh}.is-mobile .chart-card,.is-mobile .subscriptions-panel{border-radius:var(--mobile-card-radius)}.is-mobile .header-right .btn-primary,.is-mobile .goals-header .btn-primary,.is-mobile .budgets-header .btn-primary,.is-mobile .rec-header .btn-primary{display:none}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0a0a0f}.login-card{text-align:center;padding:3rem 2.5rem;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:16px;max-width:380px;width:100%}.login-logo{font-size:3.5rem;margin-bottom:.5rem}.login-title{font-size:2rem;font-weight:700;color:#fff;margin:0 0 .25rem}.login-subtitle{color:#ffffff80;font-size:.9rem;margin:0 0 2rem}.login-btn-microsoft{display:inline-flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;background:#0078d4;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .15s;width:100%;justify-content:center}.login-btn-microsoft:hover{background:#106ebe}:root{--bg-primary: #0B0F1A;--bg-secondary: #0F1528;--bg-tertiary: #111628;--bg-card: #0F1528;--bg-elevated: #1A2035;--bg-hover: #1E2642;--text-primary: #E6EAF5;--text-secondary: #9AA4BF;--text-muted: #6B7280;--border-color: #1E2A44;--border-hover: #2E3A54;--shadow: 0 2px 8px rgba(0, 0, 0, .3);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .4);--shadow-xl: 0 8px 32px rgba(0, 0, 0, .5);--success: #22D3A6;--danger: #F43F5E;--danger-light: #FB7185;--warning: #F59E0B;--primary: #60A5FA;--accent: #22D3A6;--accent-pink: #D946EF;--accent-teal: #22D3A6;--accent-blue: #60A5FA}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary)}.app{min-height:100vh;display:flex}.app-layout{display:flex;min-height:100vh;width:100%}.app-main{flex:1;display:flex;flex-direction:column;min-height:100vh;transition:margin-left var(--transition-normal)}.app-main.sidebar-expanded{margin-left:256px}.app-main.sidebar-collapsed{margin-left:72px}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary) 0%,#1A3D7A 100%);padding:2rem}.login-container{max-width:480px;width:100%}.login-header{text-align:center;margin-bottom:2rem;color:#fff}.logo-large{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-bottom:1rem}.logo-large span{font-size:4rem}.logo-large h1{font-size:2.5rem;margin:0;font-weight:700}.login-subtitle{font-size:1.125rem;color:#ffffffe6;margin:0}.login-modal-wrapper{width:100%}.login-modal-wrapper .modal{position:static;transform:none;box-shadow:0 20px 60px #0000004d;margin:0}.header{background:var(--bg-secondary);padding:1.5rem 2rem;box-shadow:var(--shadow);position:sticky;top:0;z-index:100}.login-btn,.logout-btn{background:transparent;color:var(--primary);border:2px solid var(--primary);padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .2s}.login-btn:hover{background:var(--primary);color:#fff}.logout-btn{padding:.5rem;border-color:var(--danger);color:var(--danger)}.logout-btn:hover{background:var(--danger);color:#fff}.navigation{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);position:sticky;top:73px;z-index:90}.nav-content{max-width:1200px;margin:0 auto;display:flex;gap:.5rem;padding:0 2rem}.nav-btn{background:transparent;border:none;padding:1rem 1.5rem;color:var(--text-secondary);font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;border-bottom:3px solid transparent;transition:all .2s}.nav-btn:hover{color:var(--primary);background:var(--bg-primary)}.nav-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.logo{font-size:1.5rem;font-weight:700;color:var(--primary);display:flex;align-items:center;gap:.5rem}.add-transaction-btn{background:var(--primary);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:transform .2s,box-shadow .2s}.add-transaction-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.currency-selector{position:relative}.currency-select{padding:.75rem 1rem;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;font-weight:600;background:var(--bg-card);color:var(--text-primary);cursor:pointer;transition:all .2s;min-width:140px}.currency-select:hover{border-color:var(--primary)}.currency-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0984e31a}.container{width:100%;max-width:var(--content-max-width, 1600px);margin:0 auto;padding:1.5rem var(--gap-desktop)}.dashboard-footer{text-align:center;padding:1.5rem 0;margin-top:2rem;border-top:1px solid var(--border-color)}.last-updated{font-size:.75rem;color:var(--text-secondary);font-weight:500}.month-selector-container{margin-bottom:0}.month-selector{display:inline-flex;align-items:center;gap:.5rem;background:var(--bg-secondary);padding:.5rem .75rem;border-radius:8px;border:1px solid var(--border-color);box-shadow:var(--shadow)}.month-nav-btn{background:transparent;border:none;color:var(--primary);cursor:pointer;padding:.25rem;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.month-nav-btn:hover:not(:disabled){background:var(--bg-primary)}.month-nav-btn:disabled{opacity:.3;cursor:not-allowed}.month-display{display:flex;align-items:center;gap:.5rem;padding:.25rem .75rem;font-weight:600;color:var(--text-primary);min-width:150px;justify-content:center}.month-display svg{color:var(--primary)}.current-month-chip{display:inline-flex;align-items:center;gap:.5rem;background:#1f427814;border:1px solid rgba(31,66,120,.2);color:var(--primary);padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600;margin-left:1rem;cursor:pointer;transition:all .2s}.current-month-chip:hover{background:#1f42781f;border-color:var(--primary)}.chip-action{text-decoration:underline;text-underline-offset:2px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:var(--bg-secondary);padding:1.25rem;border-radius:12px;box-shadow:var(--shadow);border:1px solid var(--border-color);transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-header{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1rem}.stat-icon{font-size:1.75rem;line-height:1}.stat-title-group{flex:1}.stat-title{font-size:.875rem;color:var(--text-primary);font-weight:600;margin-bottom:.125rem;letter-spacing:.2px}.stat-period{font-size:.75rem;color:var(--text-secondary);font-weight:500}.stat-value{font-size:1.75rem;font-weight:800;margin-bottom:.5rem;white-space:nowrap;text-align:right;letter-spacing:-.5px}.stat-value.income{color:var(--success)}.stat-value.expense{color:var(--danger)}.stat-badge{font-size:.75rem;padding:.25rem .625rem;border-radius:12px;font-weight:600;display:inline-block;text-align:right;float:right}.stat-badge.success{background:#02b08d1a;color:var(--success);border:1px solid rgba(2,176,141,.2)}.stat-badge.danger{background:#e8519e1a;color:var(--danger);border:1px solid rgba(232,81,158,.2)}.stat-badge.warning{background:#fdcb6e26;color:#d35400;border:1px solid rgba(253,203,110,.3)}.stat-card-v2{background:var(--bg-secondary);padding:1.25rem;border-radius:12px;box-shadow:var(--shadow);border:1px solid var(--border-color);transition:transform .2s,box-shadow .2s;position:relative;min-width:0;overflow:hidden}.stat-card-v2:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:.5rem}.stat-card-v2.has-badge .stat-card-header{padding-right:7rem}@media(max-width:380px){.stat-card-v2.has-badge .stat-card-header{padding-right:5.5rem}.stat-badge-absolute{font-size:.563rem;padding:.2rem .4rem}}.stat-icon-text{display:flex;align-items:flex-start;gap:.75rem;flex:1;min-width:0}.stat-icon-v2{font-size:2rem;line-height:1;flex-shrink:0;display:flex;align-items:center}.stat-text-group{display:flex;flex-direction:column;gap:.0625rem;flex:1;min-width:0}.stat-title-v2{font-size:.875rem;font-weight:700;color:var(--text-primary);letter-spacing:.2px;line-height:1.2}.stat-subtitle-v2{font-size:.688rem;font-weight:500;color:var(--text-secondary);letter-spacing:.1px;white-space:nowrap;line-height:1.1}.stat-amount{font-size:clamp(1.5rem,4vw,1.875rem);font-weight:800;letter-spacing:-.75px;line-height:1.2;word-break:break-word;overflow-wrap:break-word}.stat-explanation{margin-top:.5rem;font-size:.688rem;color:var(--text-secondary);font-weight:500;line-height:1.3;padding-bottom:.25rem}.stat-delta{margin-top:.625rem;padding-top:.375rem;border-top:1px solid var(--border-color);font-size:.688rem;font-weight:600;display:flex;align-items:center;gap:.25rem}.stat-delta.positive{color:var(--success)}.stat-delta.negative{color:var(--danger)}.stat-delta.neutral{color:var(--text-secondary)}.income-color{color:var(--success)}.expense-color{color:var(--danger)}.neutral-color{color:var(--text-primary)}.stat-badge-corner{font-size:.625rem;padding:.25rem .5rem;border-radius:8px;font-weight:700;white-space:nowrap;flex-shrink:0;line-height:1}.stat-badge-corner.danger{background:#ef53501f;color:var(--danger);border:1px solid rgba(239,83,80,.25)}.stat-badge-corner.warning{background:#fdcb6e26;color:#d35400;border:1px solid rgba(253,203,110,.35)}.stat-badge-corner.success{background:#02b08d1f;color:var(--success);border:1px solid rgba(2,176,141,.25)}.stat-badge-absolute{position:absolute;top:1rem;right:1rem;font-size:.625rem;padding:.25rem .5rem;border-radius:8px;font-weight:700;white-space:nowrap;line-height:1;z-index:10}.stat-badge-absolute.danger{background:#ef53501f;color:var(--danger);border:1px solid rgba(239,83,80,.25)}.stat-badge-absolute.warning{background:#fdcb6e26;color:#d35400;border:1px solid rgba(253,203,110,.35)}.stat-badge-absolute.success{background:#02b08d1f;color:var(--success);border:1px solid rgba(2,176,141,.25)}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem;margin-bottom:2rem}.chart-card{background:var(--bg-secondary);padding:1.5rem;border-radius:12px;box-shadow:var(--shadow)}.chart-title{font-size:1.25rem;font-weight:600;margin-bottom:1.5rem;color:var(--text-primary)}.transactions-section{background:var(--bg-secondary);padding:1.5rem;border-radius:12px;box-shadow:var(--shadow)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-title{font-size:1.25rem;font-weight:600}.add-transaction-btn-mobile{display:none}.filter-buttons{display:flex;gap:.5rem}.filter-btn{padding:.5rem 1rem;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);border-radius:6px;cursor:pointer;font-size:.875rem;transition:all .2s}.filter-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-hover)}.filter-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.filter-btn.add-new-btn{background:var(--success);color:#fff;border-color:var(--success);font-weight:500}.filter-btn.add-new-btn:hover{background:#16a34a;border-color:#16a34a}.transactions-list{display:flex;flex-direction:column;gap:.75rem}.transaction-item{display:flex;align-items:center;padding:1rem;border:1px solid var(--border-color);border-radius:8px;transition:all .2s}.transaction-item:hover{box-shadow:var(--shadow);transform:translate(4px)}.transaction-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:1.5rem;margin-right:1rem}.transaction-details{flex:1}.transaction-category{font-weight:600;margin-bottom:.25rem}.transaction-description{font-size:.875rem;color:var(--text-secondary)}.transaction-date{font-size:.875rem;color:var(--text-secondary);margin-right:1rem}.transaction-amount{font-size:1.25rem;font-weight:700}.transaction-amount.income{color:var(--success)}.transaction-amount.expense{color:var(--danger)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-card);border-radius:16px;padding:2rem;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;animation:slideUp .3s;border:1px solid var(--border-color)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-title{font-size:1.5rem;font-weight:700}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);padding:.25rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px}.close-btn:hover{background:var(--bg-primary)}.form-group{margin-bottom:1.5rem}.form-label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text-primary)}.form-input,.form-select,.form-textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;font-family:inherit;transition:border-color .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary)}.form-textarea{resize:vertical;min-height:80px}.type-toggle{display:flex;gap:1rem;margin-bottom:1.5rem}.type-btn{flex:1;padding:.75rem;border:2px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s}.type-btn:hover{border-color:var(--border-hover);background:var(--bg-hover)}.type-btn.active.income{background:var(--success);border-color:var(--success);color:#fff}.type-btn.active.expense{background:var(--danger);border-color:var(--danger);color:#fff}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem;margin-bottom:1.5rem}.category-btn{padding:1rem .5rem;border:2px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);border-radius:8px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.5rem;transition:all .2s;font-size:.875rem}.category-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.category-btn.active{border-width:3px;font-weight:600}.category-icon{font-size:2rem}.catmgr-link{display:inline-flex;align-items:center;margin-left:6px;padding:2px;border:none;background:none;color:var(--text-muted);cursor:pointer;opacity:.6;transition:opacity .15s;vertical-align:middle}.catmgr-link:hover{opacity:1;color:var(--accent-blue)}.catmgr{max-width:440px}.catmgr-body{padding:1rem 1.25rem 1.25rem;overflow-y:auto;max-height:60vh}.catmgr-section-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.5rem}.catmgr-row{display:flex;align-items:center;gap:.6rem;padding:.5rem .4rem;border-radius:8px;transition:background .15s}.catmgr-row:hover{background:var(--bg-elevated)}.catmgr-row--hidden{opacity:.4}.catmgr-row--hidden .catmgr-name{text-decoration:line-through}.catmgr-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.catmgr-name{flex:1;font-size:.85rem;font-weight:500;color:var(--text-primary)}.catmgr-action{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:6px;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s;flex-shrink:0}.catmgr-action:hover{background:var(--bg-hover);color:var(--text-primary)}.catmgr-action--danger:hover{background:var(--danger-bg);color:var(--danger)}.catmgr-add-btn{display:flex;align-items:center;justify-content:center;gap:.4rem;width:100%;padding:.7rem;margin-top:1rem;border:1px dashed var(--border);border-radius:10px;background:transparent;color:var(--accent-blue);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s}.catmgr-add-btn:hover{background:var(--info-bg);border-color:var(--accent-blue)}.catmgr-form{margin-top:1rem;padding:1rem;border:1px solid var(--border);border-radius:12px;background:var(--bg-elevated);display:flex;flex-direction:column;gap:.75rem}.catmgr-form-title{font-size:.8rem;font-weight:600;color:var(--text-primary)}.catmgr-picker-label{font-size:.7rem;font-weight:500;color:var(--text-muted)}.catmgr-emoji-grid{display:flex;flex-wrap:wrap;gap:4px}.catmgr-emoji-btn{width:34px;height:34px;border:1px solid transparent;border-radius:8px;background:transparent;font-size:1rem;cursor:pointer;transition:all .1s;display:flex;align-items:center;justify-content:center}.catmgr-emoji-btn:hover{background:var(--bg-hover)}.catmgr-emoji-btn.active{border-color:var(--accent-blue);background:var(--info-bg)}.catmgr-color-grid{display:flex;flex-wrap:wrap;gap:6px}.catmgr-color-btn{width:28px;height:28px;border:2px solid transparent;border-radius:50%;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.catmgr-color-btn:hover{transform:scale(1.15)}.catmgr-color-btn.active{border-color:#fff;box-shadow:0 0 0 2px var(--accent-blue)}.catmgr-form-actions{display:flex;gap:.5rem;margin-top:.25rem}.catmgr-btn{flex:1;padding:.55rem;border:none;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s}.catmgr-btn--cancel{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary)}.catmgr-btn--cancel:hover{background:var(--bg-hover)}.catmgr-btn--save{background:var(--accent-blue);color:#fff}.catmgr-btn--save:hover{opacity:.9}.catmgr-btn--save:disabled{opacity:.4;cursor:not-allowed}.submit-btn{padding:1rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;color:#fff;background:var(--primary)}.submit-btn.income{background:var(--success)}.submit-btn.expense{background:var(--danger)}.submit-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.modal-actions{display:flex;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border)}.modal-actions .submit-btn,.modal-actions .cancel-btn{flex:1}.cancel-btn{padding:.875rem 1.5rem;border:2px solid var(--border);border-radius:8px;background:transparent;color:var(--text);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.cancel-btn:hover{background:var(--background);border-color:var(--text-secondary);transform:translateY(-1px)}.tm-modal{max-width:480px}.tm-row{display:flex;gap:.75rem}.tm-amount{font-size:1.5rem!important;font-weight:700!important;letter-spacing:-.02em}.tm-kbd{display:inline-flex;align-items:center;justify-content:center;min-width:20px;padding:1px 5px;border:1px solid var(--border);border-radius:4px;background:var(--bg-elevated);color:var(--text-muted);font-family:inherit;font-size:.6rem;font-weight:500;line-height:1.4}.tm-suggestion{display:inline-flex;align-items:center;gap:3px;margin-left:8px;padding:2px 8px;border-radius:10px;background:var(--info-bg);color:var(--accent-blue);font-size:.65rem;font-weight:500}.tm-receipt-section{margin-top:.5rem}.tm-receipt-toggle{display:flex;align-items:center;gap:.5rem;width:100%;padding:.65rem 1rem;border:1px dashed var(--border);border-radius:10px;background:transparent;color:var(--text-secondary);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.tm-receipt-toggle:hover{border-color:var(--accent-blue);color:var(--accent-blue);background:var(--info-bg)}.tm-receipt-dot{width:8px;height:8px;border-radius:50%;background:var(--accent-green);margin-left:auto;box-shadow:0 0 6px var(--accent-green)}.tm-receipt-body{margin-top:.75rem;display:flex;flex-direction:column;gap:.75rem}.tm-receipt-actions{display:flex;flex-direction:column;gap:.5rem}.tm-receipt-buttons{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}.tm-receipt-btn{display:flex;align-items:center;justify-content:center;gap:.6rem;padding:.85rem 1rem;border:1px solid var(--border);border-radius:10px;background:var(--bg-elevated);color:var(--text-secondary);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.tm-receipt-btn svg{flex-shrink:0;color:var(--accent-blue);opacity:.85}.tm-receipt-btn:hover{border-color:var(--accent-blue);background:var(--info-bg);color:var(--text-primary);transform:translateY(-1px);box-shadow:0 4px 12px #7aa2ff1a}.tm-receipt-btn:hover svg{opacity:1}.tm-receipt-btn:active{transform:translateY(0)}.tm-receipt-hint{font-size:.7rem;color:var(--text-muted);text-align:center;margin:0;padding:0}.tm-receipt-preview{position:relative;border-radius:10px;overflow:hidden;border:1px solid var(--border);background:var(--bg-elevated)}.tm-receipt-img{display:block;width:100%;max-height:200px;object-fit:cover}.tm-receipt-remove{position:absolute;top:8px;right:8px;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:50%;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;cursor:pointer;transition:background .2s}.tm-receipt-remove:hover{background:var(--danger)}.tm-ocr-status{display:flex;align-items:center;gap:.5rem;padding:.6rem .85rem;border-radius:8px;font-size:.75rem;font-weight:500}.tm-ocr-status.processing{background:var(--info-bg);color:var(--accent-blue);border:1px solid var(--info-border)}.tm-ocr-status.error{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border)}@keyframes tm-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tm-spin{animation:tm-spin 1s linear infinite}.tm-ocr-result{border:1px solid var(--success-border);border-radius:10px;background:var(--success-bg);overflow:hidden}.tm-ocr-result-header{display:flex;align-items:center;gap:.4rem;padding:.55rem .85rem;font-size:.72rem;font-weight:500;color:var(--accent-green);border-bottom:1px solid var(--success-border)}.tm-ocr-apply-btn{margin-left:auto;padding:3px 10px;border:1px solid var(--success-border);border-radius:6px;background:transparent;color:var(--accent-green);font-size:.68rem;font-weight:600;cursor:pointer;transition:all .15s}.tm-ocr-apply-btn:hover{background:var(--accent-green);color:var(--bg-base)}.tm-ocr-fields{display:flex;flex-wrap:wrap;gap:.5rem;padding:.6rem .85rem}.tm-ocr-field{display:inline-flex;align-items:center;gap:3px;padding:3px 10px;border-radius:6px;background:#ffffff0a;font-size:.72rem;font-weight:500;color:var(--text-primary)}@media(max-width:480px){.tm-receipt-actions{flex-direction:column}.tm-receipt-btn{flex-direction:row;padding:.85rem 1rem}}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.empty-state-icon{font-size:4rem;margin-bottom:1rem}.empty-state-text{font-size:1.125rem;margin-bottom:.5rem}.search-input{width:100%;padding:.875rem 1rem;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;font-family:inherit;transition:all .2s}.search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #1f42781a}.transaction-actions{display:flex;gap:.5rem;margin-left:1rem}.action-btn{background:transparent;border:none;font-size:1.25rem;cursor:pointer;padding:.5rem;border-radius:6px;transition:all .2s;display:flex;align-items:center;justify-content:center;width:36px;height:36px}.action-btn:hover{background:var(--bg-primary);transform:scale(1.1)}.edit-btn:hover{background:#02b08d1a}.delete-btn:hover{background:#e8519e1a}.import-export-container{position:relative}.import-export-btn{background:var(--accent-teal);color:#fff;border:none;padding:.75rem 1.25rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .2s}.import-export-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);background:#03a87d}.menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999}.import-export-menu{position:absolute;top:100%;right:0;margin-top:.5rem;background:var(--bg-card);border-radius:8px;box-shadow:var(--shadow-lg);border:1px solid var(--border-color);padding:.5rem;min-width:220px;z-index:1000;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.menu-item{width:100%;padding:.75rem 1rem;border:none;background:transparent;text-align:left;cursor:pointer;font-size:.95rem;font-weight:500;color:var(--text-primary);border-radius:6px;transition:all .2s;display:flex;align-items:center;gap:.75rem}.menu-item:hover{background:var(--bg-hover);color:var(--accent-blue)}@media(max-width:768px){.container{padding:1rem}.stats-grid,.charts-grid{grid-template-columns:1fr}.filter-buttons{flex-wrap:wrap}.category-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.section-header{flex-wrap:wrap;gap:1rem}.section-title{flex:1;min-width:0}.nav-content{padding:0 .5rem;gap:.25rem;overflow-x:auto;flex-wrap:nowrap}.month-selector-container{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.current-month-chip{margin-left:0;width:100%;justify-content:center}.nav-btn{padding:.75rem .4rem;font-size:.75rem;gap:.25rem;flex-shrink:0;white-space:nowrap}.nav-btn svg{width:14px;height:14px;flex-shrink:0}.nav-btn span{font-size:.7rem}.import-export-menu{right:0;left:auto}.transaction-item{flex-wrap:wrap;gap:.5rem;padding:.75rem}.transaction-icon{width:40px;height:40px;font-size:1.25rem;margin-right:.5rem}.transaction-details{flex:1;min-width:0}.transaction-date{width:100%;order:3;font-size:.75rem;margin-left:48px}.transaction-amount{flex-shrink:0;font-size:.875rem}.transaction-actions{width:100%;order:4;justify-content:flex-end;margin-left:48px;gap:.5rem}.action-btn{padding:.4rem .6rem;font-size:1rem}.add-transaction-btn{display:none}.add-transaction-btn-mobile{display:flex!important;align-items:center;justify-content:center;background:var(--primary);color:#fff;border:none;border-radius:50%;width:40px;height:40px;font-size:1.5rem;cursor:pointer;box-shadow:var(--shadow-md);transition:transform .2s}.add-transaction-btn-mobile:active{transform:scale(.95)}.import-export-btn{background:transparent;border:none;padding:.5rem;min-width:auto;font-size:1.5rem}.import-export-btn:hover{background:transparent;box-shadow:none;transform:none}}.auth-modal{max-width:450px}.auth-submit{background:var(--primary)}.auth-toggle{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.auth-toggle p{margin:0;color:var(--text-secondary)}.auth-link{background:none;border:none;color:var(--primary);font-weight:600;cursor:pointer;text-decoration:underline;padding:0}.auth-link:hover{color:var(--accent-teal)}.auth-info{margin-top:1.5rem;padding:1rem;background:var(--bg-primary);border-radius:8px;text-align:center}.auth-info p{margin:.5rem 0;font-size:.875rem;color:var(--text-secondary)}.error-message{padding:.75rem;background:#e8519e1a;border:1px solid var(--danger);border-radius:6px;color:var(--danger);margin-bottom:1rem;font-size:.875rem}.goals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.goal-card{background:var(--bg-secondary);padding:1.5rem;border-radius:12px;box-shadow:var(--shadow);transition:transform .2s}.goal-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.goal-card.goal-inactive{opacity:.6;filter:grayscale(40%)}.goal-header-v2{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.875rem;gap:1rem}.goal-actions{opacity:0;transition:opacity .2s}.goal-card:hover .goal-actions{opacity:1}.goal-title-row{display:flex;align-items:flex-start;gap:.75rem;flex:1;min-width:0}.goal-title-text{flex:1;min-width:0}.goal-name-status{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.goal-name-status h3{margin:0;font-size:1.125rem;font-weight:700;color:var(--text-primary)}.goal-inactive-tag{font-size:.688rem;font-weight:600;color:var(--text-secondary);background:#5a6b8a1a;padding:.125rem .5rem;border-radius:6px;border:1px solid rgba(90,107,138,.2)}.goal-description{font-size:.813rem;color:var(--text-secondary);margin:0;line-height:1.4}.goal-amounts{display:flex;align-items:baseline;gap:.375rem;margin-bottom:.625rem;font-size:1rem}.goal-progress-bar-large{height:10px;background:var(--bg-primary);border-radius:10px;overflow:hidden;margin-bottom:.75rem}.progress-fill-large{height:100%;transition:width .4s ease;border-radius:10px}.goal-current{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.goal-separator{font-size:.875rem;color:var(--text-secondary)}.goal-target{font-size:1rem;font-weight:600;color:var(--text-secondary)}.goal-percentage{font-size:.875rem;color:var(--text-secondary);margin-left:.25rem}.goal-empty-hint{font-size:.75rem;color:var(--text-secondary);font-style:italic;margin-bottom:.75rem}.goal-info-compact{display:flex;justify-content:space-between;align-items:center;margin-bottom:.875rem;gap:1rem}.goal-days-compact{font-size:.813rem;color:var(--text-primary);font-weight:600}.goal-required-chips{display:flex;gap:.5rem}.required-chip{background:var(--bg-primary);border:1px solid var(--border-color);padding:.25rem .625rem;border-radius:6px;font-size:.75rem;font-weight:600;color:var(--primary);white-space:nowrap}.goal-status-message{padding:.75rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600;text-align:center;margin-bottom:1rem}.goal-status-message.achieved{background:#02b08d1f;color:var(--success);border:1px solid rgba(2,176,141,.25)}.goal-status-message.expired{background:#ef53501f;color:var(--danger);border:1px solid rgba(239,83,80,.25)}.goal-actions-footer{margin-top:.875rem;padding-top:.875rem;border-top:1px solid var(--border-color)}.goal-action-buttons{display:flex;gap:1rem;align-items:center}.btn-contribute-primary{flex:1;background:var(--primary);color:#fff;border:none;padding:.75rem 1.25rem;border-radius:8px;font-size:.938rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-contribute-primary:hover{background:#1a3866;transform:translateY(-1px);box-shadow:var(--shadow)}.btn-contribute-primary.paused{background:var(--text-secondary)}.btn-contribute-primary.paused:hover{background:#4a5a75}.btn-contribute-link{background:transparent;color:var(--primary);border:none;padding:0;font-size:.875rem;font-weight:600;cursor:pointer;text-decoration:underline;text-underline-offset:2px;transition:opacity .2s}.btn-contribute-link:hover{opacity:.7}.contribute-form-inline{display:flex;gap:.5rem}.form-input-inline{flex:1;padding:.75rem;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;font-weight:600;transition:all .2s}.form-input-inline:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #1f42781a}.btn-contribute-confirm{background:var(--success);color:#fff;border:none;padding:.75rem 1.25rem;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-contribute-confirm:hover{background:#029876}.btn-contribute-cancel{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);padding:.75rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-contribute-cancel:hover{background:var(--bg-primary)}@media(max-width:640px){.goal-info-compact{flex-direction:column;align-items:flex-start;gap:.5rem}.goal-required-chips{width:100%}.required-chip{flex:1;text-align:center}.goal-actions{opacity:1}}.goal-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.goal-icon{font-size:2rem}.goal-header h3{margin:0;color:var(--text-primary)}.goal-progress{margin:1rem 0}.progress-bar{height:12px;background:var(--bg-primary);border-radius:6px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-teal),#04e5b8);transition:width .3s ease;border-radius:6px}.goal-deadline{color:var(--text-secondary);font-size:.875rem;margin:.5rem 0 0}.budget-item{background:var(--bg-secondary);padding:1rem;border-radius:8px;border-left:4px solid var(--border-color);margin-bottom:1rem}.budget-warning{border-left-color:var(--warning)}.budget-exceeded{border-left-color:var(--danger)}.budget-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.budget-percentage{font-size:.875rem;font-weight:600}.investment-card{background:var(--bg-secondary);padding:1.5rem;border-radius:12px;box-shadow:var(--shadow)}.investment-gain{color:var(--success);font-weight:600}.investment-loss{color:var(--danger);font-weight:600}.investment-type{display:inline-block;padding:.25rem .75rem;background:var(--bg-primary);border-radius:4px;font-size:.875rem;font-weight:500}.recurring-item{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:var(--bg-secondary);border-radius:8px;margin-bottom:.75rem}.recurring-item .goal-actions{opacity:1}.recurring-inactive{opacity:.6}.frequency-badge{padding:.25rem .75rem;background:var(--accent-teal);color:#fff;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase}.toggle-switch{position:relative;width:48px;height:24px;background:#ddd;border-radius:12px;cursor:pointer;transition:background .2s}.toggle-switch.active{background:var(--accent-teal)}.toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .2s}.toggle-switch.active:after{transform:translate(24px)}.savings-goals{padding:2rem;max-width:1200px;margin:0 auto}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.section-header h2{font-size:1.75rem;color:var(--text-primary)}.goal-title{display:flex;align-items:flex-start;gap:1rem;flex:1}.goal-description{font-size:.875rem;color:var(--text-secondary);margin-top:.25rem}.goal-actions{display:flex;gap:.5rem}.progress-text{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;margin-bottom:.25rem}.current-amount{font-weight:700;color:var(--text-primary);font-size:1.125rem}.target-amount{color:var(--text-secondary)}.progress-percentage{font-size:.75rem;color:var(--text-secondary);margin:.25rem 0 0}.goal-footer{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.status-badge{display:inline-block;padding:.375rem .75rem;border-radius:6px;font-size:.875rem;font-weight:600}.status-badge.achieved{background:#02b08d1a;color:var(--success)}.status-badge.expired{background:#fdcb6e1a;color:var(--warning)}.status-badge.active{background:#1f42781a;color:var(--primary)}.goal-achieved{border-left:4px solid var(--success)!important}.goal-expired{border-left:4px solid var(--warning)!important}.contribute-section{margin-top:1rem}.btn-contribute{width:100%;padding:.75rem;background:var(--accent-teal);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-contribute:hover{background:#01997a;transform:translateY(-2px)}.contribute-form{display:flex;gap:.5rem;align-items:center}.form-input.small{padding:.5rem;font-size:.875rem}.btn-primary.small,.btn-secondary.small{padding:.5rem 1rem;font-size:.875rem;white-space:nowrap}.btn-primary{background:var(--primary);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;transition:all .2s}.btn-primary:hover{background:#173358}.btn-secondary{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;font-weight:600;transition:all .2s}.btn-secondary:hover{background:var(--border-color)}.icon-selector,.color-selector{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.icon-option{width:48px;height:48px;border:2px solid var(--border-color);border-radius:8px;background:#fff;font-size:1.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.icon-option:hover{border-color:var(--primary);transform:scale(1.1)}.icon-option.selected{border-color:var(--primary);background:#1f42781a;box-shadow:0 0 0 3px #1f42781a}.color-option{width:40px;height:40px;border:3px solid transparent;border-radius:50%;cursor:pointer;transition:all .2s}.color-option:hover{transform:scale(1.15)}.color-option.selected{border-color:var(--text-primary);box-shadow:0 0 0 3px #1f427833}.empty-state{text-align:center;padding:4rem 2rem}.empty-state h3{margin:1rem 0 .5rem;color:var(--text-primary)}.empty-state p{color:var(--text-secondary);margin-bottom:2rem}.add-btn{background:var(--primary);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;transition:all .2s}.add-btn:hover{background:#173358;transform:translateY(-2px);box-shadow:var(--shadow-lg)}.icon-btn{background:transparent;border:none;padding:.5rem;cursor:pointer;color:var(--text-secondary);border-radius:6px;transition:all .2s;display:flex;align-items:center;justify-content:center}.icon-btn:hover{background:var(--bg-primary);color:var(--text-primary)}.icon-btn.danger:hover{background:#e8519e1a;color:var(--danger)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.budgets{padding:2rem;max-width:1200px;margin:0 auto}.budget-summary{margin-bottom:2rem}.summary-card{background:var(--bg-secondary);padding:1.5rem;border-radius:12px;box-shadow:var(--shadow)}.summary-card h3{margin:0 0 1rem;color:var(--text-primary);font-size:1.25rem}.summary-amounts{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.5rem;margin-bottom:1rem}.summary-item{display:flex;flex-direction:column;gap:.25rem}.summary-label{font-size:.875rem;color:var(--text-secondary)}.summary-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.budgets-list{display:flex;flex-direction:column;gap:1rem}.budget-item{background:var(--bg-secondary);padding:1.25rem;border-radius:12px;box-shadow:var(--shadow);border-left:4px solid var(--border-color);transition:all .2s}.budget-item:hover{box-shadow:var(--shadow-lg)}.budget-item h4{margin:0;color:var(--text-primary);font-size:1.125rem}.warning-message,.danger-message{display:flex;align-items:center;gap:.5rem;padding:.75rem;border-radius:6px;font-size:.875rem;font-weight:600;margin-top:.75rem}.warning-message{background:#fdcb6e1a;color:var(--warning);border:1px solid var(--warning)}.danger-message{background:#e8519e1a;color:var(--danger);border:1px solid var(--danger)}.budget-info{background:var(--bg-primary);padding:1rem;border-radius:8px;margin-top:1rem}.budget-info p{margin:0;font-size:.875rem;color:var(--text-secondary);line-height:1.5}.recurring-transactions{padding:2rem;max-width:1200px;margin:0 auto}.recurring-summary,.recurring-section{margin-bottom:2rem}.recurring-list{display:flex;flex-direction:column;gap:.75rem}.recurring-item h4{margin:0;color:var(--text-primary);font-size:1rem}.user-management{padding:2rem;max-width:1400px;margin:0 auto}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat-card{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:var(--bg-secondary);border-radius:12px;box-shadow:var(--shadow)}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.stat-info{flex:1}.stat-label{font-size:.875rem;color:var(--text-secondary);margin:0 0 .25rem}.stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0}.users-table-container{background:var(--bg-secondary);border-radius:12px;box-shadow:var(--shadow);overflow-x:auto}.users-table{width:100%;border-collapse:collapse}.users-table thead{background:var(--bg-primary)}.users-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.users-table td{padding:1rem;border-top:1px solid var(--border-color);font-size:.875rem;color:var(--text-primary)}.users-table tbody tr:hover{background:var(--bg-primary)}.user-cell{display:flex;align-items:center;gap:.75rem}.user-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.125rem;overflow:hidden}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-name{font-weight:600;color:var(--text-primary)}.role-badge{display:inline-block;padding:.375rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge{font-weight:600;font-size:.875rem}.table-actions{display:flex;gap:.5rem;align-items:center}@media(max-width:768px){.recurring-item{flex-direction:column;align-items:flex-start!important;gap:1rem!important}.recurring-item>div:last-child{width:100%;justify-content:space-between}.form-row,.goals-grid{grid-template-columns:1fr}.contribute-form{flex-direction:column}.btn-primary.small,.btn-secondary.small{width:100%}.summary-amounts,.stats-row{grid-template-columns:1fr}.users-table-container{overflow-x:scroll}.users-table{min-width:800px}.monthly-plan-container{margin-bottom:2rem}.monthly-plan-card{padding:1.5rem}.plan-breakdown{gap:.75rem}.plan-item{flex-direction:column;align-items:flex-start;gap:.25rem}.plan-item-label{font-size:.875rem}.plan-final-value{font-size:2rem}.plan-actual-items{padding-left:0}.plan-actual-item{flex-direction:column;align-items:flex-start;gap:.5rem}.plan-actual-value-final{font-size:1.25rem}.plan-cards-row,.plan-real-grid{grid-template-columns:1fr}.plan-real-item-final{grid-column:span 1}}.monthly-plan-container{margin-bottom:0}.section-header-inline{margin-bottom:1rem}.section-title-inline{font-size:1.125rem;font-weight:600;color:var(--text-primary);display:inline-flex;align-items:center;gap:.5rem}.plan-cards-row{display:grid;grid-template-columns:2fr 1fr;gap:var(--gap-desktop);margin-bottom:var(--gap-desktop)}.plan-mini-card{background:var(--bg-card);border-radius:14px;padding:18px 20px;border:1px solid var(--border);transition:all .17s ease}.plan-mini-card:hover{border-color:#60a5fa59;box-shadow:0 6px 16px #0000003d}.plan-mini-card.highlighted{border-width:2px}.plan-mini-card.positive-border{border-color:var(--success);background:linear-gradient(135deg,rgba(34,211,166,.04) 0%,var(--bg-card) 100%)}.plan-mini-card.negative-border{border-color:#f43f5e;background:linear-gradient(135deg,rgba(244,63,94,.04) 0%,var(--bg-card) 100%)}.plan-mini-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.plan-mini-icon{font-size:1.25rem}.plan-mini-title{font-size:.813rem;font-weight:600;color:var(--text-primary);letter-spacing:.2px}.plan-mini-amount{font-size:1.5rem;font-weight:800;margin-bottom:.75rem;letter-spacing:-.5px}.plan-mini-amount.positive{color:var(--success)}.plan-mini-amount.expense{color:var(--danger)}.plan-mini-amount-large{font-size:1.875rem;font-weight:800;margin-bottom:.75rem;letter-spacing:-.75px;text-align:center}.plan-mini-amount-large.positive{color:var(--success)}.plan-mini-amount-large.negative{color:var(--danger)}.plan-mini-detail{display:flex;justify-content:space-between;align-items:center;padding:.375rem 0;font-size:.75rem;border-top:1px solid var(--border)}.plan-mini-detail:first-of-type{margin-top:.5rem}.detail-label{color:var(--text-secondary);font-weight:500;font-size:.75rem}.detail-value{font-weight:700;color:var(--text-primary);text-align:right;font-feature-settings:var(--font-feature-tabular)}.detail-value.income{color:var(--accent-green)}.detail-value.expense{color:#f43f5e}.plan-status-badge{text-align:center;padding:.375rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;margin-top:.5rem}.plan-status-badge.success{background:#02b08d1a;color:var(--success);border:1px solid rgba(2,176,141,.2)}.plan-status-badge.warning{background:#fdcb6e26;color:#d35400;border:1px solid rgba(253,203,110,.3)}.plan-status-badge.danger{background:#e8519e1a;color:var(--danger);border:1px solid rgba(232,81,158,.2)}.plan-real-section{background:var(--bg-card);border-radius:14px;padding:18px 20px;border:1px solid var(--border);transition:all .17s ease}.plan-real-section:hover{border-color:#60a5fa59;box-shadow:0 6px 16px #0000003d}.plan-real-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.plan-real-icon{font-size:1.25rem}.plan-real-title{font-size:1rem;font-weight:700;color:var(--text-primary);flex:1}.difference-badge{font-size:.6875rem;padding:3px 10px;border-radius:9999px;font-weight:700;white-space:nowrap;font-feature-settings:var(--font-feature-tabular)}.difference-badge.positive{background:#22d3a61f;color:var(--accent-green);border:1px solid rgba(34,211,166,.25)}.difference-badge.negative{background:#f43f5e1f;color:#f43f5e;border:1px solid rgba(244,63,94,.25)}.plan-real-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1rem}.plan-real-item{background:var(--bg-tertiary);padding:.875rem;border-radius:8px;border-left:3px solid var(--border-color)}.plan-real-label{font-size:.75rem;color:var(--text-secondary);font-weight:600;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.3px}.plan-real-value{font-size:1.25rem;font-weight:800;letter-spacing:-.5px;font-feature-settings:var(--font-feature-tabular)}.plan-real-value.income{color:var(--accent-green)}.plan-real-value.expense{color:var(--danger)}.plan-real-item-final{grid-column:span 3;background:linear-gradient(135deg,#02b08d0d,#1f42780d);padding:1rem 1.25rem;border-radius:10px;border:2px solid var(--accent-teal);display:flex;justify-content:space-between;align-items:center}.plan-real-item-final.deficit{background:linear-gradient(135deg,#e8519e0d,#d630310d);border-color:var(--danger)}.plan-real-label-final{font-size:.938rem;color:var(--text-primary);font-weight:700;display:flex;align-items:center;gap:.5rem}.warning-icon{font-size:1.125rem}.plan-real-value-final{font-size:1.75rem;font-weight:800;letter-spacing:-.75px}.plan-real-value-final.positive{color:var(--success)}.plan-real-value-final.negative{color:var(--danger)}.execution-bar-container{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border)}.execution-bar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.8125rem;font-weight:600;color:var(--text-primary)}.execution-percentage{font-size:.9375rem;font-weight:800;color:var(--accent-teal);font-feature-settings:var(--font-feature-tabular)}.execution-bar{position:relative;height:8px;background:var(--border);border-radius:8px;overflow:visible}.execution-bar-fill{height:100%;transition:width .3s ease;border-radius:8px}.execution-bar-fill.normal{background:linear-gradient(90deg,var(--success) 0%,var(--accent-teal) 100%)}.execution-bar-fill.over{background:linear-gradient(90deg,#f43f5e,#d63031)}.execution-markers{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}.execution-marker{position:absolute;top:-3px;bottom:-3px;width:2px;border-radius:1px}.execution-marker.at-80{left:80%;background:var(--text-muted);opacity:.4}.execution-marker.at-100{left:100%;background:var(--text-secondary);opacity:.6}.execution-marker.at-110{left:110%;background:#f43f5e;opacity:.4}.execution-over-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:9999px;font-size:.6875rem;font-weight:700;background:#f43f5e26;color:#f43f5e;margin-left:8px}.saldo-libre-bar-container{margin-top:1rem}.saldo-libre-bar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.375rem;font-size:.8125rem;font-weight:600;color:var(--text-primary)}.saldo-libre-bar{position:relative;height:10px;background:var(--border);border-radius:5px;overflow:hidden}.saldo-libre-bar-fill{height:100%;border-radius:5px;transition:width .3s ease}.saldo-libre-bar-fill.positive{background:linear-gradient(90deg,var(--accent-green) 0%,var(--accent-green-light) 100%)}.saldo-libre-bar-fill.negative{background:linear-gradient(90deg,#f43f5e,#fb7185)}.plan-section{margin-bottom:1.5rem}.plan-section:last-child{margin-bottom:0}.plan-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.plan-icon{font-size:1.5rem}.plan-label{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.plan-breakdown{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem;padding-left:2.25rem}.plan-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.plan-item-label{font-size:.938rem;color:var(--text-secondary)}.plan-item-value{font-size:1rem;font-weight:600}.plan-item-value.income{color:var(--success)}.plan-item-value.expense{color:var(--danger)}.plan-total{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-tertiary);border-radius:8px;margin-left:2.25rem}.plan-total-label{font-size:1rem;font-weight:600;color:var(--text-primary)}.plan-total-value{font-size:1.25rem;font-weight:700}.plan-total-value.positive{color:var(--success)}.plan-total-value.negative{color:var(--danger)}.plan-divider{text-align:center;font-size:1.5rem;font-weight:600;color:var(--text-secondary);margin:1rem 0;padding:.5rem 0}.plan-divider-thick{text-align:center;font-size:2rem;font-weight:700;color:var(--primary);margin:1.5rem 0;padding:.75rem 0;border-top:2px solid var(--border-color);border-bottom:2px solid var(--border-color)}.plan-result{background:linear-gradient(135deg,#1f427808,#02b08d08);border-radius:12px;padding:1.5rem;margin-top:1.5rem;border:2px solid var(--border-color)}.plan-final-total{display:flex;justify-content:center;align-items:center;padding:1.5rem;margin:1rem 0}.plan-final-value{font-size:2.5rem;font-weight:800;letter-spacing:-.5px}.plan-final-value.positive{color:var(--success)}.plan-final-value.negative{color:var(--danger)}.plan-message{text-align:center;padding:.75rem 1rem;border-radius:8px;font-size:.938rem;font-weight:600}.plan-message.success{background:#02b08d1a;color:var(--success);border:1px solid rgba(2,176,141,.2)}.plan-message.warning{background:#fdcb6e1a;color:#d63031;border:1px solid rgba(253,203,110,.3)}.plan-divider-thin{border-top:1px dashed var(--border-color);margin:1.5rem 0}.plan-actual{background:#02b08d05;border-radius:12px;padding:1.5rem;margin-top:1rem;border:1px dashed var(--accent-teal)}.plan-actual-items{display:flex;flex-direction:column;gap:1rem;padding-left:2.25rem}.plan-actual-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-secondary);border-radius:8px;border-left:3px solid var(--border-color)}.plan-actual-label{font-size:.938rem;color:var(--text-secondary);font-weight:500}.plan-actual-value{font-size:1.125rem;font-weight:700}.plan-actual-value.income{color:var(--success)}.plan-actual-value.expense{color:var(--danger)}.plan-actual-item-final{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:linear-gradient(135deg,#02b08d14,#1f427814);border-radius:10px;border:2px solid var(--accent-teal);margin-top:.5rem}.plan-actual-label-final{font-size:1.063rem;color:var(--text-primary);font-weight:700}.plan-actual-value-final{font-size:1.5rem;font-weight:800;letter-spacing:-.5px}.plan-actual-value-final.positive{color:var(--success)}.plan-actual-value-final.negative{color:var(--danger)}.toggle-switch{display:inline-flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-switch input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.toggle-slider{position:relative;display:inline-block;width:44px;height:24px;background-color:#ccc;border-radius:24px;transition:background-color .3s}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background-color:#fff;border-radius:50%;transition:transform .3s}.toggle-switch input[type=checkbox]:checked+.toggle-slider{background-color:var(--success)}.toggle-switch input[type=checkbox]:checked+.toggle-slider:before{transform:translate(20px)}.toggle-switch input[type=checkbox]:focus+.toggle-slider{box-shadow:0 0 0 3px #02b08d33}.sidebar{position:fixed;left:0;top:0;height:100vh;background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:200;transition:width var(--transition-normal)}.sidebar.expanded{width:256px}.sidebar.collapsed{width:72px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid var(--border-color);min-height:64px}.sidebar-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none;overflow:hidden}.sidebar-logo-icon{font-size:1.75rem;flex-shrink:0}.sidebar-logo-text{font-size:1.25rem;font-weight:700;color:var(--text-primary);white-space:nowrap;opacity:1;transition:opacity var(--transition-normal)}.sidebar.collapsed .sidebar-logo-text{opacity:0;width:0}.sidebar-toggle{background:var(--bg-hover);border:1px solid var(--border-color);border-radius:8px;padding:.5rem;cursor:pointer;color:var(--text-secondary);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.sidebar-toggle:hover{background:var(--bg-elevated);color:var(--text-primary)}.sidebar.collapsed .sidebar-toggle{margin:0 auto}.sidebar-nav{flex:1;padding:1rem .75rem;display:flex;flex-direction:column;gap:.25rem}.sidebar-nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:10px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);border:none;background:transparent;width:100%;text-align:left;font-size:.9375rem;font-weight:500}.sidebar-nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-nav-item.active{background:#22d3a61a;color:var(--accent-green)}.sidebar-nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:24px;background:var(--accent-green);border-radius:0 3px 3px 0}.sidebar-nav-icon{flex-shrink:0;width:20px;height:20px}.sidebar-nav-text{white-space:nowrap;overflow:hidden;transition:opacity var(--transition-normal)}.sidebar.collapsed .sidebar-nav-text{opacity:0;width:0}.sidebar.collapsed .sidebar-nav-item{justify-content:center;padding:.75rem}.sidebar-footer{padding:1rem;border-top:1px solid var(--border-color)}.app-header{background:var(--bg-card);border-bottom:1px solid var(--border-color);padding:0 1.5rem;height:64px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #0000001f,0 1px 2px #00000014}.header-left{display:flex;align-items:center;gap:1.5rem}.header-title{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.header-period-filter{display:flex;gap:2px;background:var(--bg-elevated);padding:3px;border-radius:9999px;border:1px solid var(--border)}.period-btn{padding:0 .875rem;height:34px;border:none;background:transparent;color:var(--text-secondary);border-radius:9999px;cursor:pointer;font-size:.8125rem;font-weight:600;transition:all var(--transition-fast);line-height:34px}.period-btn:hover{color:var(--text-primary);background:#ffffff0a}.period-btn.active{background:var(--accent-green);color:var(--bg-primary);box-shadow:0 1px 3px #0003}.period-btn:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px}.header-right{display:flex;align-items:center;gap:1rem}.header-user-info{display:flex;align-items:center;gap:.5rem}.header-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#0078d4,#00bcf2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600}.header-user-name{font-size:.85rem;color:var(--text-secondary);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-logout-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center;transition:all .15s}.header-logout-btn:hover{color:#ef4444;background:#ef44441a}.header-login-btn{display:flex;align-items:center;gap:.4rem;padding:6px 14px;background:#0078d4;color:#fff;border:none;border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;transition:background .15s}.header-login-btn:hover{background:#106ebe}.header-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border-radius:10px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.header-btn-primary{background:var(--accent-green);color:var(--bg-primary);border:none}.header-btn-primary:hover{background:var(--accent-green-light);transform:translateY(-1px)}.header-btn-secondary{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}.header-btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-hover)}.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:18px 20px;transition:all .17s ease}.kpi-card:hover{border-color:#60a5fa59;box-shadow:0 6px 16px #0000003d}.kpi-card:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px}.kpi-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1rem}.kpi-icon-wrapper{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.25rem}.kpi-icon-wrapper.green{background:#22d3a626;color:var(--accent-green)}.kpi-icon-wrapper.red{background:#f43f5e26;color:var(--danger)}.kpi-icon-wrapper.blue{background:#60a5fa26;color:var(--accent-blue)}.kpi-icon-wrapper.amber{background:#f59e0b26;color:var(--warning)}.kpi-delta{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:9999px;font-size:.6875rem;font-weight:600;font-feature-settings:var(--font-feature-tabular)}.kpi-delta.positive{background:#22d3a626;color:var(--accent-green)}.kpi-delta.negative{background:#f43f5e26;color:#f43f5e}.kpi-delta.neutral{background:var(--bg-hover);color:var(--text-secondary)}.kpi-content{margin-bottom:.5rem}.kpi-title{font-size:.75rem;font-weight:600;color:var(--text-secondary);margin-bottom:6px;letter-spacing:.02em;text-transform:none}.kpi-value{font-size:clamp(1.75rem,2.5vw,2rem);font-weight:800;color:var(--text-primary);line-height:1.1;font-feature-settings:var(--font-feature-tabular)}.kpi-value.income{color:var(--accent-green)}.kpi-value.expense{color:#f43f5e}.kpi-currency{color:var(--text-secondary);font-weight:700}.kpi-sparkline{height:27px;margin-top:.5rem}.dashboard-grid{display:grid;gap:var(--gap-desktop)}.dashboard-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap-desktop)}.dashboard-row{display:grid;grid-template-columns:1fr 2fr;gap:var(--gap-desktop)}.dashboard-row-equal{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap-desktop)}@media(max-width:1024px){.dashboard-kpis{grid-template-columns:repeat(2,1fr);gap:var(--gap-md)}.dashboard-row,.dashboard-row-equal{grid-template-columns:1fr;gap:var(--gap-md)}.dashboard-grid{gap:var(--gap-md)}}@media(max-width:640px){.dashboard-kpis{grid-template-columns:1fr;gap:var(--gap-sm)}.dashboard-grid{gap:var(--gap-sm)}.container{padding:1rem var(--gap-sm)}}.wallet-section{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:18px 20px;transition:all .17s ease}.wallet-section:hover{border-color:#60a5fa59;box-shadow:0 6px 16px #0000003d}.wallet-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.wallet-title{font-size:1rem;font-weight:600;color:var(--text-primary)}.wallet-add-btn{background:transparent;border:1px dashed var(--border-color);border-radius:8px;padding:.5rem .75rem;color:var(--text-secondary);cursor:pointer;font-size:.8125rem;font-weight:500;transition:all var(--transition-fast)}.wallet-add-btn:hover{border-color:var(--accent-green);color:var(--accent-green)}.wallet-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.wallet-tile{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:10px;padding:1rem;cursor:pointer;transition:all var(--transition-fast)}.wallet-tile:hover{border-color:var(--border-hover);background:var(--bg-hover)}.wallet-tile-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.wallet-tile-icon{font-size:1.25rem}.wallet-tile-name{font-size:.8125rem;font-weight:500;color:var(--text-secondary)}.wallet-tile-balance{font-size:1.125rem;font-weight:700;color:var(--text-primary)}.wallet-total{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.wallet-total-label{font-size:.8125rem;font-weight:500;color:var(--text-secondary)}.wallet-total-value{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.chart-card-new{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:18px 20px;height:100%;display:flex;flex-direction:column;transition:all .17s ease}.chart-card-new:hover{border-color:#60a5fa59;box-shadow:0 6px 16px #0000003d}.chart-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1rem}.chart-card-title{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.chart-card-subtitle{font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}.table-compact{width:100%}.table-compact-row{display:flex;align-items:center;min-height:46px;padding:.5rem 0;border-bottom:1px solid var(--border);transition:background var(--transition-fast)}.table-compact-row:last-child{border-bottom:none}.table-compact-row:hover{background:var(--bg-hover);margin:0 -.5rem;padding-left:.5rem;padding-right:.5rem;border-radius:8px}.table-compact-row:focus-visible{outline:2px solid var(--accent-blue);outline-offset:-2px;border-radius:8px}.table-compact-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;margin-right:.75rem;flex-shrink:0}.table-compact-content{flex:1;min-width:0}.table-compact-title{font-size:.875rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.table-compact-subtitle{font-size:.75rem;color:var(--text-secondary)}.table-compact-amount{font-size:.9375rem;font-weight:600;text-align:right;font-feature-settings:var(--font-feature-tabular)}.table-compact-amount.income{color:var(--accent-green)}.table-compact-amount.expense{color:#f43f5e}.budget-bar-container{margin-bottom:1rem}.budget-bar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.budget-bar-category{display:flex;align-items:center;gap:.5rem}.budget-bar-icon{font-size:1.125rem}.budget-bar-name{font-size:.875rem;font-weight:500;color:var(--text-primary)}.budget-bar-amounts{font-size:.8125rem;color:var(--text-secondary)}.budget-bar-amounts span{font-weight:600;color:var(--text-primary)}.budget-bar-track{position:relative;height:8px;background:var(--bg-elevated);border-radius:4px;overflow:visible}.budget-bar-fill{height:100%;border-radius:4px;transition:width var(--transition-normal)}.budget-bar-fill.green{background:var(--accent-green)}.budget-bar-fill.amber{background:var(--warning)}.budget-bar-fill.red{background:var(--danger)}.budget-bar-markers{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}.budget-bar-marker{position:absolute;top:-4px;bottom:-4px;width:2px;background:var(--text-muted);opacity:.5}.budget-bar-marker.at-80{left:80%}.budget-bar-marker.at-100{left:100%;background:var(--text-secondary)}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:1100;display:flex;flex-direction:column;gap:.75rem}.toast{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;box-shadow:var(--shadow-lg);min-width:300px;max-width:420px;animation:slideInRight .3s ease}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-icon{flex-shrink:0;width:20px;height:20px}.toast.success{border-left:3px solid var(--accent-green)}.toast.success .toast-icon{color:var(--accent-green)}.toast.error{border-left:3px solid var(--danger)}.toast.error .toast-icon{color:var(--danger)}.toast.info{border-left:3px solid var(--accent-blue)}.toast.info .toast-icon{color:var(--accent-blue)}.toast-message{flex:1;font-size:.875rem;color:var(--text-primary)}.toast-close{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:4px;transition:all var(--transition-fast)}.toast-close:hover{background:var(--bg-hover);color:var(--text-primary)}@media(max-width:1024px){.sidebar{transform:translate(-100%)!important;width:260px!important}.sidebar.mobile-open{transform:translate(0)!important}.sidebar-toggle.desktop-only{display:none!important}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:199;opacity:0;visibility:hidden;transition:all var(--transition-normal)}.sidebar-overlay.visible{opacity:1;visibility:visible}.mobile-menu-btn{display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:8px;padding:.5rem;color:var(--text-primary);cursor:pointer}.app-main.sidebar-expanded,.app-main.sidebar-collapsed{margin-left:0!important}}.form-input,.form-select,.form-textarea{background:var(--bg-elevated);border-color:var(--border-color);color:var(--text-primary)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent-green);box-shadow:0 0 0 3px #22d3a626}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.icon-option{background:var(--bg-elevated);border-color:var(--border-color)}.icon-option:hover{border-color:var(--accent-green)}.icon-option.selected{border-color:var(--accent-green);background:#22d3a61a}.search-input{background:var(--bg-elevated);border-color:var(--border-color);color:var(--text-primary)}.search-input:focus{border-color:var(--accent-green);box-shadow:0 0 0 3px #22d3a626}.search-input::placeholder{color:var(--text-muted)}.header-mobile-menu{display:none}@media(max-width:1024px){.header-mobile-menu{display:flex;flex-shrink:0}}@media(max-width:768px){.app-header{height:auto;min-height:56px;padding:.625rem .75rem;flex-wrap:wrap;gap:.5rem}.header-left{flex:1;min-width:0;gap:.75rem;flex-wrap:wrap}.header-title{font-size:1.0625rem;flex-shrink:0}.header-period-filter{order:3;width:100%;justify-content:stretch}.period-btn{flex:1;text-align:center;padding:0 .5rem;height:32px;line-height:32px;font-size:.75rem}.header-right{gap:.5rem}.header-mobile-menu{display:flex;flex-shrink:0}.header-btn span{display:none}.header-btn{padding:.5rem;border-radius:8px;min-width:40px;min-height:40px;justify-content:center}.mobile-menu-btn{min-width:40px;min-height:40px}.container{padding:.75rem}.sidebar.mobile-open{width:280px!important}.sidebar-nav-item{min-height:44px;font-size:.9375rem}.kpi-card{padding:14px 16px}.kpi-value{font-size:1.5rem}.kpi-title{font-size:.6875rem}.kpi-header{margin-bottom:.625rem}.kpi-icon-wrapper{width:36px;height:36px}.kpi-sparkline{height:24px}.wallet-section{padding:14px 16px}.wallet-grid{grid-template-columns:1fr;gap:.5rem}.wallet-tile{padding:.75rem}.wallet-title{font-size:.9375rem}.wallet-total-value{font-size:1.125rem}.chart-card-new{padding:14px 16px}.chart-card-title{font-size:1rem}.plan-mini-card{padding:14px 16px}.plan-mini-amount{font-size:1.25rem}.plan-mini-amount-large{font-size:1.5rem}.plan-mini-title{font-size:.75rem}.plan-mini-detail,.detail-label{font-size:.6875rem}.plan-real-section{padding:14px 16px}.plan-real-title{font-size:.875rem}.plan-real-value{font-size:1.125rem}.plan-real-label{font-size:.6875rem}.difference-badge{font-size:.625rem;padding:2px 8px}.execution-bar-header{font-size:.75rem}.execution-percentage{font-size:.8125rem}.table-compact-row{min-height:48px;padding:.625rem 0}.table-compact-icon{width:40px;height:40px;font-size:1.125rem}.table-compact-title{font-size:.8125rem}.table-compact-amount{font-size:.875rem}.section-title-inline{font-size:1rem}.dashboard-footer{padding:1rem 0;margin-top:1rem}.users-table{min-width:auto;font-size:.8125rem}.users-table th,.users-table td{padding:.5rem .375rem}.goal-actions{opacity:1}.month-selector{padding:.375rem .5rem;font-size:.8125rem}.month-display{min-width:120px;font-size:.8125rem}}@media(max-width:480px){.container,.app-header{padding:.5rem}.header-title{font-size:1rem}.dashboard-kpis{grid-template-columns:repeat(2,1fr);gap:var(--gap-sm)}.kpi-card{padding:12px}.kpi-value{font-size:1.25rem}.kpi-title{font-size:.625rem;margin-bottom:4px}.kpi-header{margin-bottom:.5rem}.kpi-icon-wrapper{width:32px;height:32px;border-radius:8px}.kpi-icon-wrapper svg{width:16px;height:16px}.kpi-delta{font-size:.5625rem;padding:2px 6px}.kpi-sparkline{height:20px;margin-top:.375rem}.dashboard-grid,.dashboard-row,.dashboard-row-equal{gap:var(--gap-sm)}.wallet-section{padding:12px}.wallet-tile{padding:.625rem}.wallet-tile-balance{font-size:1rem}.wallet-tile-name{font-size:.75rem}.chart-card-new{padding:12px}.chart-card-title{font-size:.9375rem}.plan-mini-card{padding:12px}.plan-mini-amount{font-size:1.125rem;margin-bottom:.5rem}.plan-mini-amount-large{font-size:1.375rem}.plan-mini-header{gap:.375rem;margin-bottom:.5rem}.plan-mini-icon{font-size:1rem}.plan-mini-title{font-size:.6875rem}.plan-mini-detail{padding:.25rem 0;font-size:.625rem}.plan-real-section{padding:12px}.plan-real-header{flex-wrap:wrap;gap:.5rem}.plan-real-title{font-size:.8125rem;flex:none}.plan-real-item{padding:.625rem}.plan-real-value{font-size:1rem}.plan-real-label{font-size:.625rem;margin-bottom:.375rem}.table-compact-row{min-height:44px}.table-compact-icon{width:36px;height:36px;margin-right:.5rem}.table-compact-title{font-size:.75rem}.table-compact-subtitle{font-size:.6875rem}.table-compact-amount{font-size:.8125rem}.plan-status-badge{font-size:.6875rem;padding:.25rem .5rem}.execution-bar-header{font-size:.6875rem}.execution-percentage{font-size:.75rem}.execution-over-badge{font-size:.5625rem;padding:1px 6px}.saldo-libre-bar-header{font-size:.75rem}.modal{width:96%;max-width:96%;padding:1.25rem;border-radius:12px}.modal-title{font-size:1.25rem}.transaction-item{padding:.625rem}.transaction-icon{width:36px;height:36px;font-size:1.125rem;margin-right:.375rem}.transaction-category{font-size:.8125rem}.transaction-description{font-size:.75rem}.transaction-date{margin-left:40px}.transaction-amount{font-size:.8125rem}.category-grid{grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:.5rem}.category-btn{padding:.625rem .375rem;font-size:.75rem}.category-icon{font-size:1.5rem}}@media(max-width:360px){.dashboard-kpis{grid-template-columns:1fr}.kpi-card{padding:12px 10px;display:flex;flex-direction:row;align-items:center;gap:12px}.kpi-header{margin-bottom:0;flex-direction:column;gap:4px;flex-shrink:0}.kpi-content{flex:1;margin-bottom:0;min-width:0}.kpi-sparkline{display:none}.kpi-value{font-size:1.375rem}.kpi-delta{margin-top:2px}.header-title{font-size:.9375rem}.period-btn{font-size:.6875rem;height:30px;line-height:30px}}@media(pointer:coarse){.period-btn,.header-btn,.sidebar-nav-item,.wallet-add-btn,.filter-btn,.action-btn,.month-nav-btn,.close-btn{min-height:44px;min-width:44px}.table-compact-row{min-height:48px}.sidebar-toggle{min-width:44px;min-height:44px}.wallet-tile{min-height:56px}.close-btn{width:44px;height:44px}}@supports (padding: env(safe-area-inset-bottom)){.app-header{padding-left:max(.75rem,env(safe-area-inset-left));padding-right:max(.75rem,env(safe-area-inset-right))}.sidebar{padding-bottom:env(safe-area-inset-bottom)}.container{padding-left:max(.75rem,env(safe-area-inset-left));padding-right:max(.75rem,env(safe-area-inset-right))}.dashboard-footer{padding-bottom:max(1rem,env(safe-area-inset-bottom))}}@media(max-height:500px)and (orientation:landscape){.app-header{min-height:48px;padding:.375rem .75rem}.header-period-filter{order:0;width:auto}.dashboard-kpis{grid-template-columns:repeat(4,1fr)}.sidebar.mobile-open{width:220px!important}.kpi-card{padding:10px 12px}.kpi-sparkline{display:none}}.health-score-card{background:var(--bg-card, #121826);border:1px solid var(--border, #1e293b);border-radius:var(--radius-card, 12px);padding:20px;height:100%;display:flex;flex-direction:column;transition:box-shadow var(--transition-normal, .2s ease),transform var(--transition-normal, .2s ease)}.health-score-card:hover{box-shadow:0 6px 16px #00000059;transform:translateY(-1px)}.health-score-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.health-score-title{font-size:1rem;font-weight:600;color:var(--text-primary);letter-spacing:var(--tracking-tight, -.01em)}.health-score-badge{font-size:.75rem;font-weight:600;padding:4px 10px;border-radius:9999px;border:1px solid;background:transparent}.health-score-body{display:flex;align-items:center;gap:24px}.health-score-gauge{position:relative;flex-shrink:0}.health-score-value{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;flex-direction:column}.health-score-number{font-size:2.25rem;font-weight:700;line-height:1;font-feature-settings:"tnum" on,"lnum" on}.health-score-max{font-size:.8rem;color:var(--text-muted);margin-top:2px}.health-score-breakdown{flex:1;display:flex;flex-direction:column;gap:12px}.health-breakdown-item{display:flex;flex-direction:column;gap:4px}.health-breakdown-header{display:flex;justify-content:space-between;align-items:center}.health-breakdown-label{font-size:.8rem;color:var(--text-secondary);font-weight:500}.health-breakdown-weight{font-size:.7rem;color:var(--text-muted)}.health-breakdown-bar-bg{height:6px;background:var(--border, #1e293b);border-radius:3px;overflow:hidden}.health-breakdown-bar-fill{height:100%;border-radius:3px;transition:width .6s ease}.health-breakdown-value{font-size:.75rem;font-weight:600;color:var(--text-primary);font-feature-settings:"tnum" on,"lnum" on}.health-breakdown-detail{color:var(--text-muted);font-weight:400}.cashflow-card{background:var(--bg-card, #121826);border:1px solid var(--border, #1e293b);border-radius:var(--radius-card, 12px);padding:20px;height:100%;display:flex;flex-direction:column;transition:box-shadow var(--transition-normal, .2s ease),transform var(--transition-normal, .2s ease)}.cashflow-card:hover{box-shadow:0 6px 16px #00000059;transform:translateY(-1px)}.cashflow-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}.cashflow-title{font-size:1rem;font-weight:600;color:var(--text-primary);letter-spacing:var(--tracking-tight, -.01em)}.cashflow-subtitle{font-size:.8rem;color:var(--text-muted);margin-top:2px}.cashflow-empty{text-align:center;padding:3rem 1rem;color:var(--text-muted);font-size:.9rem}.cashflow-projection{text-align:right;display:flex;flex-direction:column;gap:2px}.cashflow-proj-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.cashflow-proj-value{font-size:1rem;font-weight:700;font-feature-settings:"tnum" on,"lnum" on}.cashflow-chart{margin:0 -8px}.cashflow-card .recharts-tooltip-cursor{stroke:#ffffff14}.heatmap-card{background:var(--bg-card, #121826);border:1px solid var(--border, #1e293b);border-radius:var(--radius-card, 12px);padding:20px;transition:box-shadow var(--transition-normal, .2s ease),transform var(--transition-normal, .2s ease)}.heatmap-card:hover{box-shadow:0 6px 16px #00000059;transform:translateY(-1px)}.heatmap-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.heatmap-title{font-size:1rem;font-weight:600;color:var(--text-primary);letter-spacing:var(--tracking-tight, -.01em)}.heatmap-legend{display:flex;align-items:center;gap:3px}.heatmap-legend-label{font-size:.65rem;color:var(--text-muted);margin:0 4px}.heatmap-legend-cell{border-radius:2px}.heatmap-scroll{overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}.heatmap-scroll::-webkit-scrollbar{height:4px}.heatmap-scroll::-webkit-scrollbar-track{background:transparent}.heatmap-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.heatmap-tooltip{background:var(--bg-elevated, #1a2035);border:1px solid var(--border, #1e293b);border-radius:8px;padding:8px 12px;box-shadow:var(--shadow-md);pointer-events:none;z-index:1100;white-space:nowrap}.heatmap-tooltip-date{font-size:.75rem;color:var(--text-secondary);margin-bottom:2px}.heatmap-tooltip-count{font-size:.8rem;font-weight:600;color:var(--text-primary)}.heatmap-tooltip-net{font-size:.75rem;font-weight:600;font-feature-settings:"tnum" on,"lnum" on;margin-top:1px}.dashboard-cashflow-row{display:grid;grid-template-columns:1fr 340px;gap:var(--gap-desktop, 16px)}.dashboard-heatmap-row{display:grid;grid-template-columns:1fr;gap:var(--gap-desktop, 16px)}@media(max-width:1024px){.dashboard-cashflow-row{grid-template-columns:1fr 300px}}@media(max-width:768px){.dashboard-cashflow-row{grid-template-columns:1fr}.health-score-body{flex-direction:column;align-items:center;text-align:center}.health-score-breakdown{width:100%}.cashflow-header{flex-direction:column;gap:8px}.cashflow-projection{text-align:left;flex-direction:row;align-items:center;gap:8px}}@media(max-width:480px){.health-score-gauge svg{width:120px;height:120px}.health-score-number{font-size:1.75rem}.health-score-card,.cashflow-card,.heatmap-card{padding:14px}}.txn-container{display:flex;flex-direction:column;gap:0;min-height:0;flex:1}.txn-header{position:sticky;top:0;z-index:var(--z-sticky);background:var(--txn-bg-panel);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--txn-border);padding:20px 24px 16px;display:flex;flex-direction:column;gap:16px}.txn-header-top{display:flex;align-items:center;justify-content:space-between;gap:16px}.txn-header-title{display:flex;align-items:center;gap:10px}.txn-header-title h2{margin:0;font-size:1.35rem;font-weight:700;color:var(--txn-text-primary);letter-spacing:-.01em}.txn-header-count{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:24px;padding:0 8px;border-radius:var(--radius-full);background:var(--txn-info);color:#fff;font-size:.75rem;font-weight:600}.txn-header-actions{display:flex;gap:8px}.txn-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius-sm);font-size:.8125rem;font-weight:600;border:none;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.txn-btn--primary{background:var(--txn-info);color:#fff}.txn-btn--primary:hover{background:#4a90e8;box-shadow:0 0 16px #60a5fa4d}.txn-btn--ghost{background:transparent;color:var(--txn-text-secondary);border:1px solid transparent}.txn-btn--ghost:hover{background:#ffffff0d;color:var(--txn-text-primary)}.txn-btn--outline{background:transparent;color:var(--txn-text-secondary);border:1px solid var(--txn-border)}.txn-btn--outline:hover{border-color:var(--txn-text-muted);color:var(--txn-text-primary)}.txn-btn--danger{background:#ef44441f;color:var(--txn-danger);border:1px solid rgba(239,68,68,.25)}.txn-btn--danger:hover{background:#ef444433}.txn-segmented{display:flex;position:relative;background:#ffffff0a;border-radius:var(--radius-sm);padding:3px;gap:2px}.txn-segmented-indicator{position:absolute;top:3px;left:3px;width:calc(33.333% - 2px);height:calc(100% - 6px);background:var(--txn-info);border-radius:6px;transition:transform var(--transition-normal);z-index:0}.txn-segmented-tab{flex:1;position:relative;z-index:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;border:none;background:none;color:var(--txn-text-muted);font-size:.8125rem;font-weight:600;cursor:pointer;border-radius:6px;transition:color var(--transition-fast)}.txn-segmented-tab--active{color:#fff}.txn-segmented-tab:not(.txn-segmented-tab--active):hover{color:var(--txn-text-secondary)}.txn-segmented-count{font-size:.6875rem;padding:1px 6px;border-radius:var(--radius-full);background:#ffffff1a}.txn-segmented-tab--active .txn-segmented-count{background:#fff3}.txn-header-filters{display:flex;align-items:center;gap:12px}.txn-search-wrapper{flex:1;position:relative;display:flex;align-items:center}.txn-search-icon{position:absolute;left:12px;color:var(--txn-text-muted);pointer-events:none}.txn-search-input{width:100%;padding:9px 12px 9px 36px;border:1px solid var(--txn-border);border-radius:var(--radius-sm);background:#ffffff08;color:var(--txn-text-primary);font-size:.8125rem;transition:border-color var(--transition-fast);outline:none}.txn-search-input::placeholder{color:var(--txn-text-muted)}.txn-search-input:focus{border-color:var(--txn-info);box-shadow:0 0 0 3px #60a5fa26}.txn-filter-group{display:flex;gap:8px}.txn-header-chips{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.txn-filter-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 8px 4px 10px;border-radius:var(--radius-full);background:#60a5fa1f;border:1px solid rgba(96,165,250,.25);font-size:.75rem;color:var(--txn-info)}.txn-filter-chip-label{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.txn-filter-chip-remove{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border:none;background:none;color:var(--txn-info);cursor:pointer;border-radius:var(--radius-full);transition:background var(--transition-fast)}.txn-filter-chip-remove:hover{background:#60a5fa33}.txn-chips-clear{border:none;background:none;color:var(--txn-text-muted);font-size:.75rem;cursor:pointer;text-decoration:underline;padding:4px}.txn-chips-clear:hover{color:var(--txn-text-secondary)}.txn-filter-dropdown{position:absolute;top:calc(100% + 6px);left:0;z-index:var(--z-dropdown);min-width:220px;background:var(--txn-bg-card);border:1px solid var(--txn-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:12px;animation:txn-dropdown-in .15s ease}.txn-filter-dropdown--right{left:auto;right:0}@keyframes txn-dropdown-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.txn-category-dropdown{max-height:280px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.txn-category-dropdown-title,.txn-date-dropdown-title{font-size:.75rem;font-weight:600;color:var(--txn-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.txn-category-option{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;cursor:pointer;font-size:.8125rem;color:var(--txn-text-secondary);transition:background var(--transition-fast)}.txn-category-option:hover{background:#ffffff0d}.txn-category-option input[type=checkbox]{accent-color:var(--txn-info)}.txn-date-dropdown{display:flex;flex-direction:column;gap:10px}.txn-date-label{display:flex;flex-direction:column;gap:4px;font-size:.75rem;color:var(--txn-text-muted)}.txn-date-input{padding:7px 10px;border:1px solid var(--txn-border);border-radius:6px;background:#ffffff08;color:var(--txn-text-primary);font-size:.8125rem;outline:none}.txn-date-input:focus{border-color:var(--txn-info)}.txn-date-apply{margin-top:4px}.txn-grid-header{display:grid;grid-template-columns:40px 180px 1fr 140px 160px 80px;align-items:center;padding:0 24px;height:36px;border-bottom:1px solid var(--txn-border);background:var(--txn-bg-panel)}.txn-col-account{display:none}.txn-col-header{font-size:.6875rem;font-weight:600;color:var(--txn-text-muted);text-transform:uppercase;letter-spacing:.05em}.txn-col-amount{text-align:right}.txn-scroll-container{flex:1;overflow-y:auto;min-height:300px;max-height:calc(100vh - 360px)}.txn-row{display:grid;grid-template-columns:40px 180px 1fr 140px 160px 80px;align-items:center;padding:0 24px;height:var(--txn-row-height);border-bottom:1px solid rgba(35,48,68,.4);transition:background var(--transition-fast);cursor:default}.txn-row:hover{background:#ffffff05}.txn-row--selected{background:#60a5fa0f!important;border-left:2px solid var(--txn-info)}.txn-row--focused{background:#60a5fa0a;outline:1px solid rgba(96,165,250,.2);outline-offset:-1px}.txn-row-check{display:flex;align-items:center;justify-content:center}.txn-checkbox{width:16px;height:16px;accent-color:var(--txn-info);cursor:pointer}.txn-row-category{display:flex;align-items:center;gap:8px;overflow:hidden;cursor:pointer}.txn-row-category-icon{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;font-size:.875rem;flex-shrink:0}.txn-row-category-label{font-size:.8125rem;font-weight:500;color:var(--txn-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.txn-row-description{font-size:.8125rem;color:var(--txn-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-right:12px}.txn-inline-editable{cursor:text;border-bottom:1px dashed transparent;transition:border-color var(--transition-fast)}.txn-inline-editable:hover{border-color:var(--txn-text-muted)}.txn-row-account{display:none}.txn-row-date{font-size:.8125rem;color:var(--txn-text-muted)}.txn-row-amount{font-size:.875rem;font-weight:600;text-align:right;font-feature-settings:"tnum" on,"lnum" on}.txn-amount-positive{color:var(--txn-positive)}.txn-amount-negative{color:var(--txn-negative)}.txn-row-actions{display:flex;align-items:center;justify-content:flex-end;gap:2px;opacity:0;transition:opacity var(--transition-fast)}.txn-row:hover .txn-row-actions{opacity:1}.txn-action-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:none;color:var(--txn-text-muted);border-radius:6px;cursor:pointer;transition:all var(--transition-fast)}.txn-action-btn:hover{background:#ffffff14;color:var(--txn-text-primary)}.txn-action-btn--danger:hover{background:#ef44441f;color:var(--txn-danger)}.txn-badge-recurring{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;border-radius:var(--radius-full);background:#a855f71f;color:var(--txn-recurring);font-size:.6875rem;font-weight:600;flex-shrink:0}.txn-badge-receipt{font-size:.75rem;flex-shrink:0;opacity:.7}.txn-inline-edit{width:100%;padding:4px 8px;border:1px solid var(--txn-info);border-radius:6px;background:#60a5fa0f;color:var(--txn-text-primary);font-size:.8125rem;outline:none;box-shadow:0 0 0 3px #60a5fa26}.txn-bulk-bar{position:sticky;bottom:0;z-index:var(--z-sticky);display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:var(--txn-bg-card);border-top:1px solid var(--txn-border);box-shadow:0 -4px 20px #0000004d;animation:txn-slide-up .2s ease}@keyframes txn-slide-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.txn-bulk-count{font-size:.875rem;font-weight:600;color:var(--txn-text-primary)}.txn-bulk-actions{display:flex;gap:8px}.txn-bulk-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:var(--radius-sm);font-size:.8125rem;font-weight:500;border:1px solid var(--txn-border);background:transparent;color:var(--txn-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.txn-bulk-btn:hover{border-color:var(--txn-text-muted);color:var(--txn-text-primary);background:#ffffff0a}.txn-bulk-btn--danger{border-color:#ef444440;color:var(--txn-danger)}.txn-bulk-btn--danger:hover{background:#ef44441a;border-color:#ef444466}.txn-drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal-backdrop);background:#00000080;animation:txn-fade-in .2s ease}@keyframes txn-fade-in{0%{opacity:0}to{opacity:1}}.txn-drawer{position:fixed;top:0;right:0;bottom:0;width:var(--txn-drawer-width);z-index:var(--z-modal);background:var(--txn-bg-panel);border-left:1px solid var(--txn-border);box-shadow:var(--shadow-xl);transform:translate(100%);transition:transform var(--transition-slow);display:flex;flex-direction:column;overflow:hidden}.txn-drawer--open{transform:translate(0)}.txn-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--txn-border);flex-shrink:0}.txn-drawer-title{margin:0;font-size:1.05rem;font-weight:700;color:var(--txn-text-primary)}.txn-drawer-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:none;color:var(--txn-text-muted);border-radius:8px;cursor:pointer;transition:all var(--transition-fast)}.txn-drawer-close:hover{background:#ffffff14;color:var(--txn-text-primary)}.txn-drawer-body{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:20px}.txn-drawer-amount{font-size:2rem;font-weight:700;text-align:center;padding:16px 0;font-feature-settings:"tnum" on,"lnum" on}.txn-drawer-field{display:flex;flex-direction:column;gap:4px}.txn-drawer-label{font-size:.6875rem;font-weight:600;color:var(--txn-text-muted);text-transform:uppercase;letter-spacing:.05em}.txn-drawer-value{display:flex;align-items:center;gap:8px;font-size:.9rem;color:var(--txn-text-primary)}.txn-drawer-type-badge{display:inline-flex;padding:3px 10px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.txn-drawer-type-badge.income{background:#2dd4bf1f;color:var(--txn-positive)}.txn-drawer-type-badge.expense{background:#f871711f;color:var(--txn-negative)}.txn-drawer-receipt-thumb{margin-top:8px;max-width:100%;max-height:180px;border-radius:8px;border:1px solid var(--txn-border);cursor:pointer;object-fit:cover;transition:opacity .15s}.txn-drawer-receipt-thumb:hover{opacity:.85}.txn-drawer-receipt-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#000c;display:flex;align-items:center;justify-content:center;cursor:zoom-out;padding:24px}.txn-drawer-receipt-full{max-width:90vw;max-height:90vh;border-radius:8px;object-fit:contain}.txn-drawer-footer{display:flex;flex-direction:column;gap:8px;padding:20px 24px;border-top:1px solid var(--txn-border);flex-shrink:0}.txn-skeleton-container{display:flex;flex-direction:column}.txn-skeleton-row{display:grid;grid-template-columns:40px 160px 1fr 120px 120px 140px 80px;align-items:center;padding:0 24px;height:var(--txn-row-height);border-bottom:1px solid rgba(35,48,68,.4)}.txn-skeleton-cell{height:14px;border-radius:6px;background:linear-gradient(90deg,#ffffff0a 25%,#ffffff14,#ffffff0a 75%);background-size:200% 100%;animation:txn-pulse 1.5s ease-in-out infinite}@keyframes txn-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.txn-skeleton-check{width:16px;height:16px}.txn-skeleton-category{width:80%}.txn-skeleton-description{width:70%}.txn-skeleton-account{width:60%}.txn-skeleton-date{width:70%}.txn-skeleton-amount{width:80px;margin-left:auto}.txn-skeleton-actions{width:50px;margin-left:auto}.txn-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 24px;text-align:center}.txn-empty-icon{color:var(--txn-text-muted);margin-bottom:16px;opacity:.5}.txn-empty-title{margin:0 0 8px;font-size:1.1rem;font-weight:600;color:var(--txn-text-primary)}.txn-empty-text{margin:0 0 24px;font-size:.875rem;color:var(--txn-text-muted);max-width:320px}.txn-empty-cta{padding:10px 20px;border:none;border-radius:var(--radius-sm);background:var(--txn-info);color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.txn-empty-cta:hover{background:#4a90e8;box-shadow:0 0 16px #60a5fa4d}.txn-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 24px;text-align:center}.txn-error-icon{color:var(--txn-danger);margin-bottom:16px}.txn-error-title{margin:0 0 8px;font-size:1.1rem;font-weight:600;color:var(--txn-text-primary)}.txn-error-text{margin:0 0 24px;font-size:.875rem;color:var(--txn-text-muted);max-width:320px}.txn-error-retry{padding:10px 20px;border:1px solid var(--txn-border);border-radius:var(--radius-sm);background:transparent;color:var(--txn-text-primary);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.txn-error-retry:hover{border-color:var(--txn-text-muted);background:#ffffff0a}.toast-action{padding:4px 10px;border:1px solid rgba(255,255,255,.2);border-radius:6px;background:#ffffff1a;color:#fff;font-size:.75rem;font-weight:600;cursor:pointer;transition:background var(--transition-fast);white-space:nowrap}.toast-action:hover{background:#fff3}.txn-row:focus-visible,.txn-btn:focus-visible,.txn-segmented-tab:focus-visible,.txn-action-btn:focus-visible{outline:2px solid var(--txn-info);outline-offset:-2px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media(max-width:768px){.txn-header{padding:16px}.txn-header-top{flex-wrap:wrap}.txn-header-filters{flex-direction:column}.txn-filter-group{width:100%;justify-content:stretch}.txn-filter-group .txn-btn--outline{flex:1}.txn-grid-header,.txn-row{grid-template-columns:36px 130px 1fr 80px 110px 60px;padding:0 16px}.txn-scroll-container{max-height:calc(100vh - 300px)}.txn-drawer{width:100%}.txn-bulk-bar{padding:12px 16px}.txn-bulk-actions{flex-wrap:wrap;gap:6px}.txn-bulk-btn span{display:none}}@media(max-width:480px){.txn-grid-header{grid-template-columns:36px 1fr 100px 50px;padding:0 12px}.txn-col-account,.txn-col-date,.txn-col-header:nth-child(3){display:none}.txn-row{grid-template-columns:36px 1fr 100px 50px;padding:0 12px}.txn-row-account,.txn-row-date,.txn-row-description{display:none}}.rec-container{padding:var(--spacing-xl);max-width:var(--content-max-width);margin:0 auto;display:flex;flex-direction:column;gap:var(--spacing-lg)}.rec-top-bar{display:flex;align-items:center;justify-content:space-between}.rec-title{font-size:1.5rem;font-weight:700;color:var(--rec-text-primary);margin:0}.rec-add-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--accent-green);color:var(--text-inverse);border:none;border-radius:var(--radius-sm);font-size:.8125rem;font-weight:600;cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast)}.rec-add-btn:hover{background:var(--accent-green-light);transform:translateY(-1px)}.rec-header{display:flex;flex-direction:column;gap:var(--spacing-md)}.rec-header-top{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md)}.rec-period-selector{display:flex;gap:2px;background:var(--rec-bg-panel);border-radius:var(--radius-sm);padding:2px;border:1px solid var(--rec-border)}.rec-period-btn{padding:6px 14px;border:none;background:transparent;color:var(--rec-text-secondary);font-size:.8125rem;font-weight:500;border-radius:6px;cursor:pointer;transition:all var(--transition-fast)}.rec-period-btn--active{background:var(--accent-green);color:var(--text-inverse)}.rec-period-btn:hover:not(.rec-period-btn--active){color:var(--rec-text-primary);background:var(--bg-hover)}.rec-header-badge{display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.rec-header-badge--positive{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}.rec-header-badge--negative{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border)}.rec-kpi-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}.rec-kpi-card{background:var(--rec-bg-card);border:1px solid var(--rec-border);border-radius:var(--radius-card);padding:var(--spacing-lg);display:flex;flex-direction:column;gap:4px}.rec-kpi-label{font-size:.75rem;color:var(--rec-text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:500}.rec-kpi-value{display:flex;align-items:center;gap:6px;font-size:1.25rem;font-weight:700;font-feature-settings:var(--font-feature-tabular)}.rec-kpi-value--income{color:var(--rec-success)}.rec-kpi-value--expense{color:var(--rec-danger)}.rec-kpi-sub{font-size:.6875rem;color:var(--rec-text-muted)}.rec-header-info{display:flex;align-items:center;gap:var(--spacing-xl);flex-wrap:wrap}.rec-header-next,.rec-header-savings{display:flex;align-items:center;gap:6px;font-size:.8125rem;color:var(--rec-text-secondary)}.rec-header-next strong,.rec-header-savings strong{color:var(--rec-text-primary)}.rec-search-bar{display:flex;flex-direction:column;gap:var(--spacing-sm)}.rec-search-input-wrap{position:relative;display:flex;align-items:center}.rec-search-icon{position:absolute;left:12px;color:var(--rec-text-muted);pointer-events:none}.rec-search-input{width:100%;padding:10px 12px 10px 36px;background:var(--rec-bg-panel);border:1px solid var(--rec-border);border-radius:var(--radius-sm);color:var(--rec-text-primary);font-size:.875rem;outline:none;transition:border-color var(--transition-fast)}.rec-search-input::placeholder{color:var(--rec-text-muted)}.rec-search-input:focus{border-color:var(--accent-blue)}.rec-search-clear{position:absolute;right:40px;background:none;border:none;color:var(--rec-text-muted);cursor:pointer;padding:4px;display:flex}.rec-search-clear:hover{color:var(--rec-text-primary)}.rec-filter-count{position:absolute;right:10px;background:var(--accent-blue);color:#fff;font-size:.625rem;font-weight:700;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center}.rec-quick-filters{display:flex;gap:6px;flex-wrap:wrap}.rec-quick-chip{display:flex;align-items:center;gap:4px;padding:5px 10px;background:var(--rec-bg-panel);border:1px solid var(--rec-border);border-radius:var(--radius-full);font-size:.75rem;color:var(--rec-text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.rec-quick-chip:hover{border-color:var(--accent-blue);color:var(--rec-text-primary)}.rec-quick-chip--active{background:var(--info-bg);border-color:var(--info-border);color:var(--rec-info)}.rec-quick-chip-count{font-size:.625rem;font-weight:700;background:#ffffff14;padding:1px 5px;border-radius:var(--radius-full)}.rec-quick-chip--active .rec-quick-chip-count{background:#60a5fa33}.rec-active-filters{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.rec-filter-chip{display:flex;align-items:center;gap:4px;padding:3px 8px;background:var(--info-bg);border:1px solid var(--info-border);border-radius:var(--radius-full);font-size:.6875rem;color:var(--rec-info)}.rec-filter-chip button{background:none;border:none;color:inherit;cursor:pointer;padding:0;display:flex;opacity:.7}.rec-filter-chip button:hover{opacity:1}.rec-filter-reset{background:none;border:none;color:var(--rec-text-muted);font-size:.6875rem;cursor:pointer;text-decoration:underline}.rec-filter-reset:hover{color:var(--rec-text-secondary)}.rec-sort-bar{display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-xs)}.rec-sort-label{font-size:.75rem;color:var(--rec-text-muted);font-weight:500}.rec-sort-controls{display:flex;align-items:center;gap:4px}.rec-sort-select{padding:4px 8px;background:var(--rec-bg-panel);border:1px solid var(--rec-border);border-radius:6px;color:var(--rec-text-secondary);font-size:.75rem;outline:none;cursor:pointer}.rec-sort-select:focus{border-color:var(--accent-blue)}.rec-sort-dir{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--rec-bg-panel);border:1px solid var(--rec-border);border-radius:6px;color:var(--rec-text-secondary);font-size:.8125rem;cursor:pointer;transition:all var(--transition-fast)}.rec-sort-dir:hover{border-color:var(--accent-blue);color:var(--rec-text-primary)}.rec-main{display:flex;gap:0;position:relative;transition:all var(--transition-normal)}.rec-list-area{flex:1;min-width:0}.rec-list-scroll{border:1px solid var(--rec-border);border-radius:var(--radius-card);overflow:auto}.rec-row{display:grid;grid-template-columns:36px 36px 1fr auto auto auto auto var(--rec-toggle-width) auto;align-items:center;gap:8px;padding:0 12px;height:var(--rec-row-height);border-bottom:1px solid var(--rec-border);cursor:pointer;transition:background var(--transition-fast);position:relative}.rec-row:hover{background:var(--bg-hover)}.rec-row--paused{opacity:.55}.rec-row--selected{background:var(--info-bg)}.rec-row--focused{outline:2px solid var(--accent-blue);outline-offset:-2px;border-radius:4px}.rec-row:last-child{border-bottom:none}.rec-row-check{display:flex;align-items:center;justify-content:center}.rec-checkbox{width:18px;height:18px;border:2px solid var(--rec-border);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:.625rem;color:#fff;transition:all var(--transition-fast);cursor:pointer}.rec-checkbox:hover{border-color:var(--accent-blue)}.rec-checkbox--checked{background:var(--accent-blue);border-color:var(--accent-blue)}.rec-row-icon{font-size:1.25rem;display:flex;align-items:center;justify-content:center}.rec-row-info{display:flex;flex-direction:column;gap:1px;min-width:0}.rec-row-name{font-size:.875rem;font-weight:600;color:var(--rec-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rec-row-category{font-size:.6875rem;color:var(--rec-text-muted)}.rec-row-badges{display:flex;gap:4px}.rec-badge{padding:2px 6px;border-radius:var(--radius-full);font-size:.625rem;font-weight:700;white-space:nowrap}.rec-badge--increase{background:var(--rec-increase-bg);color:var(--rec-increase-text)}.rec-badge--soon{background:var(--warning-bg);color:var(--warning)}.rec-row-freq{display:flex;align-items:center}.rec-freq-badge{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.625rem;font-weight:700;background:var(--rec-badge-bg);color:var(--rec-badge-text)}.rec-row-date{font-size:.75rem;color:var(--rec-text-secondary);white-space:nowrap;font-feature-settings:var(--font-feature-tabular)}.rec-row-amount{text-align:right;display:flex;flex-direction:column;align-items:flex-end}.rec-row-amount-main{font-size:.875rem;font-weight:700;font-feature-settings:var(--font-feature-tabular)}.rec-row-amount--income .rec-row-amount-main{color:var(--rec-success)}.rec-row-amount--expense .rec-row-amount-main{color:var(--rec-danger)}.rec-row-amount-monthly{font-size:.625rem;color:var(--rec-text-muted)}.rec-row-toggle{display:flex;align-items:center;justify-content:center}.rec-toggle{width:var(--rec-toggle-width);height:var(--rec-toggle-height);background:var(--rec-border);border-radius:var(--radius-full);position:relative;cursor:pointer;transition:background var(--transition-fast)}.rec-toggle--active{background:var(--accent-green)}.rec-toggle-knob{width:16px;height:16px;background:#fff;border-radius:50%;position:absolute;top:3px;left:3px;transition:transform var(--transition-fast);box-shadow:0 1px 3px #0000004d}.rec-toggle--active .rec-toggle-knob{transform:translate(22px)}.rec-row-actions{display:flex;gap:2px;opacity:0;transition:opacity var(--transition-fast)}.rec-row:hover .rec-row-actions{opacity:1}.rec-action-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--rec-text-muted);border-radius:6px;cursor:pointer;transition:all var(--transition-fast)}.rec-action-btn:hover{background:var(--bg-hover);color:var(--rec-text-primary)}.rec-action-btn--danger:hover{color:var(--rec-danger);background:var(--danger-bg)}.rec-drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:var(--z-modal-backdrop);animation:rec-fade-in .2s ease}.rec-drawer{position:fixed;top:0;right:0;width:var(--rec-drawer-width);height:100vh;background:var(--rec-bg-panel);border-left:1px solid var(--rec-border);z-index:var(--z-modal);transform:translate(100%);transition:transform var(--transition-slow);overflow-y:auto;display:flex;flex-direction:column}.rec-drawer--open{transform:translate(0)}@keyframes rec-fade-in{0%{opacity:0}to{opacity:1}}.rec-drawer-header{padding:var(--spacing-lg);border-bottom:1px solid var(--rec-border);position:sticky;top:0;background:var(--rec-bg-panel);z-index:1}.rec-drawer-close{position:absolute;top:12px;right:12px;background:none;border:none;color:var(--rec-text-muted);cursor:pointer;padding:4px;border-radius:6px;display:flex}.rec-drawer-close:hover{color:var(--rec-text-primary);background:var(--bg-hover)}.rec-drawer-title-row{display:flex;align-items:center;gap:var(--spacing-md);margin-top:4px}.rec-drawer-icon{font-size:2rem}.rec-drawer-title{margin:0;font-size:1.125rem;color:var(--rec-text-primary)}.rec-drawer-subtitle{font-size:.8125rem;color:var(--rec-text-muted)}.rec-drawer-hero{padding:var(--spacing-xl) var(--spacing-lg);text-align:center;border-bottom:1px solid var(--rec-border)}.rec-drawer-amount{font-size:2rem;font-weight:800;font-feature-settings:var(--font-feature-tabular)}.rec-drawer-amount--income{color:var(--rec-success)}.rec-drawer-amount--expense{color:var(--rec-danger)}.rec-drawer-monthly{font-size:.8125rem;color:var(--rec-text-muted);margin-top:2px}.rec-drawer-price-change{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;margin-top:8px}.rec-drawer-price-change--up{background:var(--rec-increase-bg);color:var(--rec-increase-text)}.rec-drawer-price-change--down{background:var(--success-bg);color:var(--success)}.rec-drawer-field{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--rec-border)}.rec-drawer-field-label{display:block;font-size:.6875rem;color:var(--rec-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}.rec-drawer-field-value{display:flex;align-items:center;gap:6px;font-size:.875rem;color:var(--rec-text-primary)}.rec-drawer-status-row{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--rec-text-primary)}.rec-drawer-status-row .rec-toggle{margin-left:auto}.rec-status-dot{width:8px;height:8px;border-radius:50%}.rec-status-dot--active{background:var(--rec-success)}.rec-status-dot--paused{background:var(--rec-text-muted)}.rec-drawer-days-badge{padding:1px 6px;background:var(--warning-bg);color:var(--warning);font-size:.6875rem;font-weight:600;border-radius:var(--radius-full)}.rec-drawer-details{border-bottom:none}.rec-drawer-section{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--rec-border)}.rec-drawer-section-title{display:flex;align-items:center;gap:6px;font-size:.8125rem;font-weight:600;color:var(--rec-text-secondary);margin:0 0 var(--spacing-sm) 0}.rec-drawer-timeline{display:flex;flex-direction:column;gap:4px}.rec-drawer-timeline-item{display:flex;justify-content:space-between;padding:4px 8px;font-size:.8125rem;color:var(--rec-text-secondary);border-radius:4px}.rec-drawer-timeline-item--current{background:var(--info-bg);color:var(--rec-info);font-weight:600}.rec-drawer-timeline-date{color:var(--rec-text-muted)}.rec-drawer-timeline-amount{font-feature-settings:var(--font-feature-tabular)}.rec-drawer-tags{display:flex;flex-wrap:wrap;gap:6px}.rec-drawer-tag{display:flex;align-items:center;gap:4px;padding:3px 8px;background:var(--rec-badge-bg);color:var(--rec-badge-text);border-radius:var(--radius-full);font-size:.75rem}.rec-drawer-tag button{background:none;border:none;color:inherit;cursor:pointer;padding:0;display:flex;opacity:.6}.rec-drawer-tag button:hover{opacity:1}.rec-drawer-tag-input input{background:transparent;border:1px dashed var(--rec-border);border-radius:var(--radius-full);padding:3px 8px;font-size:.75rem;color:var(--rec-text-primary);outline:none;width:80px}.rec-drawer-tag-input input::placeholder{color:var(--rec-text-muted)}.rec-drawer-tag-input input:focus{border-color:var(--accent-blue)}.rec-drawer-notes{width:100%;padding:8px;background:var(--rec-bg-card);border:1px solid var(--rec-border);border-radius:var(--radius-sm);color:var(--rec-text-primary);font-size:.8125rem;font-family:inherit;resize:vertical;outline:none}.rec-drawer-notes::placeholder{color:var(--rec-text-muted)}.rec-drawer-notes:focus{border-color:var(--accent-blue)}.rec-drawer-charges{max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.rec-drawer-charge-row{display:flex;justify-content:space-between;padding:4px 8px;font-size:.8125rem;border-radius:4px}.rec-drawer-charge-row:nth-child(odd){background:#ffffff05}.rec-drawer-charge-date{color:var(--rec-text-muted)}.rec-drawer-charge-amount{font-feature-settings:var(--font-feature-tabular)}.rec-text-income{color:var(--rec-success)}.rec-text-expense{color:var(--rec-danger)}.rec-drawer-footer{padding:var(--spacing-lg);border-top:1px solid var(--rec-border);display:flex;gap:8px;margin-top:auto;position:sticky;bottom:0;background:var(--rec-bg-panel)}.rec-drawer-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;background:var(--rec-bg-card);border:1px solid var(--rec-border);border-radius:var(--radius-sm);color:var(--rec-text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.rec-drawer-btn:hover{background:var(--bg-hover);color:var(--rec-text-primary)}.rec-drawer-btn--danger:hover{color:var(--rec-danger);border-color:var(--danger-border);background:var(--danger-bg)}.rec-bulk-bar{position:fixed;bottom:16px;left:50%;transform:translate(-50%);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-xl);padding:12px 20px;background:var(--bg-elevated);border:1px solid var(--rec-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:var(--z-sticky);min-width:500px;max-width:90vw;animation:rec-slide-up .2s ease}@keyframes rec-slide-up{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.rec-bulk-left{display:flex;flex-direction:column;gap:2px}.rec-bulk-count{font-size:.8125rem;font-weight:600;color:var(--rec-text-primary)}.rec-bulk-savings{font-size:.6875rem;color:var(--rec-success)}.rec-bulk-actions{display:flex;gap:6px}.rec-bulk-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;background:var(--rec-bg-card);border:1px solid var(--rec-border);border-radius:var(--radius-sm);color:var(--rec-text-secondary);font-size:.75rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.rec-bulk-btn:hover{background:var(--bg-hover);color:var(--rec-text-primary)}.rec-bulk-btn--danger:hover{color:var(--rec-danger);border-color:var(--danger-border);background:var(--danger-bg)}.rec-bulk-btn--muted{border-color:transparent}.rec-bulk-btn--muted:hover{background:var(--bg-hover)}.rec-calendar{background:var(--rec-bg-card);border:1px solid var(--rec-border);border-radius:var(--radius-card);overflow:hidden}.rec-calendar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);cursor:pointer;transition:background var(--transition-fast)}.rec-calendar-header:hover{background:var(--bg-hover)}.rec-calendar-title{font-size:.9375rem;font-weight:600;color:var(--rec-text-primary);margin:0}.rec-calendar-body{padding:0 var(--spacing-lg) var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-lg)}.rec-calendar-nav{display:flex;align-items:center;justify-content:space-between}.rec-calendar-nav button{background:none;border:none;color:var(--rec-text-muted);cursor:pointer;padding:4px;border-radius:6px;display:flex}.rec-calendar-nav button:hover{color:var(--rec-text-primary);background:var(--bg-hover)}.rec-calendar-month{font-size:.875rem;font-weight:600;color:var(--rec-text-primary);text-transform:capitalize}.rec-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.rec-calendar-dayname{text-align:center;font-size:.625rem;font-weight:600;color:var(--rec-text-muted);padding:4px 0;text-transform:uppercase}.rec-calendar-cell{position:relative;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;border-radius:6px;transition:background var(--transition-fast)}.rec-calendar-cell--empty{visibility:hidden}.rec-calendar-cell--today{background:var(--bg-hover)}.rec-calendar-cell--today .rec-calendar-day{color:var(--accent-blue);font-weight:700}.rec-calendar-cell--has-charge{cursor:pointer}.rec-calendar-cell--has-charge:hover{background:var(--bg-hover)}.rec-calendar-day{font-size:.6875rem;color:var(--rec-text-secondary)}.rec-calendar-dots{display:flex;gap:2px}.rec-calendar-dot{width:var(--rec-calendar-dot);height:var(--rec-calendar-dot);border-radius:50%}.rec-calendar-dot--income{background:var(--rec-success)}.rec-calendar-dot--expense{background:var(--rec-danger)}.rec-calendar-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--bg-elevated);border:1px solid var(--rec-border);border-radius:var(--radius-sm);padding:8px;min-width:180px;z-index:var(--z-dropdown);box-shadow:var(--shadow-lg);pointer-events:none}.rec-calendar-tooltip-item{display:flex;justify-content:space-between;gap:12px;font-size:.75rem;padding:2px 0;white-space:nowrap}.rec-calendar-projection{border-top:1px solid var(--rec-border);padding-top:var(--spacing-md)}.rec-calendar-projection-title{font-size:.75rem;font-weight:600;color:var(--rec-text-muted);margin:0 0 var(--spacing-sm) 0;text-transform:uppercase;letter-spacing:.04em}.rec-calendar-bars{display:flex;gap:4px;align-items:flex-end;height:80px}.rec-calendar-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%}.rec-calendar-bar-wrap{flex:1;width:100%;display:flex;flex-direction:column;justify-content:flex-end;gap:1px}.rec-calendar-bar{width:100%;border-radius:2px;min-height:2px;transition:height var(--transition-normal)}.rec-calendar-bar--income{background:var(--rec-success);opacity:.7}.rec-calendar-bar--expense{background:var(--rec-danger);opacity:.7}.rec-calendar-bar-label{font-size:.5625rem;color:var(--rec-text-muted);text-transform:uppercase}.rec-health{background:var(--rec-bg-card);border:1px solid var(--rec-border);border-radius:var(--radius-card);overflow:hidden}.rec-health-header{display:flex;align-items:center;gap:8px;padding:var(--spacing-lg);color:var(--rec-text-secondary);border-bottom:1px solid var(--rec-border)}.rec-health-title{font-size:.9375rem;font-weight:600;color:var(--rec-text-primary);margin:0}.rec-health-body{padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-lg)}.rec-health-score{position:relative;width:120px;height:120px;margin:0 auto}.rec-health-ring{width:100%;height:100%}.rec-health-score-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.rec-health-score-number{font-size:1.75rem;font-weight:800;line-height:1}.rec-health-score-label{font-size:.6875rem;color:var(--rec-text-muted);margin-top:2px}.rec-health-alerts{display:flex;flex-direction:column;gap:6px}.rec-health-alert{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);font-size:.8125rem}.rec-health-alert--success{background:var(--success-bg);color:var(--rec-success)}.rec-health-alert--warning{background:var(--warning-bg);color:var(--warning)}.rec-health-dupes{border-top:1px solid var(--rec-border);padding-top:var(--spacing-md)}.rec-health-dupes-title{display:flex;align-items:center;gap:6px;font-size:.75rem;font-weight:600;color:var(--rec-text-muted);margin:0 0 var(--spacing-sm) 0}.rec-health-dupe-row{display:flex;align-items:center;gap:8px;font-size:.8125rem;color:var(--rec-text-secondary);padding:4px 0}.rec-health-dupe-vs{font-size:.625rem;color:var(--rec-text-muted);font-weight:600}.rec-skeleton{display:flex;flex-direction:column;gap:0}.rec-skeleton-row{display:grid;grid-template-columns:36px 36px 1fr auto auto auto auto;align-items:center;gap:8px;padding:0 12px;height:var(--rec-row-height);border-bottom:1px solid var(--rec-border)}.rec-skeleton-check,.rec-skeleton-icon,.rec-skeleton-badge,.rec-skeleton-toggle{border-radius:4px;animation:rec-shimmer 1.2s infinite ease-in-out}.rec-skeleton-check{width:18px;height:18px;background:var(--rec-border)}.rec-skeleton-icon{width:28px;height:28px;border-radius:50%;background:var(--rec-border)}.rec-skeleton-badge{width:48px;height:18px;background:var(--rec-border)}.rec-skeleton-toggle{width:var(--rec-toggle-width);height:var(--rec-toggle-height);background:var(--rec-border);border-radius:var(--radius-full)}.rec-skeleton-text{display:flex;flex-direction:column;gap:6px}.rec-skeleton-line{height:10px;background:var(--rec-border);border-radius:4px;animation:rec-shimmer 1.2s infinite ease-in-out}.rec-skeleton-line--name{width:140px;height:12px}.rec-skeleton-line--cat{width:80px}.rec-skeleton-line--date{width:60px}.rec-skeleton-line--amount{width:80px;height:12px}@keyframes rec-shimmer{0%,to{opacity:.4}50%{opacity:.15}}.rec-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl) var(--spacing-xl);text-align:center}.rec-empty-icon{color:var(--rec-text-muted);margin-bottom:var(--spacing-lg);opacity:.5}.rec-empty-title{font-size:1.125rem;font-weight:600;color:var(--rec-text-primary);margin:0 0 4px}.rec-empty-text{font-size:.875rem;color:var(--rec-text-muted);margin:0 0 var(--spacing-lg) 0;max-width:320px}.rec-empty-suggestions{display:flex;gap:8px;margin-bottom:var(--spacing-lg);flex-wrap:wrap;justify-content:center}.rec-empty-chip{padding:6px 12px;background:var(--rec-bg-card);border:1px solid var(--rec-border);border-radius:var(--radius-full);font-size:.8125rem;color:var(--rec-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.rec-empty-chip:hover{border-color:var(--accent-blue);color:var(--rec-text-primary)}.rec-empty-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--rec-bg-card);border:1px solid var(--rec-border);border-radius:var(--radius-sm);color:var(--rec-text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.rec-empty-btn:hover{background:var(--bg-hover);color:var(--rec-text-primary)}.rec-empty-btn--primary{background:var(--accent-green);border-color:var(--accent-green);color:var(--text-inverse)}.rec-empty-btn--primary:hover{background:var(--accent-green-light)}@media(max-width:768px){.rec-container{padding:var(--spacing-lg) var(--spacing-md);gap:var(--spacing-md)}.rec-kpi-strip{grid-template-columns:1fr}.rec-header-top{flex-direction:column;align-items:flex-start}.rec-header-info{flex-direction:column;gap:var(--spacing-sm)}.rec-row{grid-template-columns:30px 30px 1fr auto auto auto;gap:6px;padding:0 8px}.rec-row-badges,.rec-row-freq,.rec-row-actions,.rec-row-amount-monthly{display:none}.rec-drawer{width:100vw}.rec-bulk-bar{min-width:auto;width:calc(100vw - 32px);flex-direction:column;gap:var(--spacing-sm)}.rec-bulk-actions{flex-wrap:wrap;justify-content:center}.rec-calendar-grid{gap:1px}.rec-calendar-bars{height:60px}.rec-sort-bar{flex-direction:column;gap:var(--spacing-sm);align-items:flex-start}.rec-quick-filters{overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px}}.gl-container{padding:var(--spacing-xl);max-width:var(--content-max-width);margin:0 auto;display:flex;flex-direction:column;gap:var(--spacing-lg)}.gl-top-bar{display:flex;align-items:center;justify-content:space-between}.gl-title{font-size:1.5rem;font-weight:700;color:var(--goal-text-primary);margin:0}.gl-add-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--accent-green);color:var(--text-inverse);border:none;border-radius:var(--radius-sm);font-size:.8125rem;font-weight:600;cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast)}.gl-add-btn:hover{background:var(--accent-green-light);transform:translateY(-1px)}.gl-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md)}.gl-summary-card{background:var(--goal-bg-card);border:1px solid var(--goal-border);border-radius:var(--radius-card);padding:var(--spacing-lg);display:flex;flex-direction:column;gap:4px}.gl-summary-label{font-size:.6875rem;color:var(--goal-text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:500}.gl-summary-value{font-size:1.25rem;font-weight:700;color:var(--goal-text-primary);font-feature-settings:var(--font-feature-tabular)}.gl-summary-value--success{color:var(--goal-success)}.gl-filter-bar{display:flex;flex-direction:column;gap:var(--spacing-sm)}.gl-filter-row{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);flex-wrap:wrap}.gl-status-chips{display:flex;gap:4px}.gl-chip{display:flex;align-items:center;gap:4px;padding:5px 10px;background:var(--goal-bg-panel);border:1px solid var(--goal-border);border-radius:var(--radius-full);font-size:.75rem;color:var(--goal-text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.gl-chip:hover{border-color:var(--accent-blue);color:var(--goal-text-primary)}.gl-chip--active{background:var(--info-bg);border-color:var(--info-border);color:var(--goal-info)}.gl-chip-count{font-size:.625rem;font-weight:700;background:#ffffff14;padding:1px 5px;border-radius:var(--radius-full)}.gl-chip--active .gl-chip-count{background:#60a5fa33}.gl-period-chips{display:flex;gap:2px;background:var(--goal-bg-panel);border-radius:var(--radius-sm);padding:2px;border:1px solid var(--goal-border)}.gl-period-btn{padding:5px 12px;border:none;background:transparent;color:var(--goal-text-secondary);font-size:.75rem;font-weight:500;border-radius:6px;cursor:pointer;transition:all var(--transition-fast)}.gl-period-btn--active{background:var(--accent-green);color:var(--text-inverse)}.gl-period-btn:hover:not(.gl-period-btn--active){color:var(--goal-text-primary);background:var(--bg-hover)}.gl-toolbar{display:flex;align-items:center;gap:var(--spacing-sm)}.gl-search-wrap{flex:1;position:relative;display:flex;align-items:center}.gl-search-icon{position:absolute;left:10px;color:var(--goal-text-muted);pointer-events:none}.gl-search-input{width:100%;padding:8px 10px 8px 32px;background:var(--goal-bg-panel);border:1px solid var(--goal-border);border-radius:var(--radius-sm);color:var(--goal-text-primary);font-size:.8125rem;outline:none;transition:border-color var(--transition-fast)}.gl-search-input::placeholder{color:var(--goal-text-muted)}.gl-search-input:focus{border-color:var(--accent-blue)}.gl-search-clear{position:absolute;right:8px;background:none;border:none;color:var(--goal-text-muted);cursor:pointer;padding:2px;display:flex}.gl-search-clear:hover{color:var(--goal-text-primary)}.gl-sort-select{padding:8px 10px;background:var(--goal-bg-panel);border:1px solid var(--goal-border);border-radius:var(--radius-sm);color:var(--goal-text-secondary);font-size:.75rem;outline:none;cursor:pointer}.gl-sort-select:focus{border-color:var(--accent-blue)}.gl-view-toggle{display:flex;gap:0;background:var(--goal-bg-panel);border:1px solid var(--goal-border);border-radius:var(--radius-sm);overflow:hidden}.gl-view-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--goal-text-muted);cursor:pointer;transition:all var(--transition-fast)}.gl-view-btn:hover{color:var(--goal-text-primary);background:var(--bg-hover)}.gl-view-btn--active{background:var(--accent-blue);color:#fff}.gl-active-filters{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.gl-filter-tag{display:flex;align-items:center;gap:4px;padding:3px 8px;background:var(--info-bg);border:1px solid var(--info-border);border-radius:var(--radius-full);font-size:.6875rem;color:var(--goal-info)}.gl-filter-tag button{background:none;border:none;color:inherit;cursor:pointer;padding:0;display:flex;opacity:.7}.gl-filter-tag button:hover{opacity:1}.gl-filter-reset{background:none;border:none;color:var(--goal-text-muted);font-size:.6875rem;cursor:pointer;text-decoration:underline}.gl-filter-reset:hover{color:var(--goal-text-secondary)}.gl-count-label{font-size:.75rem;color:var(--goal-text-muted);font-weight:500;padding:0 var(--spacing-xs)}.gl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(var(--goal-card-min),1fr));gap:var(--spacing-lg)}.gl-card{background:var(--goal-bg-card);border:1px solid var(--goal-border);border-radius:var(--radius-card);padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md);border-left:4px solid var(--goal-accent, var(--goal-border));transition:transform var(--transition-fast),box-shadow var(--transition-fast);position:relative}.gl-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.gl-card--paused{opacity:.6;filter:grayscale(30%)}.gl-card--completed{border-left-color:var(--goal-success)!important}.gl-card--expired{border-left-color:var(--goal-danger)!important}.gl-card-header{display:flex;align-items:flex-start;gap:var(--spacing-sm)}.gl-card-icon{font-size:1.75rem;line-height:1}.gl-card-title-area{flex:1;min-width:0}.gl-card-name{font-size:1rem;font-weight:700;color:var(--goal-text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gl-card-status{font-size:.6875rem;font-weight:600}.gl-card-kebab{position:relative}.gl-kebab-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--goal-text-muted);border-radius:6px;cursor:pointer;transition:all var(--transition-fast)}.gl-kebab-btn:hover{background:var(--bg-hover);color:var(--goal-text-primary)}.gl-kebab-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99}.gl-kebab-menu{position:absolute;top:100%;right:0;background:var(--bg-elevated);border:1px solid var(--goal-border);border-radius:var(--radius-sm);padding:4px;min-width:140px;z-index:100;box-shadow:var(--shadow-lg)}.gl-kebab-menu button{display:flex;align-items:center;gap:8px;width:100%;padding:7px 10px;background:none;border:none;color:var(--goal-text-secondary);font-size:.8125rem;border-radius:4px;cursor:pointer;transition:background var(--transition-fast)}.gl-kebab-menu button:hover{background:var(--bg-hover);color:var(--goal-text-primary)}.gl-kebab-danger:hover{color:var(--goal-danger)!important;background:var(--danger-bg)!important}.gl-card-progress-wrap{width:100%}.gl-card-progress-bar{height:var(--goal-progress-height-lg);background:#ffffff0f;border-radius:var(--radius-full);overflow:hidden;cursor:help}.gl-card-progress-fill{height:100%;border-radius:var(--radius-full);transition:width .4s ease}.gl-card-amounts{display:flex;align-items:baseline;gap:4px;flex-wrap:wrap}.gl-card-current{font-size:1.125rem;font-weight:700;color:var(--goal-text-primary);font-feature-settings:var(--font-feature-tabular)}.gl-card-of{font-size:.8125rem;color:var(--goal-text-muted)}.gl-card-target{font-size:.9375rem;font-weight:600;color:var(--goal-text-secondary);font-feature-settings:var(--font-feature-tabular)}.gl-card-pct{font-size:.8125rem;color:var(--goal-text-muted);margin-left:2px}.gl-card-footer{display:flex;flex-direction:column;gap:var(--spacing-sm)}.gl-card-info-row{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.gl-card-deadline{font-size:.8125rem;color:var(--goal-text-secondary);font-weight:500}.gl-card-req-chips{display:flex;gap:4px}.gl-req-chip{padding:2px 8px;background:#7aa2ff1a;border:1px solid rgba(122,162,255,.2);border-radius:var(--radius-full);font-size:.6875rem;font-weight:600;color:var(--goal-info);white-space:nowrap;font-feature-settings:var(--font-feature-tabular)}.gl-card-status-msg{padding:8px 12px;border-radius:var(--radius-sm);font-size:.8125rem;font-weight:600;text-align:center}.gl-card-status-msg--achieved{background:var(--success-bg);color:var(--goal-success);border:1px solid var(--success-border)}.gl-card-status-msg--expired{background:var(--danger-bg);color:var(--goal-danger);border:1px solid var(--danger-border)}.gl-card-actions{display:flex;gap:var(--spacing-sm);align-items:center;padding-top:var(--spacing-sm);border-top:1px solid var(--goal-border)}.gl-card-cta{flex:1;padding:8px 14px;background:var(--accent-green);color:var(--text-inverse);border:none;border-radius:var(--radius-sm);font-size:.8125rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.gl-card-cta:hover{background:var(--accent-green-light);transform:translateY(-1px)}.gl-card-cta--resume{background:var(--goal-text-muted)}.gl-card-cta--resume:hover{background:var(--goal-text-secondary)}.gl-card-detail-btn{background:none;border:none;color:var(--goal-info);font-size:.8125rem;font-weight:500;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.gl-card-detail-btn:hover{opacity:.7}.gl-list{border:1px solid var(--goal-border);border-radius:var(--radius-card);overflow:hidden}.gl-list-header{display:grid;grid-template-columns:40px 1fr 140px 120px 60px 100px auto;gap:8px;padding:8px 12px;background:var(--goal-bg-panel);border-bottom:1px solid var(--goal-border);font-size:.6875rem;font-weight:600;color:var(--goal-text-muted);text-transform:uppercase;letter-spacing:.04em}.gl-list-row{display:grid;grid-template-columns:40px 1fr 140px 120px 60px 100px auto;gap:8px;padding:10px 12px;align-items:center;border-bottom:1px solid var(--goal-border);cursor:pointer;transition:background var(--transition-fast)}.gl-list-row:last-child{border-bottom:none}.gl-list-row:hover{background:var(--bg-hover)}.gl-list-row--paused{opacity:.55}.gl-list-row--completed{opacity:.7}.gl-list-icon{font-size:1.25rem;text-align:center}.gl-list-info{display:flex;flex-direction:column;gap:1px;min-width:0}.gl-list-name{font-size:.875rem;font-weight:600;color:var(--goal-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gl-list-status{font-size:.6875rem;font-weight:600}.gl-list-progress-col{display:flex;align-items:center;gap:6px}.gl-list-progress-bar{flex:1;height:6px;background:#ffffff0f;border-radius:var(--radius-full);overflow:hidden}.gl-list-progress-fill{height:100%;border-radius:var(--radius-full);transition:width .3s ease}.gl-list-pct{font-size:.6875rem;font-weight:700;color:var(--goal-text-secondary);width:32px;text-align:right;font-feature-settings:var(--font-feature-tabular)}.gl-list-amounts{display:flex;flex-direction:column;text-align:right;font-feature-settings:var(--font-feature-tabular)}.gl-list-current{font-size:.8125rem;font-weight:600;color:var(--goal-text-primary)}.gl-list-target{font-size:.625rem;color:var(--goal-text-muted)}.gl-list-deadline{font-size:.75rem;color:var(--goal-text-secondary);text-align:center;font-feature-settings:var(--font-feature-tabular)}.gl-list-req{font-size:.75rem;color:var(--goal-info);font-weight:500;text-align:right;font-feature-settings:var(--font-feature-tabular)}.gl-list-actions{display:flex;gap:4px;justify-content:flex-end}.gl-list-toggle-btn{width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--goal-border);border-radius:6px;color:var(--goal-text-muted);cursor:pointer;transition:all var(--transition-fast)}.gl-list-toggle-btn:hover{border-color:var(--accent-blue);color:var(--goal-text-primary)}.gl-list-cta{padding:4px 10px;background:var(--accent-green);color:var(--text-inverse);border:none;border-radius:6px;font-size:.6875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.gl-list-cta:hover{background:var(--accent-green-light)}.gl-drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:var(--z-modal-backdrop);animation:gl-fade-in .2s ease}.gl-drawer{position:fixed;top:0;right:0;width:var(--goal-drawer-width);height:100vh;background:var(--goal-bg-panel);border-left:1px solid var(--goal-border);z-index:var(--z-modal);transform:translate(100%);transition:transform var(--transition-slow);overflow-y:auto;display:flex;flex-direction:column}.gl-drawer--open{transform:translate(0)}@keyframes gl-fade-in{0%{opacity:0}to{opacity:1}}.gl-drawer-header{padding:var(--spacing-lg);border-bottom:1px solid var(--goal-border);position:sticky;top:0;background:var(--goal-bg-panel);z-index:1}.gl-drawer-close{position:absolute;top:12px;right:12px;background:none;border:none;color:var(--goal-text-muted);cursor:pointer;padding:4px;border-radius:6px;display:flex}.gl-drawer-close:hover{color:var(--goal-text-primary);background:var(--bg-hover)}.gl-drawer-title-row{display:flex;align-items:center;gap:var(--spacing-md);margin-top:4px}.gl-drawer-icon{font-size:2rem}.gl-drawer-title{margin:0;font-size:1.125rem;color:var(--goal-text-primary)}.gl-drawer-status{font-size:.8125rem;font-weight:600}.gl-drawer-hero{padding:var(--spacing-xl) var(--spacing-lg);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);border-bottom:1px solid var(--goal-border)}.gl-drawer-progress-ring-wrap{position:relative;width:100px;height:100px}.gl-drawer-ring{width:100%;height:100%}.gl-drawer-ring-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.gl-drawer-ring-pct{font-size:1.5rem;font-weight:800;color:var(--goal-text-primary)}.gl-drawer-hero-amounts{text-align:center}.gl-drawer-hero-current{font-size:1.25rem;font-weight:700;color:var(--goal-text-primary);font-feature-settings:var(--font-feature-tabular)}.gl-drawer-hero-of{font-size:.875rem;color:var(--goal-text-muted);margin-left:4px}.gl-drawer-hero-remaining{font-size:.8125rem;color:var(--goal-text-secondary)}.gl-drawer-details{border-bottom:1px solid var(--goal-border)}.gl-drawer-field{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--goal-border)}.gl-drawer-field:last-child{border-bottom:none}.gl-drawer-field-label{display:flex;align-items:center;gap:4px;font-size:.6875rem;color:var(--goal-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}.gl-drawer-field-value{display:flex;align-items:center;gap:6px;font-size:.875rem;color:var(--goal-text-primary)}.gl-drawer-days-badge{padding:1px 6px;background:var(--warning-bg);color:var(--goal-warning);font-size:.6875rem;font-weight:600;border-radius:var(--radius-full)}.gl-drawer-section{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--goal-border)}.gl-drawer-section-title{display:flex;align-items:center;gap:6px;font-size:.8125rem;font-weight:600;color:var(--goal-text-secondary);margin:0 0 var(--spacing-sm) 0}.gl-drawer-suggestions{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.gl-drawer-sug-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px;background:#ffffff08;border:1px solid var(--goal-border);border-radius:var(--radius-sm)}.gl-drawer-sug-label{font-size:.625rem;color:var(--goal-text-muted);text-transform:uppercase}.gl-drawer-sug-value{font-size:.875rem;font-weight:700;color:var(--goal-info);font-feature-settings:var(--font-feature-tabular)}.gl-drawer-projection-text{font-size:.8125rem;color:var(--goal-text-secondary);line-height:1.5;margin:0}.gl-drawer-projection-text strong{color:var(--goal-text-primary)}.gl-drawer-no-data{font-size:.8125rem;color:var(--goal-text-muted);font-style:italic;margin:0}.gl-drawer-contributions{max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.gl-drawer-contrib-row{display:flex;align-items:center;gap:8px;padding:4px 8px;font-size:.8125rem;border-radius:4px}.gl-drawer-contrib-row:nth-child(odd){background:#ffffff05}.gl-drawer-contrib-date{color:var(--goal-text-muted);min-width:80px}.gl-drawer-contrib-amount{color:var(--goal-success);font-weight:600;font-feature-settings:var(--font-feature-tabular)}.gl-drawer-contrib-note{color:var(--goal-text-muted);font-style:italic;flex:1;text-align:right;font-size:.75rem}.gl-drawer-footer{padding:var(--spacing-lg);border-top:1px solid var(--goal-border);display:flex;gap:8px;flex-wrap:wrap;margin-top:auto;position:sticky;bottom:0;background:var(--goal-bg-panel)}.gl-drawer-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;background:var(--goal-bg-card);border:1px solid var(--goal-border);border-radius:var(--radius-sm);color:var(--goal-text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.gl-drawer-btn:hover{background:var(--bg-hover);color:var(--goal-text-primary)}.gl-drawer-btn--primary{background:var(--accent-green);border-color:var(--accent-green);color:var(--text-inverse)}.gl-drawer-btn--primary:hover{background:var(--accent-green-light)}.gl-drawer-btn--danger:hover{color:var(--goal-danger);border-color:var(--danger-border);background:var(--danger-bg)}.gl-contribute-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:var(--z-modal-backdrop);display:flex;align-items:center;justify-content:center;animation:gl-fade-in .15s ease}.gl-contribute-modal{background:var(--goal-bg-panel);border:1px solid var(--goal-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);width:380px;max-width:90vw;box-shadow:var(--shadow-xl);position:relative}.gl-contribute-close{position:absolute;top:12px;right:12px;background:none;border:none;color:var(--goal-text-muted);cursor:pointer;padding:4px;border-radius:6px;display:flex}.gl-contribute-close:hover{color:var(--goal-text-primary);background:var(--bg-hover)}.gl-contribute-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.gl-contribute-icon{font-size:2rem}.gl-contribute-title{font-size:1rem;font-weight:700;color:var(--goal-text-primary);margin:0}.gl-contribute-sub{font-size:.8125rem;color:var(--goal-text-muted)}.gl-contribute-remaining{font-size:.875rem;color:var(--goal-text-secondary);margin-bottom:var(--spacing-lg);text-align:center}.gl-contribute-remaining strong{color:var(--goal-text-primary)}.gl-contribute-field{margin-bottom:var(--spacing-md)}.gl-contribute-label{display:block;font-size:.75rem;color:var(--goal-text-muted);margin-bottom:4px;font-weight:500}.gl-contribute-input{width:100%;padding:10px 12px;background:var(--goal-bg-card);border:1px solid var(--goal-border);border-radius:var(--radius-sm);color:var(--goal-text-primary);font-size:1rem;font-weight:600;outline:none;transition:border-color var(--transition-fast)}.gl-contribute-input::placeholder{color:var(--goal-text-muted);font-weight:400}.gl-contribute-input:focus{border-color:var(--accent-blue)}.gl-contribute-suggestions{display:flex;gap:6px;margin-bottom:var(--spacing-md);flex-wrap:wrap}.gl-contribute-sug-btn{padding:4px 10px;background:var(--goal-bg-card);border:1px solid var(--goal-border);border-radius:var(--radius-full);font-size:.6875rem;color:var(--goal-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.gl-contribute-sug-btn:hover{border-color:var(--accent-blue);color:var(--goal-info)}.gl-contribute-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-lg)}.gl-contribute-cancel{flex:1;padding:10px;background:var(--goal-bg-card);border:1px solid var(--goal-border);border-radius:var(--radius-sm);color:var(--goal-text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.gl-contribute-cancel:hover{background:var(--bg-hover)}.gl-contribute-confirm{flex:2;padding:10px;background:var(--accent-green);border:none;border-radius:var(--radius-sm);color:var(--text-inverse);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.gl-contribute-confirm:hover{background:var(--accent-green-light)}.gl-contribute-confirm:disabled{opacity:.4;cursor:not-allowed}.gl-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl) var(--spacing-xl);text-align:center}.gl-empty-icon{color:var(--goal-text-muted);margin-bottom:var(--spacing-lg);opacity:.5}.gl-empty-title{font-size:1.125rem;font-weight:600;color:var(--goal-text-primary);margin:0 0 4px}.gl-empty-text{font-size:.875rem;color:var(--goal-text-muted);margin:0 0 var(--spacing-lg) 0;max-width:320px}.gl-empty-tips{display:flex;gap:8px;margin-bottom:var(--spacing-lg);flex-wrap:wrap;justify-content:center}.gl-empty-tip{padding:6px 12px;background:var(--goal-bg-card);border:1px solid var(--goal-border);border-radius:var(--radius-full);font-size:.8125rem;color:var(--goal-text-secondary)}.gl-empty-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--goal-bg-card);border:1px solid var(--goal-border);border-radius:var(--radius-sm);color:var(--goal-text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.gl-empty-btn:hover{background:var(--bg-hover);color:var(--goal-text-primary)}.gl-empty-btn--primary{background:var(--accent-green);border-color:var(--accent-green);color:var(--text-inverse)}.gl-empty-btn--primary:hover{background:var(--accent-green-light)}.gl-skeleton-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(var(--goal-card-min),1fr));gap:var(--spacing-lg)}.gl-skeleton-card{background:var(--goal-bg-card);border:1px solid var(--goal-border);border-radius:var(--radius-card);padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.gl-skeleton-header{display:flex;gap:var(--spacing-sm);align-items:center}.gl-skel{background:var(--goal-border);border-radius:4px;animation:gl-shimmer 1.2s infinite ease-in-out}.gl-skel--icon{width:36px;height:36px;border-radius:50%;flex-shrink:0}.gl-skel-text{flex:1;display:flex;flex-direction:column;gap:6px}.gl-skel--name{width:120px;height:14px}.gl-skel--status{width:60px;height:10px}.gl-skel--bar{width:100%;height:var(--goal-progress-height-lg);border-radius:var(--radius-full)}.gl-skel--amounts{width:160px;height:12px}.gl-skel--footer{width:100%;height:36px;border-radius:var(--radius-sm)}@keyframes gl-shimmer{0%,to{opacity:.4}50%{opacity:.15}}@media(max-width:768px){.gl-container{padding:var(--spacing-lg) var(--spacing-md);gap:var(--spacing-md)}.gl-summary{grid-template-columns:repeat(2,1fr)}.gl-filter-row{flex-direction:column;align-items:flex-start}.gl-status-chips{overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px;width:100%}.gl-toolbar{flex-wrap:wrap}.gl-search-wrap{width:100%}.gl-grid{grid-template-columns:1fr}.gl-list-header{display:none}.gl-list-row{grid-template-columns:36px 1fr auto auto}.gl-list-progress-col,.gl-list-deadline,.gl-list-req{display:none}.gl-drawer{width:100vw}.gl-contribute-modal{width:calc(100vw - 32px)}}.dash-12{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--gap-desktop, 16px)}.dash-col-12{grid-column:span 12}.dash-col-8{grid-column:span 8}.dash-col-7{grid-column:span 7}.dash-col-6{grid-column:span 6}.dash-col-5{grid-column:span 5}.dash-col-4{grid-column:span 4}[class^=dash-col]>*{height:100%}@media(max-width:1024px){.dash-12{gap:var(--gap-md, 12px)}.dash-col-8,.dash-col-7,.dash-col-5,.dash-col-4,.dash-col-6{grid-column:span 12}}@media(max-width:640px){.dash-12{gap:var(--gap-sm, 8px)}}.disponible-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:1.25rem;display:flex;flex-direction:column;gap:.875rem;height:100%;box-sizing:border-box}.disponible-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.disponible-title{font-size:.9rem;font-weight:700;color:var(--text-primary);margin:0}.disponible-subtitle{font-size:.72rem;color:var(--text-muted);margin:.1rem 0 0}.disponible-main{display:flex;flex-direction:column;align-items:flex-start;gap:.2rem}.disponible-amount{font-size:2rem;font-weight:800;line-height:1;letter-spacing:-.03em;font-feature-settings:"tnum" on,"lnum" on}.disponible-per-day{font-size:.72rem;color:var(--text-muted);font-feature-settings:"tnum" on}.disponible-breakdown{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;background:var(--bg-elevated);border-radius:10px;font-size:.78rem}.disponible-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.disponible-row.bold{margin-top:.15rem;font-weight:700}.disponible-row-label{color:var(--text-secondary);flex:1}.disponible-row.bold .disponible-row-label{color:var(--text-primary)}.disponible-row-value{font-weight:500;font-feature-settings:"tnum" on;flex-shrink:0}.disponible-row.bold .disponible-row-value{font-weight:700}.disponible-divider{border-top:1px solid var(--border-color);margin:.25rem 0}.disponible-forecast{display:flex;align-items:center;gap:.5rem;padding:.55rem .875rem;border-radius:8px;font-size:.8rem;font-weight:600;margin-top:auto}.disponible-forecast.positive{background:#22c55e1a;color:var(--success);border:1px solid rgba(34,197,94,.2)}.disponible-forecast.negative{background:#f43f5e1a;color:var(--danger);border:1px solid rgba(244,63,94,.2)}.forecast-icon{font-size:.9rem}.forecast-msg{flex:1}.formula-btn{display:flex;align-items:center;gap:.3rem;padding:.3rem .65rem;border-radius:6px;border:1px solid var(--border-color);background:var(--bg-elevated);color:var(--text-muted);font-size:.72rem;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:color .15s,border-color .15s}.formula-btn:hover{color:var(--text-secondary);border-color:var(--accent-blue)}.formula-panel{position:relative;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:10px;padding:.875rem 1rem}.formula-close{position:absolute;top:.5rem;right:.5rem;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.2rem;display:flex;align-items:center;justify-content:center;border-radius:4px}.formula-close:hover{color:var(--text-primary)}.formula-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin:0 0 .5rem}.formula-text{display:block;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.73rem;color:var(--text-secondary);line-height:1.6;white-space:pre-wrap;background:none}.rule-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:1.25rem;display:flex;flex-direction:column;gap:.875rem;height:100%;overflow-y:auto;box-sizing:border-box}.rule-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.rule-header-left{display:flex;align-items:center;gap:.5rem}.rule-title{font-size:.9rem;font-weight:700;color:var(--text-primary);margin:0}.rule-alert-badge{display:flex;align-items:center;gap:.25rem;padding:.15rem .5rem;border-radius:20px;background:#f43f5e1f;color:var(--danger);font-size:.68rem;font-weight:600}.rule-income-ref{font-size:.75rem;color:var(--text-muted);padding:.4rem .75rem;background:var(--bg-elevated);border-radius:8px}.rule-segments{display:flex;flex-direction:column;gap:1rem}.segment-item{display:flex;flex-direction:column;gap:.3rem}.segment-header{display:flex;align-items:center;gap:.4rem}.segment-emoji{font-size:.95rem;flex-shrink:0}.segment-label{flex:1;font-size:.8rem;font-weight:600;color:var(--text-primary)}.segment-badge{display:flex;align-items:center;gap:.2rem;font-size:.68rem;font-weight:600;padding:.15rem .45rem;border-radius:20px;flex-shrink:0}.segment-badge.alert-green{background:#22c55e1f;color:var(--success)}.segment-badge.alert-yellow{background:#f59e0b1f;color:var(--warning)}.segment-badge.alert-red{background:#f43f5e1f;color:var(--danger)}.segment-bar-wrap{padding:0}.segment-bar-bg{position:relative;height:8px;background:var(--bg-elevated);border-radius:4px;overflow:visible}.segment-bar-fill{height:100%;border-radius:4px;transition:width .6s ease}.segment-target-marker{position:absolute;top:-3px;width:2px;height:14px;background:var(--text-muted);border-radius:1px;transform:translate(-50%);opacity:.5}.segment-meta{display:flex;align-items:center;justify-content:space-between;font-size:.72rem}.segment-amount{color:var(--text-secondary);font-feature-settings:"tnum" on}.segment-pct{font-weight:700;font-feature-settings:"tnum" on}.segment-pct-target{font-weight:400;color:var(--text-muted)}.segment-overflow-msg{font-size:.68rem;color:var(--danger);padding:.2rem .5rem;background:#f43f5e0f;border-radius:4px;margin-top:.1rem}.top-spending-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;overflow:hidden;height:100%;display:flex;flex-direction:column}.top-spending-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem .75rem;gap:.5rem;flex-wrap:wrap}.top-spending-tabs{display:flex;background:var(--bg-elevated);border-radius:8px;padding:2px;gap:2px;margin:0 1rem .5rem}.top-spending-tabs button{flex:1;padding:5px 6px;border:none;border-radius:6px;background:transparent;color:var(--text-muted);font-size:.65rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.top-spending-tabs button.active{background:var(--bg-card);color:var(--text-primary);box-shadow:0 1px 3px #0003}.top-spending-freq{display:inline-block;margin-left:4px;font-size:.6rem;color:var(--text-muted);background:var(--bg-elevated);padding:1px 5px;border-radius:4px;font-weight:400}.top-spending-toggle{display:flex;background:var(--bg-elevated);border-radius:8px;padding:2px;gap:2px}.top-spending-toggle button{padding:4px 10px;border:none;border-radius:6px;background:transparent;color:var(--text-muted);font-size:.7rem;font-weight:500;cursor:pointer;transition:all .2s}.top-spending-toggle button.active{background:var(--bg-card);color:var(--text-primary);box-shadow:0 1px 3px #0003}.top-spending-list{flex:1;padding:0 1rem;display:flex;flex-direction:column;gap:6px}.top-spending-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .25rem}.top-spending-rank{width:22px;height:22px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;flex-shrink:0}.top-spending-icon{font-size:1rem;flex-shrink:0}.top-spending-info{flex:1;min-width:0}.top-spending-name{font-size:.78rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:3px}.top-spending-bar-track{height:4px;background:var(--border-color);border-radius:2px;overflow:hidden}.top-spending-bar-fill{height:100%;border-radius:2px;transition:width .4s ease}.top-spending-amount{text-align:right;flex-shrink:0}.top-spending-value{display:block;font-size:.78rem;font-weight:600;color:var(--text-primary)}.top-spending-pct{display:block;font-size:.65rem;color:var(--text-muted)}.top-spending-more{display:flex;align-items:center;justify-content:center;gap:.4rem;width:100%;padding:.65rem;border:none;border-top:1px solid var(--border-color);background:transparent;color:var(--primary);font-size:.78rem;font-weight:500;cursor:pointer;transition:background .2s;margin-top:auto}.top-spending-more:hover{background:var(--bg-elevated)}.top-spending-drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000}.top-spending-drawer{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:90vw;background:var(--bg-card);border-left:1px solid var(--border-color);z-index:1001;display:flex;flex-direction:column;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1)}.top-spending-drawer--open{transform:translate(0)}.top-spending-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem;border-bottom:1px solid var(--border-color);flex-shrink:0}.top-spending-drawer-header h3{font-size:1rem;font-weight:600;color:var(--text-primary)}.top-spending-drawer-header button{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:6px}.top-spending-drawer-header button:hover{background:var(--bg-elevated);color:var(--text-primary)}.top-spending-drawer-body{overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:4px;flex:1}.subs-panel{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;overflow:hidden;height:100%;display:flex;flex-direction:column}.subs-panel-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:none;border:none;cursor:pointer;color:var(--text-primary)}.subs-panel-body{flex:1;display:flex;flex-direction:column;overflow:hidden}.subs-kpi-strip{display:flex;gap:.5rem;padding:0 1rem .75rem;flex-wrap:wrap}.subs-kpi{flex:1;min-width:70px;padding:.5rem;background:var(--bg-elevated);border-radius:8px;text-align:center}.subs-kpi-value{display:block;font-size:.85rem;font-weight:700;color:var(--text-primary)}.subs-kpi-label{display:block;font-size:.6rem;color:var(--text-muted);margin-top:2px}.subs-kpi-alert .subs-kpi-value{color:var(--warning)}.subs-filter-tabs{display:flex;padding:0 1rem .5rem;gap:4px}.subs-filter-tabs button{padding:3px 10px;border:1px solid var(--border-color);border-radius:6px;background:transparent;color:var(--text-muted);font-size:.68rem;cursor:pointer;transition:all .2s}.subs-filter-tabs button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.subs-list{flex:1;overflow-y:auto;padding:0 .75rem .75rem;display:flex;flex-direction:column;gap:4px;max-height:400px}.subs-item{border:1px solid var(--border-color);border-radius:10px;overflow:hidden;transition:border-color .2s}.subs-item:hover{border-color:var(--border-hover)}.subs-item.dismissed{opacity:.5}.subs-item.confirmed{border-color:#22d3a64d}.subs-item-main{display:flex;align-items:center;justify-content:space-between;padding:.6rem .75rem;cursor:pointer;gap:.5rem}.subs-item-left{min-width:0;flex:1}.subs-item-name{font-size:.8rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.subs-item-meta{display:flex;align-items:center;gap:4px;margin-top:3px}.subs-freq-badge{font-size:.6rem;font-weight:600;padding:1px 5px;border-radius:3px;background:#60a5fa1f;color:var(--primary)}.subs-item-right{text-align:right;flex-shrink:0}.subs-item-amount{font-size:.82rem;font-weight:700;color:var(--text-primary)}.subs-item-monthly{margin-top:1px}.subs-item-detail{border-top:1px solid var(--border-color);padding:.75rem;background:var(--bg-elevated)}.subs-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:.4rem}.subs-detail-item{display:flex;align-items:center;gap:4px;font-size:.7rem;color:var(--text-secondary)}.subs-detail-item svg{color:var(--text-muted);flex-shrink:0}.subs-alerts{display:flex;flex-direction:column;gap:4px;margin-top:.5rem}.subs-alert{display:flex;align-items:center;gap:4px;font-size:.68rem;padding:4px 8px;border-radius:6px}.subs-alert-warning{background:#f59e0b1a;color:var(--warning)}.subs-alert-danger{background:#f43f5e1a;color:var(--danger)}.subs-alert-info{background:#60a5fa1a;color:var(--primary)}.subs-actions{display:flex;flex-wrap:wrap;gap:4px;margin-top:.5rem}.subs-action-btn{display:flex;align-items:center;gap:3px;padding:4px 8px;border:1px solid var(--border-color);border-radius:6px;background:transparent;font-size:.65rem;font-weight:500;cursor:pointer;transition:all .15s}.subs-action-btn.confirm{color:var(--success);border-color:#22d3a64d}.subs-action-btn.confirm:hover{background:#22d3a61a}.subs-action-btn.dismiss{color:var(--danger);border-color:#f43f5e4d}.subs-action-btn.dismiss:hover{background:#f43f5e1a}.subs-action-btn.silence{color:var(--text-muted)}.subs-action-btn.silence:hover{background:var(--bg-hover)}.subs-action-btn.view{color:var(--primary);border-color:#60a5fa4d}.subs-action-btn.view:hover{background:#60a5fa1a}.subs-tx-list{margin-top:.5rem;border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.subs-tx-row{display:flex;align-items:center;justify-content:space-between;padding:.35rem .6rem;font-size:.68rem;gap:.5rem;border-bottom:1px solid var(--border-color)}.subs-tx-row:last-child{border-bottom:none}.subs-tx-date{color:var(--text-muted);flex-shrink:0;width:70px}.subs-tx-desc{flex:1;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.subs-tx-amount{font-weight:600;color:var(--text-primary);flex-shrink:0}.sub-cal-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:3rem;color:var(--text-muted);font-size:.875rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;text-align:center}.sub-cal-wrap{display:flex;flex-direction:column;gap:1.25rem}.sub-cal-summary{display:flex;gap:1rem;padding:.875rem 1.25rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px}.sub-cal-stat{display:flex;flex-direction:column;gap:.1rem}.sub-cal-stat-value{font-size:1.15rem;font-weight:700;color:var(--text-primary);font-feature-settings:"tnum" on}.sub-cal-stat-label{font-size:.68rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.sub-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:.875rem}.sub-cal-day{min-height:72px;border-radius:8px;padding:.35rem;display:flex;flex-direction:column;gap:.2rem;background:var(--bg-elevated);transition:background .15s}.sub-cal-day.today{background:#3b82f614;border:1px solid rgba(59,130,246,.25)}.sub-cal-day.has-charges{background:#f43f5e0a}.sub-cal-day-num{display:flex;flex-direction:column;align-items:center;line-height:1}.sub-cal-weekday{font-size:.55rem;text-transform:uppercase;color:var(--text-muted);font-weight:500}.sub-cal-date-n{font-size:.8rem;font-weight:600;color:var(--text-secondary)}.sub-cal-day.today .sub-cal-date-n{color:var(--accent-blue)}.sub-cal-charges{display:flex;flex-direction:column;gap:.15rem;margin-top:.1rem}.sub-cal-chip{display:block;width:100%;padding:.15rem .3rem;border-radius:4px;border:none;background:#f43f5e1f;color:var(--danger);font-size:.55rem;font-weight:600;text-align:left;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:background .15s}.sub-cal-chip:hover{background:#f43f5e38}.sub-cal-chip-name{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sub-cal-chip-more{font-size:.55rem;color:var(--text-muted);padding-left:.3rem}.sub-cal-day-total{font-size:.6rem;font-weight:700;color:var(--danger);text-align:right;margin-top:.1rem;font-feature-settings:"tnum" on}.sub-cal-list{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.35rem}.sub-cal-list-title{font-size:.8rem;font-weight:600;color:var(--text-secondary);margin:0 0 .5rem;text-transform:uppercase;letter-spacing:.04em}.sub-cal-list-row{display:flex;align-items:center;gap:.75rem;padding:.45rem .6rem;border-radius:8px;border:none;background:var(--bg-elevated);cursor:pointer;text-align:left;transition:background .15s;width:100%}.sub-cal-list-row:hover{background:var(--bg-card);border-color:var(--border-color);outline:1px solid var(--border-color)}.sub-cal-list-date{width:36px;display:flex;flex-direction:column;align-items:center;flex-shrink:0}.sub-cal-list-day{font-size:1rem;font-weight:700;color:var(--accent-blue);line-height:1}.sub-cal-list-month{font-size:.6rem;text-transform:uppercase;color:var(--text-muted)}.sub-cal-list-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.05rem}.sub-cal-list-name{font-size:.82rem;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sub-cal-list-when{font-size:.65rem;color:var(--text-muted)}.sub-cal-list-amount{font-size:.875rem;font-weight:700;color:var(--danger);flex-shrink:0;font-feature-settings:"tnum" on}@media(max-width:900px){.sub-cal-grid{grid-template-columns:repeat(5,1fr)}}@media(max-width:600px){.sub-cal-grid{grid-template-columns:repeat(4,1fr)}}
