.upload-container{max-width:500px;margin:0 auto;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000000d;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.upload-header{text-align:center;margin-bottom:1.5rem}.upload-header h3{margin:0 0 .5rem;font-size:1.25rem;color:#1e293b;font-weight:600}.file-name{font-size:.9rem;color:#64748b;margin-top:.5rem;padding:.5rem;background:#f0f5ff;border-radius:6px;display:inline-block}.bank-selection{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap;justify-content:center}.select-group{flex:1;min-width:200px;position:relative}.select-group label{display:block;margin-bottom:.5rem;font-size:.9rem;color:#64748b;font-weight:500}.select-group select{width:100%;padding:.75rem 2.5rem .75rem 1rem;border:1px solid #e2e8f0;border-radius:8px;font-size:1rem;color:#1e293b;background-color:#fff;cursor:pointer;transition:all .2s;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%2364748b' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;background-size:12px}.select-group select:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.select-group select:disabled{background-color:#f8fafc;cursor:not-allowed;opacity:.7}.select-group select option{padding:.5rem;background:#fff}.select-group select option:hover{background-color:#e0e7ff!important}.select-group select option:checked{background-color:#4f46e5;color:#fff}.upload-button-wrapper{display:flex;justify-content:center;margin-top:1rem}.upload-button{display:inline-flex;align-items:center;justify-content:center;padding:1rem 1.5rem;background:#4f46e5;color:#fff;border-radius:8px;cursor:pointer;transition:all .2s;font-weight:500;border:none;width:auto;min-width:200px}.upload-button:hover{background:#4338ca}.upload-button.disabled{background:#e2e8f0;color:#94a3b8;cursor:not-allowed}.upload-button:before{content:"📁";margin-right:.5rem}.upload-button input{display:none}.error-message{margin-top:1rem;padding:.75rem;background:#fee2e2;color:#b91c1c;border-radius:8px;display:flex;justify-content:space-between;align-items:center}.error-message button{background:none;border:none;font-size:1.2rem;cursor:pointer;color:#b91c1c;padding:0;line-height:1}@media (max-width: 600px){.bank-selection{flex-direction:column;gap:1rem}.select-group{min-width:100%}}.auth-modal-overlay{position:fixed;inset:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;opacity:0;visibility:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer}.auth-modal-overlay.active{opacity:1;visibility:visible}.auth-modal{background-color:#fff;border-radius:16px;padding:2rem;width:90%;max-width:400px;box-shadow:0 20px 40px #00000026;position:relative;transform:translateY(20px);transition:transform .3s cubic-bezier(.4,0,.2,1);cursor:default;box-sizing:border-box;margin:0 auto}.auth-modal h2{margin:0 0 1.5rem;color:#1e293b;text-align:center;font-size:1.5rem;font-weight:700}.close-btn{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#64748b;transition:all .2s;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%}.close-btn:hover{color:#4f46e5;background-color:#f1f5f9}.auth-form{width:100%;box-sizing:border-box}.form-group{margin-bottom:1.25rem;width:100%;box-sizing:border-box}.form-group label{display:block;margin-bottom:.5rem;color:#334155;font-weight:500;font-size:.9rem}.form-group input{width:100%;padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.95rem;transition:all .2s;background-color:#f8fafc;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#4f46e5;background-color:#fff;box-shadow:0 0 0 3px #4f46e51a}.auth-error-message{background-color:#fee2e2;color:#b91c1c;padding:.75rem 1rem;border-radius:8px;margin-bottom:1.5rem;font-size:.9rem;animation:fadeIn .3s ease-out}.error-text{color:#dc2626;font-size:.8rem;margin-top:.375rem;display:block}.form-group input.error{border-color:#f87171;background-color:#fef2f2}.submit-btn{width:100%;padding:.75rem;background-color:#4f46e5;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:.5rem}.submit-btn:hover:not(:disabled){background-color:#4338ca}.submit-btn:disabled{background-color:#c7d2fe;cursor:not-allowed}.auth-switch{text-align:center;margin-top:1.5rem;color:#64748b;font-size:.9rem}.switch-mode-btn{background:none;border:none;color:#4f46e5;cursor:pointer;font-weight:600;margin-left:.25rem;transition:all .2s}.switch-mode-btn:hover{text-decoration:underline;color:#4338ca}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 480px){.auth-modal{padding:1.5rem;width:95%}.auth-modal h2{font-size:1.25rem}.form-group input{padding:.65rem .9rem}}.status-indicator{margin:1.5rem 0;padding:1rem;border-radius:8px;background:#f8fafc}.status-indicator.uploading{background:#f0f5ff;color:#4f46e5}.status-indicator.processing{background:#ecfdf5;color:#059669}.status-indicator.error{background:#fee2e2;color:#dc2626}.progress-bar{height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden;margin:.5rem 0}.progress-fill{height:100%;background:#4f46e5;transition:width .3s ease}.status-indicator.processing .progress-fill{background:#10b981}:root{--primary-color: #4f46e5;--primary-hover: #4338ca;--text-dark: #1e293b;--text-gray: #64748b;--border-color: #e2e8f0;--light-bg: #f0f5ff;--white: #ffffff}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex;justify-content:center;background-color:#f8fafc}.app{display:flex;flex-direction:column;align-items:center;min-height:100vh;width:100%;max-width:1200px;margin:0 auto;padding:0}.app-header{width:100%;padding:2rem 2rem 1.5rem;text-align:center;border-bottom:1px solid var(--border-color)}.header-content{display:flex;justify-content:space-between;align-items:center;width:100%;padding:0 1rem}.app-title{font-size:3rem;font-weight:800;margin:0 0 .5rem;cursor:pointer;transition:transform .2s ease;color:var(--text-dark)}.app-title:hover{transform:scale(1.02)}.title-part{display:inline-block;transition:color .3s ease}.title-part.accent{color:var(--primary-color)}.app-title:hover .title-part.accent{color:var(--primary-hover)}.title-icon{display:inline-block;margin-left:.5rem;transition:transform .3s ease}.app-title:hover .title-icon{transform:rotate(15deg)}.app-subtitle{font-size:1.1rem;color:var(--text-gray);margin:.75rem 0 0;font-weight:400}.user-nav{display:flex;gap:1rem;justify-content:center;margin:1rem auto 0;width:100%}.nav-link{padding:.5rem 1rem;color:var(--primary-color);text-decoration:none;border-radius:6px;transition:all .2s}.nav-link:hover{background:var(--light-bg)}.nav-link.primary{background:var(--primary-color);color:var(--white)}.nav-link.primary:hover{background:var(--primary-hover)}.auth-actions{display:flex;gap:12px;align-items:center}.auth-btn{padding:8px 20px;border-radius:20px;font-weight:500;font-size:.95rem;transition:all .2s;cursor:pointer}.login-btn{background:transparent;color:var(--primary-color);border:1px solid var(--primary-color)}.login-btn:hover{background:var(--light-bg)}.register-btn{background:var(--primary-color);color:var(--white);border:none;box-shadow:0 2px 5px #4f46e54d}.register-btn:hover{background:var(--primary-hover)}.user-profile{display:flex;align-items:center;gap:10px}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary-color),#8b5cf6);color:var(--white);display:flex;align-items:center;justify-content:center;font-weight:600}.user-name{font-weight:500;font-size:.9rem}.user-email{font-size:.75rem;color:#666}.logout-btn{background:none;border:1px solid #e2e8f0;padding:5px 12px;border-radius:6px;margin-left:12px;cursor:pointer;font-size:.8rem;transition:all .2s}.logout-btn:hover{background:#f8fafc;border-color:#cbd5e1}.app-content{width:100%;padding:0 2rem 2rem;display:flex;flex-direction:column;align-items:center}.analysis-sections{background-color:var(--white);border-radius:12px;padding:2rem;box-shadow:0 2px 10px #0000000d;width:100%;margin-top:1rem}.reset-button{background:var(--primary-color);color:var(--white);border:none;padding:.75rem 1.5rem;font-size:1rem;border-radius:8px;cursor:pointer;margin:2rem auto 0;transition:background .2s}.reset-button:hover{background:var(--primary-hover)}.auth-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;opacity:0;pointer-events:none;transition:opacity .3s ease}.auth-modal-overlay.active{opacity:1;pointer-events:all}.auth-modal{background:var(--white);padding:2rem;border-radius:12px;width:90%;max-width:400px;box-shadow:0 4px 20px #00000026;transform:translateY(20px);transition:transform .3s ease}.auth-modal-overlay.active .auth-modal{transform:translateY(0)}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width: 768px){.app-header{padding:1.5rem 1rem}.app-title{font-size:2.5rem}.header-content{flex-direction:column;gap:1rem}.auth-actions{margin-top:1rem;justify-content:center}.app-content{padding:0 1rem 1rem}}@media (max-width: 480px){.app-header{padding:1rem}.app-title{font-size:2rem}.auth-btn{padding:6px 12px;font-size:.85rem}.reset-button{width:100%;padding:1rem}.analysis-sections{padding:1rem}}.history-container{max-width:1200px;margin:0 auto;padding:2rem}.analyses-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:2rem}.analysis-card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.status-badge{padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500}.status-badge.completed{background:#ecfdf5;color:#059669}.view-button{display:inline-block;margin-top:1rem;color:#4f46e5;text-decoration:none;font-weight:500}.history-container{max-width:500px;margin:0 auto;padding:2rem}.analyses-list{margin-top:2rem}.analysis-item{display:flex;justify-content:space-between;padding:1rem;border-bottom:1px solid #e2e8f0}.analysis-item a{color:#4f46e5;text-decoration:none}.analysis-item a:hover{text-decoration:underline}.status{padding:.25rem .5rem;border-radius:4px;font-size:.8rem}.status.completed{background:#ecfdf5;color:#059669}.spends-container{max-width:1200px;margin:2rem auto;background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000014;overflow:hidden}.spends-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;background:#f8fafc;cursor:pointer;transition:background .2s ease}.spends-header:hover{background:#f1f5f9}.spends-header h2{margin:0;font-size:1.25rem;font-weight:600;color:#1e293b;display:flex;align-items:center;gap:.75rem}.toggle-icon{transition:transform .3s ease;color:#64748b}.header-icon{color:#ef4444;font-size:1.2rem}.spends-content{overflow:hidden;transition:all .3s ease}.spends-content.expanded{max-height:5000px;opacity:1;padding:1.5rem}.spends-content.collapsed{max-height:0;opacity:0;padding:0 1.5rem}.section-subtitle{color:#64748b;margin:0 0 1.5rem;font-size:.95rem;line-height:1.5}.expenses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}.expense-card{background:#fff;border-radius:12px;border:1px solid #e2e8f0;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;transition:transform .2s ease,box-shadow .2s ease}.expense-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000000d;border-color:#cbd5e1}.expense-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.expense-category{margin:0;font-size:1.1rem;font-weight:600;color:#1e293b}.expense-amount{font-weight:600;color:#b91c1c;font-size:1rem;white-space:nowrap}.expense-examples{display:flex;flex-direction:column;gap:.5rem;margin-top:.75rem;padding-top:.75rem;border-top:1px dashed #e2e8f0}.example-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#475569}.example-icon{color:#10b981;font-size:.8rem}.expenses-summary{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e2e8f0}.summary-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-radius:8px;font-weight:500}.summary-item.required{background:#f0fdf4;color:#166534}.summary-item.optional{background:#fee2e2;color:#b91c1c}@media (max-width: 768px){.spends-container{margin:1rem auto;border-radius:12px}.spends-header,.spends-content.expanded{padding:1rem}.expenses-grid{grid-template-columns:1fr}.expenses-summary{grid-template-columns:1fr;margin-top:1.5rem}}@media (max-width: 480px){.spends-header h2{font-size:1.1rem}.month-preview{font-size:.9rem;padding:.3rem .6rem}}.savings-container{max-width:1200px;margin:2rem auto;background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000014;overflow:hidden}.savings-header{padding:1.25rem 1.5rem;background:#f0fdf4;cursor:pointer;transition:background .2s ease}.savings-header:hover{background:#dcfce7}.header-content{display:flex;justify-content:space-between;align-items:center}.savings-header h2{margin:0;font-size:1.25rem;font-weight:600;color:#166534;display:flex;align-items:center;gap:.75rem}.header-icon{color:#10b981}.savings-preview{background:#fff;color:#166534;padding:.5rem 1rem;border-radius:20px;font-weight:600;border:1px solid #86efac}.savings-content{padding:1.5rem}.tabs{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.tabs button{padding:.5rem 1rem;border-radius:8px;border:1px solid #e2e8f0;background:#fff;cursor:pointer;display:flex;align-items:center;gap:.5rem;font-size:.9rem;transition:all .2s ease}.tabs button.active{background:#10b981;color:#fff;border-color:#10b981}.expenses-list{display:flex;flex-direction:column;gap:1.25rem}.expense-card{background:#fff;border-radius:12px;border:1px solid #e2e8f0;padding:1.5rem;transition:transform .2s ease}.expense-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.card-header h3{margin:0;font-size:1.1rem}.amount-block{display:flex;flex-direction:column;align-items:flex-end}.amount-block .current{color:#64748b;font-size:.9rem}.amount-block .potential{color:#10b981;font-weight:600;font-size:.95rem}.tips-section{background:#f8fafc;padding:1rem;border-radius:8px;margin:1rem 0}.tips-section h4{margin:0 0 .5rem;color:#1e293b}.tips-list{margin:0;padding-left:1.25rem}.tips-list li{margin:.5rem 0}.summary-card{margin-top:2rem;padding:1.5rem;background:#f0fdf4;border-radius:12px;text-align:center}.summary-card h3{margin:0 0 .5rem;color:#166534}.summary-amount{font-size:1.5rem;font-weight:700;color:#065f46}@media (max-width: 768px){.savings-container{margin:1rem;border-radius:12px}.card-header{flex-direction:column;align-items:flex-start;gap:.5rem}.amount-block{align-items:flex-start;width:100%}.tabs{overflow-x:auto;padding-bottom:.5rem}.tabs button{flex-shrink:0}}.subscriptions-container{max-width:1200px;margin:2rem auto;background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000014;overflow:hidden}.subscriptions-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;background:#f8fafc;cursor:pointer;transition:background .2s ease}.subscriptions-header:hover{background:#f1f5f9}.subscriptions-header h2{margin:0;font-size:1.25rem;font-weight:600;color:#1e293b;display:flex;align-items:center;gap:.75rem}.toggle-icon{transition:transform .3s ease}.header-icon{color:#f59e0b;font-size:1.2rem}.badge{background:#e2e8f0;color:#475569;padding:.25rem .75rem;border-radius:20px;font-size:.85rem;font-weight:500}.subscriptions-content{overflow:hidden;transition:all .3s ease}.subscriptions-content.expanded{max-height:5000px;opacity:1;padding:1.5rem}.subscriptions-content.collapsed{max-height:0;opacity:0;padding:0 1.5rem}.section-description{color:#64748b;margin:0 0 1.5rem;font-size:.95rem;line-height:1.5}.subscriptions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}.subscription-card{background:#fff;border-radius:12px;border:1px solid #e2e8f0;padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;transition:transform .2s ease,box-shadow .2s ease}.subscription-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000000d;border-color:#cbd5e1}.card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.subscription-name{margin:0;font-size:1.1rem;font-weight:600;color:#1e293b;line-height:1.4}.amount-badge{display:flex;align-items:center;gap:.4rem;background:#f0fdf4;color:#166534;padding:.35rem .75rem;border-radius:20px;font-weight:500;font-size:.95rem;flex-shrink:0}.amount-icon{font-size:.9rem}.card-details{display:flex;flex-direction:column;gap:.75rem}.detail-row{display:flex;justify-content:space-between;align-items:center}.detail-label{display:flex;align-items:center;gap:.5rem;color:#64748b;font-size:.85rem}.detail-icon{font-size:.9rem;color:#94a3b8}.detail-value{font-size:.95rem;font-weight:500;color:#1e293b}.frequency{background:#eff6ff;color:#1e40af;padding:.25rem .75rem;border-radius:12px;font-weight:500}.card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;border-top:1px dashed #e2e8f0;margin-top:auto}.total-label{font-size:.85rem;color:#64748b}.total-amount{font-size:1.05rem;font-weight:600;color:#b91c1c}@media (max-width: 768px){.subscriptions-container{margin:1rem auto;border-radius:12px}.subscriptions-header,.subscriptions-content.expanded{padding:1rem}.subscriptions-grid{grid-template-columns:1fr}.subscription-card{padding:1.25rem}}@media (max-width: 480px){.subscriptions-header h2{font-size:1.1rem}.badge{font-size:.8rem}.amount-badge{padding:.3rem .6rem;font-size:.9rem}}:root{--color-primary: #d32f2f;--color-primary-light: #d63031;--color-text: #495057;--color-bg-light: #f8f9fa;--color-bg-hover: #f1f3f5;--color-border: #f1f3f5;--color-white: #fff;--color-dark: #495057;--shadow-default: 0 2px 10px rgba(0, 0, 0, .08);--transition-default: all .3s ease;--transition-fast: all .2s ease;--radius-large: 12px;--radius-medium: 8px;--radius-small: 4px;--radius-pill: 20px;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem}.spends-container{margin-top:var(--space-xl);background:var(--color-white);border-radius:var(--radius-large);box-shadow:var(--shadow-default);overflow:hidden;transition:var(--transition-default);width:100%}.spends-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-lg);background:var(--color-bg-light);cursor:pointer;-webkit-user-select:none;user-select:none;transition:var(--transition-fast)}.spends-header:hover{background:var(--color-bg-hover)}.spends-header h2{margin:0;font-size:var(--text-xl);display:flex;align-items:center;gap:var(--space-sm)}.toggle-icon{display:flex;align-items:center;transition:var(--transition-fast)}.spends-content{max-height:0;overflow:hidden;transition:max-height .3s ease-out}.spends-content.expanded{max-height:1000px}.month-filter-container{display:flex;flex-direction:column;gap:var(--space-sm);width:calc(100% - 2rem);padding:var(--space-sm) var(--space-md) 0;margin:0 auto var(--space-md)}.month-filter-row{display:flex;gap:var(--space-sm);justify-content:flex-start;width:100%;padding:0 var(--space-xs)}.month-tab{flex:1 0 auto;min-width:0;max-width:calc(100% - .5rem);padding:var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius-medium);background:var(--color-white);cursor:pointer;transition:var(--transition-fast);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:var(--text-sm);margin:0 var(--space-xs)}.month-tab:hover{background:var(--color-bg-hover)}.month-tab.active{background:var(--color-dark);color:var(--color-white);border-color:var(--color-dark)}.month-preview{display:flex;align-items:center;gap:var(--space-sm);background:var(--color-bg-hover);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-pill);font-size:var(--text-sm)}.spends-table{width:100%;border-collapse:collapse;margin-bottom:var(--space-md)}.spends-table th{padding:var(--space-md);font-weight:600;text-align:left;background:var(--color-bg-light)}.spends-table td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border)}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.sortable{cursor:pointer;transition:var(--transition-fast)}.sortable:hover{background:var(--color-bg-hover)}.header-content-table{display:flex;align-items:center;justify-content:center;gap:var(--space-sm)}.total-sum-container{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background-color:var(--color-bg-light);border-radius:var(--radius-medium);margin:var(--space-md)}.total-sum-label{font-weight:600;color:var(--color-text);font-size:var(--text-base)}.total-sum-amount{font-weight:700;color:var(--color-primary-light);font-size:var(--text-lg)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.spends-table tbody tr{animation:fadeIn .3s ease-out}@media (max-width: 768px){.spends-header{padding:var(--space-sm) var(--space-md)}.spends-header h2{font-size:var(--text-lg)}.month-filter-row{gap:var(--space-xs)}.month-tab{padding:var(--space-xs);font-size:var(--text-xs)}.spends-table th,.spends-table td{padding:var(--space-sm);font-size:var(--text-sm)}.total-sum-container{margin:var(--space-sm);padding:var(--space-sm)}.month-preview{display:none}}[aria-hidden=false]{display:inline!important;visibility:visible!important}.modal-backdrop{position:fixed;inset:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-container{background-color:#fff;border-radius:16px;width:90%;max-width:600px;max-height:80vh;box-shadow:0 10px 25px -5px #0003;overflow:hidden;display:flex;flex-direction:column}.modal-header{background-color:#4f46e5;color:#fff;padding:1.5rem;display:flex;align-items:center;gap:1rem;position:relative}.modal-icon{background-color:#fff;width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#4f46e5;font-size:1.5rem;flex-shrink:0}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600;flex-grow:1;padding-right:2rem}.close-btn{position:absolute;top:1rem;right:1rem;background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:.25rem;border-radius:50%;transition:background-color .2s ease}.close-btn:hover{background-color:#fff3}.modal-content{padding:1.5rem;overflow-y:auto;flex-grow:1}.operations-header{display:grid;grid-template-columns:2fr 1fr;gap:1rem;padding:.75rem 0;margin-bottom:.5rem;border-bottom:1px solid #e2e8f0;font-weight:600;color:#4a5568;position:sticky;top:0;background-color:#fff;z-index:10}.sortable-header{display:flex;align-items:center;gap:.5rem;background:none;border:none;font:inherit;font-weight:600;color:inherit;cursor:pointer;padding:0;justify-content:flex-end}.sort-icon{font-size:.9rem;transition:transform .2s ease}.sortable-header:hover .sort-icon{transform:translateY(-2px)}.operations-list{display:flex;flex-direction:column;gap:.75rem}.operation-row{display:grid;grid-template-columns:2fr 1fr;gap:1rem;padding:.75rem;border-radius:8px;background-color:#fff;transition:background-color .2s ease}.operation-row:hover{background-color:#f8fafc}.operation-description{color:#2d3748;font-size:.95rem;word-break:break-word}.operation-amount{font-weight:600;color:#ef4444;text-align:right;white-space:nowrap}.operations-list::-webkit-scrollbar{width:6px}.operations-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.operations-list::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.operations-list::-webkit-scrollbar-thumb:hover{background:#a0aec0}@media (max-width: 768px){.modal-container{width:95%;max-height:85vh}.modal-header{padding:1rem}.modal-icon{width:40px;height:40px;font-size:1.25rem}.modal-header h3{font-size:1.1rem}.modal-content{padding:1rem}.operations-header{grid-template-columns:1.5fr 1fr;font-size:.9rem;gap:.5rem}.operation-row{grid-template-columns:1.5fr 1fr;gap:.5rem;padding:.5rem}.operation-description,.operation-amount{font-size:.9rem}.operation-date{font-size:.75rem}}.spends-container{max-width:1200px;margin:2rem auto;background:#fff;border-radius:12px;box-shadow:0 2px 10px #00000014;overflow:hidden;transition:all .3s ease}.spends-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#f8f9fa;cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s ease}.spends-header:hover{background:#f1f3f5}.spends-header h2{margin:0;font-size:1.25rem;display:flex;align-items:center;gap:.5rem;color:#495057}.toggle-icon{display:flex;align-items:center;transition:transform .3s ease}.month-preview{display:flex;align-items:center;gap:.5rem;background:#f1f3f5;padding:.25rem .75rem;border-radius:20px;font-size:.875rem}.calendar-icon{font-size:.875rem}.spends-content{max-height:0;overflow:hidden;transition:max-height .4s ease-out}.spends-content.expanded{max-height:5000px}.table-container{display:flex;flex-direction:column;width:100%}.table-header{display:flex;background:#f8f9fa;font-weight:600;color:#495057;position:sticky;top:0}.header-cell{padding:1rem 1.5rem;flex:1;border-bottom:1px solid #e2e8f0}.table-body{display:flex;flex-direction:column}.table-row{display:flex;border-bottom:1px solid #f1f3f5;cursor:pointer;transition:background-color .2s ease}.table-row:hover{background-color:#f8f9fa!important}.table-cell{padding:.75rem 1.5rem;flex:1;display:flex;align-items:center}.category-cell{display:flex;align-items:center;gap:.75rem}.category-icon{font-size:1.25rem;color:#fff;background:#4f46e5;width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.advice-text{color:#495057;line-height:1.5}.savings-amount{font-weight:600;color:#10b981;justify-content:flex-end}.sortable{cursor:pointer;transition:background .2s}.sortable:hover{background:#f1f5f9}.header-content{display:flex;align-items:center;gap:.5rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.table-row{animation:fadeIn .3s ease-out forwards}@media (max-width: 768px){.spends-container{margin:1rem auto;border-radius:8px}.spends-header{padding:.75rem 1rem}.spends-header h2{font-size:1rem}.header-cell,.table-cell{padding:.5rem 1rem;font-size:.875rem}.category-icon{width:28px;height:28px;font-size:1rem}.table-header{display:none}.table-row{flex-direction:column;padding:1rem;gap:.5rem}.table-cell{padding:.25rem 0;width:100%}.category-cell{margin-bottom:.5rem}.savings-amount{justify-content:flex-start;font-size:1.1rem;margin-top:.5rem}}.modal-backdrop{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-container{background:#fff;border-radius:16px;width:90%;max-width:600px;max-height:80vh;overflow:hidden;box-shadow:0 20px 25px -5px #0000001a}.modal-header{background:#4f46e5;color:#fff;padding:1.5rem;display:flex;align-items:center;gap:1rem;position:relative}.modal-header h3{margin:0;font-size:1.5rem;flex:1}.modal-icon{background:#fff;width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#4f46e5;font-size:1.5rem}.close-btn{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s ease}.close-btn:hover{background:#fff3}.modal-content{padding:1.5rem}.operations-header{display:grid;grid-template-columns:2fr 1fr;gap:1rem;padding:.5rem 0;margin-bottom:.5rem;border-bottom:1px solid #e2e8f0;font-weight:600;color:#4a5568}.operations-list{display:flex;flex-direction:column;gap:.5rem;max-height:50vh;overflow-y:auto;padding-right:.5rem}.operation-row{display:grid;grid-template-columns:2fr 1fr;gap:1rem;padding:.75rem;border-radius:8px;transition:background .2s ease}.operation-row:hover{background:#f8fafc}.operation-description{color:#2d3748;font-size:.95rem}.operation-amount{font-weight:600;color:#ef4444;text-align:right}.operation-date{grid-column:span 2;font-size:.8rem;color:#718096;margin-top:.25rem}.no-operations{text-align:center;padding:2rem;color:#718096;font-size:.95rem}.loading-spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top-color:#4f46e5;border-radius:50%;margin:2rem auto;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.fhd-distribution-section{margin-top:2rem}.fhd-distribution-content{display:flex;flex-direction:column;gap:1.5rem}.fhd-total-summary{display:flex;flex-direction:column;align-items:center;margin-bottom:.5rem}.fhd-total-amount{font-size:1.8rem;font-weight:700;color:var(--text-dark);line-height:1}.fhd-total-label{font-size:.9rem;color:var(--text-gray);margin-top:.5rem}.fhd-chart-container{height:250px;margin-top:1rem}.fhd-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.fhd-stat-card{background:var(--bg-light);border-radius:var(--radius-md);padding:1rem;text-align:center;transition:all .2s}.fhd-stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.fhd-stat-card.accent{background:var(--primary-light)}.fhd-stat-value{font-weight:700;font-size:1.1rem;color:var(--text-dark);margin-bottom:.25rem}.fhd-stat-label{font-size:.8rem;color:var(--text-gray)}@media (max-width: 600px){.fhd-distribution-section{padding:1rem}.fhd-total-amount{font-size:1.5rem}.fhd-stats-grid{grid-template-columns:1fr 1fr}.fhd-chart-container{height:200px}}.fh-container{background:#fff;border-radius:16px;box-shadow:0 4px 12px #0000000d;margin:1.5rem 0;overflow:visible;font-family:Segoe UI,system-ui,sans-serif;position:relative}.fh-header{padding:1.25rem 1.5rem;background:#f9fafb;cursor:pointer;display:flex;align-items:center;transition:all .2s ease;position:relative;z-index:2}.fh-header:hover{background:#f3f4f6}.fh-header h2{margin:0;font-size:1.1rem;font-weight:600;color:#111827;display:flex;align-items:center;gap:.75rem}.fh-toggle-icon{display:flex;transition:transform .2s}.fh-icon{font-size:1.2em}.fh-overall-score{margin-left:auto;padding:.35rem .8rem;border-radius:20px;font-size:.9rem;font-weight:600;color:#fff;min-width:40px;text-align:center}.fh-content{padding:1.5rem}.fh-indicators-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem;margin-bottom:1.5rem;position:relative}.fh-indicator-card{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 1px 3px #0000000d;border:1px solid #f3f4f6;position:relative}.fh-indicator-card.patterns{border-left:3px solid #8b5cf6}.fh-indicator-card.patterns .fh-progress-bar{background:linear-gradient(90deg,#8b5cf6,#ec4899)}.fh-indicator-card.patterns .fh-indicator-desc{font-size:.8rem;line-height:1.4;margin-bottom:.75rem}.fh-indicator-card.patterns .fh-status-label{font-size:.8rem;text-transform:none;letter-spacing:normal}.fh-indicator-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.fh-indicator-header h3{margin:0;font-size:1rem;font-weight:600;color:#1f2937}.fh-indicator-value{font-size:1.2rem;font-weight:700}.fh-indicator-desc{margin:0 0 1rem;font-size:.85rem;color:#6b7280}.fh-progress-container{height:8px;background:#f3f4f6;border-radius:4px;margin-bottom:1rem;overflow:hidden}.fh-progress-bar{height:100%;border-radius:4px;transition:width .5s ease}.fh-indicator-footer{display:flex;justify-content:space-between;align-items:center}.fh-status-label{font-size:.85rem;font-weight:600;text-transform:uppercase}.fh-indicator-card .dual-value{display:flex;justify-content:space-between;width:100%}.fh-indicator-card .dual-value span{font-size:.9em}.fh-tooltip{position:relative;display:inline-block}.fh-info-icon{color:#9ca3af;cursor:help;transition:color .2s}.fh-info-icon:hover{color:#6b7280}.fh-tooltip-text{visibility:hidden;width:220px;background:#374151;color:#fff;text-align:left;border-radius:6px;padding:.75rem;position:absolute;z-index:1000;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:10px;opacity:0;transition:opacity .3s;font-size:.85rem;font-weight:400;line-height:1.4;box-shadow:0 4px 6px #0000001a;pointer-events:none;white-space:pre-line}.fh-indicator-card:nth-child(2n) .fh-tooltip-text,.fh-indicator-card:nth-child(4n) .fh-tooltip-text{left:0;right:auto;transform:none}.fh-indicator-card:nth-child(3n) .fh-tooltip-text{left:auto;right:0;transform:none}.fh-tooltip:hover .fh-tooltip-text{visibility:visible;opacity:1}.fh-summary{text-align:center;padding:1.5rem;background:#f9fafb;border-radius:12px}.fh-summary-score{font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.fh-summary-text{font-size:1rem;color:#4b5563;max-width:500px;margin:0 auto}.fh-no-data{padding:1.5rem;text-align:center;color:#6b7280}@media (max-width: 768px){.fh-indicators-grid{grid-template-columns:1fr}.fh-header,.fh-content{padding:1rem}.fh-tooltip-text{left:50%!important;right:auto!important;transform:translate(-50%)!important;width:200px}.fh-indicator-card.patterns .fh-indicator-desc{font-size:.75rem}}:root{--primary: #4f46e5;--primary-light: #f0f5ff;--text-dark: #111827;--text-gray: #6b7280;--text-light: #9ca3af;--bg-light: #f9fafb;--border: #e5e7eb;--success: #10b981;--white: #ffffff;--shadow-sm: 0 2px 8px rgba(0,0,0,.05);--shadow-md: 0 4px 12px rgba(0,0,0,.05);--shadow-lg: 0 10px 25px rgba(0,0,0,.05);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 20px}.fhd-container{max-width:800px;margin:0 auto;padding:1.5rem;font-family:Inter,-apple-system,sans-serif}.fhd-main-card{display:flex;align-items:center;justify-content:space-between;padding:2rem;border-radius:var(--radius-xl);margin-bottom:2rem;box-shadow:var(--shadow-lg)}.fhd-score{text-align:center}.fhd-score-value{font-size:4rem;font-weight:800;line-height:1;background:linear-gradient(135deg,var(--primary),#8b5cf6);-webkit-background-clip:text;background-clip:text;color:transparent}.fhd-score-label{font-size:1rem;color:var(--text-gray);display:block;margin-top:.5rem}.fhd-status h2{margin:0 0 .5rem;font-size:1.5rem;color:var(--text-dark)}.fhd-status-badge{padding:.5rem 1rem;border-radius:100px;font-weight:600;color:var(--white);display:inline-block;font-size:.9rem}.fhd-metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.fhd-metric-card{background:var(--white);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-md);display:flex;align-items:center;transition:transform .2s}.fhd-metric-card:hover{transform:translateY(-3px)}.fhd-metric-icon{margin-right:1rem;padding:.75rem;border-radius:50%;background:var(--bg-light)}.fhd-metric-content h3{margin:0 0 .25rem;font-size:.95rem;color:var(--text-gray);font-weight:500}.fhd-metric-value{font-size:1.5rem;font-weight:700}.fhd-metric-tip{font-size:.8rem;color:var(--text-gray);margin-top:.25rem}.fhd-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:1.5rem}.fhd-tab{padding:.75rem 1.5rem;background:none;border:none;font-weight:500;color:var(--text-light);cursor:pointer;position:relative}.fhd-tab.active{color:var(--primary)}.fhd-tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--primary)}.fhd-progress-bars{margin-top:1rem}.fhd-progress-item{margin-bottom:1rem}.fhd-progress-label{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.9rem}.fhd-progress-track{height:8px;background:var(--bg-light);border-radius:var(--radius-sm);overflow:hidden}.fhd-progress-bar{height:100%;border-radius:var(--radius-sm)}.fhd-quick-actions{margin-top:2rem}.fhd-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.fhd-action-card{display:flex;align-items:center;padding:1.25rem;background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);cursor:pointer;transition:all .2s}.fhd-action-card:hover{transform:translateY(-3px);box-shadow:0 6px 16px #0000001a}.fhd-action-icon{margin-right:1rem;padding:.75rem;border-radius:var(--radius-lg);background:var(--primary-light);color:var(--primary)}.fhd-action-content{flex-grow:1}.fhd-action-content h4{margin:0 0 .25rem;font-size:1rem}.fhd-action-value{font-size:1.25rem;font-weight:700;margin-bottom:.25rem}.fhd-action-tip{font-size:.8rem;color:var(--text-gray)}.fhd-action-arrow{color:var(--text-light);margin-left:1rem}.fhd-no-data{text-align:center;padding:2rem;color:var(--text-light);background:var(--bg-light);border-radius:var(--radius-lg)}.fhd-tab-content{display:flex;flex-direction:column;gap:2rem}.fhd-section{background:var(--white);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-md)}.fhd-recommendations-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1rem}.fhd-recommendation-item{display:flex;gap:1rem;align-items:flex-start}.fhd-recommendation-content{flex:1}.fhd-recommendation-badge{background:var(--primary);color:var(--white);width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}.fhd-recommendation-savings{background:color-mix(in srgb,var(--success) 12%,transparent);color:var(--success);padding:.25rem .75rem;border-radius:100px;font-weight:600;font-size:.85rem}@media (max-width: 600px){.fhd-main-card{flex-direction:column;text-align:center;padding:1.5rem}.fhd-status{margin-top:1.5rem}.fhd-metrics-grid,.fhd-actions-grid{grid-template-columns:1fr}}.analysis-details-container{box-sizing:border-box;width:100%;max-width:1000px;margin:0 auto;padding:2rem;overflow-x:hidden}.analysis-sections{box-sizing:border-box;width:100%;background-color:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 10px #0000000d;margin:0 auto}.analysis-section-card{box-sizing:border-box;width:100%;background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 10px #00000014;margin-bottom:1.5rem}.back-button{box-sizing:border-box;display:inline-block;background:none;border:none;color:#4f46e5;font-size:1rem;padding:.5rem 1rem;margin-bottom:2rem;cursor:pointer}@media (max-width: 768px){.analysis-details-container{padding:1rem;max-width:100vw}.analysis-sections{padding:1.5rem;border-radius:10px;width:calc(100vw - 2rem);margin-left:1rem;margin-right:1rem}.analysis-section-card{padding:1.25rem;margin-bottom:1.25rem}}@media (max-width: 480px){.analysis-details-container{padding:.5rem}.analysis-sections{padding:1rem;border-radius:8px;width:calc(100vw - 1rem);margin-left:.5rem;margin-right:.5rem}.analysis-section-card{padding:1rem;margin-bottom:1rem}.back-button{margin-bottom:1.5rem;padding:.5rem}}@supports (-webkit-touch-callout: none){.analysis-details-container{padding-left:max(.5rem,env(safe-area-inset-left));padding-right:max(.5rem,env(safe-area-inset-right))}.analysis-sections{width:calc(100vw - max(1rem,env(safe-area-inset-left)) - max(1rem,env(safe-area-inset-right)))}}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;background-color:#f8fafc}#root{width:100%;max-width:1200px;margin:0 auto;padding:2rem}h1{font-size:3.2em;line-height:1.1;color:#1e293b}button{border-radius:8px;border:1px solid #e2e8f0;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#fff;cursor:pointer;transition:all .25s;color:#1e293b}button:hover{border-color:#4f46e5;background-color:#f0f5ff}button:focus,button:focus-visible{outline:4px auto #4f46e5}
