*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans,Helvetica,Arial,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.5;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}a{color:var(--text-link);text-decoration:none}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;color:inherit}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit;background-color:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);outline:none;transition:border-color var(--transition-fast)}input:focus,select:focus,textarea:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #58a6ff26}select{cursor:pointer}table{border-collapse:collapse;width:100%}img,svg{display:block;max-width:100%}ul,ol{list-style:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-primary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}:root{--bg-primary: #0d1117;--bg-secondary: #161b22;--bg-tertiary: #21262d;--bg-overlay: rgba(0, 0, 0, .5);--border-primary: #30363d;--border-secondary: #21262d;--text-primary: #e6edf3;--text-secondary: #8b949e;--text-muted: #484f58;--text-link: #58a6ff;--accent-blue: #58a6ff;--accent-green: #3fb950;--accent-red: #f85149;--accent-orange: #d29922;--accent-purple: #bc8cff;--accent-yellow: #e3b341;--color-success: #238636;--color-success-hover: #2ea043;--color-danger: #da3633;--color-danger-hover: #f85149;--color-warning: #9e6a03;--cat-utilities: #58a6ff;--cat-subscriptions: #bc8cff;--cat-loans: #ff7b72;--cat-insurance: #ffa657;--cat-others: #7ee787;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--font-xs: 11px;--font-sm: 12px;--font-md: 14px;--font-lg: 16px;--font-xl: 20px;--font-2xl: 24px;--font-3xl: 32px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5);--shadow-card: 0 2px 8px rgba(0, 0, 0, .3), 0 0 0 1px rgba(48, 54, 61, .5);--shadow-card-hover: 0 8px 24px rgba(0, 0, 0, .4), 0 0 0 1px rgba(88, 166, 255, .3);--gradient-blue: linear-gradient(135deg, #1a3a5c 0%, #0d1117 100%);--gradient-green: linear-gradient(135deg, #1a3c2a 0%, #0d1117 100%);--gradient-card: linear-gradient(180deg, rgba(22, 27, 34, 1) 0%, rgba(13, 17, 23, .8) 100%);--gradient-title: linear-gradient(135deg, var(--accent-blue), var(--accent-purple));--glow-blue: 0 0 20px rgba(88, 166, 255, .15);--glow-green: 0 0 20px rgba(63, 185, 80, .15);--transition-fast: .15s ease;--transition-normal: .25s ease;--header-height: 56px;--sidebar-width: 300px;--tab-height: 44px}.btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-md);font-weight:500;transition:all var(--transition-fast);white-space:nowrap}.btn-primary{background-color:var(--color-success);color:#fff}.btn-primary:hover{background-color:var(--color-success-hover)}.btn-danger{background-color:var(--color-danger);color:#fff}.btn-danger:hover{background-color:var(--color-danger-hover)}.btn-secondary{background-color:var(--bg-tertiary);border:1px solid var(--border-primary);color:var(--text-primary)}.btn-secondary:hover{background-color:var(--border-primary)}.btn-ghost{color:var(--text-secondary);padding:var(--space-xs) var(--space-sm)}.btn-ghost:hover{color:var(--text-primary);background-color:var(--bg-tertiary)}.btn-sm{padding:var(--space-xs) var(--space-sm);font-size:var(--font-sm)}.btn-lg{padding:var(--space-md) var(--space-lg);font-size:var(--font-lg)}.btn-icon{padding:var(--space-sm);border-radius:var(--radius-md);display:inline-flex;align-items:center;justify-content:center}.btn-icon:hover{background-color:var(--bg-tertiary)}.btn-success-outline{border:1px solid var(--accent-green);color:var(--accent-green)}.btn-success-outline:hover{background-color:#3fb9501a}.modal-overlay{position:fixed;inset:0;background-color:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn var(--transition-fast);padding:var(--space-md)}.modal{background:linear-gradient(180deg,var(--bg-secondary) 0%,rgba(13,17,23,.98) 100%);border:1px solid var(--border-primary);border-radius:var(--radius-xl);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;-webkit-overflow-scrolling:touch;animation:slideUp var(--transition-normal);box-shadow:0 25px 50px #00000080,0 0 0 1px #30363d80}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-primary)}.modal-header h2{font-size:var(--font-xl);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.modal-body{padding:var(--space-lg)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border-primary)}.modal-wide{max-width:700px}.form-group{margin-bottom:var(--space-md)}.form-group label{display:block;font-size:var(--font-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-xs)}.form-group input,.form-group select,.form-group textarea{width:100%}.form-group textarea{min-height:80px;resize:vertical}.form-row{display:flex;gap:var(--space-md)}.form-row .form-group{flex:1}.form-error{color:var(--accent-red);font-size:var(--font-sm);margin-top:var(--space-xs)}.estimate-range-inputs{display:flex;gap:var(--space-md)}.estimate-range-inputs .form-group{flex:1;min-width:0}@media(max-width:400px){.estimate-range-inputs{flex-direction:column;gap:var(--space-xs)}}.estimated-amount{color:var(--text-secondary);font-style:italic}.estimate-hint{color:var(--text-secondary);font-size:var(--font-sm);font-style:italic;margin-bottom:var(--space-md)}.form-checkbox{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer}.form-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent-blue);cursor:pointer}.form-hint{font-size:var(--font-xs);color:var(--text-muted);margin-top:var(--space-xs)}.modal-form-actions{display:flex;justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-md)}.currency-input-wrapper{position:relative}.currency-input-wrapper .currency-symbol{position:absolute;left:var(--space-md);top:50%;transform:translateY(-50%);color:var(--text-secondary);font-weight:500}.currency-input-wrapper input{padding-left:28px}.badge{display:inline-flex;align-items:center;padding:2px var(--space-sm);border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:500}.badge-green{background-color:#3fb95026;color:var(--accent-green)}.badge-red{background-color:#f8514926;color:var(--accent-red)}.badge-orange{background-color:#d2992226;color:var(--accent-orange)}.badge-blue{background-color:#58a6ff26;color:var(--accent-blue)}.badge-purple{background-color:#bc8cff26;color:var(--accent-purple)}.card{background:var(--gradient-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-card);transition:all var(--transition-normal)}.card:hover{border-color:#58a6ff33;box-shadow:var(--shadow-card-hover)}.card-clickable{cursor:pointer;transition:all var(--transition-normal)}.card-clickable:hover{border-color:var(--accent-blue);transform:translateY(-2px);box-shadow:var(--shadow-card-hover),var(--glow-blue)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);color:var(--text-secondary);text-align:center}.empty-state-icon{font-size:48px;margin-bottom:var(--space-md);opacity:.5}.empty-state-title{font-size:var(--font-lg);font-weight:600;margin-bottom:var(--space-sm);color:var(--text-primary)}.empty-state-text{font-size:var(--font-md);max-width:300px}.status-banner{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);font-size:var(--font-sm);font-weight:500;position:sticky;top:0;z-index:200;animation:statusBannerFadeIn .2s ease-out}@keyframes statusBannerFadeIn{0%{opacity:0}to{opacity:1}}.status-banner--offline{background-color:#b45309;color:#fff}.status-banner--syncing{background-color:#1d4ed8;color:#fff}.status-banner--synced{background-color:#15803d;color:#fff}.status-banner--conflict{background-color:#c2410c;color:#fff;cursor:pointer}.status-banner--conflict:hover{background-color:#9a3412}.status-banner-icon{font-size:var(--font-md)}.status-banner--syncing .status-banner-icon{display:inline-block;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.status-banner-text{flex-shrink:1}.status-banner-action{font-size:var(--font-xs);opacity:.8;text-decoration:underline}.status-banner-refresh{background:none;border:1px solid currentColor;color:inherit;border-radius:4px;padding:2px 8px;font-size:var(--font-xs);cursor:pointer;margin-left:auto;opacity:.8}.status-banner-refresh:hover{opacity:1}.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;gap:12px;min-height:300px}.error-boundary-icon{font-size:48px;opacity:.6}.error-boundary-title{font-size:var(--font-lg);font-weight:600;color:var(--text-primary)}.error-boundary-text{font-size:var(--font-sm);color:var(--text-secondary);max-width:320px}.conflict-modal-content{display:flex;flex-direction:column;gap:var(--space-md)}.conflict-modal-description{color:var(--text-secondary);font-size:var(--font-sm);line-height:1.5}.conflict-modal-bill-name{font-size:var(--font-lg);color:var(--text-primary)}.conflict-options{display:flex;flex-direction:column;gap:var(--space-sm)}.conflict-option{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-md);border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-secondary);cursor:pointer;transition:border-color .15s,background-color .15s}.conflict-option:hover{border-color:var(--color-primary)}.conflict-option--selected{border-color:var(--color-primary);background:#58a6ff14}.conflict-option input[type=radio]{margin-top:2px;accent-color:var(--color-primary)}.conflict-option-details{display:flex;flex-direction:column;gap:4px;flex:1}.conflict-option-amount{font-size:var(--font-md);font-weight:600;color:var(--text-primary)}.conflict-option-time{font-size:var(--font-xs);color:var(--text-tertiary)}.conflict-custom-input{margin-top:var(--space-xs);padding:var(--space-sm) var(--space-md);border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:var(--font-md);width:100%}.conflict-custom-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #58a6ff33}.conflict-modal-footer{display:flex;justify-content:flex-end;gap:var(--space-sm)}.spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--border-primary);border-top-color:var(--accent-blue);border-radius:50%;animation:spin .6s linear infinite}.spinner-lg{width:40px;height:40px;border-width:3px}.loading-container{display:flex;align-items:center;justify-content:center;padding:var(--space-2xl)}.confirm-dialog{text-align:center}.confirm-dialog p{color:var(--text-secondary);margin-bottom:var(--space-lg);font-size:var(--font-lg)}.confirm-dialog .confirm-actions{display:flex;justify-content:center;gap:var(--space-md)}.search-box{position:relative;min-width:220px}.search-box input{width:100%;padding-left:36px;padding-right:68px}.search-box .search-icon{position:absolute;left:var(--space-md);top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:var(--font-lg);pointer-events:none}.search-clear{position:absolute;right:36px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);font-size:var(--font-md);cursor:pointer;padding:2px 6px;border-radius:var(--radius-sm);line-height:1}.search-clear:hover{color:var(--text-primary);background-color:var(--bg-tertiary)}.search-count{position:absolute;right:var(--space-sm);top:50%;transform:translateY(-50%);background-color:var(--accent-blue);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:var(--radius-full);min-width:18px;text-align:center;line-height:1.5}.search-suggestions{position:absolute;top:calc(100% + 4px);left:0;right:0;background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:60;max-height:260px;overflow-y:auto;animation:fadeIn var(--transition-fast)}.search-suggestion-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);cursor:pointer;font-size:var(--font-sm);transition:background-color var(--transition-fast);border-bottom:1px solid var(--border-secondary)}.search-suggestion-item:last-child{border-bottom:none}.search-suggestion-item:hover{background-color:var(--bg-tertiary)}.suggestion-name{color:var(--text-primary);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.suggestion-date{color:var(--text-muted);font-size:var(--font-xs);white-space:nowrap;margin-left:var(--space-sm)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.text-green{color:var(--accent-green)}.text-red{color:var(--accent-red)}.text-orange{color:var(--accent-orange)}.text-blue{color:var(--accent-blue)}.text-muted{color:var(--text-secondary)}.text-center{text-align:center}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mb-md{margin-bottom:var(--space-md)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.install-btn{padding:6px 12px;background:var(--color-success);color:#fff;font-size:var(--font-sm);font-weight:600;border-radius:var(--radius-md);border:none;cursor:pointer;white-space:nowrap;transition:background var(--transition-fast),opacity var(--transition-fast)}.install-btn:hover{background:var(--color-success-hover)}.install-btn--disabled{background:var(--bg-tertiary);color:var(--text-muted);cursor:default;opacity:.7}.install-btn--disabled:hover{background:var(--bg-tertiary)}.bills-layout{display:flex;gap:var(--space-lg);height:calc(100vh - var(--header-height) - var(--tab-height) - var(--space-xl))}.bills-main{flex:1;min-width:0;display:flex;flex-direction:column}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md);flex-shrink:0}.calendar-nav{display:flex;align-items:center;gap:var(--space-md)}.calendar-nav h2{font-size:var(--font-2xl);font-weight:600;min-width:220px;text-align:center}.calendar-nav button{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);border:1px solid var(--border-primary);background-color:var(--bg-secondary);font-size:var(--font-xl);transition:all var(--transition-fast)}.calendar-nav button:hover{background-color:var(--bg-tertiary);border-color:var(--text-muted)}.btn-today{font-size:var(--font-sm)!important;width:auto!important;padding:var(--space-xs) var(--space-md)!important}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:auto;grid-auto-rows:1fr;border:1px solid var(--border-primary);border-radius:var(--radius-lg);overflow:hidden;flex:1;min-height:0}.calendar-weekday{background-color:var(--bg-secondary);padding:var(--space-sm) var(--space-xs);text-align:center;font-size:var(--font-xs);font-weight:600;color:var(--text-muted);border-bottom:1px solid var(--border-primary);border-right:1px solid var(--border-secondary);text-transform:uppercase;letter-spacing:.5px;line-height:1}.calendar-weekday:nth-child(7),.calendar-day:nth-of-type(7n){border-right:none}.weekday-short{display:none}.weekday-full{display:inline}.calendar-day{border-right:1px solid var(--border-secondary);border-bottom:1px solid var(--border-secondary);padding:var(--space-xs);min-height:90px;cursor:pointer;transition:background-color var(--transition-fast);display:flex;flex-direction:column;overflow:hidden;position:relative}.calendar-day:hover{background-color:var(--bg-secondary)}.calendar-day.outside-month{opacity:.3;cursor:default}.calendar-day.outside-month:hover{background-color:transparent}.calendar-day.before-start{opacity:.2;cursor:not-allowed;background-color:var(--bg-primary)}.calendar-day.before-start:hover{background-color:var(--bg-primary)}.calendar-day.is-today{outline:2px solid var(--accent-blue);outline-offset:-2px;background-color:#58a6ff0d;z-index:1}.calendar-day.clickable{cursor:pointer}.calendar-day.clickable:hover{background-color:var(--bg-tertiary)}.calendar-day.has-overdue{outline:2px solid var(--accent-red);outline-offset:-2px;box-shadow:0 0 8px #f8514966,0 0 20px #f8514933,inset 0 0 12px #f851490f;animation:pulseRed 2s ease-in-out infinite;background-color:#f851490a;z-index:1}@keyframes pulseRed{0%,to{box-shadow:0 0 8px #f8514966,0 0 20px #f8514933}50%{box-shadow:0 0 14px #f8514999,0 0 30px #f851494d}}.calendar-day.has-late{outline:2px solid #d94040;outline-offset:-2px;box-shadow:0 0 6px #d9404040;background-color:#d940400a;z-index:1}.calendar-day.search-match{background-color:#58a6ff1f;outline:2px solid var(--accent-blue);outline-offset:-2px;box-shadow:0 0 8px #58a6ff66,0 0 18px #58a6ff26;animation:pulseBlue 1.5s ease-in-out infinite;z-index:1}@keyframes pulseBlue{0%,to{box-shadow:0 0 8px #58a6ff66,0 0 18px #58a6ff26}50%{box-shadow:0 0 14px #58a6ff99,0 0 28px #58a6ff40}}.day-number{font-size:var(--font-sm);font-weight:600;padding:2px var(--space-xs);margin-bottom:2px;color:var(--text-secondary)}.is-today .day-number{background-color:var(--accent-blue);color:#fff;border-radius:var(--radius-full);width:24px;height:24px;display:flex;align-items:center;justify-content:center}.day-bills{flex:1;overflow:hidden;display:flex;flex-direction:column;gap:1px}.day-bill-item{font-size:var(--font-xs);padding:1px var(--space-xs);border-radius:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4}.day-bill-item.cat-utilities{background-color:#58a6ff26;color:var(--cat-utilities)}.day-bill-item.cat-subscriptions{background-color:#bc8cff26;color:var(--cat-subscriptions)}.day-bill-item.cat-loans{background-color:#ff7b7226;color:var(--cat-loans)}.day-bill-item.cat-insurance{background-color:#ffa65726;color:var(--cat-insurance)}.day-bill-item.cat-others{background-color:#7ee78726;color:var(--cat-others)}.day-bill-item.is-paid{text-decoration:line-through;opacity:.5}.day-bill-more{font-size:var(--font-xs);color:var(--text-muted);padding:0 var(--space-xs)}.day-total{font-size:var(--font-xs);font-weight:600;color:var(--text-secondary);padding:2px var(--space-xs);margin-top:auto;border-top:1px solid var(--border-secondary)}.day-total.has-estimate{font-style:italic}.bills-sidebar{width:var(--sidebar-width);flex-shrink:0;display:flex;flex-direction:column;gap:var(--space-md);overflow-y:auto}.sidebar-section{background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-md)}.sidebar-section h3{font-size:var(--font-md);font-weight:600;margin-bottom:var(--space-sm);color:var(--text-secondary)}.sidebar-stat{display:flex;justify-content:space-between;align-items:center;padding:var(--space-xs) 0}.sidebar-stat-label{color:var(--text-secondary);font-size:var(--font-sm)}.sidebar-stat-value{font-weight:600;font-size:var(--font-md)}.sidebar-bill-list{display:flex;flex-direction:column;gap:var(--space-xs)}.sidebar-bill-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-sm);cursor:pointer}.sidebar-bill-row:hover{background-color:var(--bg-tertiary)}.sidebar-bill-date{color:var(--text-muted);min-width:50px}.sidebar-bill-name{flex:1;margin:0 var(--space-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-late-item{display:flex;justify-content:space-between;padding:var(--space-xs) var(--space-sm);font-size:var(--font-sm);color:var(--accent-orange);border-radius:var(--radius-sm);background-color:#d299221a}.day-modal-bills{display:flex;flex-direction:column;gap:var(--space-sm)}.day-modal-bill{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-primary);gap:var(--space-md)}.day-modal-bill.is-paid{opacity:.6}.day-modal-bill.is-paid .bill-name{text-decoration:line-through}.day-modal-bill.is-late{border-left:3px solid var(--accent-orange)}.bill-info{flex:1;min-width:0}.bill-name{font-weight:600;display:flex;align-items:center;gap:var(--space-sm)}.bill-name .paid-check{color:var(--accent-green)}.bill-meta{font-size:var(--font-sm);color:var(--text-secondary);margin-top:2px}.bill-amount{font-weight:700;font-size:var(--font-lg);white-space:nowrap}.bill-actions{display:flex;gap:var(--space-xs)}.day-modal-total{display:flex;justify-content:space-between;padding:var(--space-md);font-weight:600;font-size:var(--font-lg);border-top:1px solid var(--border-primary);margin-top:var(--space-sm)}.container-picker{display:flex;flex-direction:column;gap:var(--space-sm)}.container-picker-label{font-size:var(--font-md);color:var(--text-secondary);margin:0}@media(max-width:900px){.bills-layout{flex-direction:column;height:auto}.bills-sidebar{width:100%;flex-direction:row;flex-wrap:wrap}.sidebar-section{flex:1;min-width:250px}.calendar-day{min-height:70px}.calendar-nav h2{font-size:var(--font-xl);min-width:180px}.weekday-short{display:inline}.weekday-full{display:none}}@media(max-width:600px){.calendar-day{min-height:50px;padding:2px}.day-bill-item{font-size:9px}.day-number{font-size:var(--font-xs)}.day-total{display:none}.calendar-weekday{font-size:var(--font-xs);padding:var(--space-xs)}.calendar-header{flex-direction:column;gap:var(--space-sm)}}.full-paid-stamp{position:absolute;top:4px;right:4px;pointer-events:none}.full-paid-stamp-text{display:inline-block;padding:1px 6px;background:var(--accent-green);color:#fff;font-size:9px;font-weight:800;letter-spacing:.5px;border-radius:var(--radius-sm);transform:rotate(3deg);box-shadow:0 1px 3px #3fb9504d}.calendar-day.all-paid{background:#3fb9500f;outline:2px solid var(--accent-green);outline-offset:-2px;box-shadow:0 0 8px #3fb9504d,0 0 16px #3fb9501f;z-index:1}.calendar-day.in-cycle{background-color:#58a6ff0f}.calendar-day.in-cycle:not(.has-overdue):not(.has-late):not(.search-match):not(.all-paid):not(.is-today){border-top:2px solid rgba(88,166,255,.25);border-bottom:2px solid rgba(88,166,255,.25)}.calendar-day.cycle-start{border-left:3px solid var(--accent-blue)!important}.calendar-day.cycle-end{border-right:3px solid var(--accent-blue)!important}.cycle-indicator{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);margin-bottom:var(--space-sm);font-size:var(--font-sm);color:var(--accent-blue);background:#58a6ff14;border:1px solid rgba(88,166,255,.2);border-radius:var(--radius-md);font-weight:500}.cycle-indicator-clickable{cursor:pointer;transition:all var(--transition-fast)}.cycle-indicator-clickable:hover{background:#58a6ff26;border-color:#58a6ff66}.cycle-indicator-edit{margin-left:auto;font-size:var(--font-xs);color:var(--accent-blue);opacity:.6;transition:opacity var(--transition-fast)}.cycle-indicator-clickable:hover .cycle-indicator-edit{opacity:1}.cycle-indicator-dot{width:8px;height:8px;border-radius:50%;background:var(--accent-blue);flex-shrink:0}.cycle-summary-section{border-color:#58a6ff4d;background:linear-gradient(135deg,var(--bg-secondary),rgba(88,166,255,.04))}.cycle-summary-range{font-size:var(--font-sm);color:var(--accent-blue);font-weight:600;margin-bottom:var(--space-sm)}.streak-tracker{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:#d2992214;border:1px solid rgba(210,153,34,.2);border-radius:var(--radius-md);margin-top:var(--space-sm)}.streak-icon{font-size:20px}.streak-count{font-size:var(--font-xl);font-weight:800;color:var(--accent-orange)}.streak-label{font-size:var(--font-sm);color:var(--text-secondary)}.bills-progress{display:flex;flex-direction:column;gap:var(--space-xs)}.bills-progress-header{display:flex;justify-content:space-between;align-items:center}.bills-progress-label{font-size:var(--font-sm);font-weight:600;color:var(--text-primary)}.bills-progress-pct{font-size:var(--font-sm);color:var(--text-muted)}.bills-progress-bar{height:8px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.bills-progress-fill{height:100%;background:var(--accent-blue);border-radius:var(--radius-full);transition:width var(--transition-normal)}.bills-progress-complete{background:var(--accent-green)}.bills-progress-congrats{font-size:var(--font-xs);color:var(--accent-green);font-weight:600;text-align:center}.sidebar-checklist{display:flex;flex-direction:column;gap:2px}.checklist-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) 0;font-size:var(--font-sm)}.checklist-check{font-size:14px;flex-shrink:0;width:18px;text-align:center}.checklist-paid .checklist-check{color:var(--accent-green)}.checklist-late .checklist-check{color:var(--accent-orange)}.checklist-name{flex:1;color:var(--text-primary);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.checklist-strikethrough{text-decoration:line-through;color:var(--text-muted)}.checklist-date{color:var(--text-muted);font-size:var(--font-xs);flex-shrink:0}.checklist-amount{font-weight:500;flex-shrink:0}.checklist-paid .checklist-amount{color:var(--text-muted)}.month-complete-banner{text-align:center;padding:var(--space-md);background:#3fb9501a;border:1px solid rgba(63,185,80,.3);border-radius:var(--radius-md);color:var(--accent-green);font-weight:600;font-size:var(--font-md)}.cycle-picker{display:flex;flex-direction:column;gap:var(--space-md)}.cycle-picker-desc{font-size:var(--font-sm);color:var(--text-secondary);margin:0}.cycle-picker-input label{display:block;font-size:var(--font-sm);color:var(--text-secondary);margin-bottom:var(--space-xs)}.cycle-picker-row{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-md);color:var(--text-primary)}.cycle-picker-row input{width:60px;text-align:center;padding:var(--space-xs) var(--space-sm);border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-tertiary);color:var(--text-primary);font-size:var(--font-lg);font-weight:600}.cycle-picker-row input:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 2px #58a6ff33}.cycle-picker-current{padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-primary)}.cycle-picker-current-label{font-size:var(--font-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}.cycle-picker-current-range{font-size:var(--font-md);font-weight:600;color:var(--text-primary)}.cycle-picker-preview{background:#58a6ff0f;border:1px solid rgba(88,166,255,.2);border-radius:var(--radius-md);padding:var(--space-md)}.cycle-picker-preview-label{font-size:var(--font-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-xs)}.cycle-picker-preview-range{font-size:var(--font-lg);font-weight:600;color:var(--accent-blue)}.cycle-picker-preview-hint{font-size:var(--font-xs);color:var(--text-muted);margin-top:var(--space-xs)}.analytics-layout{display:flex;flex-direction:column;gap:var(--space-lg);padding-bottom:var(--space-xl);overflow-x:hidden}.analytics-filters{display:flex;gap:var(--space-md);align-items:center;flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:var(--space-sm)}.filter-group label{font-size:var(--font-sm);color:var(--text-secondary);white-space:nowrap}.filter-group select{padding:var(--space-xs) var(--space-sm);font-size:var(--font-sm);background-color:var(--bg-secondary)}.analytics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-lg)}.chart-card{background:var(--gradient-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-card);transition:all var(--transition-normal);overflow:hidden}.chart-card:hover{box-shadow:var(--shadow-card-hover)}.chart-card-full{grid-column:1 / -1}.chart-card h3{font-size:var(--font-lg);font-weight:600;margin-bottom:var(--space-md)}.chart-container{width:100%;height:300px}.chart-container-sm{height:200px}.analytics-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md)}.summary-card{background:var(--gradient-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:center;box-shadow:var(--shadow-card);transition:all var(--transition-normal)}.summary-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-card-hover)}.summary-card .summary-value{font-size:var(--font-3xl);font-weight:700;margin-bottom:var(--space-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.summary-card .summary-label{font-size:var(--font-sm);color:var(--text-secondary)}.progress-bar-container{margin-top:var(--space-md)}.progress-bar{width:100%;height:24px;background-color:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden;display:flex}.progress-bar .progress-paid{background-color:var(--accent-green);height:100%;transition:width var(--transition-normal);display:flex;align-items:center;justify-content:center;font-size:var(--font-xs);font-weight:600;color:#fff;min-width:fit-content;padding:0 var(--space-sm)}.progress-bar .progress-remaining{background-color:var(--accent-red);height:100%;transition:width var(--transition-normal);display:flex;align-items:center;justify-content:center;font-size:var(--font-xs);font-weight:600;color:#fff;min-width:fit-content;padding:0 var(--space-sm)}.progress-legend{display:flex;justify-content:space-between;margin-top:var(--space-sm);font-size:var(--font-sm)}.top-expenses-list{display:flex;flex-direction:column;gap:var(--space-sm)}.top-expense-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) 0}.top-expense-rank{width:24px;height:24px;border-radius:var(--radius-full);background-color:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:var(--font-xs);font-weight:700;flex-shrink:0}.top-expense-info{flex:1;min-width:0}.top-expense-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.top-expense-category{font-size:var(--font-xs);color:var(--text-secondary)}.top-expense-amount{font-weight:700;white-space:nowrap}.top-expense-bar{width:100%;height:6px;background-color:var(--bg-tertiary);border-radius:var(--radius-full);margin-top:var(--space-xs);overflow:hidden}.top-expense-bar-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-normal)}.payment-stats{display:flex;gap:var(--space-lg);margin-top:var(--space-md)}.payment-stat{flex:1;text-align:center}.payment-stat-value{font-size:var(--font-2xl);font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.payment-stat-label{font-size:var(--font-sm);color:var(--text-secondary)}.recharts-text{fill:var(--text-secondary)!important;font-size:var(--font-sm)!important}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:var(--border-secondary)!important}.recharts-tooltip-wrapper .recharts-default-tooltip{background-color:var(--bg-tertiary)!important;border:1px solid var(--border-primary)!important;border-radius:var(--radius-md)!important}.recharts-tooltip-item{color:var(--text-primary)!important}.recharts-legend-item-text{color:var(--text-secondary)!important}.custom-date-range{display:flex;align-items:center;gap:var(--space-sm)}.custom-date-range input[type=date]{padding:var(--space-xs) var(--space-sm);font-size:var(--font-sm);background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);color-scheme:dark}.custom-date-range span{color:var(--text-muted);font-size:var(--font-sm)}@media(max-width:768px){.analytics-grid{grid-template-columns:1fr}.chart-container{height:250px}.payment-stats{flex-direction:column;gap:var(--space-md)}}.analytics-tabs{display:flex;align-items:center;gap:var(--space-xs);border-bottom:1px solid var(--border-primary);padding-bottom:var(--space-xs)}.analytics-tab{padding:var(--space-sm) var(--space-lg);border:none;background:none;color:var(--text-secondary);font-size:var(--font-md);font-weight:500;cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition-fast)}.analytics-tab:hover{color:var(--text-primary)}.analytics-tab-active{color:var(--accent-blue);border-bottom-color:var(--accent-blue)}.analytics-card{background:var(--gradient-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-card);overflow:hidden}.analytics-card h3{font-size:var(--font-lg);font-weight:600;margin:0 0 var(--space-md);color:var(--text-primary)}.analytics-empty{text-align:center;padding:var(--space-xl);color:var(--text-muted)}.pie-chart-container{display:flex;gap:var(--space-lg);align-items:center}.pie-chart{width:180px;height:180px;border-radius:50%;flex-shrink:0}.pie-legend{display:flex;flex-direction:column;gap:var(--space-xs);flex:1;min-width:0}.pie-legend-item{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-sm)}.pie-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.pie-legend-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary)}.pie-legend-value{font-weight:500;flex-shrink:0}.pie-legend-pct{color:var(--text-muted);flex-shrink:0;width:32px;text-align:right}.pie-total{margin-top:var(--space-md);text-align:center;font-weight:600;color:var(--text-secondary)}.bva-chart{display:flex;flex-direction:column;gap:var(--space-md)}.bva-row{display:flex;flex-direction:column;gap:4px}.bva-label{font-size:var(--font-sm);font-weight:600;color:var(--text-primary)}.bva-bars{display:flex;flex-direction:column;gap:3px}.bva-bar-track{height:12px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.bva-bar{height:100%;border-radius:var(--radius-full);transition:width var(--transition-normal)}.bva-bar-over{background:var(--accent-red)!important}.bva-amounts{display:flex;justify-content:space-between;font-size:var(--font-xs)}.bva-legend{display:flex;gap:var(--space-lg);justify-content:center;margin-top:var(--space-md);font-size:var(--font-sm);color:var(--text-secondary)}.bva-legend-item{display:flex;align-items:center;gap:var(--space-xs)}.bva-legend-bar{display:inline-block;width:16px;height:8px;background:var(--accent-blue);border-radius:var(--radius-full)}.trend-chart{position:relative;height:200px}.trend-bars{display:flex;gap:2px;height:100%;align-items:flex-end;padding-bottom:24px;overflow-x:auto;overflow-y:hidden;min-width:0}.trend-bar-col{flex:1 0 0;min-width:20px;display:flex;flex-direction:column;align-items:center;height:100%}.trend-bar-wrapper{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center}.trend-bar{width:70%;max-width:40px;background:var(--accent-blue);border-radius:var(--radius-sm) var(--radius-sm) 0 0;transition:height var(--transition-normal);min-height:2px}.trend-bar-label{font-size:9px;color:var(--text-muted);margin-top:var(--space-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.trend-avg-line{position:absolute;left:0;right:0;height:1px;border-top:2px dashed var(--accent-orange);opacity:.5;pointer-events:none}.trend-summary{display:flex;justify-content:space-between;font-size:var(--font-sm);color:var(--text-secondary);margin-top:var(--space-md)}.btn-tips-pulse{margin-left:auto;padding:var(--space-sm) var(--space-lg);background:#ffb74d1f;border:1px solid rgba(255,183,77,.3);border-radius:var(--radius-md);color:var(--accent-orange);font-size:var(--font-md);font-weight:600;cursor:pointer;animation:tipsPulse 2.5s ease-in-out infinite;transition:all var(--transition-fast)}.btn-tips-pulse:hover{background:#ffb74d33;border-color:var(--accent-orange);transform:scale(1.05)}@keyframes tipsPulse{0%,to{box-shadow:0 0 4px #ffb74d33}50%{box-shadow:0 0 12px #ffb74d66,0 0 24px #ffb74d26}}.budget-tip-warning{padding:var(--space-md);background:#ffb74d1a;border:1px solid rgba(255,183,77,.3);border-radius:var(--radius-md);color:var(--accent-orange);font-weight:600;font-size:var(--font-sm);margin-bottom:var(--space-md)}.bva-performance-summary{padding:var(--space-md);background:var(--bg-secondary);border-radius:var(--radius-md);margin-bottom:var(--space-md);text-align:center}.bva-perf-score{font-size:var(--font-xl);font-weight:800;margin-bottom:var(--space-xs)}.bva-perf-detail{font-size:var(--font-sm);color:var(--text-secondary)}.analytics-period-toggle{display:flex;gap:var(--space-xs);flex-wrap:wrap;margin-bottom:var(--space-md)}.analytics-period-btn{padding:var(--space-xs) var(--space-md);border:1px solid var(--border-primary);border-radius:var(--radius-full);background:var(--bg-secondary);color:var(--text-secondary);font-size:var(--font-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.analytics-period-btn:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--text-muted)}.analytics-period-btn-active,.analytics-period-btn-active:hover{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}@media(max-width:768px){.analytics-tabs{flex-wrap:wrap}.analytics-card{padding:var(--space-md)}.pie-chart-container{flex-direction:column;align-items:center}.pie-chart{width:140px;height:140px}.pie-legend-value{font-size:var(--font-xs)}.btn-tips-pulse{margin-left:0;width:100%;text-align:center}.analytics-period-toggle{gap:4px}.analytics-period-btn{padding:3px var(--space-sm);font-size:var(--font-xs)}.trend-chart{height:160px}.trend-bar{width:90%;max-width:24px}.trend-summary{flex-direction:column;gap:var(--space-xs);align-items:flex-start}.bva-performance-summary{padding:var(--space-sm)}.bva-perf-detail{font-size:var(--font-xs);word-break:break-word}.bva-legend{gap:var(--space-md);font-size:var(--font-xs)}.bva-amounts{font-size:10px}.summary-card .summary-value{font-size:var(--font-xl)}.custom-date-range{flex-wrap:wrap}.custom-date-range input[type=date]{flex:1;min-width:0}}.savings-hero{background:var(--gradient-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-card);text-align:center}.savings-hero-verdict{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:8px}.savings-hero-icon{font-size:32px;line-height:1}.savings-hero-text{font-size:22px;font-weight:800;letter-spacing:-.5px}.savings-hero-amount{font-size:36px;font-weight:800;line-height:1.1;margin-bottom:4px}.savings-hero-amount-label{display:block;font-size:13px;font-weight:500;color:var(--text-muted);margin-top:4px}.savings-hero-bar-section{margin-top:20px;text-align:left}.savings-hero-bar-labels{display:flex;justify-content:space-between;font-size:12px;color:var(--text-secondary);margin-bottom:6px}.savings-hero-bar-track{height:10px;border-radius:5px;background:#ffffff14;overflow:hidden}.savings-hero-bar-fill{height:100%;border-radius:5px;transition:width .4s ease}.savings-hero-bar-footer{display:flex;justify-content:space-between;align-items:center;margin-top:6px;font-size:13px;font-weight:600}.savings-goal-input{width:44px;padding:2px 4px;margin-left:4px;border-radius:var(--radius-sm);border:1px solid var(--border-primary);background:var(--bg-secondary);color:var(--text-primary);font-size:12px;text-align:center}.savings-hero-projection{margin-top:16px;padding-top:12px;border-top:1px solid var(--border-primary);display:flex;justify-content:space-between;align-items:center;font-size:13px}.savings-quick-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md)}.savings-stat-box{background:var(--gradient-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-md);text-align:center}.savings-stat-value{font-size:16px;font-weight:700;line-height:1.3}.savings-stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:4px}@media(max-width:768px){.savings-hero-icon{font-size:26px}.savings-hero-text{font-size:18px}.savings-hero-amount{font-size:28px}.savings-quick-stats{grid-template-columns:repeat(3,1fr);gap:var(--space-sm)}.savings-stat-value{font-size:13px}.savings-stat-label{font-size:10px}.savings-stat-box{padding:var(--space-sm)}.savings-hero-projection{flex-direction:column;gap:4px;text-align:center}}.savings-layout{display:flex;flex-direction:column;gap:var(--space-lg);padding-bottom:var(--space-xl)}.savings-header{text-align:center;padding:var(--space-xl) var(--space-lg);background:var(--gradient-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}.savings-header .total-label{font-size:var(--font-md);color:var(--text-secondary);margin-bottom:var(--space-xs)}.savings-header .total-amount{font-size:var(--font-3xl);font-weight:700;color:var(--accent-green);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.savings-header-actions{display:flex;justify-content:center;gap:var(--space-md);margin-top:var(--space-md)}.bank-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-md)}.bank-card{background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-lg);cursor:pointer;transition:all var(--transition-fast);position:relative;overflow:hidden}.bank-card:hover{border-color:var(--accent-blue);transform:translateY(-2px);box-shadow:var(--shadow-md)}.bank-card-gradient{position:absolute;top:0;left:0;right:0;height:4px}.bank-card .bank-name{font-size:var(--font-lg);font-weight:600;margin-bottom:var(--space-xs);margin-top:var(--space-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bank-card .bank-purpose{font-size:var(--font-sm);color:var(--text-secondary);margin-bottom:var(--space-md);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.bank-card .bank-balance{font-size:var(--font-2xl);font-weight:700;color:var(--accent-green);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.container-card-flow{display:flex;justify-content:space-between;font-size:var(--font-xs);margin-top:var(--space-xs);padding-top:var(--space-xs);border-top:1px solid rgba(255,255,255,.08)}.container-flow-in{color:var(--accent-green);overflow:hidden;text-overflow:ellipsis;min-width:0}.container-flow-out{color:var(--accent-red, #f97583);overflow:hidden;text-overflow:ellipsis;min-width:0}.bank-card-add{border:2px dashed var(--border-primary);background-color:transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:150px;color:var(--text-secondary);font-size:var(--font-lg);gap:var(--space-sm)}.bank-card-add:hover{border-color:var(--accent-blue);color:var(--accent-blue)}.bank-card-add .add-icon{font-size:var(--font-3xl);line-height:1}.bank-detail{display:flex;flex-direction:column;gap:var(--space-lg)}.bank-detail-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md)}.bank-detail-info h2{font-size:var(--font-2xl);font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bank-detail-info .purpose-text{color:var(--text-secondary);margin-top:var(--space-xs)}.bank-detail-balance{text-align:right}.bank-detail-balance .balance-label{font-size:var(--font-sm);color:var(--text-secondary)}.bank-detail-balance .balance-amount{font-size:var(--font-3xl);font-weight:700;color:var(--accent-green);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bank-detail-actions{display:flex;gap:var(--space-md);justify-content:center}.bank-detail-actions .btn{min-width:140px;justify-content:center}.btn-deposit{background-color:var(--color-success);color:#fff;font-size:var(--font-lg);padding:var(--space-md) var(--space-xl)}.btn-deposit:hover{background-color:var(--color-success-hover)}.btn-withdraw{background-color:var(--color-danger);color:#fff;font-size:var(--font-lg);padding:var(--space-md) var(--space-xl)}.btn-withdraw:hover{background-color:var(--color-danger-hover)}.transaction-section{background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);overflow:hidden}.transaction-section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-primary)}.transaction-section-header h3{font-size:var(--font-lg);font-weight:600}.transaction-list{display:flex;flex-direction:column}.transaction-item{display:flex;align-items:center;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-secondary);gap:var(--space-md)}.transaction-item:last-child{border-bottom:none}.transaction-icon{width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:var(--font-lg);flex-shrink:0}.transaction-icon.deposit{background-color:#3fb95026;color:var(--accent-green)}.transaction-icon.withdrawal{background-color:#f8514926;color:var(--accent-red)}.transaction-icon-move{background-color:#58a6ff26!important;color:var(--accent-blue)!important}.transaction-move{border-left:3px solid var(--accent-blue);padding-left:var(--space-sm)}.transaction-info{flex:1;min-width:0}.transaction-type{font-weight:500;font-size:var(--font-md)}.transaction-note{font-size:var(--font-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.transaction-date{font-size:var(--font-sm);color:var(--text-muted);white-space:nowrap}.transaction-amounts{text-align:right;white-space:nowrap}.transaction-amount{font-weight:600}.transaction-amount.deposit{color:var(--accent-green)}.transaction-amount.withdrawal{color:var(--accent-red)}.transaction-running-balance{font-size:var(--font-sm);color:var(--text-secondary)}.savings-analytics{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:var(--space-lg)}@media(max-width:768px){.bank-grid{grid-template-columns:1fr}.bank-detail-header{flex-direction:column}.bank-detail-balance{text-align:left}.bank-detail-actions{flex-direction:column}.bank-detail-actions .btn{width:100%}.transaction-item{flex-wrap:wrap}.transaction-date{width:100%;order:3;margin-top:var(--space-xs);padding-left:52px}.savings-analytics{grid-template-columns:1fr}}.container-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--space-md)}.container-type-section{margin-bottom:var(--space-lg)}.container-type-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);font-size:var(--font-lg);font-weight:600;color:var(--text-secondary)}.container-type-icon{font-size:28px}.container-label-icon{font-size:32px}.container-card{background:var(--gradient-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-lg);cursor:pointer;transition:all var(--transition-fast);position:relative;overflow:hidden}.container-card:hover{border-color:var(--accent-blue);transform:translateY(-2px);box-shadow:var(--shadow-md)}.container-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm);gap:var(--space-sm);min-width:0;overflow:hidden}.container-card-name{font-size:var(--font-lg);font-weight:600;display:flex;align-items:center;gap:var(--space-sm);min-width:0;overflow:hidden}.container-card-type-icon{font-size:18px}.container-label-badge{display:inline-block;padding:3px 10px;background:#58a6ff1a;border:1px solid currentColor;font-size:var(--font-sm);font-weight:600;border-radius:var(--radius-full);opacity:.9;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.container-card-balance{font-size:var(--font-2xl);font-weight:700;color:var(--accent-green);margin:var(--space-sm) 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.container-budget-bar{height:4px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden;margin-top:var(--space-sm)}.container-budget-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-normal)}.container-budget-info{display:flex;justify-content:space-between;margin-top:4px;font-size:var(--font-xs);color:var(--text-muted)}.container-detail{display:flex;flex-direction:column;gap:var(--space-lg)}.container-detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-md)}.container-detail-info h2{font-size:var(--font-2xl);font-weight:700;display:flex;align-items:center;gap:var(--space-sm);min-width:0;overflow:hidden}.container-detail-label{margin-top:var(--space-xs)}.container-detail-purpose{margin-top:var(--space-xs);font-size:.8rem;color:var(--text-muted);font-style:italic}.container-detail-balance{text-align:right}.container-detail-balance .balance-label{font-size:var(--font-sm);color:var(--text-secondary)}.container-detail-balance .balance-amount{font-size:var(--font-3xl);font-weight:700;color:var(--accent-green);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.container-detail-actions{display:flex;gap:var(--space-md);justify-content:center}.container-detail-manage{display:flex;justify-content:center;gap:var(--space-sm);padding-top:var(--space-md);border-top:1px solid var(--border-primary)}.container-form{display:flex;flex-direction:column;gap:var(--space-md)}.container-form .color-picker{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.color-swatch{width:32px;height:32px;border-radius:var(--radius-full);border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.color-swatch:hover{transform:scale(1.15)}.color-swatch-selected{border-color:#fff;box-shadow:0 0 0 2px var(--accent-blue)}.icon-picker{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.icon-picker-item{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-secondary);font-size:20px;cursor:pointer;transition:all var(--transition-fast)}.icon-picker-item:hover{border-color:var(--accent-blue);background:var(--bg-tertiary)}.icon-picker-item.active{border-color:var(--accent-blue);background:#58a6ff26;box-shadow:var(--glow-blue)}.color-picker-item{width:32px;height:32px;border-radius:var(--radius-full);border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.color-picker-item:hover{transform:scale(1.15)}.color-picker-item.active{border-color:#fff;box-shadow:0 0 0 2px var(--accent-blue)}.label-conflict{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:#d299221a;border:1px solid var(--accent-orange);border-radius:var(--radius-md);font-size:var(--font-sm);color:var(--accent-orange)}.move-money-modal{display:flex;flex-direction:column;gap:var(--space-md)}.move-money-preview{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);justify-content:center}.move-money-arrow{font-size:24px;color:var(--accent-blue)}.move-money-account{text-align:center}.move-money-account-name{font-weight:600;color:var(--text-primary)}.move-money-account-balance{font-size:var(--font-sm);color:var(--text-secondary)}.label-swap-preview{display:flex;align-items:center;gap:var(--space-md);justify-content:center;padding:var(--space-lg)}.label-swap-container{text-align:center;padding:var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);min-width:120px}.label-swap-arrow{font-size:28px;color:var(--accent-blue)}.container-net-balance{display:flex;gap:var(--space-lg);padding:var(--space-md) var(--space-lg);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);justify-content:center}.net-balance-item{display:flex;flex-direction:column;align-items:center;gap:2px}.net-balance-item span:first-child{font-weight:600;font-size:var(--font-md)}.net-balance-label{font-size:var(--font-xs);color:var(--text-muted)}.net-balance-total{border-left:1px solid var(--border-primary);padding-left:var(--space-lg)}.net-balance-total span:first-child{font-weight:800;color:var(--text-primary)}.mymoney-allocation-stats{background:var(--gradient-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg);display:flex;align-items:center;gap:var(--space-md)}.mymoney-alloc-row{display:flex;flex:1;gap:var(--space-lg)}.mymoney-alloc-item{display:flex;flex-direction:column;gap:2px}.mymoney-alloc-label{font-size:var(--font-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.mymoney-alloc-value{font-size:var(--font-lg);font-weight:700}.mymoney-alloc-btn{flex-shrink:0}.mymoney-alloc-done{font-size:var(--font-sm);color:var(--accent-green);font-weight:600;flex-shrink:0}.mymoney-income-empty{display:flex;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-lg);border:1px dashed var(--border-primary);border-radius:var(--radius-md)}.mymoney-income-section{background:var(--gradient-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-lg)}.mymoney-income-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.mymoney-income-header h3{font-size:var(--font-lg);font-weight:600}.mymoney-income-header-right{display:flex;align-items:center;gap:var(--space-md)}.mymoney-income-summary{font-size:var(--font-md);font-weight:600}.mymoney-income-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--space-md)}@media(max-width:768px){.container-grid{grid-template-columns:1fr}.container-detail-header{flex-direction:column}.container-detail-balance{text-align:left}.container-detail-actions{flex-direction:column}.container-net-balance{flex-direction:column;align-items:center;gap:var(--space-sm)}.net-balance-total{border-left:none;border-top:1px solid var(--border-primary);padding-left:0;padding-top:var(--space-sm)}.mymoney-allocation-stats{flex-direction:column;align-items:stretch}.mymoney-alloc-row{justify-content:space-between}.mymoney-income-header{flex-direction:column;gap:var(--space-sm);align-items:flex-start}.mymoney-income-grid{grid-template-columns:1fr}}.expenses-layout{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-md);max-width:900px;margin:0 auto}.budget-header{background:var(--gradient-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-card)}.budget-header-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-md)}.budget-income-label{font-size:var(--font-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-xs)}.budget-income-amount{font-size:var(--font-3xl);font-weight:700;background:var(--gradient-title);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.budget-header-actions{display:flex;align-items:center;gap:var(--space-sm)}.btn-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);border:1px solid var(--border-primary);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;font-size:var(--font-lg);transition:all var(--transition-fast)}.btn-icon:hover{border-color:var(--accent-blue);color:var(--accent-blue);box-shadow:var(--glow-blue)}.budget-header-stats{display:flex;gap:var(--space-lg);padding:var(--space-md) 0;border-top:1px solid var(--border-primary);border-bottom:1px solid var(--border-primary)}.budget-stat{display:flex;flex-direction:column;gap:2px}.budget-stat-label{font-size:var(--font-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.budget-stat-value{font-size:var(--font-lg);font-weight:600;color:var(--text-primary)}.text-red{color:var(--accent-red)!important}.text-green{color:var(--accent-green)!important}.text-blue{color:var(--accent-blue)!important}.text-orange{color:var(--accent-orange)!important}.text-muted{color:var(--text-muted)!important}.text-secondary{color:var(--text-secondary)!important}.text-primary{color:var(--text-primary)!important}.budget-cycle-info{display:flex;justify-content:space-between;align-items:center;margin-top:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md)}.cycle-date-range{font-size:var(--font-sm);color:var(--text-secondary)}.cycle-days-left{font-size:var(--font-sm);color:var(--accent-blue);font-weight:500}.quick-expense-bar{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:var(--space-sm);padding:var(--space-sm) 0}.quick-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;min-height:72px;padding:var(--space-sm) var(--space-xs);border-radius:var(--radius-lg);border:1px solid var(--border-primary);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast)}.quick-btn:hover{border-color:var(--accent-blue);background:var(--bg-tertiary);box-shadow:var(--glow-blue);transform:translateY(-2px)}.quick-btn:active{transform:translateY(0)}.quick-btn-icon{font-size:28px;line-height:1}.quick-btn-label{font-size:var(--font-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;font-weight:500}.quick-btn-source{font-size:10px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.quick-btn-others{border-color:var(--border-secondary)}.quick-btn-add{border-style:dashed;border-color:var(--text-muted);color:var(--text-muted);min-width:56px}.quick-btn-add .quick-btn-icon{font-size:24px;font-weight:300}.quick-btn-add:hover{border-color:var(--accent-green);color:var(--accent-green)}.allocation-section{display:flex;flex-direction:column;gap:var(--space-md)}.allocation-section-header{display:flex;justify-content:space-between;align-items:center}.allocation-section-header h3{font-size:var(--font-lg);font-weight:600;color:var(--text-primary);margin:0}.allocation-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-md)}.allocation-card{background:var(--gradient-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-md);transition:all var(--transition-normal);overflow:hidden}.allocation-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.allocation-card.warning{border-color:var(--accent-orange)}.allocation-card.over-budget{border-color:var(--accent-red);box-shadow:0 0 12px #f8514926}.allocation-card-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm);min-width:0}.allocation-card-icon{font-size:20px;flex-shrink:0}.allocation-card-label{font-size:var(--font-md);font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.allocation-card-source{font-size:var(--font-xs);color:var(--text-muted);margin-bottom:var(--space-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.allocation-hero{font-size:var(--font-2xl);font-weight:700;line-height:1.1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.allocation-hero-label{font-size:var(--font-xs);color:var(--text-muted);margin-bottom:var(--space-sm)}.allocation-card-meta{display:flex;justify-content:space-between;gap:var(--space-sm)}.allocation-meta-item{display:flex;flex-direction:column;gap:1px}.allocation-meta-label{font-size:var(--font-xs);color:var(--text-muted)}.allocation-meta-value{font-size:var(--font-sm);font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.progress-bar{height:6px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--space-sm)}.progress-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-normal)}.allocation-card-footer{display:flex;justify-content:flex-end;align-items:center}.allocation-percent{font-size:var(--font-xs);color:var(--text-muted)}.allocation-empty{text-align:center;padding:var(--space-xl);color:var(--text-secondary)}.allocation-empty p{margin-bottom:var(--space-md)}.recent-expenses-section{display:flex;flex-direction:column;gap:var(--space-md)}.recent-expenses-header{display:flex;justify-content:space-between;align-items:center}.recent-expenses-header h3{font-size:var(--font-lg);font-weight:600;color:var(--text-primary);margin:0}.recent-expenses-total{font-size:var(--font-md);color:var(--accent-red);font-weight:600}.recent-expenses-empty{text-align:center;padding:var(--space-xl);color:var(--text-secondary);background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px dashed var(--border-primary)}.recent-expenses-list{display:flex;flex-direction:column;gap:var(--space-md)}.expense-date-group{display:flex;flex-direction:column;gap:2px}.expense-date-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md) var(--radius-md) 0 0;border:1px solid var(--border-primary);border-bottom:none}.expense-date-label{font-size:var(--font-sm);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}.expense-date-total{font-size:var(--font-sm);color:var(--accent-red);font-weight:500}.expense-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-primary);border-top:none;transition:background var(--transition-fast)}.expense-item:last-child{border-radius:0 0 var(--radius-md) var(--radius-md)}.expense-item:hover{background:var(--bg-tertiary)}.expense-item-left{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.expense-item-category{font-size:var(--font-md);font-weight:500;color:var(--text-primary)}.expense-item-note{font-size:var(--font-sm);color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.expense-item-right{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.expense-item-amount{font-size:var(--font-md);font-weight:600;color:var(--accent-red)}.expense-item-source{font-size:16px}.expense-item-actions{display:flex;gap:2px;margin-left:var(--space-xs)}.btn-icon-sm{background:none;border:none;cursor:pointer;padding:2px 4px;font-size:14px;opacity:.5;transition:opacity .15s;border-radius:var(--radius-sm);line-height:1}.btn-icon-sm:hover{opacity:1;background:var(--bg-tertiary)}.income-setup{display:flex;flex-direction:column;gap:var(--space-md)}.income-total-banner{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);font-weight:600}.income-list{display:flex;flex-direction:column;gap:2px}.income-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md)}.income-item-info{display:flex;flex-direction:column;gap:2px}.income-item-name{font-weight:500;color:var(--text-primary);display:flex;align-items:center;gap:var(--space-sm)}.income-item-details{font-size:var(--font-sm);color:var(--text-secondary)}.income-item-actions{display:flex;gap:var(--space-xs)}.income-form{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-primary)}.income-form h4{margin:0;font-size:var(--font-md);color:var(--text-primary)}.income-form-actions{display:flex;justify-content:flex-end;gap:var(--space-sm)}.budget-setup{display:flex;flex-direction:column;gap:var(--space-md)}.budget-setup-summary{display:flex;gap:var(--space-lg);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md)}.budget-setup-stat{display:flex;flex-direction:column;gap:2px}.budget-setup-list{display:flex;flex-direction:column;gap:4px}.budget-setup-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md)}.budget-setup-item-icon{font-size:20px;flex-shrink:0}.budget-setup-item-label{flex:1;font-weight:500;color:var(--text-primary)}.budget-setup-item-amount{flex-shrink:0}.budget-setup-item-amount .currency-input-wrapper{width:140px}.budget-setup-item-amount input{font-size:var(--font-sm);padding:4px 8px}.budget-add-form{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-primary)}.budget-add-form h4{margin:0;font-size:var(--font-md);color:var(--text-primary)}.budget-category-chips{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.budget-category-chip{display:flex;align-items:center;gap:4px;padding:4px 12px;border-radius:var(--radius-full);border:1px solid var(--border-primary);background:var(--bg-secondary);color:var(--text-primary);font-size:var(--font-sm);cursor:pointer;transition:all var(--transition-fast)}.budget-category-chip:hover{background:var(--bg-tertiary)}.budget-category-chip.active{border-color:var(--accent-blue);background:#58a6ff1a}.cycle-settings-info{margin-bottom:var(--space-md)}.cycle-current-display{display:flex;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);font-size:var(--font-sm);margin-top:var(--space-sm)}.cycle-history{display:flex;flex-direction:column;gap:var(--space-sm)}.cycle-history-item{padding:var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md)}.cycle-history-active{border-color:var(--accent-blue);background:#58a6ff0d}.cycle-history-badge{display:inline-block;padding:2px 8px;background:var(--accent-blue);color:#fff;font-size:var(--font-xs);font-weight:600;border-radius:var(--radius-full);margin-bottom:var(--space-sm)}.cycle-history-dates{font-size:var(--font-md);font-weight:500;color:var(--text-primary)}.cycle-history-income{font-size:var(--font-sm);color:var(--text-secondary);margin-top:4px}.quick-btn-setup{display:flex;flex-direction:column;gap:var(--space-sm)}.quick-btn-setup h4{margin:0;font-size:var(--font-md);color:var(--text-secondary)}.quick-btn-setup-list{display:flex;flex-direction:column;gap:4px}.quick-btn-setup-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md)}.quick-btn-setup-icon{font-size:20px}.quick-btn-setup-label{flex:1;font-weight:500;color:var(--text-primary)}.quick-btn-setup-available{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.quick-btn-add-chip{display:flex;align-items:center;gap:4px;padding:6px 12px;border-radius:var(--radius-full);border:1px dashed var(--border-primary);background:var(--bg-secondary);color:var(--text-secondary);font-size:var(--font-sm);cursor:pointer;transition:all var(--transition-fast)}.quick-btn-add-chip:hover{border-color:var(--accent-green);color:var(--accent-green);background:#3fb9500d}.quick-btn-add-plus{color:var(--accent-green);font-weight:600;font-size:var(--font-md)}.expense-form-category-display{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);font-weight:500;color:var(--text-primary)}.fund-source-options{display:flex;flex-direction:column;gap:var(--space-sm)}.fund-option{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.fund-option:hover{background:var(--bg-tertiary)}.fund-option-selected{border-color:var(--accent-blue);background:#58a6ff0d}.fund-option input[type=radio]{accent-color:var(--accent-blue)}.fund-option-icon{font-size:20px}.fund-option-details{display:flex;flex-direction:column}.fund-option-name{font-weight:500;color:var(--text-primary)}.fund-option-balance{font-size:var(--font-sm);color:var(--text-secondary)}.badge{display:inline-block;padding:1px 8px;font-size:var(--font-xs);font-weight:600;border-radius:var(--radius-full)}.badge-blue{background:#58a6ff26;color:var(--accent-blue)}.badge-green{background:#3fb95026;color:var(--accent-green)}.badge-orange{background:#d2992226;color:var(--accent-orange)}.badge-red{background:#f8514926;color:var(--accent-red)}@media(max-width:768px){.expenses-layout{padding:var(--space-sm)}.budget-header{padding:var(--space-md)}.budget-income-amount{font-size:var(--font-2xl)}.budget-header-stats{flex-wrap:wrap;gap:var(--space-md)}.budget-header-top{flex-wrap:wrap;gap:var(--space-sm)}.budget-cycle-info{flex-wrap:wrap;gap:var(--space-xs)}.quick-expense-bar{grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:var(--space-xs)}.quick-btn{min-height:64px;padding:var(--space-xs);gap:4px}.quick-btn-icon{font-size:24px}.quick-btn-label{font-size:var(--font-xs)}.allocation-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--space-sm)}.allocation-card{padding:var(--space-sm)}.allocation-card-label{font-size:var(--font-sm)}.allocation-hero{font-size:var(--font-xl)}.allocation-meta-value{font-size:var(--font-xs)}.allocation-mobile-hide{display:none}.expense-item{padding:var(--space-sm);gap:var(--space-sm)}.expense-item-category{font-size:var(--font-sm)}.expense-item-note{font-size:var(--font-xs)}.expense-item-amount{font-size:var(--font-sm)}.budget-setup-summary{flex-direction:column;gap:var(--space-sm)}.budget-setup-item{flex-wrap:wrap}.form-row{flex-direction:column}.unallocated-banner{flex-direction:column;text-align:center;gap:var(--space-sm);padding:var(--space-md)}}.budget-income-of{font-size:var(--font-lg);font-weight:400;color:var(--text-muted);-webkit-text-fill-color:var(--text-muted)}.budget-income-progress{height:4px;background:var(--bg-tertiary);border-radius:var(--radius-full);margin-top:var(--space-sm);overflow:hidden}.budget-income-progress-fill{height:100%;background:var(--accent-green);border-radius:var(--radius-full);transition:width var(--transition-normal)}.allocation-card-clickable{cursor:pointer}.unallocated-banner{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);background:#d299221a;border:1px solid var(--accent-orange);border-radius:var(--radius-lg)}.unallocated-banner-text{display:flex;align-items:center;gap:var(--space-sm);font-weight:500;color:var(--accent-orange)}.unallocated-banner-amount{font-weight:700;font-size:var(--font-lg)}.income-setup-v3{display:flex;flex-direction:column;gap:var(--space-md)}.income-tabs{display:flex;gap:var(--space-xs);border-bottom:1px solid var(--border-primary);padding-bottom:var(--space-xs)}.income-tab{padding:var(--space-sm) var(--space-md);border:none;background:none;color:var(--text-secondary);font-size:var(--font-md);font-weight:500;cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition-fast);display:flex;align-items:center;gap:var(--space-xs)}.income-tab:hover{color:var(--text-primary)}.income-tab-active{color:var(--accent-blue);border-bottom-color:var(--accent-blue)}.income-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:var(--radius-full);background:var(--accent-blue);color:#fff;font-size:var(--font-xs);font-weight:600}.income-tracker{display:flex;flex-direction:column;gap:var(--space-md)}.income-tracker-summary{padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);display:flex;flex-wrap:wrap;gap:var(--space-lg);align-items:center}.income-tracker-stat{display:flex;flex-direction:column;gap:2px}.income-tracker-stat-label{font-size:var(--font-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.income-tracker-stat-value{font-size:var(--font-xl);font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.income-progress-bar{flex:1;min-width:120px;height:6px;background:var(--bg-secondary);border-radius:var(--radius-full);overflow:hidden}.income-progress-fill{height:100%;background:var(--accent-green);border-radius:var(--radius-full);transition:width var(--transition-normal)}.income-section{display:flex;flex-direction:column;gap:var(--space-sm)}.income-section-title{margin:0;font-size:var(--font-md);font-weight:600;color:var(--text-secondary)}.income-empty{text-align:center;padding:var(--space-xl)}.income-quick-add{margin-bottom:var(--space-md);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-primary)}.income-quick-add-grid{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.income-quick-add-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 16px;border-radius:var(--radius-md);border:2px solid var(--accent-green, #3fb950);background:#3fb95014;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);min-width:100px;position:relative}.income-quick-add-btn:hover:not(:disabled){background:#3fb9502e;transform:translateY(-1px);box-shadow:0 2px 8px #3fb95033}.income-quick-add-btn:active:not(:disabled){transform:translateY(0)}.income-quick-add-btn:disabled{opacity:.6;cursor:not-allowed}.income-quick-add-name{font-weight:600;font-size:var(--font-sm);white-space:nowrap}.income-quick-add-amount{font-size:var(--font-xs, 11px);color:var(--accent-green, #3fb950);font-weight:500}.income-quick-add-loading{position:absolute;top:2px;right:6px;font-size:10px;color:var(--text-secondary)}.income-sources{display:flex;flex-direction:column;gap:var(--space-md)}.income-card{padding:var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:var(--space-sm)}.income-card-pending{border-left:3px solid var(--accent-blue)}.income-card-received{border-left:3px solid var(--accent-green)}.income-card-late{border-left:3px solid var(--accent-orange)}.income-card-header{display:flex;justify-content:space-between;align-items:center}.income-card-name{display:flex;align-items:center;gap:var(--space-sm);font-weight:600;font-size:var(--font-md)}.income-card-icon{font-size:18px}.income-card-details{display:flex;flex-direction:column;gap:2px}.income-card-amount{font-size:var(--font-lg);font-weight:600}.income-card-expected{font-size:var(--font-sm);margin-left:var(--space-xs)}.income-card-date{font-size:var(--font-sm)}.income-card-actions{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-xs)}.income-card-custom{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-sm);background:var(--bg-tertiary);border-radius:var(--radius-md)}.income-card-custom-actions{display:flex;gap:var(--space-sm)}.receive-early-modal{display:flex;flex-direction:column;gap:var(--space-md)}.receive-early-source,.receive-early-expected{display:flex;gap:var(--space-sm);align-items:center;font-size:var(--font-md)}.allocate-header{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-lg)}.allocate-available{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background:#3fb95014;border:1px solid rgba(63,185,80,.25);border-radius:var(--radius-lg);font-size:var(--font-md);font-weight:500;color:var(--text-primary)}.allocate-available .text-green{font-size:var(--font-xl);font-weight:700}.allocate-actions-row{display:flex;gap:var(--space-sm)}.allocate-list{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-md)}.allocate-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);transition:border-color var(--transition-fast);overflow:hidden}.allocate-item:focus-within{border-color:var(--accent-blue)}.allocate-item-info{display:flex;align-items:center;gap:var(--space-sm);min-width:0;flex:1;overflow:hidden}.allocate-item-icon{font-size:20px;flex-shrink:0}.allocate-item-name{font-weight:600;font-size:var(--font-sm);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.allocate-item-label{font-size:var(--font-xs);color:var(--text-muted)}.allocate-input{width:130px;min-width:130px;flex-shrink:0}.allocate-input input{width:100%;text-align:right;font-weight:600;font-size:var(--font-sm);box-sizing:border-box}.allocate-footer{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-md)}.allocate-remaining{padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);font-weight:600;font-size:var(--font-md);text-align:center}@media(max-width:768px){.allocate-item{flex-direction:column;align-items:stretch;gap:var(--space-sm);padding:var(--space-sm) var(--space-md)}.allocate-input{width:100%}.allocate-actions-row{flex-wrap:wrap}}.eoc-step{display:flex;flex-direction:column;gap:var(--space-md)}.eoc-steps-bar{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:1px solid var(--border-primary)}.eoc-step-pill{display:flex;align-items:center;gap:var(--space-xs);padding:6px 12px;border-radius:20px;font-size:var(--font-sm);color:var(--text-muted);background:var(--bg-tertiary);transition:all var(--transition-fast)}.eoc-step-pill-active{color:var(--accent-blue)}.eoc-step-pill-current{background:#58a6ff26;font-weight:600}.eoc-step-pill-num{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:var(--bg-tertiary);font-size:var(--font-xs);font-weight:700}.eoc-step-pill-current .eoc-step-pill-num{background:var(--accent-blue);color:#fff}.eoc-summary-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm)}.eoc-summary-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-xs) 0}.eoc-summary-label{color:var(--text-secondary);font-size:var(--font-md)}.eoc-summary-value{font-weight:600;font-size:var(--font-md)}.eoc-summary-highlight{padding:var(--space-sm);background:var(--bg-tertiary);border-radius:var(--radius-md);margin:var(--space-xs) 0}.eoc-summary-highlight .eoc-summary-value{font-size:var(--font-lg)}.eoc-summary-divider{height:1px;background:var(--border-primary)}.eoc-breakdown{margin-top:var(--space-sm)}.eoc-breakdown-title{font-size:var(--font-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 var(--space-sm)}.eoc-breakdown-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm)}.eoc-breakdown-row:nth-child(2n){background:var(--bg-tertiary)}.eoc-breakdown-name{font-size:var(--font-md)}.eoc-breakdown-amounts{display:flex;align-items:baseline;gap:var(--space-xs)}.eoc-breakdown-budget{font-size:var(--font-sm)}.eoc-decision-list{display:flex;flex-direction:column;gap:var(--space-md)}.eoc-decision-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm)}.eoc-decision-card-header{display:flex;justify-content:space-between;align-items:center}.eoc-decision-card-name{display:flex;align-items:center;gap:var(--space-sm)}.eoc-decision-card-balance{font-size:var(--font-lg);font-weight:700}.eoc-decision-buttons{display:flex;gap:var(--space-sm)}.eoc-choice-btn{flex:1;padding:var(--space-sm) var(--space-md);border:2px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;font-size:var(--font-md);font-weight:500;transition:all var(--transition-fast);text-align:center}.eoc-choice-btn:hover{border-color:var(--accent-blue);color:var(--text-primary)}.eoc-choice-btn-active{border-color:var(--accent-green);background:#3fb9501a;color:var(--accent-green);font-weight:600}.eoc-choice-btn-move{border-color:var(--accent-blue);background:#58a6ff1a;color:var(--accent-blue)}.eoc-transfer-dest{padding-top:var(--space-xs)}.eoc-transfer-dest select{width:100%}.eoc-transfer-section{display:flex;flex-direction:column;gap:6px;padding-top:var(--space-sm)}.eoc-transfer-row{display:flex;gap:6px;align-items:center}.eoc-transfer-row select{font-size:var(--font-sm);padding:6px 8px}.eoc-transfer-row .currency-input-wrapper{min-width:100px}.eoc-transfer-row .currency-input-wrapper input{font-size:var(--font-sm);padding:6px 8px 6px 24px}.eoc-confirm-cards{display:flex;flex-direction:column;gap:var(--space-sm)}.eoc-confirm-card{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md)}.eoc-confirm-card-left{display:flex;flex-direction:column;gap:2px}.eoc-confirm-tag{padding:4px 10px;border-radius:12px;font-size:var(--font-sm);font-weight:600;white-space:nowrap}.eoc-confirm-tag-keep{background:#3fb95026;color:var(--accent-green)}.eoc-confirm-tag-move{background:#58a6ff26;color:var(--accent-blue)}.eoc-warning-box{padding:var(--space-md);background:#e3b3411a;border:1px solid rgba(227,179,65,.3);border-radius:var(--radius-md);color:var(--accent-orange);text-align:center;font-size:var(--font-sm)}.budget-breakdown{display:flex;flex-direction:column;gap:var(--space-md)}.breakdown-summary{display:flex;gap:var(--space-md);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md)}.breakdown-stat{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.breakdown-stat-label{font-size:var(--font-xs);color:var(--text-muted);text-transform:uppercase}.breakdown-stat-value{font-size:var(--font-xl);font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.breakdown-expense-list{display:flex;flex-direction:column;gap:2px}.breakdown-expense-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-sm)}.breakdown-expense-info{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}.breakdown-expense-note{font-size:var(--font-md);color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.breakdown-expense-date{font-size:var(--font-xs)}.breakdown-expense-amount{font-weight:600;color:var(--accent-red);flex-shrink:0}@media(max-width:768px){.breakdown-summary{gap:var(--space-sm);padding:var(--space-sm)}.breakdown-stat-value{font-size:var(--font-md)}}.custom-category-form{display:flex;flex-direction:column;gap:var(--space-md)}.icon-picker-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:var(--space-xs)}.icon-picker-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-secondary);font-size:20px;cursor:pointer;transition:all var(--transition-fast)}.icon-picker-btn:hover{border-color:var(--accent-blue);background:var(--bg-tertiary)}.icon-picker-selected{border-color:var(--accent-blue);background:#58a6ff26;box-shadow:var(--glow-blue)}.cycle-history-v3{display:flex;flex-direction:column;gap:var(--space-md)}.cycle-history-v3 .cycle-history-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm)}.cycle-history-stats{display:flex;gap:var(--space-lg);flex-wrap:wrap}.cycle-stat{display:flex;flex-direction:column;gap:2px}.cycle-stat-label{font-size:var(--font-xs);color:var(--text-muted);text-transform:uppercase}.cycle-stat-value{font-size:var(--font-lg);font-weight:600}.cycle-history-categories{margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--border-primary)}.cycle-history-categories h4{margin:0 0 var(--space-sm);font-size:var(--font-sm);color:var(--text-secondary)}.cycle-category-list{display:flex;flex-direction:column;gap:2px}.cycle-category-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) 0;font-size:var(--font-sm)}.cycle-category-label{flex:1;color:var(--text-primary)}.cycle-category-amount{font-weight:600}.cycle-category-badge{font-size:var(--font-xs);font-weight:600}.cycle-history-clickable{cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.cycle-history-clickable:hover{border-color:var(--accent-blue);box-shadow:var(--glow-blue)}.cycle-history-footer{margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between;font-size:var(--font-sm)}.cycle-restore-btn{background:none;border:1px solid var(--accent-blue);color:var(--accent-blue);font-size:var(--font-xs);font-weight:600;cursor:pointer;padding:3px 10px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.cycle-restore-btn:hover{background:var(--accent-blue);color:#fff}.cycle-report{display:flex;flex-direction:column;gap:var(--space-lg)}.cycle-report-section{display:flex;flex-direction:column;gap:var(--space-sm)}.cycle-report-section h4{margin:0;font-size:var(--font-sm);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.cycle-report-income-list{display:flex;flex-direction:column;gap:var(--space-xs)}.cycle-report-income-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md)}.cycle-report-income-info{display:flex;flex-direction:column;gap:2px}.cycle-report-income-name{font-weight:500;color:var(--text-primary)}.cycle-report-income-expected{font-size:var(--font-xs);color:var(--text-muted)}.cycle-report-income-amount{font-weight:600}.cycle-report-categories{display:flex;flex-direction:column;gap:var(--space-sm)}.cycle-report-category{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);overflow:hidden}.cycle-report-category-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);cursor:pointer;transition:background var(--transition-fast)}.cycle-report-category-header:hover{background:var(--bg-tertiary)}.cycle-report-category-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.cycle-report-category-name{font-weight:600;color:var(--text-primary)}.cycle-report-category-meta{font-size:var(--font-xs);color:var(--text-muted)}.cycle-report-category-amount{font-weight:600;font-size:var(--font-md);flex-shrink:0;margin-left:var(--space-md)}.cycle-report-expense-list{border-top:1px solid var(--border-primary);padding:var(--space-sm) var(--space-md) var(--space-md);display:flex;flex-direction:column;gap:2px}.cycle-report-tabs-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm)}.cycle-report-tabs-header h4{margin:0}.cycle-report-tabs{display:flex;gap:2px;background:var(--bg-tertiary);border-radius:var(--radius-sm);padding:2px}.cycle-report-tab{padding:4px 12px;font-size:var(--font-sm);font-weight:500;border:none;background:transparent;color:var(--text-secondary);border-radius:calc(var(--radius-sm) - 2px);cursor:pointer;transition:background .15s,color .15s}.cycle-report-tab.active{background:var(--bg-card);color:var(--text-primary)}.cycle-report-bydate{display:flex;flex-direction:column;gap:var(--space-sm)}.cycle-report-date-group{background:var(--bg-card);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-primary)}.cycle-report-date-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-xs) var(--space-md);background:var(--bg-tertiary);border-bottom:1px solid var(--border-primary)}.cycle-report-date-label{font-size:var(--font-sm);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}.cycle-report-date-total{font-size:var(--font-sm);font-weight:600;color:var(--accent-red)}.cycle-report-expense-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border-primary);gap:var(--space-sm)}.cycle-report-expense-row:last-child{border-bottom:none}.cycle-report-expense-row-left{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.cycle-report-expense-row-category{font-size:var(--font-base);color:var(--text-primary);font-weight:500}.cycle-report-expense-row-note{font-size:var(--font-sm);color:var(--text-muted);font-style:italic}.cycle-report-expense-row-amount{font-size:var(--font-base);font-weight:600;color:var(--accent-red);white-space:nowrap;flex-shrink:0}.badge-gray{background:#7d859026;color:var(--text-secondary)}.budget-tips{display:flex;flex-direction:column;gap:var(--space-md)}.budget-tip-card{display:flex;gap:var(--space-md);padding:var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg)}.budget-tip-icon{font-size:28px;flex-shrink:0}.budget-tip-content h4{margin:0 0 var(--space-xs);font-size:var(--font-md);color:var(--text-primary)}.budget-tip-content p{margin:0;font-size:var(--font-sm);color:var(--text-secondary);line-height:1.5}.tutorial-overlay{position:fixed;inset:0;z-index:300;pointer-events:none}.tutorial-spotlight{position:fixed;border-radius:var(--radius-md);box-shadow:0 0 0 9999px #000000bf;z-index:301;transition:all .3s ease;pointer-events:none}.tutorial-tooltip{position:fixed;z-index:302;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-lg);max-width:400px;width:max-content;box-shadow:var(--shadow-lg);pointer-events:auto;animation:tutorialFadeIn .25s ease}.tutorial-tooltip--centered{top:50%!important;left:50%!important;transform:translate(-50%,-50%)}.tutorial-tooltip-title{font-size:var(--font-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-xs)}.tutorial-tooltip-description{font-size:var(--font-md);color:var(--text-secondary);line-height:1.5;margin-bottom:var(--space-md)}.tutorial-tooltip-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.tutorial-step-counter{font-size:var(--font-sm);color:var(--text-muted);white-space:nowrap}.tutorial-tooltip-actions{display:flex;gap:var(--space-xs)}.tutorial-btn-skip{background:none;border:none;color:var(--text-muted);font-size:var(--font-sm);cursor:pointer;padding:6px 10px;border-radius:var(--radius-sm);transition:color var(--transition-fast)}.tutorial-btn-skip:hover{color:var(--text-primary)}.tutorial-btn-back{background:var(--bg-secondary);border:1px solid var(--border-primary);color:var(--text-secondary);font-size:var(--font-sm);cursor:pointer;padding:6px 14px;border-radius:var(--radius-md);transition:all var(--transition-fast)}.tutorial-btn-back:hover{color:var(--text-primary);border-color:var(--text-muted)}.tutorial-btn-next{background:var(--accent-blue);border:none;color:#fff;font-size:var(--font-sm);font-weight:600;cursor:pointer;padding:6px 16px;border-radius:var(--radius-md);transition:opacity var(--transition-fast)}.tutorial-btn-next:hover{opacity:.85}.tutorial-header-btn{width:28px;height:28px;border-radius:50%;border:1px solid var(--border-primary);background:var(--bg-secondary);color:var(--text-muted);font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0}.tutorial-header-btn:hover{color:var(--accent-blue);border-color:var(--accent-blue)}@keyframes tutorialFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:480px){.tutorial-tooltip{max-width:calc(100vw - 32px);left:16px!important;right:16px;width:auto}.tutorial-tooltip--centered{left:16px!important;right:16px;transform:translateY(-50%)}}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{height:var(--header-height);background:linear-gradient(180deg,var(--bg-secondary) 0%,rgba(13,17,23,.95) 100%);border-bottom:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-lg);position:sticky;top:0;z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.app-header-left{display:flex;align-items:center;gap:var(--space-sm)}.app-title{font-size:var(--font-lg);font-weight:800;background:var(--gradient-title);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.3px}.app-title-icon{font-size:var(--font-xl);filter:drop-shadow(0 0 8px rgba(88,166,255,.3))}.app-header-right{display:flex;align-items:center;gap:var(--space-md)}.currency-selector{padding:var(--space-xs) var(--space-sm);font-size:var(--font-sm);background-color:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer}.tab-bar{display:flex;background-color:var(--bg-secondary);border-bottom:1px solid var(--border-primary);height:var(--tab-height);position:sticky;top:var(--header-height);z-index:49}.tab-item{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:0 var(--space-md);color:var(--text-muted);font-size:var(--font-md);font-weight:500;border-bottom:2px solid transparent;transition:all var(--transition-normal);position:relative}.tab-item:hover{color:var(--text-primary);background:linear-gradient(180deg,transparent 0%,rgba(88,166,255,.04) 100%)}.tab-active{color:var(--accent-blue);font-weight:600;border-bottom-color:var(--accent-blue);background:linear-gradient(180deg,transparent 0%,rgba(88,166,255,.06) 100%)}.tab-active .tab-icon{filter:drop-shadow(0 0 6px rgba(88,166,255,.3))}.tab-icon{font-size:var(--font-lg)}.app-content{flex:1;padding:var(--space-lg);max-width:1400px;width:100%;margin:0 auto}.app-fade-in{animation:appFadeIn .25s ease-out}@keyframes appFadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:600px){.app-header{padding:0 var(--space-md)}.app-title{font-size:var(--font-md)}.app-content{padding:var(--space-md)}.tab-label{display:none}.tab-icon{font-size:var(--font-xl)}}
