.login{align-items:center;background-color:#fafafa;display:flex;justify-content:center;min-height:100vh;padding:20px}.login-container{background:#fff;border:1px solid #f0f0f0;border-radius:2px;box-shadow:0 1px 3px #0000000d;max-width:420px;padding:60px 40px;width:100%}.login-header{margin-bottom:40px;text-align:center}.login-header h2{color:#1a1a1a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-size:1.8rem;font-weight:300;margin:0 0 10px}.login-header p{color:#666;font-size:.95rem;font-weight:400;margin:0}.login-form{margin-bottom:40px}.login-footer{border-top:1px solid #f0f0f0;padding-top:30px;text-align:center}.login-footer p{color:#666;font-size:.9rem;font-weight:400;margin:0}.register{align-items:center;background-color:#fafafa;display:flex;justify-content:center;min-height:100vh;padding:20px}.register-container{background:#fff;border:1px solid #f0f0f0;border-radius:2px;box-shadow:0 1px 3px #0000000d;max-width:480px;padding:60px 40px;width:100%}.register-header{margin-bottom:40px;text-align:center}.register-header h2{color:#1a1a1a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-size:1.8rem;font-weight:300;margin:0 0 10px}.register-header p{color:#666;font-size:.95rem;font-weight:400;margin:0}.register-form{margin-bottom:40px}.form-row{display:flex;gap:20px;margin-bottom:24px}.form-row .form-group{flex:1 1;margin-bottom:0}.form-group{margin-bottom:24px}.form-group input{background:#0000;border:none;border-bottom:1px solid #e0e0e0;border-radius:0;box-sizing:border-box;font-family:inherit;font-size:1rem;padding:16px 0;transition:border-color .3s ease;width:100%}.form-group input::placeholder{color:#999;font-weight:400}.form-group input:focus{border-bottom-color:#1a1a1a;outline:none}.form-group input:disabled{background-color:initial;color:#ccc;cursor:not-allowed}.btn-primary{border-radius:2px;font-family:inherit;letter-spacing:.01em;padding:18px 0;width:100%}.btn-primary:hover:not(:disabled){box-shadow:0 2px 8px #00000026;transform:translateY(-.5px)}.btn-primary:disabled{background:#1a1a1a;opacity:.5}.error-message{background-color:#fafafa;border:1px solid #ffebee;border-radius:2px;color:#d32f2f;font-weight:400;margin-bottom:24px;padding:16px}.register-footer{border-top:1px solid #f0f0f0;padding-top:30px;text-align:center}.register-footer p{color:#666;font-size:.9rem;font-weight:400;margin:0}.link-button{font-size:inherit;font-weight:500;text-decoration:none}.link-button:hover{text-decoration:underline}@media (max-width:480px){.register-container{margin:10px;padding:50px 30px}.form-row{flex-direction:column;gap:0}.form-row .form-group{margin-bottom:24px}}.form-help{color:#666;display:block;font-size:.85rem;font-weight:400;margin-top:8px}.verify-email{align-items:center;background-color:#fafafa;display:flex;justify-content:center;min-height:100vh;padding:20px}.verify-container{background:#fff;border:1px solid #f0f0f0;border-radius:8px;box-shadow:0 2px 10px #0000001a;max-width:520px;overflow:hidden;width:100%}.verify-header{background:linear-gradient(135deg,#1a1a1a,#333);color:#fff;padding:30px;text-align:center}.verify-header h1{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-size:1.8rem;font-weight:300;margin:0}.verify-content{padding:40px 35px;text-align:center}.verify-content h2{color:#1a1a1a;font-size:1.5rem;font-weight:500;margin:0 0 15px}.verify-content p{color:#666;font-size:1rem;line-height:1.6;margin:0 0 25px}.error-icon,.success-icon,.verify-icon{display:block;font-size:3rem;margin-bottom:20px}.success-icon{background:#d4edda;color:#28a745}.error-icon,.success-icon{align-items:center;border-radius:50%;display:flex;font-size:2.5rem;font-weight:700;height:80px;justify-content:center;margin:0 auto 20px;width:80px}.error-icon{background:#f8d7da;color:#dc3545}.verify-icon{color:#6c757d}.loading-spinner{border:4px solid #f3f3f3;height:50px;margin:0 auto 20px;width:50px}.loading-dots{display:flex;gap:8px;justify-content:center;margin-top:20px}.loading-dots span{animation:bounce 1.4s infinite;background:#1a1a1a;border-radius:50%;height:8px;width:8px}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.verify-content.success,.verify-content.success h2,.verify-content.success p{color:#155724}.verify-content.error h2,.verify-content.error p{color:#721c24}.email-info{background:#e3f2fd;border-left:4px solid #2196f3;border-radius:0 6px 6px 0;margin:20px 0;padding:15px 20px;text-align:left}.email-info strong{color:#1565c0}.verification-form{margin:30px 0}.form-group{text-align:left}.form-group label{color:#1a1a1a}.code-input{border:2px solid #e0e0e0;border-radius:6px;font-family:Courier New,monospace;font-size:1.2rem;font-weight:600;letter-spacing:8px;padding:16px;text-align:center;transition:border-color .3s ease;width:100%}.code-input:focus{border-color:#1a1a1a;outline:none}.code-input:disabled{background-color:#f8f9fa;cursor:not-allowed}.form-group small{color:#6c757d;display:block;font-size:.85rem;margin-top:8px;text-align:center}.btn-primary,.btn-secondary{border:none;border-radius:6px;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:500;margin:0 8px;padding:14px 28px;transition:all .2s ease}.btn-primary:hover:not(:disabled){background:#333;box-shadow:0 4px 12px #00000026;transform:translateY(-1px)}.btn-primary:disabled{background:#ccc;box-shadow:none;cursor:not-allowed;transform:none}.btn-secondary:hover:not(:disabled){background:#f8f9fa;border-color:#ccc}.btn-secondary:disabled{border-color:#e9ecef;color:#ccc;cursor:not-allowed}.error-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:25px 0}.resend-section{background:#f8f9fa;border-radius:6px;margin:25px 0;padding:20px}.resend-section p{color:#495057;font-size:.95rem;margin:0 0 15px}.help-section{background:#fff3cd;border-left:4px solid #ffc107;border-radius:0 6px 6px 0;margin:25px 0;padding:20px;text-align:left}.help-section p{color:#856404;font-weight:600;margin:0 0 10px}.help-section ul{color:#856404;margin:0;padding-left:20px}.help-section li{font-size:.9rem;margin:5px 0}.back-to-login{border-top:1px solid #e9ecef;margin-top:30px;padding-top:25px}.link-button{background:none;border:none;color:#1a1a1a;cursor:pointer;font-family:inherit;font-size:.95rem;text-decoration:underline}.link-button:hover{color:#333;text-decoration:none}@media (max-width:576px){.verify-email{padding:10px}.verify-container{border-radius:0;margin:0}.verify-content{padding:30px 25px}.verify-header{padding:25px 20px}.verify-header h1{font-size:1.5rem}.error-actions{flex-direction:column}.btn-primary,.btn-secondary{margin:5px 0;width:100%}.code-input{font-size:1.1rem;letter-spacing:4px}}.persian-date-picker{direction:rtl;font-family:Tahoma,Arial,sans-serif;position:relative;width:100%}.date-input-container{gap:8px}.persian-date-input{background:#fff;border:2px solid #e2e8f0;border-radius:12px;color:#2d3748;cursor:pointer;direction:rtl;flex:1 1;font-family:inherit;font-size:1rem;padding:16px 18px;text-align:right;transition:all .2s ease}.persian-date-input:focus{border-color:#1a1a1a;box-shadow:0 0 0 3px #1a1a1a1a;outline:none}.persian-date-input:disabled{background:#f7fafc;color:#a0aec0;cursor:not-allowed}.calendar-button{background:#f7fafc;border:2px solid #e2e8f0;border-radius:12px;color:#4a5568;cursor:pointer;font-family:inherit;font-size:1.2rem;padding:16px 20px;transition:all .2s ease;white-space:nowrap}.calendar-button:hover:not(:disabled){background:#edf2f7;border-color:#cbd5e0;transform:translateY(-1px)}.calendar-button:disabled{cursor:not-allowed;opacity:.5}.now-button{background:#1a1a1a;border:2px solid #1a1a1a;color:#fff}.now-button:hover:not(:disabled){background:#2d3748;border-color:#2d3748}.date-picker-dropdown{background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 10px 25px #0000001a;direction:rtl;left:0;margin-top:8px;padding:20px;position:absolute;right:0;top:100%;z-index:1000}.persian-calendar{font-family:Tahoma,Arial,sans-serif;width:100%}.calendar-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px;padding:0 10px}.nav-button{background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;color:#4a5568;cursor:pointer;font-family:inherit;font-size:1.2rem;padding:8px 12px;transition:all .2s ease}.nav-button:hover{background:#edf2f7;border-color:#cbd5e0}.month-year{color:#2d3748;font-size:1.1rem;font-weight:600;text-align:center}.calendar-weekdays{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr);margin-bottom:10px}.weekday{color:#4a5568;font-size:.9rem;font-weight:600;padding:8px 4px;text-align:center}.calendar-days{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr)}.calendar-day{align-items:center;aspect-ratio:1;border:2px solid #0000;border-radius:8px;cursor:pointer;display:flex;font-size:.9rem;justify-content:center;transition:all .2s ease}.calendar-day:hover{background:#f7fafc;border-color:#e2e8f0}.calendar-day.today{background:#e6fffa;border-color:#38b2ac;color:#234e52;font-weight:600}.calendar-day.selected{background:#1a1a1a;border-color:#1a1a1a;color:#fff;font-weight:600}.calendar-day.empty{cursor:default;opacity:0}.calendar-day.empty:hover{background:#0000;border-color:#0000}.time-picker{align-items:center;border-top:2px solid #e2e8f0;display:flex;gap:12px;margin-top:20px;padding-top:20px}.time-label{color:#4a5568;font-size:.9rem;font-weight:600;white-space:nowrap}.time-inputs{align-items:center;display:flex;gap:8px}.time-input{border:2px solid #e2e8f0;border-radius:8px;font-family:inherit;font-size:.9rem;padding:8px 12px;text-align:center;transition:all .2s ease;width:60px}.time-input:focus{border-color:#1a1a1a;box-shadow:0 0 0 3px #1a1a1a1a;outline:none}@media (max-width:768px){.date-input-container{flex-direction:column;gap:8px}.calendar-button,.now-button,.persian-date-input{width:100%}.date-picker-dropdown{left:50%;max-height:80vh;max-width:400px;overflow-y:auto;position:fixed;top:50%;transform:translate(-50%,-50%);width:90vw}.calendar-days{gap:2px}.calendar-day{font-size:.8rem}}@media (prefers-color-scheme:dark){.persian-date-input{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.persian-date-input:focus{border-color:#e2e8f0}.date-picker-dropdown{background:#2d3748;border-color:#4a5568}.month-year{color:#e2e8f0}.weekday{color:#a0aec0}.calendar-day{color:#e2e8f0}.calendar-day:hover{background:#4a5568;border-color:#718096}.calendar-day.today{background:#234e52;color:#e6fffa}.time-picker{border-color:#4a5568}.time-label{color:#a0aec0}.time-input{background:#4a5568;border-color:#718096;color:#e2e8f0}.time-input:focus{border-color:#e2e8f0}}.add-expense-overlay{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;display:flex;height:100vh;justify-content:center;left:0;padding:20px;position:fixed;top:0;width:100vw;z-index:2000}.add-expense-modal{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;max-height:90vh;max-width:600px;overflow:hidden;position:relative;width:100%}.add-expense-header{align-items:center;background:linear-gradient(135deg,#1a1a1a,#2d2d2d);border-radius:16px 16px 0 0;color:#fff;display:flex;justify-content:space-between;padding:30px 35px}.add-expense-header h2{color:#fff;font-size:1.4rem;font-weight:500;margin:0}.add-expense-form{max-height:calc(90vh - 100px);overflow-y:auto;padding:35px}.btn-cancel,.btn-submit{align-items:center;display:flex;gap:8px;justify-content:center;min-width:120px}.btn-submit:disabled{background:#a0aec0;border-color:#a0aec0}@media (max-width:768px){.add-expense-overlay{padding:10px}.add-expense-modal{max-height:95vh}.add-expense-header{padding:25px}.add-expense-header h2{font-size:1.2rem}.add-expense-form{padding:25px}.form-group{margin-bottom:20px}.date-input-container{align-items:stretch;flex-direction:column;gap:10px}.now-button{padding:12px 16px}.form-actions{flex-direction:column-reverse;gap:12px}.btn-cancel,.btn-submit{padding:14px 24px;width:100%}}@media (max-width:480px){.add-expense-form,.add-expense-header{padding:20px}.form-actions{margin-top:25px;padding-top:20px}}.receipt-badge{color:#68d391;font-size:.85rem;font-weight:400;margin-left:8px;opacity:.9}@media (max-width:768px){.receipt-badge{display:block;font-size:.75rem;margin-left:0;margin-top:4px}}.expenses-table-container{background:#fff;border:1px solid #f0f0f0;border-radius:12px;box-shadow:0 2px 8px #0000000f;overflow:hidden;width:100%}.table-wrapper{overflow-x:auto;overflow-y:visible}.expenses-table{border-collapse:collapse;font-size:.9rem;min-width:800px;width:100%}.expenses-table thead{background:#f8f9fa;border-bottom:2px solid #e9ecef}.expenses-table th{color:#495057;font-size:.85rem;font-weight:500;letter-spacing:.05em;padding:16px 12px;text-align:left;text-transform:uppercase;white-space:nowrap}.date-column{width:100px}.time-column{width:80px}.category-column{width:140px}.amount-column{text-align:right;width:100px}.description-column{width:180px}.location-column{width:140px}.notes-column{width:180px}.actions-column{text-align:center;width:60px}.expenses-table tbody{background:#fff}.expense-row{border-bottom:1px solid #f0f2f5;cursor:pointer;transition:all .2s ease}.expense-row:hover{background:#f8f9fa;box-shadow:0 2px 8px #00000014;transform:translateY(-1px)}.expense-row:active{transform:translateY(0)}.expense-row:focus{background:#f0f2f5;outline:2px solid #1a1a1a;outline-offset:-2px}.expense-row:last-child{border-bottom:none}.expenses-table td{color:#1a1a1a;padding:16px 12px;vertical-align:middle}.date-cell{font-weight:500}.date-text{color:#1a1a1a;font-size:.9rem}.time-text{color:#666;font-family:Courier New,monospace;font-size:.85rem}.category-content{align-items:center;display:flex;gap:10px}.category-icon-small{align-items:center;border-radius:6px;display:flex;flex-shrink:0;font-size:.9rem;height:28px;justify-content:center;width:28px}.category-name{color:#1a1a1a;font-size:.85rem;font-weight:500;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.amount-cell{text-align:right}.amount-text{color:#1a1a1a;font-size:.95rem;font-weight:600}.description-text,.location-text,.notes-text{color:#666;font-size:.85rem;line-height:1.4}.description-text{color:#1a1a1a;font-weight:400}.actions-cell{text-align:center}.edit-button{background:none;border:none;border-radius:6px;color:#666;cursor:pointer;font-size:1rem;padding:8px;transition:all .2s ease}.edit-button:hover{background:#e9ecef;color:#1a1a1a;transform:scale(1.1)}.edit-button:active{transform:scale(.95)}.table-loading{align-items:center;color:#666;display:flex;flex-direction:column;justify-content:center;padding:60px 40px}.loading-spinner{border:3px solid #f3f3f3;border-radius:50%;border-top-color:#1a1a1a;height:40px;margin-bottom:20px;width:40px}.table-loading p{font-size:1rem;font-weight:400;margin:0}.table-empty{color:#666;padding:60px 40px;text-align:center}.empty-icon{font-size:3rem;opacity:.7}.table-empty h3{color:#1a1a1a;font-size:1.2rem;font-weight:500;margin:0 0 10px}.table-empty p{font-size:1rem;line-height:1.5;margin:0 0 25px}.btn-retry{background:#0000;border:2px solid #e0e0e0;border-radius:8px;color:#1a1a1a;cursor:pointer;font-family:inherit;font-size:.95rem;font-weight:500;padding:12px 24px;transition:all .2s ease}.btn-retry:hover{background:#1a1a1a;border-color:#1a1a1a;color:#fff;transform:translateY(-1px)}.table-footer{align-items:center;background:#f8f9fa;border-top:1px solid #e9ecef;display:flex;justify-content:space-between;padding:20px 30px}.showing-text{color:#666;font-size:.9rem;font-weight:400;margin:0}.view-all-button{background:#0000;border:1px solid #e0e0e0;border-radius:6px;color:#1a1a1a;cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:500;padding:8px 16px;transition:all .2s ease}.view-all-button:hover{background:#1a1a1a;border-color:#1a1a1a;color:#fff;transform:translateY(-1px)}@media (max-width:768px){.table-wrapper{overflow-x:scroll}.expenses-table{min-width:900px}.expenses-table td,.expenses-table th{padding:12px 8px}.category-content{gap:8px}.category-name{max-width:80px}.table-empty,.table-loading{padding:40px 20px}.table-footer{flex-direction:column;gap:15px;padding:15px 20px;text-align:center}.view-all-button{padding:12px 20px;width:100%}}@media (max-width:480px){.expenses-table td,.expenses-table th{padding:10px 6px}.category-icon-small{font-size:.8rem;height:24px;width:24px}.category-name{font-size:.8rem;max-width:60px}.amount-text{font-size:.9rem}.description-text,.location-text,.notes-text{font-size:.8rem}}.edit-expense-overlay{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;display:flex;height:100vh;justify-content:center;left:0;padding:20px;position:fixed;top:0;width:100vw;z-index:2000}.edit-expense-modal{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;max-height:90vh;max-width:600px;overflow:hidden;position:relative;width:100%}.edit-expense-header{align-items:center;background:linear-gradient(135deg,#1a1a1a,#2d2d2d);border-radius:16px 16px 0 0;color:#fff;display:flex;justify-content:space-between;padding:30px 35px}.edit-expense-header h2{color:#fff;font-size:1.4rem;font-weight:500;margin:0}.edit-expense-form{max-height:calc(90vh - 100px);overflow-y:auto;padding:35px}.error-message{align-items:center;border-radius:10px;display:flex;font-size:.9rem;gap:10px;margin-bottom:25px;padding:16px 20px}.required{color:#e53e3e;font-weight:600}.date-input-container{align-items:center;display:flex;gap:12px}.date-input{background:#fff;border:2px solid #e2e8f0;border-radius:12px;color:#2d3748;flex:1 1;font-family:inherit;font-size:1rem;padding:16px 18px;transition:all .2s ease}.date-input:focus{border-color:#1a1a1a;box-shadow:0 0 0 3px #1a1a1a1a;outline:none}.date-input:disabled{background:#f7fafc;color:#a0aec0;cursor:not-allowed}.now-button{background:#f7fafc;border:2px solid #e2e8f0;border-radius:12px;color:#4a5568;cursor:pointer;font-family:inherit;font-size:.9rem;font-weight:500;padding:16px 20px;transition:all .2s ease;white-space:nowrap}.now-button:hover:not(:disabled){background:#edf2f7;border-color:#cbd5e0;transform:translateY(-1px)}.now-button:disabled{cursor:not-allowed;opacity:.5}.category-select{-webkit-appearance:none;appearance:none;background:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right 16px center;background-repeat:no-repeat;background-size:16px;border:2px solid #e2e8f0;border-radius:12px;color:#2d3748;font-family:inherit;font-size:1rem;padding:16px 50px 16px 18px;transition:all .2s ease;width:100%}.category-select:focus{border-color:#1a1a1a;box-shadow:0 0 0 3px #1a1a1a1a;outline:none}.category-select:disabled{background:#f7fafc;color:#a0aec0;cursor:not-allowed}.loading-select{background:#f7fafc;border:2px solid #e2e8f0;border-radius:12px;color:#a0aec0;font-style:italic;padding:16px 18px}.amount-input-container{align-items:center;display:flex;position:relative}.currency-symbol{color:#4a5568;padding-left:4px;pointer-events:none;position:absolute;right:18px;top:50%;transform:translateY(-50%);z-index:2}.amount-input,.currency-symbol{background:#fff;font-size:1.1rem;font-weight:600}.amount-input{border:2px solid #e2e8f0;border-radius:12px;color:#2d3748;font-family:inherit;padding:16px 45px 16px 18px;text-align:left;transition:all .2s ease;width:100%}.amount-input:focus{border-color:#1a1a1a;box-shadow:0 0 0 3px #1a1a1a1a;outline:none}.amount-input:disabled{background:#f7fafc;color:#a0aec0;cursor:not-allowed}.description-input,.location-input{background:#fff;border:2px solid #e2e8f0;border-radius:12px;color:#2d3748;font-family:inherit;font-size:1rem;padding:16px 18px;transition:all .2s ease;width:100%}.description-input:focus,.location-input:focus{border-color:#1a1a1a;box-shadow:0 0 0 3px #1a1a1a1a;outline:none}.description-input:disabled,.location-input:disabled{background:#f7fafc;color:#a0aec0;cursor:not-allowed}.notes-input{background:#fff;border:2px solid #e2e8f0;border-radius:12px;color:#2d3748;font-family:inherit;font-size:1rem;min-height:80px;padding:16px 18px;resize:vertical;transition:all .2s ease;width:100%}.notes-input:focus{border-color:#1a1a1a;box-shadow:0 0 0 3px #1a1a1a1a;outline:none}.notes-input:disabled{background:#f7fafc;color:#a0aec0;cursor:not-allowed}.form-actions{align-items:center;justify-content:space-between;margin-top:35px}.form-actions-left{display:flex}.form-actions-right{display:flex;gap:15px}.btn-cancel,.btn-delete,.btn-submit{align-items:center;border-radius:12px;cursor:pointer;display:flex;font-family:inherit;font-size:1rem;font-weight:500;gap:8px;justify-content:center;min-width:120px;padding:16px 32px;transition:all .2s ease}.btn-cancel{border:2px solid #e2e8f0}.btn-submit{border:2px solid #1a1a1a}.btn-delete{background:#fed7d7;border:2px solid #feb2b2;color:#c53030}.btn-delete:hover:not(:disabled){background:#fc8181;border-color:#f56565;color:#fff;transform:translateY(-1px)}.btn-cancel:disabled,.btn-delete:disabled,.btn-submit:disabled{cursor:not-allowed;opacity:.5;transform:none}.delete-confirm-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000c;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:3000}.delete-confirm-modal{animation:modalSlideIn .2s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:450px;width:90%}.delete-confirm-header{padding:25px 30px 0;text-align:center}.delete-confirm-header h3{color:#c53030;font-size:1.3rem;font-weight:600;margin:0}.delete-confirm-body{padding:20px 30px;text-align:center}.delete-confirm-body>p:first-child{color:#2d3748;font-size:1rem;margin:0 0 20px}.expense-preview{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;margin:20px 0;padding:20px;text-align:left}.expense-preview-item{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.expense-preview-item:last-child{margin-bottom:0}.expense-preview-label{color:#4a5568;font-size:.9rem;font-weight:500}.expense-preview-value{color:#1a1a1a;font-size:.9rem;font-weight:600}.delete-warning{color:#c53030;font-size:.9rem;font-weight:500;margin:15px 0 0}.delete-confirm-actions{display:flex;gap:15px;padding:0 30px 30px}.btn-cancel-delete,.btn-confirm-delete{border-radius:8px;cursor:pointer;flex:1 1;font-family:inherit;font-size:1rem;font-weight:500;padding:14px 20px;transition:all .2s ease}.btn-cancel-delete{background:#f7fafc;border:1px solid #e2e8f0;color:#4a5568}.btn-cancel-delete:hover:not(:disabled){background:#edf2f7;border-color:#cbd5e0}.btn-confirm-delete{background:#c53030;border:1px solid #c53030;color:#fff}.btn-confirm-delete:hover:not(:disabled){background:#e53e3e;border-color:#e53e3e;transform:translateY(-1px)}.btn-cancel-delete:disabled,.btn-confirm-delete:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.edit-expense-overlay{padding:10px}.edit-expense-modal{max-height:95vh}.edit-expense-header{padding:25px}.edit-expense-header h2{font-size:1.2rem}.edit-expense-form{padding:25px}.form-group{margin-bottom:20px}.date-input-container{align-items:stretch;flex-direction:column;gap:10px}.now-button{padding:12px 16px}.form-actions{flex-direction:column;gap:20px}.form-actions-left,.form-actions-right{width:100%}.form-actions-right{flex-direction:column-reverse;gap:12px}.btn-cancel,.btn-delete,.btn-submit{padding:14px 24px;width:100%}.delete-confirm-modal{width:95%}.delete-confirm-actions{flex-direction:column;gap:12px}}@media (max-width:480px){.edit-expense-form,.edit-expense-header{padding:20px}.form-actions{margin-top:25px;padding-top:20px}.delete-confirm-actions,.delete-confirm-body,.delete-confirm-header{padding-left:20px;padding-right:20px}}.manage-categories-overlay{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;display:flex;height:100vh;justify-content:center;left:0;padding:20px;position:fixed;top:0;width:100vw;z-index:2000}.manage-categories-modal{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;max-height:90vh;max-width:1000px;overflow:hidden;position:relative;width:100%}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.manage-categories-header{align-items:center;background:linear-gradient(135deg,#1a1a1a,#2d2d2d);border-radius:16px 16px 0 0;color:#fff;display:flex;justify-content:space-between;padding:30px 35px}.manage-categories-header h2{color:#fff;font-size:1.4rem;font-weight:500;margin:0}.close-button{background:none;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1.8rem;line-height:1;opacity:.8;padding:5px;transition:all .2s ease}.close-button:hover{background:#ffffff1a;opacity:1;transform:scale(1.1)}.manage-categories-content{max-height:calc(90vh - 120px);overflow-y:auto;padding:35px}.error-message,.success-message{align-items:center;border-radius:10px;font-size:.9rem;margin-bottom:25px;padding:16px 20px}.error-message{background:#fff5f5;border:1px solid #fed7d7;color:#e53e3e}.error-message:before{content:"⚠️";font-size:1rem}.success-message{background:#f0fff4;border:1px solid #c6f6d5;color:#38a169}.success-message:before{content:"✅";font-size:1rem}.list-header{align-items:center;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:25px;padding-bottom:20px}.list-header h3{color:#1a1a1a;font-size:1.2rem;font-weight:500;margin:0}.btn-add-category{align-items:center;background:#1a1a1a;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:8px;padding:12px 24px;transition:all .2s ease}.btn-add-category:hover{background:#333;box-shadow:0 4px 12px #1a1a1a33;transform:translateY(-1px)}.btn-add-category span{font-size:1.2rem;line-height:1}.loading-state{font-size:1rem;padding:60px 40px}.empty-state,.loading-state{color:#666;text-align:center}.empty-state{padding:80px 40px}.empty-icon{font-size:4rem;margin-bottom:20px;opacity:.5}.empty-state p{font-size:1.1rem;margin:0 0 30px}.btn-primary{background:#1a1a1a;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:16px 32px;transition:all .2s ease}.btn-primary:hover{background:#333;box-shadow:0 4px 12px #1a1a1a33;transform:translateY(-1px)}.categories-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));max-height:400px;overflow-y:auto;padding-right:10px}.category-card{background:#fff;border:2px solid #e9ecef;border-radius:12px;padding:20px;position:relative;transition:all .2s ease}.category-card:hover{border-color:#1a1a1a;box-shadow:0 6px 20px #0000001a;transform:translateY(-2px)}.category-card.inactive{background:#f8f9fa;opacity:.6}.category-header{align-items:flex-start;display:flex;gap:15px;margin-bottom:15px}.category-icon{border-radius:10px;flex-shrink:0;font-size:1.5rem;height:50px;width:50px}.category-info{min-width:0}.category-info h4{word-wrap:break-word;font-size:1.1rem;margin:0 0 8px}.type-badge{border-radius:20px;font-size:.75rem;font-weight:500;letter-spacing:.02em;padding:4px 12px;text-transform:uppercase}.type-badge.expense{background:#fee2e2;color:#dc2626}.type-badge.income{background:#dcfce7;color:#16a34a}.type-badge.both{background:#e0e7ff;color:#3730a3}.category-status{flex-shrink:0}.status-active,.status-inactive{border-radius:6px;font-size:.8rem;font-weight:500;padding:6px 12px}.status-active{background:#dcfce7;color:#16a34a}.status-inactive{background:#fee2e2;color:#dc2626}.category-description{color:#666;font-size:.9rem;line-height:1.5;margin:0 0 20px}.category-actions{display:flex;flex-wrap:wrap;gap:8px}.category-actions button{border:1px solid;border-radius:6px;cursor:pointer;flex:1 1;font-size:.8rem;font-weight:500;min-width:70px;padding:6px 12px;transition:all .2s ease}.btn-edit{background:#f3f4f6;border-color:#d1d5db;color:#374151}.btn-edit:hover{background:#e5e7eb;border-color:#9ca3af}.btn-toggle.activate{background:#dcfce7;border-color:#16a34a;color:#16a34a}.btn-toggle.deactivate{background:#fef3c7;border-color:#d97706;color:#d97706}.btn-toggle:hover{opacity:.8}.btn-delete{background:#fee2e2;border-color:#dc2626;color:#dc2626}.btn-delete:hover{background:#fecaca}.btn-delete.confirm{animation:pulse 1s infinite;background:#dc2626;color:#fff}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.category-form{max-width:600px}.form-header{align-items:center;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.form-header h3{color:#1a1a1a;font-size:1.2rem;font-weight:500;margin:0}.btn-back{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;color:#495057;cursor:pointer;font-size:.9rem;padding:10px 20px;transition:all .2s ease}.btn-back:hover{background:#e9ecef;border-color:#dee2e6}.form-group{margin-bottom:25px}.form-group label{color:#2d3748;display:block;font-size:.95rem;font-weight:500;margin-bottom:8px}.form-group input[type=text],.form-group select,.form-group textarea{background:#fff;border:2px solid #e2e8f0;border-radius:10px;font-family:inherit;font-size:1rem;padding:14px 16px;transition:all .2s ease;width:100%}.form-group input[type=text]:focus,.form-group select:focus,.form-group textarea:focus{border-color:#1a1a1a;box-shadow:0 0 0 3px #1a1a1a1a;outline:none}.form-group textarea{min-height:80px;resize:vertical}.icon-selector{grid-gap:10px;border:2px solid #e2e8f0;border-radius:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(50px,1fr));max-height:150px;overflow-y:auto;padding:15px}.icon-option{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;display:flex;font-size:1.5rem;height:50px;justify-content:center;transition:all .2s ease;width:50px}.icon-option:hover{border-color:#1a1a1a;transform:scale(1.1)}.icon-option.selected{background:#f8f9fa;border-color:#1a1a1a;box-shadow:0 0 0 2px #1a1a1a1a}.color-selector{grid-gap:10px;border:2px solid #e2e8f0;border-radius:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(40px,1fr));padding:15px}.color-option{border:3px solid #0000;border-radius:50%;cursor:pointer;height:40px;transition:all .2s ease;width:40px}.color-option:hover{box-shadow:0 4px 12px #0003;transform:scale(1.1)}.color-option.selected{border-color:#1a1a1a;box-shadow:0 0 0 2px #1a1a1a33}.checkbox-group{margin-bottom:30px;margin-top:30px}.checkbox-label{align-items:center;cursor:pointer;display:flex;font-size:1rem;gap:12px}.checkbox-label input[type=checkbox]{display:none}.checkmark{background:#fff;border:2px solid #e2e8f0;border-radius:4px;height:20px;position:relative;transition:all .2s ease;width:20px}.checkbox-label input[type=checkbox]:checked+.checkmark{background:#1a1a1a;border-color:#1a1a1a}.checkbox-label input[type=checkbox]:checked+.checkmark:after{color:#fff;content:"✓";font-size:.8rem;font-weight:700;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.form-actions{border-top:1px solid #e2e8f0;display:flex;gap:15px;justify-content:flex-end;margin-top:40px;padding-top:25px}.btn-cancel,.btn-submit{border:2px solid;border-radius:12px;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:500;min-width:140px;padding:16px 32px;transition:all .2s ease}.btn-cancel{background:#f7fafc;border-color:#e2e8f0;color:#4a5568}.btn-cancel:hover:not(:disabled){background:#edf2f7;border-color:#cbd5e0;transform:translateY(-1px)}.btn-submit{background:#1a1a1a;border-color:#1a1a1a;color:#fff}.btn-submit:hover:not(:disabled){background:#2d2d2d;border-color:#2d2d2d;box-shadow:0 4px 12px #1a1a1a33;transform:translateY(-1px)}.btn-cancel:disabled,.btn-submit:disabled{cursor:not-allowed;opacity:.5;transform:none}@media (max-width:768px){.manage-categories-overlay{padding:10px}.manage-categories-modal{max-height:95vh}.manage-categories-content,.manage-categories-header{padding:25px}.categories-grid{grid-template-columns:1fr;max-height:300px}.form-header,.list-header{align-items:stretch;flex-direction:column;gap:15px}.icon-selector{grid-template-columns:repeat(auto-fill,minmax(45px,1fr));max-height:120px}.color-selector{grid-template-columns:repeat(auto-fill,minmax(35px,1fr))}.form-actions{flex-direction:column-reverse;gap:12px}.btn-cancel,.btn-submit{width:100%}.category-actions{flex-direction:column}.category-actions button{flex:none}}@media (max-width:480px){.manage-categories-content,.manage-categories-header{padding:20px}.category-header{align-items:center;flex-direction:column;gap:10px}.category-header,.category-info{text-align:center}}.receipt-upload-modal{max-height:90vh;max-width:600px;overflow-y:auto;width:90%}.receipt-upload-modal .modal-body{display:flex;flex-direction:column;justify-content:center;min-height:300px;padding:30px}.file-drop-zone{align-items:center;background:#f8fafc;border:2px dashed #e2e8f0;border-radius:12px;cursor:pointer;display:flex;justify-content:center;min-height:200px;padding:40px 20px;text-align:center;transition:all .3s ease}.file-drop-zone:hover{background:#ebf8ff;border-color:#3182ce;transform:translateY(-2px)}.file-drop-zone.drag-active{background:#ebf8ff;border-color:#3182ce;box-shadow:0 0 0 3px #3182ce1a}.drop-zone-content{align-items:center;display:flex;flex-direction:column;gap:15px}.upload-icon{font-size:48px;margin-bottom:10px}.drop-zone-content h3{color:#2d3748;font-size:20px;font-weight:600;margin:0}.drop-zone-content p{color:#718096;font-size:16px;margin:0}.supported-formats{display:flex;flex-direction:column;gap:5px;margin-top:10px}.supported-formats span{color:#a0aec0;font-size:14px}.file-preview{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:25px}.file-info{gap:15px;margin-bottom:20px}.file-icon,.file-info{align-items:center;display:flex}.file-icon{background:#f7fafc;border-radius:8px;font-size:32px;height:50px;justify-content:center;width:50px}.file-details h4{color:#2d3748;font-size:16px;font-weight:600;margin:0 0 5px;word-break:break-all}.file-details p{color:#718096;font-size:14px;margin:0}.upload-actions{display:flex;gap:15px;justify-content:flex-end}.upload-progress{padding:30px 20px;text-align:center}.progress-info{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.progress-info h3{color:#2d3748;font-size:18px;font-weight:600;margin:0}.progress-info span{color:#3182ce;font-size:16px;font-weight:600}.progress-bar{background:#e2e8f0;border-radius:4px;height:8px;margin-bottom:15px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#3182ce,#63b3ed);border-radius:4px;height:100%;position:relative;transition:width .3s ease}.progress-fill:after{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#0000,#fff6,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.file-name{color:#718096;font-size:14px;margin:0;word-break:break-all}.processing-status{padding:30px 20px;text-align:center}.processing-spinner{margin-bottom:20px}.spinner{border:4px solid #e2e8f0;border-top-color:#3182ce;height:50px;margin:0 auto;width:50px}.processing-status h3{color:#2d3748;font-size:18px;font-weight:600;margin:0 0 15px}.status-details{background:#f7fafc;border-radius:8px;margin-top:20px;padding:15px}.status-details p{color:#718096;font-size:14px;margin:5px 0}.error-message,.success-message{align-items:flex-start;border-radius:8px;display:flex;flex-direction:column;font-size:14px;font-weight:500;gap:10px;margin:20px 0;padding:15px 20px}.error-message{background:#fed7d7;border:1px solid #feb2b2;color:#c53030}.success-message{background:#c6f6d5;border:1px solid #9ae6b4;color:#2f855a}.error-icon,.success-icon{font-size:16px}.category-errors{margin-top:15px;width:100%}.category-errors h4{color:#c53030;font-size:16px;font-weight:600;margin:0 0 10px}.category-errors ul{margin:10px 0;padding-left:20px}.category-errors li{color:#c53030;margin:5px 0}.error-guidance{background:#fed7d7;border:1px solid #feb2b2;border-radius:6px;color:#c53030;font-size:14px;margin-top:15px;padding:12px}.error-guidance strong{color:#9b2c2c}.transaction-navigation{align-items:center;display:flex;gap:20px;justify-content:space-between;width:100%}.transaction-counter{background:#f7fafc;border:1px solid #e2e8f0;border-radius:20px;color:#4a5568;font-size:14px;font-weight:600;padding:8px 16px}.nav-buttons{display:flex;gap:12px}@media (max-width:768px){.receipt-upload-modal{margin:20px auto;width:95%}.receipt-upload-modal .modal-body{padding:20px}.file-drop-zone{min-height:150px;padding:30px 15px}.upload-icon{font-size:36px}.drop-zone-content h3{font-size:18px}.upload-actions{flex-direction:column}.upload-actions button{width:100%}}.receipt-upload-modal .btn-primary{background:linear-gradient(135deg,#3182ce,#2c5aa0);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:12px 24px;transition:all .2s ease}.receipt-upload-modal .btn-primary:hover{background:linear-gradient(135deg,#2c5aa0,#2a4d8d);box-shadow:0 4px 12px #3182ce4d;transform:translateY(-1px)}.receipt-upload-modal .btn-secondary{background:#e2e8f0;border:1px solid #cbd5e0;border-radius:8px;color:#4a5568;cursor:pointer;font-weight:600;padding:12px 24px;transition:all .2s ease}.receipt-upload-modal .btn-secondary:hover{background:#cbd5e0;border-color:#a0aec0;transform:translateY(-1px)}.receipt-upload-modal .loading{opacity:.7;pointer-events:none}.file-drop-zone:focus,.receipt-upload-modal button:focus{outline:2px solid #3182ce;outline-offset:2px}.language-switcher{display:flex;flex-direction:column;gap:8px;position:relative}.language-switcher-compact{display:inline-block;position:relative}.language-label{color:#333;font-size:.9rem;font-weight:500;margin-bottom:4px}.language-selector{display:inline-block;position:relative}.language-switcher-button,.language-switcher-button-compact{align-items:center;background:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;display:flex;font-size:.9rem;gap:8px;min-width:120px;padding:8px 12px;position:relative;transition:all .2s ease}.language-switcher-button-compact{border-radius:4px;min-width:auto;padding:6px 8px}.language-switcher-button-compact:hover,.language-switcher-button:hover{border-color:#007bff;box-shadow:0 2px 4px #007bff1a}.language-switcher-button-compact:disabled,.language-switcher-button:disabled{cursor:not-allowed;opacity:.6}.language-flag{font-size:1.2rem;line-height:1}.language-name{color:#333;font-weight:500}.dropdown-arrow{color:#666;font-size:.8rem;margin-left:auto;transition:transform .2s ease}.language-switcher-button:hover .dropdown-arrow{transform:rotate(180deg)}.loading-spinner{animation:spin 1s linear infinite;color:#007bff;font-size:.9rem;position:absolute;right:8px}.language-dropdown,.language-dropdown-compact{background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 4px 12px #00000026;left:0;margin-top:4px;max-height:200px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000}.language-dropdown-compact{min-width:120px;right:auto}.language-option,.language-option-compact{align-items:center;background:none;border:none;cursor:pointer;display:flex;font-size:.9rem;gap:8px;padding:10px 12px;text-align:left;transition:background-color .2s ease;width:100%}.language-option-compact{padding:8px 10px}.language-option-compact:hover,.language-option:hover{background-color:#f8f9fa}.language-option-compact.active,.language-option.active{background-color:#e3f2fd;color:#1976d2}.language-info{display:flex;flex:1 1;flex-direction:column;gap:2px}.language-name-en{color:#666;font-size:.8rem;font-weight:400}.checkmark{color:#28a745;font-size:.9rem;font-weight:700}@media (max-width:768px){.language-switcher{gap:6px}.language-switcher-button{font-size:.85rem;min-width:100px;padding:6px 10px}.language-option{font-size:.85rem;padding:8px 10px}.language-dropdown{max-height:150px}}@media (prefers-color-scheme:dark){.language-switcher-button,.language-switcher-button-compact{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.language-switcher-button-compact:hover,.language-switcher-button:hover{background:#4a5568;border-color:#63b3ed}.language-dropdown,.language-dropdown-compact{background:#2d3748;border-color:#4a5568}.language-option,.language-option-compact{color:#e2e8f0}.language-option-compact:hover,.language-option:hover{background-color:#4a5568}.language-option-compact.active,.language-option.active{background-color:#2b6cb0;color:#e2e8f0}.language-name-en{color:#a0aec0}.language-label{color:#e2e8f0}}.dashboard{background-color:#fafafa;min-height:100vh}.dashboard.loading{align-items:center;color:#666;display:flex;font-size:1.1rem;font-weight:400;justify-content:center}.dashboard-header{background:#fff;border-bottom:1px solid #e8e8e8;box-shadow:0 1px 3px #0000000d;padding:0 40px}.logo{align-items:center;display:flex;gap:12px}.logo h1,.logo-icon{color:#1a1a1a;font-size:1.4rem}.logo h1{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-weight:300;margin:0}.user-menu{align-items:center;display:flex;gap:30px;height:auto;min-height:auto}.welcome{background:none;background-color:initial;border:none;box-shadow:none;color:#2d3748;font-size:.95rem;font-weight:500;margin:0;padding:0;text-shadow:none}.btn-logout{background:#0000;border:1px solid #e0e0e0;border-radius:6px;color:#1a1a1a;cursor:pointer;font-family:inherit;font-size:.9rem;font-weight:400;padding:10px 20px;transition:all .2s ease}.btn-logout:hover{background:#1a1a1a;border-color:#1a1a1a;color:#fff;transform:translateY(-1px)}.dashboard-main{margin:0 auto;max-width:1400px;padding:40px}.dashboard-content{max-width:100%}.stats-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:50px}.stat-card{align-items:center;background:#fff;border:1px solid #f0f0f0;border-radius:12px;box-shadow:0 2px 8px #0000000f;display:flex;gap:25px;overflow:hidden;padding:35px 30px;position:relative;transition:all .3s ease}.stat-card:hover{border-color:#e0e0e0;box-shadow:0 4px 20px #0000001a;transform:translateY(-2px)}.stat-card.loading{opacity:.7}.stat-card.loading:after{animation:loading 1.5s infinite;background:linear-gradient(90deg,#0000,#fff6,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%}@keyframes loading{0%{left:-100%}to{left:100%}}.stat-icon{align-items:center;background:#f8f9fa;border-radius:12px;color:#1a1a1a;display:flex;flex-shrink:0;font-size:2.2rem;height:60px;justify-content:center;width:60px}.stat-info{flex:1 1}.stat-info h3{color:#666;font-size:.9rem;font-weight:500;letter-spacing:.05em;margin:0 0 8px;text-transform:uppercase}.stat-value{color:#1a1a1a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-size:2.4rem;font-weight:300;margin:0 0 5px}.stat-detail{color:#999;font-size:.85rem;font-weight:400;margin:0}.top-categories-section{background:#fff;border:1px solid #f0f0f0;border-radius:12px;box-shadow:0 2px 8px #0000000f;margin-bottom:40px;padding:35px 30px}.top-categories-section h2{color:#1a1a1a;font-size:1.2rem;font-weight:500;letter-spacing:.01em;margin:0 0 25px}.category-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.category-item{background:#f8f9fa;border-radius:10px;gap:15px;transition:all .2s ease}.category-item:hover{background:#f0f2f5;transform:translateY(-1px)}.category-icon{border-radius:8px;font-size:1.2rem;height:40px;width:40px}.category-info h4{color:#1a1a1a;font-size:.95rem;font-weight:500;margin:0 0 4px}.category-amount{color:#666;font-size:.9rem;font-weight:600;margin:0}.quick-actions,.recent-activity{background:#fff;border:1px solid #f0f0f0;border-radius:12px;box-shadow:0 2px 8px #0000000f;margin-bottom:40px;padding:35px 30px}.quick-actions h2,.recent-activity h2{color:#1a1a1a;font-size:1.2rem;font-weight:500;letter-spacing:.01em;margin:0 0 25px}.action-buttons{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.btn-action{align-items:center;background:#f8f9fa;border:2px solid #e9ecef;border-radius:10px;color:#1a1a1a;cursor:pointer;display:flex;font-family:inherit;font-size:.95rem;font-weight:500;gap:12px;justify-content:center;padding:20px 24px;transition:all .2s ease}.btn-action:hover{background:#e9ecef;border-color:#dee2e6;transform:translateY(-1px)}.btn-action.primary{background:#1a1a1a;border-color:#1a1a1a;color:#fff}.btn-action.primary:hover{background:#333;border-color:#333}.btn-action span{font-size:1.2rem}.activity-placeholder{background:#fafafa;border:2px dashed #e0e0e0;border-radius:10px;color:#666;padding:60px 40px;text-align:center}.activity-placeholder p{font-size:1rem;font-weight:400;margin:0 0 20px}.btn-secondary{border:2px solid #e0e0e0;border-radius:8px;font-weight:500}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-height:90vh;max-width:600px;overflow:hidden;width:90%}.modal-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:25px 30px}.modal-header h3{color:#1a1a1a;font-size:1.3rem;font-weight:500;margin:0}.modal-close{background:none;border:none;color:#666;cursor:pointer;font-size:1.5rem;line-height:1;padding:5px;transition:color .2s ease}.modal-close:hover{color:#1a1a1a}.modal-body{padding:30px}.modal-footer{background:#f8f9fa;border-top:1px solid #e9ecef;display:flex;gap:15px;justify-content:flex-end;padding:20px 30px}@media (max-width:768px){.dashboard-header{padding:0 20px}.header-content{height:70px}.user-menu{gap:15px}.welcome{font-size:.9rem}.dashboard-main{padding:30px 20px}.stats-grid{gap:20px;grid-template-columns:1fr;margin-bottom:40px}.stat-card{padding:25px 20px}.stat-value{font-size:2rem}.quick-actions,.recent-activity,.top-categories-section{padding:25px 20px}.action-buttons,.category-grid{grid-template-columns:1fr}.category-grid{gap:15px}.modal-content{margin:20px;width:95%}.modal-body,.modal-footer,.modal-header{padding:20px}}@media (max-width:480px){.welcome{display:none}}.analytics-container{background:#fafafa;margin:0 auto;max-width:1400px;min-height:100vh;padding:40px}.analytics-header{align-items:center;background:#0000;border-radius:0;box-shadow:none;display:flex;justify-content:space-between;margin-bottom:50px;padding:0}.analytics-header h1{color:#1a1a1a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-size:1.8rem;font-weight:300;margin:0}.analytics-controls{align-items:center;display:flex;gap:20px}.period-selector{background:#fff;border:1px solid #e0e0e0;border-radius:6px;color:#1a1a1a;cursor:pointer;font-family:inherit;font-size:.95rem;padding:12px 16px;transition:all .2s ease}.period-selector:focus{border-color:#1a1a1a;box-shadow:0 0 0 2px #1a1a1a1a;outline:none}.btn-secondary{background:#0000;border:1px solid #e0e0e0;border-radius:6px;color:#1a1a1a;cursor:pointer;font-family:inherit;font-size:.95rem;font-weight:400;padding:12px 24px;transition:all .2s ease}.btn-secondary:hover{background:#1a1a1a;border-color:#1a1a1a;color:#fff;transform:translateY(-1px)}.loading-spinner{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:300px}.spinner{animation:spin 1s linear infinite;border:3px solid #e0e0e0;border-radius:50%;border-top-color:#1a1a1a;height:40px;margin-bottom:20px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-spinner p{color:#666;font-size:1rem;font-weight:400;margin:0}.error-message{background:#fff;border:1px solid #f0f0f0;border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:60px 40px;text-align:center}.error-message h3{color:#d32f2f;font-size:1.2rem;font-weight:500;margin:0 0 15px}.error-message p{color:#666;font-size:.95rem;margin:0 0 25px}.analytics-overview,.overview-cards{margin-bottom:50px}.overview-cards{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(3,1fr)}@media (max-width:768px){.overview-cards{gap:20px;grid-template-columns:1fr}}.overview-card{background:#fff;border:1px solid #f0f0f0;border-radius:12px;box-shadow:0 2px 8px #0000000f;overflow:hidden;padding:35px 30px;position:relative;transition:all .3s ease}.overview-card:hover{border-color:#e0e0e0;box-shadow:0 4px 20px #0000001a;transform:translateY(-2px)}.overview-card h3{color:#666;font-size:.9rem;font-weight:500;letter-spacing:.05em;margin:0 0 10px;text-transform:uppercase}.overview-card .amount{color:#1a1a1a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-size:2.4rem;font-weight:300;line-height:1.2;margin:0 0 8px}.overview-card .label{color:#999;font-size:.85rem;font-weight:400;margin:0}.charts-section{background:#fff;border:1px solid #f0f0f0;border-radius:12px;box-shadow:0 2px 8px #0000000f;margin-bottom:50px;padding:35px 30px}.charts-section h2{color:#1a1a1a;font-size:1.2rem;font-weight:500;letter-spacing:.01em;margin:0 0 30px}.charts-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}@media (max-width:768px){.charts-grid{gap:25px;grid-template-columns:1fr}}.chart-container{background:#fff;border:1px solid #f0f0f0;border-radius:16px;box-shadow:0 2px 8px #0000000a;overflow:hidden;padding:30px;position:relative;transition:all .3s ease}.chart-container:before{background:linear-gradient(90deg,#0000,#e0e0e0,#0000);content:"";height:1px;left:0;position:absolute;right:0;top:0}.chart-container:hover{border-color:#e0e0e0;box-shadow:0 8px 25px #00000014;transform:translateY(-2px)}.chart-container h3{color:#1a1a1a;font-size:1rem;font-weight:500;letter-spacing:.01em;margin:0 0 25px;text-align:center}.chart-wrapper{border-radius:12px;margin-top:10px;padding:10px;position:relative}.chart-no-data,.chart-wrapper{background:#fafafa;height:350px}.chart-no-data{align-items:center;border:2px dashed #e0e0e0;border-radius:8px;color:#666;display:flex;flex-direction:column;justify-content:center}.no-data-icon{font-size:48px;margin-bottom:20px;opacity:.7}.chart-no-data p{font-size:1rem;font-weight:400;margin:0 0 8px}.chart-no-data small{color:#999;font-size:.85rem;margin:0}.trends-section{background:#fff;border:1px solid #f0f0f0;border-radius:12px;box-shadow:0 2px 8px #0000000f;margin-bottom:50px;padding:35px 30px}.trends-section h2{color:#1a1a1a;font-size:1.2rem;font-weight:500;letter-spacing:.01em;margin:0 0 30px}.trend-summary{margin-bottom:0}.trend-indicator{align-items:center;background:#f8f9fa;border:1px solid #f0f0f0;border-radius:12px;box-shadow:0 1px 3px #0000000d;display:flex;gap:20px;padding:25px}.trend-direction{font-size:28px;min-width:40px;text-align:center}.trend-info h3{color:#1a1a1a;font-size:1.1rem;font-weight:500;margin:0 0 8px;text-transform:capitalize}.trend-info p{color:#666;font-size:.9rem;font-weight:400;margin:3px 0}.categories-section{background:#fff;border:1px solid #f0f0f0;border-radius:12px;box-shadow:0 2px 8px #0000000f;margin-bottom:50px;padding:35px 30px}.categories-section h2{color:#1a1a1a;font-size:1.2rem;font-weight:500;letter-spacing:.01em;margin:0 0 30px}.categories-list{display:flex;flex-direction:column;gap:20px}.category-item{align-items:center;background:#fff;border:1px solid #f0f0f0;border-radius:12px;cursor:pointer;display:flex;justify-content:space-between;padding:20px;transition:all .3s ease}.category-item:hover{background:#fafafa;border-color:#e0e0e0;box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.category-info{flex:1 1;gap:20px}.category-icon,.category-info{align-items:center;display:flex}.category-icon{background:#f8f9fa;border-radius:6px;color:#666;font-size:1rem;font-weight:500;height:32px;justify-content:center;width:32px}.category-details h4{color:#1a1a1a;font-size:.95rem;font-weight:500;margin:0 0 4px}.category-details p{color:#666;font-size:.9rem;font-weight:400;margin:0}.category-bar{background:#f0f0f0;border-radius:3px;height:6px;margin-left:20px;overflow:hidden;width:120px}.category-progress{border-radius:3px;height:100%;position:relative;transition:width .5s ease}.insights-section{background:#fff;border:1px solid #f0f0f0;border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:35px 30px}.insights-section h2{color:#1a1a1a;font-size:1.2rem;font-weight:500;letter-spacing:.01em;margin:0 0 30px}.insights-list{display:flex;flex-direction:column;gap:20px}.insight-item{align-items:flex-start;background:#fff;border:1px solid #f0f0f0;border-radius:12px;cursor:pointer;display:flex;gap:20px;padding:20px;transition:all .3s ease}.insight-item:hover{background:#fafafa;border-color:#e0e0e0;box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.insight-indicator{background:#e0e0e0;border-radius:50%;flex-shrink:0;height:8px;margin-top:6px;width:8px}.insight-content h4{color:#1a1a1a;font-size:.95rem;font-weight:500;margin:0 0 8px}.insight-content p{color:#666;font-size:.9rem;font-weight:400;line-height:1.6;margin:0}@media (max-width:1024px){.charts-grid{grid-template-columns:1fr}.overview-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.analytics-container{padding:30px 20px}.analytics-header{flex-direction:column;gap:20px;margin-bottom:40px;text-align:center}.analytics-controls{justify-content:center;width:100%}.overview-cards{gap:20px;grid-template-columns:1fr;margin-bottom:40px}.overview-card{padding:25px 20px}.overview-card .amount{font-size:2rem}.chart-wrapper{height:300px}.category-item{align-items:flex-start;flex-direction:column;gap:15px}.category-bar{margin-left:0;width:100%}.categories-section,.charts-section,.insights-section,.trends-section{padding:25px 20px}}.all-transactions{background-color:#fafafa;min-height:100vh}.transactions-header{background:#fff;border-bottom:1px solid #e8e8e8;box-shadow:0 1px 3px #0000000d;padding:0 40px}.header-content{height:80px;justify-content:space-between;margin:0 auto;max-width:1400px}.header-content,.header-left{align-items:center;display:flex}.header-left{gap:20px}.back-button{background:#0000;border:1px solid #e0e0e0;border-radius:6px;color:#1a1a1a;cursor:pointer;font-family:inherit;font-size:.9rem;font-weight:400;padding:10px 20px;transition:all .2s ease}.back-button:hover{background:#1a1a1a;border-color:#1a1a1a;color:#fff;transform:translateY(-1px)}.transactions-header h1{color:#1a1a1a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-size:1.4rem;font-weight:300;margin:0}.transactions-main{margin:0 auto;max-width:1400px;padding:40px}.transactions-content{max-width:100%}.filters-section{background:#fff;border:1px solid #f0f0f0;border-radius:12px;box-shadow:0 2px 8px #0000000f;margin-bottom:30px;padding:35px 30px}.filters-section h2{color:#1a1a1a;font-size:1.2rem;font-weight:500;letter-spacing:.01em;margin:0 0 25px}.filters-grid{grid-gap:20px;align-items:end;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-group label{color:#4a5568;font-size:.9rem;font-weight:500;margin:0}.filter-input{background:#fff;border:2px solid #e2e8f0;border-radius:8px;color:#2d3748;font-family:inherit;font-size:.95rem;padding:12px 16px;transition:all .2s ease}.filter-input:focus{border-color:#1a1a1a;box-shadow:0 0 0 3px #1a1a1a1a;outline:none}.filter-input:disabled{background:#f7fafc;color:#a0aec0;cursor:not-allowed}.clear-filters-btn{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;color:#1a1a1a;cursor:pointer;font-family:inherit;font-size:.95rem;font-weight:500;padding:12px 20px;transition:all .2s ease;width:100%}.clear-filters-btn:hover{background:#e9ecef;border-color:#dee2e6;transform:translateY(-1px)}.results-summary{background:#fff;border:1px solid #f0f0f0;border-radius:12px;box-shadow:0 2px 8px #0000000f;margin-bottom:20px;padding:20px 30px}.results-summary p{color:#666;font-size:.95rem;margin:0}.transactions-table-section{margin-bottom:30px;padding:35px 30px}.pagination,.transactions-table-section{background:#fff;border:1px solid #f0f0f0;border-radius:12px;box-shadow:0 2px 8px #0000000f}.pagination{align-items:center;display:flex;gap:20px;justify-content:center;padding:25px 30px}.pagination-btn{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;color:#1a1a1a;cursor:pointer;font-family:inherit;font-size:.95rem;font-weight:500;padding:12px 24px;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background:#e9ecef;border-color:#dee2e6;transform:translateY(-1px)}.pagination-btn:disabled{background:#f7fafc;border-color:#e2e8f0;color:#a0aec0;cursor:not-allowed;transform:none}.pagination-info{color:#666;font-size:.95rem;font-weight:500}@media (max-width:768px){.transactions-header{padding:0 20px}.header-content{height:70px}.header-left{gap:15px}.transactions-header h1{font-size:1.2rem}.transactions-main{padding:30px 20px}.filters-section,.results-summary,.transactions-table-section{padding:25px 20px}.filters-grid{gap:15px;grid-template-columns:1fr}.pagination{gap:15px;padding:20px}.pagination-btn{font-size:.9rem;padding:10px 16px}}@media (max-width:480px){.back-button{font-size:.85rem;padding:8px 16px}.transactions-header h1{font-size:1.1rem}}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fafafa;color:#1a1a1a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:16px;font-weight:400;line-height:1.5;margin:0;padding:0}.app{min-height:100vh}button{background:#0000;border:none;cursor:pointer;font-family:inherit;transition:all .2s ease}button:focus{outline:1px solid #1a1a1a;outline-offset:2px}button:focus:not(:focus-visible){outline:none}input{color:inherit;font-family:inherit;font-size:inherit}input::placeholder{color:#999;font-weight:400}input:focus{outline:none}h1,h2,h3,h4,h5,h6{font-weight:300;line-height:1.2;margin:0}p{line-height:1.6;margin:0}.loading{align-items:center;display:flex;justify-content:center}.text-center{text-align:center}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}@media (max-width:768px){body{font-size:15px}}button,input,select,textarea{-webkit-tap-highlight-color:transparent}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#e0e0e0;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ccc}[tabindex="-1"]:focus{outline:0!important}@media (prefers-reduced-motion:no-preference){*{scroll-behavior:smooth}}
/*# sourceMappingURL=main.19b7c68d.css.map*/