:root{--color-bg: #f7fafd;--color-surface: #ffffff;--color-primary: #23214b;--color-primary-hover: #1a1840;--color-text: #18181b;--color-text-muted: #64748b;--color-border: #e5e7eb;--color-border-light: #f1f5f9;--color-success: #166534;--color-success-bg: #f0fdf4;--color-warning: #b45309;--color-warning-bg: #fef3c7;--color-danger: #991b1b;--color-danger-bg: #fef2f2;--color-info: #1e40af;--color-info-bg: #eff6ff;--color-faturado: #7c3aed;--color-faturado-bg: #f5f3ff}*,*:before,*:after{box-sizing:border-box}body,#root{min-height:100vh;margin:0;padding:0;background:var(--color-bg);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--color-text);font-size:15px;line-height:1.5}.app-header{display:flex;align-items:center;padding:16px 48px;background:var(--color-bg);gap:32px}.app-header .logo{font-size:1.3rem;font-weight:800;color:var(--color-primary);text-decoration:none}.app-header nav{display:flex;gap:20px}.app-header nav a{font-size:.9rem;color:var(--color-text-muted);text-decoration:none;font-weight:500;transition:color .15s}.app-header nav a:hover{color:var(--color-primary)}.app-header nav a.active{color:var(--color-primary);font-weight:600}.page-content{max-width:1120px;margin:0 auto;padding:0 24px 48px}.page-title{font-size:1.6rem;font-weight:800;color:var(--color-text);margin:0 0 4px}.page-subtitle{font-size:.95rem;color:var(--color-text-muted);margin:0 0 24px}.card{background:var(--color-surface);border-radius:12px;box-shadow:0 1px 3px #0000000a,0 1px 2px #0000000f;padding:20px;margin-bottom:20px}.card-title{font-size:1rem;font-weight:700;color:var(--color-text);margin:0 0 16px;display:flex;align-items:center;gap:8px}.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s;white-space:nowrap}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover)}.btn-secondary{background:var(--color-surface);color:var(--color-primary);border:1.5px solid var(--color-border)}.btn-secondary:hover{border-color:var(--color-primary)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-compact{padding:8px 14px;font-size:.85rem}.form-row{display:flex;gap:12px;align-items:center}.form-input,.form-select{padding:10px 14px;border:1.5px solid var(--color-border);border-radius:8px;font-size:.9rem;color:var(--color-text);background:var(--color-surface);transition:border-color .15s;outline:none}.form-input:focus,.form-select:focus{border-color:var(--color-primary)}.form-input::placeholder{color:var(--color-text-muted)}.form-label{font-size:.85rem;font-weight:500;color:var(--color-text-muted);margin-bottom:6px;display:block}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:10px 12px;border-bottom:2px solid var(--color-border);color:var(--color-text-muted);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.data-table td{padding:10px 12px;border-bottom:1px solid var(--color-border-light);font-size:.9rem}.data-table .group-row td{background:#f8fafc;font-weight:700;color:var(--color-primary);padding-top:14px}.data-table .subtotal-row td{font-weight:600;border-bottom:2px solid var(--color-border)}.data-table .total-row td{font-weight:800;font-size:.95rem;color:var(--color-primary);background:var(--color-border-light);border-top:2px solid var(--color-primary)}.text-right{text-align:right}.tabular-nums{font-variant-numeric:tabular-nums}.summary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-bottom:20px}.summary-card{background:#f8fafc;border-radius:10px;padding:14px;border:1px solid var(--color-border)}.summary-card .label{font-size:.8rem;color:var(--color-text-muted);margin-bottom:2px}.summary-card .value{font-size:1.05rem;font-weight:700;color:var(--color-primary);font-variant-numeric:tabular-nums}.summary-card.highlight{background:var(--color-primary);border-color:var(--color-primary)}.summary-card.highlight .label{color:#94a3b8}.summary-card.highlight .value{color:#fff}.status-msg{padding:10px 16px;border-radius:8px;font-size:.85rem;margin-bottom:20px}.status-msg.success{background:var(--color-success-bg);color:var(--color-success);border:1px solid #bbf7d0}.status-msg.error{background:var(--color-danger-bg);color:var(--color-danger);border:1px solid #fecaca}.status-msg.loading{background:var(--color-info-bg);color:var(--color-info);border:1px solid #bfdbfe}.status-msg.warning{background:var(--color-warning-bg);color:var(--color-warning);border:1px solid #fde68a}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px}.upload-dropzone{border:2px dashed var(--color-border);border-radius:10px;padding:32px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s;background:var(--color-bg)}.upload-dropzone:hover{border-color:var(--color-primary)}.upload-dropzone.drag-active{border-color:var(--color-primary);background:#e0e7ff}.upload-spinner-area{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--color-text-muted);font-size:.9rem}.spinner{width:28px;height:28px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.status-pill{display:inline-block;padding:3px 10px;border-radius:9999px;font-size:.8rem;font-weight:600}.status-pill.success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.status-pill.faturado{background:var(--color-faturado-bg);color:var(--color-faturado);border:1px solid #e9d5ff}.status-pill.warning{background:var(--color-warning-bg);color:var(--color-warning);border:1px solid #fde68a}.status-pill.error{background:var(--color-danger-bg);color:var(--color-danger);border:1px solid #fecaca}.status-pill.loading{background:var(--color-info-bg);color:var(--color-info);border:1px solid #bfdbfe}.match-suggestions{display:flex;flex-direction:column;gap:12px}.match-card{border:1.5px solid var(--color-border);border-radius:10px;padding:16px;background:var(--color-bg)}.match-card.confirmed{border-color:var(--color-success);background:var(--color-success-bg)}.match-card.rejected{border-color:var(--color-border);opacity:.5}.match-card-header{display:flex;justify-content:space-between;align-items:flex-start}.confidence-badge{display:inline-block;padding:2px 10px;border-radius:9999px;font-size:.85rem;font-weight:700;background:var(--color-info-bg);color:var(--color-info)}.match-card-actions{display:flex;gap:8px;margin-top:12px}.progress-bar-track{height:8px;background:var(--color-border-light);border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;border-radius:4px;transition:width .3s ease}.progress-bar-fill.success{background:var(--color-success)}.progress-bar-fill.faturado{background:var(--color-faturado)}.progress-bar-fill.warning{background:var(--color-warning)}.progress-bar-fill.danger{background:var(--color-danger)}.progress-bar-stacked{display:flex;height:100%;width:100%}.progress-bar-stacked .progress-bar-fill{border-radius:0}.progress-bar-stacked .progress-bar-fill:first-child{border-radius:4px 0 0 4px}.progress-bar-stacked .progress-bar-fill:last-child{border-radius:0 4px 4px 0}.legend-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:4px;vertical-align:middle}.legend-dot.success{background:var(--color-success)}.legend-dot.faturado{background:var(--color-faturado)}.legend-dot.warning{background:var(--color-warning)}.category-row-clickable:hover{background:#f8fafc}.expand-arrow{font-size:.7rem;color:var(--color-text-muted);display:inline-block;width:14px}.category-detail-row td{background:#f8fafc}.category-docs{padding:8px 16px 16px 30px}.category-docs-table{margin-bottom:0}.category-docs-table th{font-size:.75rem;padding:6px 10px}.category-docs-table td{font-size:.85rem;padding:8px 10px}.doc-link{color:var(--color-primary);text-decoration:none;font-weight:500}.doc-link:hover{text-decoration:underline}.category-alert{padding:8px 14px;margin-bottom:10px;border-radius:6px;font-size:.83rem;font-weight:500;background:var(--color-faturado-bg);color:var(--color-faturado);border:1px solid #ddd6fe}.flex-1{flex:1}.mb-0{margin-bottom:0}body{margin:0;min-width:320px;min-height:100vh}
