:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}.container{max-width:900px;margin:0 auto;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;overflow:hidden}.header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:30px;text-align:center}.header h1{font-size:28px;margin-bottom:10px}.upload-section{padding:60px 40px;text-align:center}.upload-box{border:3px dashed #667eea;border-radius:12px;padding:60px 40px;cursor:pointer;transition:all .3s;background:#f8f9ff}.upload-box:hover{border-color:#764ba2;background:#f0f2ff}.upload-icon{font-size:64px;margin-bottom:20px;opacity:.6}.transaction-view{display:flex;flex-direction:column;min-height:600px}.transaction-details{flex:1;padding:40px;border-bottom:2px solid #e5e7eb;display:flex;flex-direction:column;justify-content:center;align-items:center;background:linear-gradient(to bottom,#f9fafb,#fff);transition:all .3s}.transaction-details.multiple-match{border:3px solid #f59e0b;background:linear-gradient(to bottom,#fffbeb,#fef3c7)}.multiple-match-warning{background:#fef3c7;color:#92400e;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:600;margin-top:15px;border:2px solid #fbbf24}.auto-categorized-badge{background:#ddd6fe;color:#5b21b6;padding:6px 12px;border-radius:12px;font-size:12px;font-weight:600;margin-top:10px;display:inline-block}.progress{font-size:14px;color:#6b7280;margin-bottom:20px}.transaction-date{font-size:14px;color:#6b7280;margin-bottom:10px;font-weight:500}.transaction-description{font-size:24px;font-weight:600;color:#1f2937;text-align:center;margin-bottom:10px}.transaction-amount{font-size:32px;font-weight:700;margin-top:10px}.amount-positive{color:#10b981}.amount-negative{color:#ef4444}.current-category{margin-top:20px;padding:10px 20px;background:#667eea;color:#fff;border-radius:20px;font-size:14px;font-weight:600}.categories-section{flex:1;padding:30px 40px;overflow-y:auto}.categories-section h3{font-size:18px;margin-bottom:20px;color:#374151}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-bottom:20px}.category-btn{padding:16px 20px;border:2px solid #e5e7eb;border-radius:8px;background:#fff;cursor:grab;font-size:15px;font-weight:500;transition:all .2s;color:#374151;-webkit-user-select:none;user-select:none}.category-btn:active{cursor:grabbing}.category-btn.dragging{opacity:.5;cursor:grabbing}.category-btn.drag-over{border-color:#667eea;background:#f0f2ff;transform:scale(1.05)}.category-btn:hover{border-color:#667eea;background:#f0f2ff;transform:translateY(-2px)}.category-btn.selected{background:#667eea;color:#fff;border-color:#667eea}.category-btn.multiple-match{background:#fbbf24;color:#78350f;border-color:#f59e0b;font-weight:600;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.add-category-section{display:flex;gap:10px;margin-top:20px;padding-top:20px;border-top:2px solid #e5e7eb}.add-category-input{flex:1;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:15px;outline:none}.add-category-input:focus{border-color:#667eea}.add-category-btn{padding:12px 24px;background:#10b981;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.add-category-btn:hover{background:#059669}.rules-section{margin-top:20px;padding-top:20px;border-top:2px solid #e5e7eb}.rules-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:10px 0;-webkit-user-select:none;user-select:none}.rules-header h4{font-size:15px;color:#374151;font-weight:600;display:flex;align-items:center;gap:8px}.rules-toggle{font-size:12px;color:#9ca3af;transition:transform .3s}.rules-toggle.expanded{transform:rotate(90deg)}.rules-list{margin-top:15px}.rule-item{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;background:#f9fafb;border-radius:8px;margin-bottom:8px;font-size:14px}.rule-pattern{font-family:monospace;background:#fff;padding:4px 8px;border-radius:4px;color:#374151;font-weight:600}.rule-arrow{color:#9ca3af;margin:0 10px}.rule-category{color:#667eea;font-weight:600}.rule-actions{display:flex;gap:8px}.rule-action-btn{padding:4px 10px;border:none;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s;font-weight:600}.rule-action-btn.edit{background:#dbeafe;color:#1e40af}.rule-action-btn.edit:hover{background:#bfdbfe}.rule-action-btn.delete{background:#fee2e2;color:#991b1b}.rule-action-btn.delete:hover{background:#fecaca}.create-rule-btn{margin-top:15px;padding:10px 20px;background:#ddd6fe;color:#5b21b6;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;width:100%}.create-rule-btn:hover{background:#c4b5fd}.review-auto-toggle{display:flex;align-items:center;gap:10px;margin-top:15px;padding:10px;background:#f3f4f6;border-radius:8px;font-size:13px}.review-auto-toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer}.review-auto-toggle label{cursor:pointer;color:#374151;-webkit-user-select:none;user-select:none}.auto-save-indicator{position:fixed;bottom:20px;right:20px;background:#10b981;color:#fff;padding:10px 16px;border-radius:8px;font-size:13px;font-weight:600;opacity:0;transition:opacity .3s;pointer-events:none;z-index:1000;display:flex;align-items:center;gap:8px}.auto-save-indicator.show{opacity:1}.modal-overlay{position:fixed;inset:0;background:#00000080;z-index:2000;display:flex;justify-content:center;align-items:center}.modal-content{background:#fff;border-radius:16px;padding:30px;max-width:500px;width:90%;box-shadow:0 20px 60px #0000004d}.modal-header{font-size:24px;font-weight:700;color:#374151;margin-bottom:20px}.modal-body{margin-bottom:25px}.modal-field{margin-bottom:20px}.modal-field label{display:block;font-size:14px;font-weight:600;color:#374151;margin-bottom:8px}.modal-field input{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:15px;outline:none}.modal-field input:focus{border-color:#667eea}.modal-field select{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:15px;outline:none;cursor:pointer}.modal-field-hint{font-size:13px;color:#6b7280;margin-top:6px}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.modal-btn{padding:12px 24px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.modal-btn-primary{background:#667eea;color:#fff}.modal-btn-primary:hover{background:#5568d3}.modal-btn-secondary{background:#e5e7eb;color:#374151}.modal-btn-secondary:hover{background:#d1d5db}.navigation{display:flex;justify-content:space-between;padding:20px 40px;background:#f9fafb;border-top:1px solid #e5e7eb}.nav-btn{padding:12px 32px;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.nav-btn:hover{background:#5568d3;transform:translateY(-2px)}.nav-btn:disabled{background:#d1d5db;cursor:not-allowed;transform:none}.summary-section{padding:40px}.summary-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px;border-radius:12px;text-align:center}.stat-value{font-size:32px;font-weight:700;margin-bottom:5px}.stat-label{font-size:14px;opacity:.9}.category-breakdown{margin-top:30px}.category-breakdown h3{font-size:20px;margin-bottom:20px;color:#374151}.breakdown-item{background:#f9fafb;border-radius:8px;margin-bottom:10px;overflow:hidden}.breakdown-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;cursor:pointer;transition:background .2s}.breakdown-header:hover{background:#f3f4f6}.breakdown-left{display:flex;align-items:center;gap:12px}.breakdown-arrow{font-size:12px;transition:transform .3s;color:#9ca3af}.breakdown-arrow.expanded{transform:rotate(90deg)}.breakdown-category{font-weight:600;color:#374151}.breakdown-right{display:flex;align-items:center;gap:20px;font-size:14px}.breakdown-count{color:#6b7280}.breakdown-amount{font-weight:600;color:#374151;min-width:100px;text-align:right}.breakdown-transactions{padding:0 20px 15px 52px}.transaction-item{padding:10px 15px;background:#fff;border-radius:6px;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center;font-size:14px}.transaction-desc{color:#374151;flex:1}.transaction-date-small{color:#9ca3af;font-size:13px;margin-right:15px}.transaction-amt{font-weight:600;color:#6b7280;min-width:80px;text-align:right}.breakdown-total{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px;border-radius:8px;margin-top:20px;display:flex;justify-content:space-between;align-items:center;font-size:18px;font-weight:700}.export-btn{margin-top:30px;width:100%;padding:16px;background:#10b981;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.export-btn:hover{background:#059669}.restart-btn{margin-top:15px;width:100%;padding:16px;background:#6b7280;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.restart-btn:hover{background:#4b5563}.hidden{display:none!important}
