:root{--bg: #faf8f5;--card-bg: #ffffff;--text: #2d2a27;--text-muted: #8a857f;--accent: #5b8def;--accent-hover: #4a7de0;--green: #4caf50;--yellow: #ffc107;--red: #ef5350;--border: #e8e4df;--shadow: 0 2px 8px rgba(0, 0, 0, .06);--radius: 12px;--font: "Segoe UI", system-ui, -apple-system, sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh}.app-header{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:var(--card-bg);border-bottom:1px solid var(--border);box-shadow:var(--shadow);position:sticky;top:0;z-index:100;flex-wrap:wrap;gap:8px}.header-left h1{font-size:1.3rem;cursor:pointer;-webkit-user-select:none;user-select:none}.header-nav{display:flex;gap:4px}.header-nav button{background:none;border:2px solid transparent;padding:8px 16px;border-radius:20px;font-size:.9rem;cursor:pointer;color:var(--text-muted);transition:all .2s;font-weight:500}.header-nav button:hover{color:var(--text)}.header-nav button.active{color:var(--accent);border-color:var(--accent);background:#5b8def0f}.header-right{display:flex;align-items:center;gap:12px}.month-picker{padding:6px 12px;border:1px solid var(--border);border-radius:8px;font-size:.85rem;background:var(--card-bg);cursor:pointer}.user-badge{font-size:.8rem;color:var(--text-muted)}.logout-btn{background:none;border:1px solid var(--border);padding:6px 14px;border-radius:8px;cursor:pointer;font-size:.8rem;color:var(--text-muted);transition:all .2s}.logout-btn:hover{border-color:var(--red);color:var(--red)}.app-main{max-width:960px;margin:0 auto;padding:24px 16px}.loading{text-align:center;padding:80px 20px;font-size:1.2rem;color:var(--text-muted)}.error-box{background:#fff5f5;border:1px solid var(--red);border-radius:var(--radius);padding:16px;color:var(--red);text-align:center}.error-msg{color:var(--red);font-size:.9rem;margin:8px 0}.primary-btn{background:var(--accent);color:#fff;border:none;padding:12px 28px;border-radius:24px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s,transform .1s}.primary-btn:hover{background:var(--accent-hover);transform:translateY(-1px)}.primary-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.secondary-btn{background:none;color:var(--accent);border:2px solid var(--accent);padding:10px 24px;border-radius:24px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.secondary-btn:hover{background:#5b8def14}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#e8f0fe,#faf8f5,#fef3e2)}.login-card{background:var(--card-bg);padding:48px 40px;border-radius:20px;box-shadow:0 8px 30px #00000014;text-align:center;width:100%;max-width:380px}.login-card h1{font-size:3rem;margin-bottom:8px}.login-card h2{font-size:1.4rem;margin-bottom:4px}.login-subtitle{color:var(--text-muted);margin-bottom:28px}.login-card form{display:flex;flex-direction:column;gap:12px}.login-card input{padding:14px 16px;border:1px solid var(--border);border-radius:10px;font-size:1rem;outline:none;transition:border-color .2s}.login-card input:focus{border-color:var(--accent)}.login-card button[type=submit]{margin-top:8px;background:var(--accent);color:#fff;border:none;padding:14px;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer}.login-card button[type=submit]:hover{background:var(--accent-hover)}.dashboard-header{margin-bottom:24px}.dashboard-header h2{font-size:1.5rem;display:flex;align-items:center;gap:12px}.locked-badge{font-size:.8rem;background:#f0f0f0;padding:4px 12px;border-radius:12px;font-weight:500;color:var(--text-muted)}.summary-stats{display:flex;gap:24px;margin-top:12px}.stat{display:flex;flex-direction:column}.stat-value{font-size:1.4rem;font-weight:700}.stat-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.stat-warning{cursor:pointer;color:var(--yellow)}.stat-warning .stat-value{color:#e6a800}.bucket-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.bucket-card{background:var(--card-bg);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);border-left:4px solid var(--border);transition:transform .15s,box-shadow .15s}.bucket-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.bucket-stable{border-left-color:var(--green)}.bucket-dripping{border-left-color:var(--yellow)}.bucket-overflowing{border-left-color:var(--red)}.bucket-header{display:flex;justify-content:space-between;margin-bottom:8px}.bucket-emoji{font-size:1.6rem}.bucket-status{font-size:1.2rem}.bucket-name{font-size:.95rem;font-weight:600;margin-bottom:4px}.bucket-amount{font-size:1.4rem;font-weight:700}.bucket-target{font-size:.8rem;color:var(--text-muted);margin-bottom:8px}.bucket-bar{height:6px;background:#eee;border-radius:3px;overflow:hidden;margin-bottom:8px}.bucket-bar-fill{height:100%;border-radius:3px;transition:width .4s ease-out}.bucket-stable .bucket-bar-fill{background:var(--green)}.bucket-dripping .bucket-bar-fill{background:var(--yellow)}.bucket-overflowing .bucket-bar-fill{background:var(--red)}.bucket-status-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.bucket-stable .bucket-status-label{color:var(--green)}.bucket-dripping .bucket-status-label{color:#e6a800}.bucket-overflowing .bucket-status-label{color:var(--red)}.bucket-count{font-size:.75rem;color:var(--text-muted);margin-top:2px}.bucket-no-target{font-size:.8rem;color:var(--accent);cursor:pointer;margin-bottom:4px;opacity:.7;transition:opacity .2s}.bucket-no-target:hover{opacity:1;text-decoration:underline}.empty-state{text-align:center;padding:60px 20px}.empty-icon{font-size:4rem;margin-bottom:16px}.empty-state h3{font-size:1.3rem;margin-bottom:8px}.empty-state p{color:var(--text-muted);margin-bottom:24px}.cta-bar{text-align:center;margin-top:28px}.upload-page{max-width:560px;margin:0 auto}.upload-page h2{font-size:1.5rem;margin-bottom:4px}.page-subtitle{color:var(--text-muted);margin-bottom:24px}.source-toggle{display:flex;gap:8px;margin-bottom:20px}.source-toggle button{flex:1;padding:12px;border:2px solid var(--border);border-radius:10px;background:var(--card-bg);font-size:.95rem;cursor:pointer;transition:all .2s}.source-toggle button.active{border-color:var(--accent);background:#5b8def0f;font-weight:600}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:48px 24px;text-align:center;cursor:pointer;transition:all .2s;background:var(--card-bg)}.drop-zone:hover,.drop-zone.dragging{border-color:var(--accent);background:#5b8def0a}.drop-zone.has-file{border-style:solid;border-color:var(--green)}.drop-icon,.file-icon{font-size:2.5rem;margin-bottom:8px}.drop-prompt{color:var(--text-muted)}.file-preview{display:flex;flex-direction:column;align-items:center;gap:4px}.file-name{font-weight:600}.file-size{font-size:.85rem;color:var(--text-muted)}.upload-btn{display:block;width:100%;margin-top:16px}.upload-result{text-align:center;background:var(--card-bg);border-radius:var(--radius);padding:32px;margin-top:24px;box-shadow:var(--shadow)}.result-icon{font-size:2.5rem;margin-bottom:8px}.result-stats{display:flex;justify-content:center;gap:32px;margin:16px 0}.result-stat{display:flex;flex-direction:column;align-items:center}.result-value{font-size:1.6rem;font-weight:700}.result-stat span:last-child{font-size:.8rem;color:var(--text-muted)}.result-actions{display:flex;flex-direction:column;gap:12px;align-items:center;margin-top:20px}.paystub-source-input{display:flex;align-items:center;gap:10px;margin-bottom:16px}.paystub-source-input label{font-size:.9rem;font-weight:500;white-space:nowrap}.paystub-source-input input{flex:1;padding:10px 14px;border:1px solid var(--border);border-radius:8px;font-size:.95rem;outline:none}.paystub-source-input input:focus{border-color:var(--accent)}.paystub-employer{color:var(--text-muted);margin-bottom:16px}.paystub-breakdown{text-align:left;margin:16px 0;padding:16px;background:var(--bg);border-radius:var(--radius)}.paystub-line{display:flex;justify-content:space-between;padding:6px 0;font-size:.95rem}.paystub-line.gross{font-weight:700;font-size:1.1rem;color:var(--accent)}.paystub-line.net{font-weight:700;font-size:1.05rem;color:var(--green)}.paystub-amount{font-weight:600}.paystub-amount.deduction{color:var(--text-muted)}.paystub-divider{height:1px;background:var(--border);margin:8px 0}.faucet-section{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;margin-bottom:28px}.faucet-header{display:flex;align-items:center;gap:14px;margin-bottom:20px}.faucet-icon{font-size:2rem}.faucet-header h3{font-size:1.2rem;margin:0}.faucet-subtitle{color:var(--text-muted);font-size:.85rem;margin:2px 0 0}.faucet-gross{display:flex;align-items:baseline;gap:12px;padding:14px 18px;background:linear-gradient(135deg,#e8f0fe,#d4e4fc);border-radius:10px;flex-wrap:wrap}.faucet-gross-label{font-weight:600;font-size:1rem}.faucet-gross-amount{font-weight:700;font-size:1.4rem;color:var(--accent)}.faucet-count{font-size:.82rem;color:var(--text-muted);margin-left:auto}.faucet-flow-arrow{text-align:center;color:var(--accent);font-size:1.1rem;padding:6px 0;opacity:.6}.faucet-into-buckets{font-size:.82rem;color:var(--text-muted);padding:8px 0 0}.faucet-waterfall{display:flex;flex-direction:column;gap:8px}.waterfall-row{background:var(--bg);border-radius:8px;padding:10px 14px}.waterfall-row-main{display:flex;align-items:center;gap:10px;cursor:pointer}.waterfall-label{flex:1;font-weight:500;font-size:.95rem}.waterfall-expand{font-size:.8rem;margin-left:4px;color:var(--text-muted)}.waterfall-amount{font-weight:600;color:var(--red);font-size:.95rem}.waterfall-pct{font-size:.82rem;color:var(--text-muted);min-width:36px;text-align:right}.waterfall-bar{height:4px;background:var(--border);border-radius:2px;margin-top:8px;overflow:hidden}.waterfall-bar-fill{height:100%;background:var(--red);border-radius:2px;opacity:.5;transition:width .3s ease}.waterfall-details{margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}.waterfall-detail-row{display:flex;justify-content:space-between;padding:3px 0;font-size:.85rem;color:var(--text-muted)}.faucet-takehome{display:flex;align-items:baseline;gap:12px;padding:14px 18px;background:linear-gradient(135deg,#e8f8e9,#c8e6c9);border-radius:10px;flex-wrap:wrap}.faucet-takehome-label{font-weight:600;font-size:1rem}.faucet-takehome-amount{font-weight:700;font-size:1.4rem;color:var(--green)}.faucet-takehome-pct{font-size:.82rem;color:var(--text-muted);margin-left:auto}.review-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:8px}.review-header h2{font-size:1.5rem}.review-stats{display:flex;gap:16px;font-size:.9rem;color:var(--text-muted)}.needs-attention{color:#e6a800;font-weight:600}.all-good{color:var(--green);font-weight:600}.review-section{margin-bottom:32px}.review-section h3{margin-bottom:12px;font-size:1.1rem}.transaction-list{display:flex;flex-direction:column;gap:12px}.txn-card{background:var(--card-bg);border-radius:var(--radius);padding:16px 20px;box-shadow:var(--shadow);border-left:3px solid var(--yellow)}.txn-card-top{display:flex;justify-content:space-between;margin-bottom:4px}.txn-date{font-size:.85rem;color:var(--text-muted)}.txn-amount{font-weight:700}.txn-amount.negative{color:var(--text)}.txn-amount.positive{color:var(--green)}.txn-description{font-weight:600;margin-bottom:8px}.txn-ai-hint{font-size:.85rem;color:var(--text-muted);margin-bottom:12px;padding:6px 10px;background:#f8f6f3;border-radius:8px}.txn-ai-hint strong{color:var(--text)}.confidence{margin-left:6px;font-size:.8rem}.txn-card-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.txn-card-actions select{flex:1;min-width:160px;padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:.9rem}.remember-label{display:flex;align-items:center;gap:4px;font-size:.8rem;color:var(--text-muted);white-space:nowrap}.categorize-btn{background:var(--green);color:#fff;border:none;padding:8px 20px;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s}.categorize-btn:hover{background:#43a047}.categorize-btn:disabled{opacity:.4;cursor:not-allowed}.transaction-list.compact{gap:2px}.txn-row{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--card-bg);border-radius:6px;font-size:.88rem}.txn-row:nth-child(2n){background:#faf8f5}.txn-row .txn-date{flex:0 0 90px}.txn-row .txn-desc{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.txn-row .txn-bucket{flex:0 0 140px;font-size:.8rem;color:var(--accent);font-weight:500}.txn-row .txn-bucket.clickable{cursor:pointer;border-radius:4px;padding:2px 6px;margin:-2px -6px;transition:background .15s}.txn-row .txn-bucket.clickable:hover{background:#e8f5e9}.txn-row .txn-bucket-edit{flex:0 0 200px;display:flex;align-items:center;gap:4px}.txn-row .txn-bucket-edit select{font-size:.8rem;padding:2px 4px;border:1px solid var(--accent);border-radius:4px;background:#fff;flex:1}.inline-save-btn,.inline-cancel-btn{border:none;border-radius:4px;padding:2px 8px;font-size:.8rem;cursor:pointer}.inline-save-btn{background:var(--accent);color:#fff}.inline-save-btn:hover{background:#43a047}.inline-save-btn:disabled{opacity:.4;cursor:not-allowed}.inline-cancel-btn{background:#eee;color:#666}.inline-cancel-btn:hover{background:#ddd}.txn-row .txn-amount{flex:0 0 80px;text-align:right;font-weight:600}.result-processing-note{color:#555;margin:12px 0 4px;font-size:.95rem;line-height:1.5}.result-processing-hint{color:#888;font-size:.88rem;margin-bottom:16px}.lock-section{text-align:center;margin-top:32px;padding:24px;background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow)}.lock-section p{margin-bottom:16px;color:var(--text-muted)}.lock-btn{background:var(--accent);color:#fff;border:none;padding:14px 36px;border-radius:24px;font-size:1.05rem;font-weight:600;cursor:pointer;transition:all .2s}.lock-btn:hover{background:var(--accent-hover);transform:translateY(-1px)}.lock-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}@media (max-width: 640px){.app-header{padding:10px 12px}.header-right{width:100%;justify-content:flex-end}.summary-stats{gap:16px}.stat-value{font-size:1.1rem}.bucket-grid{grid-template-columns:1fr 1fr;gap:10px}.bucket-card{padding:14px}.txn-card-actions{flex-direction:column;align-items:stretch}.txn-row .txn-bucket{display:none}}.settings-page{max-width:560px;margin:0 auto}.settings-page h2{font-size:1.5rem;margin-bottom:4px}.settings-section{background:var(--card-bg);border-radius:var(--radius);padding:24px;margin-top:24px;box-shadow:var(--shadow)}.settings-section h3{font-size:1.1rem;margin-bottom:8px}.settings-desc{color:var(--text-muted);font-size:.9rem;margin-bottom:16px;line-height:1.6}.danger-btn{background:var(--red);color:#fff;border:none;padding:12px 28px;border-radius:24px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s,transform .1s}.danger-btn:hover{background:#d32f2f;transform:translateY(-1px)}.danger-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.delete-confirm{background:#fff5f5;border:1px solid var(--red);border-radius:var(--radius);padding:20px}.confirm-warning{color:var(--red);margin-bottom:12px;font-size:.95rem}.confirm-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.confirm-actions input{padding:10px 14px;border:2px solid var(--red);border-radius:8px;font-size:1rem;outline:none;flex:1;min-width:140px}.delete-result{text-align:center;padding:20px}.delete-result h4{margin:8px 0}.delete-stats{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin:12px 0;font-size:.85rem;color:var(--text-muted)}.bucket-targets-list{display:flex;flex-direction:column;gap:8px}.bucket-target-row{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--bg);border-radius:8px;transition:background .15s}.bucket-target-row:hover{background:#f0ece7}.bucket-target-emoji{font-size:1.3rem;flex:0 0 32px;text-align:center}.bucket-target-name{flex:1;font-weight:500;font-size:.95rem}.bucket-target-input-group{display:flex;align-items:center;gap:4px;flex:0 0 150px}.dollar-prefix{font-size:.95rem;color:var(--text-muted);font-weight:500}.bucket-target-input{width:100px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-size:.95rem;outline:none;transition:border-color .2s;text-align:right}.bucket-target-input:focus{border-color:var(--accent)}.save-target-btn{width:32px;height:32px;border:none;background:var(--green);color:#fff;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:background .2s;display:flex;align-items:center;justify-content:center}.save-target-btn:hover{background:#43a047}.save-target-btn:disabled{opacity:.5;cursor:not-allowed}
