:root{--color-bg:#f7f6f4;--color-surface:#fff;--color-surface-2:#f2f1ef;--color-primary:#2d5a8e;--color-primary-dark:#1f4068;--color-primary-light:#eaf0f8;--color-success:#2e7d5e;--color-success-light:#edf7f3;--color-warning:#b45309;--color-warning-light:#fef3e2;--color-danger:#b91c1c;--color-danger-light:#fef2f2;--color-text:#1c1917;--color-text-muted:#6b7280;--color-text-subtle:#9ca3af;--color-border:#e5e3df;--color-nav:#1e3a5f;--radius-sm:6px;--radius-md:10px;--radius-lg:18px;--radius-pill:999px;--shadow-sm:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);--shadow-md:0 4px 14px rgba(0,0,0,.08),0 2px 6px rgba(0,0,0,.04);--shadow-lg:0 16px 48px rgba(0,0,0,.12),0 4px 16px rgba(0,0,0,.06)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;background:#f7f6f4;background:var(--color-bg);color:#1c1917;color:var(--color-text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.55}body{min-height:100vh}p{font-size:1rem}button{background:transparent;border:none;cursor:pointer;font-family:inherit;line-height:1.4;max-width:none;padding:0}input[type=date],input[type=email],input[type=number],input[type=password],input[type=text],select,textarea{background:#f2f1ef;background:var(--color-surface-2);border:none;border-radius:10px;border-radius:var(--radius-md);box-sizing:border-box;color:#1c1917;color:var(--color-text);font-family:inherit;font-size:.9375rem;line-height:1.4;padding:.6rem .875rem;transition:box-shadow .15s,background .15s;width:100%}input[type=date]:focus,input[type=email]:focus,input[type=number]:focus,input[type=password]:focus,input[type=text]:focus,select:focus,textarea:focus{background:#fff;background:var(--color-surface);box-shadow:0 0 0 2.5px #2d5a8e;box-shadow:0 0 0 2.5px var(--color-primary);outline:none}input::-webkit-input-placeholder{color:#9ca3af;color:var(--color-text-subtle)}input:-ms-input-placeholder{color:#9ca3af;color:var(--color-text-subtle)}input::placeholder{color:#9ca3af;color:var(--color-text-subtle)}textarea{resize:vertical}select{cursor:pointer}label{color:#1c1917;color:var(--color-text);display:block;font-size:.875rem;font-weight:500}.btn-primary{align-items:center;background:#2d5a8e;background:var(--color-primary);border:none;border-radius:999px;border-radius:var(--radius-pill);color:#fff;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.9375rem;font-weight:600;gap:.4rem;padding:.65rem 1.75rem;transition:background .15s,box-shadow .15s;white-space:nowrap}.btn-primary:hover:not(:disabled){background:#1f4068;background:var(--color-primary-dark);box-shadow:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);box-shadow:var(--shadow-sm)}.btn-primary:disabled{cursor:not-allowed;opacity:.5}.btn-secondary{align-items:center;background:#fff;background:var(--color-surface);border:1.5px solid #2d5a8e;border:1.5px solid var(--color-primary);border-radius:999px;border-radius:var(--radius-pill);color:#2d5a8e;color:var(--color-primary);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.9rem;font-weight:500;padding:.55rem 1.4rem;transition:background .15s;white-space:nowrap}.btn-secondary:hover{background:#eaf0f8;background:var(--color-primary-light)}.btn-danger{align-items:center;background:#b91c1c;background:var(--color-danger);border:none;border-radius:999px;border-radius:var(--radius-pill);color:#fff;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.9rem;font-weight:500;padding:.55rem 1.4rem;transition:background .15s;white-space:nowrap}.btn-danger:hover{background:#a93226}.btn-link{background:none;border:none;color:#b91c1c;color:var(--color-danger);font-size:.85rem;padding:.2rem 0;text-decoration:underline}.btn-action,.btn-link{cursor:pointer;font-family:inherit}.btn-action{background:#fff;background:var(--color-surface);border:1.5px solid #2d5a8e;border:1.5px solid var(--color-primary);border-radius:999px;border-radius:var(--radius-pill);color:#2d5a8e;color:var(--color-primary);font-size:.8rem;font-weight:500;padding:.28rem .85rem;transition:background .15s;white-space:nowrap}.btn-action:hover{background:#eaf0f8;background:var(--color-primary-light)}.btn-action.approve{border-color:#2e7d5e;border-color:var(--color-success);color:#2e7d5e;color:var(--color-success)}.btn-action.approve:hover{background:#edf7f3;background:var(--color-success-light)}.btn-action.reject{border-color:transparent;color:#6b7280;color:var(--color-text-muted)}.btn-action.reject:hover{background:#fef2f2;background:var(--color-danger-light);border-color:#b91c1c;border-color:var(--color-danger);color:#b91c1c;color:var(--color-danger)}.btn-action.reset{border-color:#e5e3df;border-color:var(--color-border);color:#6b7280;color:var(--color-text-muted)}.btn-action.reset:hover{border-color:#6b7280;border-color:var(--color-text-muted);color:#1c1917;color:var(--color-text)}.form-actions{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1rem}.form-group{display:flex;flex:1 1;flex-direction:column;gap:.35rem;min-width:160px}.form-row{display:flex;flex-wrap:wrap;gap:1.25rem}.alert{border-radius:10px;border-radius:var(--radius-md);font-size:.9rem;font-weight:500;margin-bottom:1.5rem;padding:.875rem 1.25rem}.alert-success{background:#edf7f3;background:var(--color-success-light);color:#2e7d5e;color:var(--color-success)}.alert-error{background:#fef2f2;background:var(--color-danger-light);color:#b91c1c;color:var(--color-danger)}.alert-info{background:#eaf0f8;background:var(--color-primary-light);color:#2d5a8e;color:var(--color-primary)}.container{align-items:center;display:flex;justify-content:center;min-height:calc(100vh - 80px);padding:2rem 1rem}.form{background:#fff;background:var(--color-surface);border-radius:18px;border-radius:var(--radius-lg);box-shadow:0 4px 14px rgba(0,0,0,.08),0 2px 6px rgba(0,0,0,.04);box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:1.25rem;max-width:420px;padding:2.5rem 2.25rem;text-align:left;width:100%}.form h2{color:#1c1917;color:var(--color-text);font-size:1.2rem;font-weight:700}.form h2,.form p{text-align:center}.form p{color:#6b7280;color:var(--color-text-muted);font-size:.9rem;margin:0}.form label{color:#1c1917;color:var(--color-text);display:flex;flex-direction:column;font-size:.875rem;font-weight:500;gap:.4rem}.form input{display:block;height:auto;margin:0;width:100%}.form button{background:#2d5a8e;background:var(--color-primary);border:none;border-radius:999px;border-radius:var(--radius-pill);color:#fff;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;margin-top:.25rem;max-width:none;padding:.75rem 2rem;transition:background .15s;width:100%}.form button:hover{background:#1f4068;background:var(--color-primary-dark);color:#fff}.error{color:#b91c1c;color:var(--color-danger);font-size:.875rem;font-weight:500;text-align:center}.mt-2{margin-top:1.5rem}.mb-2{margin-bottom:1rem}.empty,.muted{color:#9ca3af;color:var(--color-text-subtle)}.empty{font-style:italic}.form:not(:has(>h2)):before{color:var(--color-text);content:"Sign In";display:block;font-size:1.5rem;font-weight:700;margin-bottom:.5rem;text-align:center}.ss-container{position:relative;width:100%}.ss-trigger{align-items:center;background:#fff;border:1px solid #ccc;border-radius:4px;cursor:pointer;display:flex;font-size:14px;justify-content:space-between;min-height:38px;padding:8px 10px;-webkit-user-select:none;-ms-user-select:none;user-select:none}.ss-trigger.ss-open{border-color:#4a90e2;box-shadow:0 0 0 2px rgba(74,144,226,.15)}.ss-trigger.ss-required{border-color:#e57373}.ss-placeholder{color:#999}.ss-value{color:#222}.ss-icons{align-items:center;display:flex;flex-shrink:0;gap:6px;margin-left:8px}.ss-clear{color:#999;cursor:pointer;font-size:18px;line-height:1;padding:0 2px}.ss-clear:hover{color:#333}.ss-arrow{color:#666;font-size:10px}.ss-dropdown{background:#fff;border:1px solid #ccc;border-radius:4px;box-shadow:0 4px 12px rgba(0,0,0,.12);left:0;position:absolute;right:0;top:calc(100% + 2px);z-index:1000}.ss-search{border:none;border-bottom:1px solid #eee;box-sizing:border-box;font-size:14px;outline:none;padding:8px 10px;width:100%}.ss-list{-webkit-overflow-scrolling:touch;max-height:240px;overflow-y:auto}.ss-option{color:#222;cursor:pointer;font-size:14px;padding:9px 12px}.ss-option:hover{background:#f0f4ff}.ss-option.ss-selected{background:#e8efff;font-weight:500}.ss-empty{color:#999;font-size:13px;padding:12px;text-align:center}.submit-page{margin:2rem auto;max-width:860px;padding:0 1.5rem 4rem}.submit-page h1{color:var(--color-text);font-size:1.625rem;font-weight:700;margin-bottom:.25rem}.submit-subtitle{color:var(--color-text-muted);font-size:.9375rem;margin-bottom:2rem}.submit-form{display:flex;flex-direction:column;gap:1.5rem}.form-section{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:1.75rem}.form-section h2{border-bottom:1px solid var(--color-border);color:var(--color-text-muted);font-size:.72rem;font-weight:600;letter-spacing:.09em;margin:0 0 1.25rem;padding-bottom:.75rem;text-transform:uppercase}.submit-page .form-group{min-width:180px}.submit-page .form-group.flex-2{flex:2 1}.submit-page .form-group.amount-field{flex:0 0 auto;max-width:130px;min-width:100px}.drop-zone{background:var(--color-surface-2);border:2px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;font-size:.9375rem;padding:2.5rem 1.5rem;text-align:center;transition:border-color .2s,background .2s,color .2s}.drop-zone small{color:var(--color-text-subtle);display:block;font-size:.825rem;margin-top:.4rem}.drop-zone.drag-over,.drop-zone:hover{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.drop-zone.has-file{background:var(--color-success-light);border-color:var(--color-success);border-style:solid;color:var(--color-success);font-weight:500}.line-item-row{align-items:flex-end;border-bottom:1px solid var(--color-surface-2);display:flex;gap:.75rem;margin-bottom:1rem;padding-bottom:1rem}.line-item-row:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.line-item-fields{display:flex;flex:1 1;flex-wrap:wrap;gap:.75rem}.btn-remove-line{align-items:center;background:none;border:1.5px solid transparent;border-radius:50%;color:var(--color-text-subtle);cursor:pointer;display:flex;flex-shrink:0;font-size:.9rem;height:30px;justify-content:center;margin-bottom:2px;max-width:none;transition:color .15s,border-color .15s,background .15s;width:30px}.btn-remove-line:hover{background:var(--color-danger-light);border-color:var(--color-danger);color:var(--color-danger)}.line-item-footer{align-items:center;display:flex;justify-content:space-between;margin-top:.5rem}.line-total{color:var(--color-text);font-size:1rem;font-weight:600}.submit-page .form-actions{justify-content:flex-end;margin-top:0}.wizard-toggle-bar{align-items:center;background:#eef2ff;background:var(--color-primary-light,#eef2ff);border:1px solid #4f46e5;border:1px solid var(--color-primary,#4f46e5);border-radius:var(--radius-md);color:var(--color-text);display:flex;font-size:.9375rem;justify-content:space-between;margin-bottom:1.5rem;padding:.75rem 1.25rem}.wizard-container{margin:0 auto;max-width:560px;position:relative}.wizard-close{background:none;border:none;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;font-size:1.1rem;line-height:1;padding:.25rem .5rem;position:absolute;right:0;top:0}.wizard-close:hover{background:var(--color-border);color:var(--color-text)}.wizard-progress{background:var(--color-border);border-radius:3px;height:6px;margin-bottom:.5rem;overflow:hidden}.wizard-progress-bar{background:#4f46e5;background:var(--color-primary,#4f46e5);border-radius:3px;height:100%;transition:width .3s ease}.wizard-progress-labels{display:flex;justify-content:space-between;margin-bottom:1.5rem}.wizard-step-dot{color:var(--color-text-subtle);font-size:.7rem;letter-spacing:.05em;text-transform:uppercase}.wizard-step-dot.active{color:#4f46e5;color:var(--color-primary,#4f46e5);font-weight:700}.wizard-step-dot.done{color:#16a34a;color:var(--color-success,#16a34a)}.wizard-card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:2rem 2rem 1.5rem}.wizard-question{color:var(--color-text);font-size:1.3rem;font-weight:700;margin-bottom:.4rem}.wizard-hint{color:var(--color-text-muted);font-size:.9rem;margin-bottom:1.25rem}.wizard-card-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem}.wizard-card-option{background:var(--color-surface-2);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;font-size:.9375rem;padding:.75rem 1rem;text-align:left;transition:border-color .15s,background .15s}.wizard-card-option.selected,.wizard-card-option:hover{background:#eef2ff;background:var(--color-primary-light,#eef2ff);border-color:#4f46e5;border-color:var(--color-primary,#4f46e5)}.wizard-card-option.selected{font-weight:600}.wizard-yn-row{display:flex;gap:1rem;margin-bottom:.5rem}.wizard-yn-btn{background:var(--color-surface-2);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;flex:1 1;font-size:1.1rem;font-weight:600;padding:1rem;transition:border-color .15s,background .15s}.wizard-yn-btn.selected,.wizard-yn-btn:hover{border-color:#4f46e5;border-color:var(--color-primary,#4f46e5)}.wizard-yn-btn.selected{background:#eef2ff;background:var(--color-primary-light,#eef2ff);color:#4f46e5;color:var(--color-primary,#4f46e5)}.wizard-tax-helpers{align-items:center;display:flex;font-size:.875rem;gap:.75rem;margin-top:.4rem}.wizard-date-input{font-size:1rem;padding:.625rem .75rem;width:100%}.wizard-line-item{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:.75rem;padding:1rem}.wizard-li-header{align-items:center;color:var(--color-text-muted);display:flex;font-size:.875rem;font-weight:600;justify-content:space-between;letter-spacing:.05em;margin-bottom:.75rem;text-transform:uppercase}.wizard-subtotal{color:var(--color-text);font-size:1rem;margin-top:.75rem;text-align:right}.wizard-review-items,.wizard-review-table{background:var(--color-surface-2);border-radius:var(--radius-md);margin-bottom:.75rem;padding:.75rem 1rem}.wizard-review-section-label{color:var(--color-text-muted);font-size:.7rem;font-weight:600;letter-spacing:.08em;margin-bottom:.5rem;text-transform:uppercase}.wizard-review-row{align-items:baseline;border-bottom:1px solid var(--color-border);display:flex;font-size:.9375rem;justify-content:space-between;padding:.35rem 0}.wizard-review-row:last-child{border-bottom:none}.wizard-review-row span{color:var(--color-text-muted)}.wizard-review-total{font-size:1rem}.wizard-review-total span,.wizard-review-total strong{color:var(--color-text)}.wizard-file-list{display:flex;flex-direction:column;font-size:.9rem;gap:.25rem;list-style:none;margin:.75rem 0 0;padding:0}.wizard-nav{align-items:center;border-top:1px solid var(--color-border);display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem}.wizard-skip{color:var(--color-text-muted);font-size:.875rem}.wizard-card-option.card-number{font-family:monospace;font-size:1.1rem;font-weight:700;letter-spacing:.05em;text-align:center}.wizard-card-sub{color:var(--color-text-muted);display:block;font-family:inherit;font-size:.8rem;font-weight:400;letter-spacing:normal;margin-top:.2rem}.wizard-card-option:has(.wizard-card-sub){padding:1rem 1.25rem}.wizard-total-block{margin-bottom:.75rem}.wizard-total-label{display:block;font-size:.9375rem;font-weight:600;margin-bottom:.4rem}.wizard-total-input-wrap{align-items:center;border:2px solid var(--color-border);border-radius:var(--radius-md);display:flex;max-width:220px;overflow:hidden;transition:border-color .15s}.wizard-total-input-wrap:focus-within{border-color:#4f46e5;border-color:var(--color-primary,#4f46e5)}.wizard-dollar{background:var(--color-surface-2);border-right:1px solid var(--color-border);color:var(--color-text-muted);font-size:1.1rem;font-weight:600;padding:.625rem .6rem .625rem .9rem;-webkit-user-select:none;-ms-user-select:none;user-select:none}.wizard-total-input{background:var(--color-surface);border:none;color:var(--color-text);flex:1 1;font-size:1.25rem;font-weight:700;min-width:0;outline:none;padding:.625rem .75rem;width:0}.wizard-split-btn{background:none;border:1.5px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;font-size:.875rem;margin-bottom:.25rem;margin-top:.25rem;padding:.6rem 1rem;text-align:center;transition:border-color .15s,color .15s;width:100%}.wizard-split-btn:hover{border-color:#4f46e5;border-color:var(--color-primary,#4f46e5);color:#4f46e5;color:var(--color-primary,#4f46e5)}.wizard-optional{color:var(--color-text-muted);font-size:.8rem;font-weight:400;margin-left:.3rem}.wizard-tax-preview{background:var(--color-surface-2);border-radius:4px;border-radius:var(--radius-sm,4px);color:var(--color-text-muted);font-size:.875rem;margin-top:.5rem;padding:.4rem .75rem}@media (max-width:480px){.wizard-total-input-wrap{max-width:100%}.wizard-card-option.card-number{font-size:1.25rem;padding:1rem}.wizard-yn-btn{font-size:1rem;padding:.875rem}}.select-list{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:1rem;overflow-y:auto}.select-list-item{border-bottom:1px solid var(--color-border);color:var(--color-text);cursor:pointer;font-size:.875rem;padding:.4rem .75rem;transition:background .1s,color .1s;-webkit-user-select:none;-ms-user-select:none;user-select:none}.select-list-item:last-child{border-bottom:none}.select-list-item:hover:not(.selected){background:var(--color-primary-light)}.select-list-item.selected{background:var(--color-primary);color:#fff}.mobile-card-list{display:none}.desktop-only{display:table}@media (max-width:768px){.mobile-card-list{display:flex;flex-direction:column;gap:.75rem}.desktop-only{display:none!important}.mobile-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.875rem 1rem}.mobile-card-mismatch{border-left:3px solid #e67e22}.mobile-card-row{align-items:flex-start;display:flex;gap:.75rem;justify-content:space-between}.mobile-card-vendor{font-size:1rem;font-weight:600;margin-bottom:.2rem}.mobile-card-meta{color:var(--color-text-muted);font-size:.8rem;margin-bottom:.2rem}.mobile-card-amount{font-size:1rem;font-weight:600;margin-bottom:.25rem}.mobile-card-qbo-link{color:var(--color-primary);display:block;font-size:.75rem;margin-top:.2rem}.mobile-card-mismatch-label{color:#c0392b;font-size:.75rem;font-weight:500;margin-top:.25rem}.mobile-card-actions{align-items:center;border-top:1px solid var(--color-border);display:flex;justify-content:space-between;margin-top:.625rem;padding-top:.625rem}.tab-header>div{flex-wrap:wrap}}.admin-page{margin:2rem auto;max-width:1100px;padding:0 1.5rem 4rem}.admin-page h1{color:var(--color-text);font-size:1.625rem;font-weight:700;margin-bottom:1.5rem}.tab-bar{-webkit-overflow-scrolling:touch;background:var(--color-surface);border-radius:var(--radius-pill);box-shadow:var(--shadow-sm);display:flex;flex-wrap:nowrap;gap:.3rem;margin-bottom:2rem;max-width:100%;overflow-x:auto;padding:.3rem;scrollbar-width:none;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content}.tab-bar::-webkit-scrollbar{display:none}.tab-btn{background:transparent;border:none;border-radius:var(--radius-pill);color:var(--color-text-muted);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:500;margin-bottom:0;max-width:none;padding:.48rem 1.1rem;transition:background .15s,color .15s,box-shadow .15s;white-space:nowrap}.tab-btn:hover{background:var(--color-surface-2);color:var(--color-text)}.tab-btn.active{background:var(--color-primary);box-shadow:var(--shadow-sm);color:#fff}.tab-bar .tab-btn:first-child{color:var(--color-primary);font-weight:600}.tab-bar .tab-btn:first-child:hover{background:var(--color-primary-light);color:var(--color-primary)}.tab-content{-webkit-animation:fadein .15s ease;animation:fadein .15s ease}@-webkit-keyframes fadein{0%{opacity:0;-webkit-transform:translateY(4px);transform:translateY(4px)}to{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}@keyframes fadein{0%{opacity:0;-webkit-transform:translateY(4px);transform:translateY(4px)}to{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}.tab-header{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between;margin-bottom:1.25rem}.tab-header h2{color:var(--color-text);font-size:1.1rem;font-weight:600;margin:0}.data-table{background:var(--color-surface);border-collapse:collapse;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);font-size:.875rem;overflow:hidden;width:100%}.data-table th{background:var(--color-surface-2);border-bottom:1px solid var(--color-border);color:var(--color-text-muted);font-size:.78rem;font-weight:600;letter-spacing:.05em;padding:.75rem 1rem;text-align:left;text-transform:uppercase}.data-table td{border-bottom:1px solid var(--color-surface-2);color:var(--color-text);padding:.75rem 1rem;vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--color-primary-light)}.status-badge{border-radius:var(--radius-pill);display:inline-block;font-size:.775rem;font-weight:600;letter-spacing:.02em;padding:.22rem .75rem;text-transform:capitalize;text-transform:none}.status-pending{background:var(--color-warning-light);color:var(--color-warning)}.status-needs-review{background:#fde8d8;color:#c0392b}.status-submitted{background:var(--color-success-light);color:var(--color-success)}.status-posted{background:#d0f0ea;color:#16a085}.status-rejected{background:var(--color-danger-light);color:var(--color-danger)}.status-badge.pending{background:var(--color-warning-light);color:var(--color-warning)}.status-badge.submitted{background:var(--color-success-light);color:var(--color-success)}.status-badge.rejected{background:var(--color-danger-light);color:var(--color-danger)}.action-cell{display:flex;flex-wrap:wrap;gap:.4rem}.card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:1.5rem}.card h3{font-size:1rem;font-weight:600;margin:0 0 1rem}.inline-form{align-items:flex-end;display:flex;flex-wrap:wrap;gap:.6rem}.inline-form input,.inline-form select{flex:1 1;min-width:130px}.msg-ok{color:var(--color-success)}.msg-error,.msg-ok{font-size:.9rem;font-weight:500;margin:.5rem 0}.msg-error{color:var(--color-danger)}.sync-buttons{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));margin-bottom:1.5rem}.sync-card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:1.5rem;transition:box-shadow .15s}.sync-card:hover{box-shadow:var(--shadow-md)}.sync-card h3{font-size:1rem;font-weight:600;margin:0 0 .5rem}.sync-card p{color:var(--color-text-muted);font-size:.875rem;margin:0 0 1rem}.match-result{border-radius:var(--radius-md);font-size:.875rem;font-weight:500;margin:4px 0;padding:.5rem 1rem}.match-result.matched{background:var(--color-success-light);color:var(--color-success)}.match-result.no_match{background:var(--color-warning-light);color:var(--color-warning)}.match-result.multiple_matches{background:var(--color-primary-light);color:var(--color-primary)}.match-result.error{background:var(--color-danger-light);color:var(--color-danger)}.match-result.already_matched{background:var(--color-surface-2);color:var(--color-text-muted)}.badge{background:var(--color-danger);border-radius:var(--radius-pill);color:#fff;display:inline-block;font-size:.68rem;font-weight:700;line-height:1.4;margin-left:5px;padding:.1rem .45rem;vertical-align:middle}.modal-overlay{align-items:flex-start;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);background:hsla(0,0%,6%,.38);display:flex;inset:0;justify-content:center;overflow-y:auto;padding:2rem 1rem;position:fixed;z-index:1000}@-webkit-keyframes slideUp{0%{opacity:0;-webkit-transform:translateY(18px);transform:translateY(18px)}to{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;-webkit-transform:translateY(18px);transform:translateY(18px)}to{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}.modal-panel{-webkit-animation:slideUp .2s ease;animation:slideUp .2s ease;background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:780px;padding:2rem;width:100%}.modal-panel h2{font-size:1.2rem;font-weight:700;margin:0 0 .25rem}.modal-panel h3{color:var(--color-text-muted);font-size:.875rem;font-weight:600;letter-spacing:.06em;margin:1.5rem 0 .6rem;text-transform:uppercase}.modal-panel .form-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.75rem}.modal-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem}.receipt-preview{margin-bottom:1rem}.receipt-preview-item{margin-bottom:.75rem}.receipt-img-preview{border-radius:var(--radius-md);box-shadow:var(--shadow-sm);display:block;max-height:420px;max-width:100%}.pdf-open-btn{align-items:center;background:var(--color-surface-2);border-radius:var(--radius-md);color:var(--color-primary);display:inline-flex;font-size:.9375rem;font-weight:500;gap:.5rem;padding:.75rem 1.25rem;text-decoration:none;transition:background .15s}.pdf-open-btn:hover{background:var(--color-primary-light)}.match-detail-table{border-collapse:collapse;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);font-size:.875rem;margin-top:.5rem;overflow:hidden;width:100%}.match-detail-table td,.match-detail-table th{border-bottom:1px solid var(--color-surface-2);padding:.55rem .875rem;text-align:left}.match-detail-table th{background:var(--color-surface-2);border-bottom:1px solid var(--color-border);color:var(--color-text-muted);font-size:.78rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.match-detail-table tr:last-child td{border-bottom:none}.match-detail-table tr.mismatch-row td{background:var(--color-warning-light);color:var(--color-warning);font-weight:500}.att-delete-btn{background:none;border:none;color:var(--color-text-subtle);cursor:pointer;font-family:inherit;font-size:.85rem;max-width:none;padding:0 .3rem;transition:color .15s}.att-delete-btn:hover{color:var(--color-danger)}.navBar{background:var(--color-nav);box-shadow:0 1px 0 rgba(0,0,0,.14),0 2px 8px rgba(0,0,0,.08);color:#fff;height:60px;padding:0 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.navBar,.navBar ul{align-items:center;display:flex}.navBar ul{gap:.25rem;list-style:none;margin:0;padding:0;width:100%}.navBar li{font-size:.9375rem}.brand a{color:#fff;font-size:1.05rem;font-weight:700;letter-spacing:.01em;margin-right:.75rem;white-space:nowrap}.brand a,.navBar a{text-decoration:none}.navBar a{border-radius:var(--radius-sm);color:hsla(0,0%,100%,.72);display:block;font-weight:500;padding:.4rem .8rem;transition:color .15s,background .15s}.navBar a:hover{background:hsla(0,0%,100%,.1);color:#fff}.nav-right{margin-left:auto}.nav-user-info{align-items:center;color:hsla(0,0%,100%,.75);display:flex;font-size:.875rem;gap:.75rem;white-space:nowrap}.role-badge{background:hsla(0,0%,100%,.14);border-radius:var(--radius-pill);color:hsla(0,0%,100%,.88);font-size:.7rem;font-weight:600;letter-spacing:.07em;padding:.15rem .65rem;text-transform:uppercase}.nav-avatar-wrap{position:relative}.nav-avatar-btn{align-items:center;background:transparent;border:none;border-radius:var(--radius-pill);color:hsla(0,0%,100%,.88);cursor:pointer;display:flex;font-family:inherit;font-size:.875rem;gap:.5rem;padding:.25rem .5rem;transition:background .15s;white-space:nowrap}.nav-avatar-btn:hover{background:hsla(0,0%,100%,.1);color:#fff}.nav-avatar-circle{align-items:center;background:hsla(0,0%,100%,.22);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.875rem;font-weight:700;height:32px;justify-content:center;letter-spacing:0;width:32px}.nav-avatar-name{align-items:center;display:flex;gap:.5rem}.nav-avatar-caret{font-size:.7rem;margin-left:.1rem;opacity:.6}.nav-dropdown{-webkit-animation:dropIn .12s ease;animation:dropIn .12s ease;background:#fff;border-radius:var(--radius-md);box-shadow:0 4px 20px rgba(0,0,0,.18);min-width:160px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);z-index:200}@-webkit-keyframes dropIn{0%{opacity:0;-webkit-transform:translateY(-6px);transform:translateY(-6px)}to{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}@keyframes dropIn{0%{opacity:0;-webkit-transform:translateY(-6px);transform:translateY(-6px)}to{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}.nav-dropdown-item{background:none;border:none;color:var(--color-text);cursor:pointer;display:block;font-family:inherit;font-size:.9rem;padding:.65rem 1rem;text-align:left;transition:background .12s;width:100%}.nav-dropdown-item:hover{background:#f5f5f5;background:var(--color-surface-2,#f5f5f5)}.nav-dropdown-divider{background:#e5e7eb;background:var(--color-border,#e5e7eb);height:1px;margin:0}.nav-dropdown-logout{color:#dc3545}footer{background:var(--color-surface);border-top:1px solid var(--color-border);color:var(--color-text-subtle);font-size:.8125rem;margin-top:3rem;padding:1.5rem 1rem;text-align:center}
/*# sourceMappingURL=main.1f508087.css.map*/