@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";
@import "https://fonts.googleapis.com/icon?family=Material+Icons";
:root{--primary:#fbbf24;--primary-hover:#f59e0b;--secondary:#0ea5e9;--secondary-hover:#0284c7;--bg:#f3f4f6;--surface:#fff;--text:#1f2937;--text-muted:#6b7280;--text-light:#9ca3af;--border:#e5e7eb;--border-light:#f3f4f6;--success:#10b981;--success-bg:#d1fae5;--success-text:#065f46;--warning:#f59e0b;--warning-bg:#fef3c7;--warning-text:#92400e;--danger:#ef4444;--danger-bg:#fee2e2;--danger-text:#991b1b;--info:#3b82f6;--info-bg:#dbeafe;--info-text:#1e40af;--radius:.5rem;--radius-lg:.75rem;--shadow-sm:0 1px 2px #0000000d;--shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;--shadow-lg:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;font-size:14px}body{background:var(--bg);color:var(--text);flex-direction:column;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;display:flex}a{color:inherit;text-decoration:none}.navbar{background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);z-index:100;justify-content:space-between;align-items:center;height:64px;padding:0 2rem;display:flex;position:sticky;top:0}.navbar-left{align-items:center;gap:.5rem;display:flex}.navbar-logo{align-items:center;gap:.5rem;margin-right:1rem;display:flex}.navbar-logo-icon{color:var(--secondary);font-family:Arial Black,sans-serif;font-size:1.75rem;font-weight:800;line-height:1}.navbar-logo-text{flex-direction:column;line-height:1.1;display:flex}.navbar-logo-text span{color:var(--primary);letter-spacing:.05em;text-transform:uppercase;font-size:1.05rem;font-weight:700}.navbar-nav{align-items:center;gap:0;margin-left:1rem;display:flex}.navbar-link{color:var(--text-muted);border-bottom:2px solid #0000;align-items:center;height:64px;margin-top:2px;padding:.5rem .75rem;font-size:.9rem;font-weight:500;transition:all .15s;display:flex}.navbar-link:hover{color:var(--text);border-bottom-color:var(--border)}.navbar-link.active{color:var(--text);border-bottom-color:var(--secondary)}.navbar-right{align-items:center;gap:1rem;display:flex}.navbar-bell{cursor:pointer;color:var(--text-light);background:0 0;border:none;border-radius:50%;align-items:center;padding:.5rem;transition:background .15s;display:flex}.navbar-bell:hover{background:var(--border-light);color:var(--text-muted)}.navbar-user{align-items:center;gap:.75rem;display:flex}.navbar-user-info{text-align:right}.navbar-user-name{color:var(--text);font-size:.85rem;font-weight:600}.navbar-user-role{color:var(--text-light);font-size:.7rem}.navbar-avatar{background:var(--secondary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:.75rem;font-weight:700;display:flex}.main-container{flex:1;width:100%;max-width:1280px;margin:0 auto;padding:2rem}.page-header{justify-content:space-between;align-items:flex-start;margin-bottom:2rem;display:flex}.page-title{color:var(--text);font-size:1.75rem;font-weight:700;line-height:1.2}.page-subtitle{color:var(--text-muted);margin-top:.25rem;font-size:.9rem}.page-actions{align-items:center;gap:.75rem;display:flex}.stat-grid{grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-bottom:2rem;display:grid}.stat-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);border-left:4px solid var(--stat-color,var(--secondary));cursor:pointer;align-items:center;gap:1rem;padding:1.25rem;transition:box-shadow .15s,transform .15s;display:flex}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}.stat-card.active{box-shadow:0 0 0 2px var(--stat-color,var(--secondary))}.stat-card-icon{color:var(--stat-color,var(--secondary));font-size:2rem}.stat-card-label{color:var(--text-muted);font-size:.85rem;font-weight:500}.stat-card-value{color:var(--text);font-size:1.25rem;font-weight:700}.filter-bar{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);grid-template-columns:2fr 1fr 1fr;gap:1rem;margin-bottom:1.5rem;padding:1rem;display:grid}.filter-input{position:relative}.filter-input-icon{color:var(--text-light);font-size:1.25rem;position:absolute;top:50%;left:.75rem;transform:translateY(-50%)}.form-control{border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);background:#fff;outline:none;padding:.5rem .75rem;font-family:inherit;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.form-control:focus{border-color:var(--secondary);box-shadow:0 0 0 3px #0ea5e91a}.form-control.search{padding-left:2.5rem}select.form-control{cursor:pointer}textarea.form-control{resize:vertical;min-height:60px}.form-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.3rem;font-size:.7rem;font-weight:600;display:block}.form-group{margin-bottom:1rem}.form-grid{grid-template-columns:1fr 1fr;gap:1.25rem;display:grid}.form-grid .full{grid-column:1/-1}.table-wrap{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}table{border-collapse:collapse;width:100%}thead{background:#f9fafb}thead th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);padding:.75rem 1.5rem;font-size:.7rem;font-weight:600}tbody td{border-bottom:1px solid var(--border);vertical-align:middle;padding:1rem 1.5rem;font-size:.9rem}tbody tr{transition:background .1s}tbody tr:hover{background:#f9fafb}tbody tr:last-child td{border-bottom:none}.td-num{text-align:right;font-variant-numeric:tabular-nums}.supplier-badge{align-items:center;gap:.75rem;display:flex}.supplier-initials{border-radius:var(--radius);color:#6b7280;background:#e5e7eb;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.7rem;font-weight:700;display:flex}.badge{white-space:nowrap;border-radius:999px;align-items:center;padding:.15rem .6rem;font-size:.7rem;font-weight:600;display:inline-flex}.badge-validated,.badge-validado{background:var(--success-bg);color:var(--success-text)}.badge-pending,.badge-pendiente{background:var(--warning-bg);color:var(--warning-text)}.badge-error,.badge-datos_incorrectos,.badge-manual_review,.badge-revision{background:var(--danger-bg);color:var(--danger-text)}.badge-processing{background:var(--info-bg);color:var(--info-text)}.action-link{color:var(--secondary);cursor:pointer;font-size:.85rem;font-weight:500;transition:color .1s}.action-link:hover{color:var(--secondary-hover);text-decoration:underline}.action-link.muted{color:var(--text-light)}.action-link.muted:hover{color:var(--text-muted)}.pagination-bar{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);justify-content:space-between;align-items:center;margin-top:1rem;padding:.75rem 1.5rem;display:flex}.pagination-info{color:var(--text-muted);font-size:.85rem}.pagination-info b{color:var(--text)}.pagination-pages{gap:0;display:flex}.page-btn{border:1px solid var(--border);min-width:36px;height:36px;color:var(--text-muted);cursor:pointer;background:#fff;justify-content:center;align-items:center;margin-left:-1px;font-family:inherit;font-size:.85rem;font-weight:500;transition:all .1s;display:flex}.page-btn:first-child{border-radius:var(--radius)0 0 var(--radius);margin-left:0}.page-btn:last-child{border-radius:0 var(--radius)var(--radius)0}.page-btn:hover:not(.active):not(:disabled){color:var(--text);background:#f9fafb}.page-btn.active{background:var(--secondary);border-color:var(--secondary);color:#fff;z-index:1}.page-btn:disabled{opacity:.4;cursor:default}.btn{border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:.5rem;padding:.5rem 1rem;font-family:inherit;font-size:.85rem;font-weight:600;transition:all .15s;display:inline-flex}.btn-outline{border-color:var(--border);color:var(--text);background:#fff}.btn-outline:hover{background:#f9fafb}.btn-primary{background:var(--secondary);color:#fff;border-color:var(--secondary)}.btn-primary:hover{background:var(--secondary-hover);border-color:var(--secondary-hover)}.btn-confirm{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:var(--shadow-sm);font-weight:700}.btn-confirm:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn-confirm:active{transform:scale(.97)}.btn-danger-ghost{color:var(--text-muted);background:0 0;border:none;padding:.5rem 1rem}.btn-danger-ghost:hover{color:var(--danger);background:var(--danger-bg)}.btn-reprocess{border:1px solid var(--secondary);color:var(--secondary);background:0 0}.btn-reprocess:hover{background:var(--secondary);color:#fff}.btn-sm{padding:.4rem .75rem;font-size:.8rem}.confidence-bar{align-items:center;gap:.5rem;display:flex}.confidence-track{background:var(--border);border-radius:999px;width:80px;height:8px;overflow:hidden}.confidence-fill{border-radius:999px;height:100%;transition:width .3s}.confidence-fill.high{background:var(--success)}.confidence-fill.medium{background:var(--warning)}.confidence-fill.low{background:var(--danger)}.confidence-label{color:var(--text-muted);font-size:.8rem}.detail-container{flex:1;height:calc(100vh - 64px);display:flex;overflow:hidden}.pdf-panel{border-right:1px solid var(--border);background:#d1d5db;flex-direction:column;width:50%;display:flex}.pdf-toolbar{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:.5rem 1rem;display:flex}.pdf-toolbar-left{align-items:center;gap:.5rem;display:flex}.pdf-zoom{background:#f3f4f6;border-radius:.25rem;padding:.2rem .5rem;font-family:Roboto Mono,monospace;font-size:.75rem}.pdf-toolbar-center{color:var(--text-muted);font-size:.8rem;font-weight:500}.pdf-viewer{background:#9ca3af4d;flex:1;justify-content:center;padding:2rem;display:flex;overflow:auto}.pdf-page{background:#fff;width:595px;min-height:842px;padding:3rem;font-size:.8rem;box-shadow:0 4px 20px #00000026}.form-panel{background:var(--surface);flex-direction:column;width:50%;display:flex;overflow:hidden}.form-panel-scroll{flex:1;padding:1.5rem;overflow-y:auto}.form-panel-footer{border-top:1px solid var(--border);background:var(--surface);flex-shrink:0;justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.alert-bar{border-left:4px solid;flex-shrink:0;align-items:flex-start;gap:.75rem;padding:1rem;display:flex}.alert-bar.warning{background:var(--danger-bg);border-color:var(--danger)}.alert-bar.warning .alert-icon{color:var(--danger)}.alert-bar.warning .alert-title{color:var(--danger-text);font-size:.9rem;font-weight:600}.alert-bar.warning .alert-desc{color:#b91c1c;margin-top:.25rem;font-size:.85rem}.section-title{color:var(--text);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.1rem;font-weight:600;display:flex}.section-title .material-icons{color:var(--secondary);font-size:1.25rem}.line-input{color:var(--text);background:0 0;border:none;outline:none;width:100%;padding:0;font-family:inherit;font-size:.9rem}.line-input:focus{color:var(--text)}.line-input.num{text-align:right;font-variant-numeric:tabular-nums}.line-cell-muted{text-align:right;color:var(--text-muted);font-size:.85rem}.line-cell-total{text-align:right;color:var(--text);font-size:.85rem;font-weight:600}.line-delete{color:var(--text-light);cursor:pointer;background:0 0;border:none;border-radius:.25rem;align-items:center;padding:.25rem;transition:color .1s;display:flex}.line-delete:hover{color:var(--danger)}.totals-section{justify-content:flex-end;padding-top:1rem;display:flex}.totals-block{width:50%}.total-row{color:var(--text-muted);justify-content:space-between;padding:.5rem 0;font-size:.9rem;display:flex}.total-row-final{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:.5rem;padding:.75rem 0;display:flex}.total-row-final .label{color:var(--text);font-size:1rem;font-weight:700}.total-input-highlight{border:1px solid var(--primary);border-radius:var(--radius);text-align:right;width:140px;color:var(--text);background:#fbbf2414;outline:none;padding:.5rem .75rem;font-family:inherit;font-size:1.1rem;font-weight:700}.api-panel{border:1px solid var(--border);border-radius:var(--radius);background:#f9fafb;margin-top:1rem;padding:1rem}.api-row{border-bottom:1px solid var(--border-light);justify-content:space-between;padding:.4rem 0;font-size:.8rem;display:flex}.api-row:last-child{border-bottom:none}.api-row .label{color:var(--text-muted);font-weight:600}.api-row .value{color:var(--text);font-weight:600}.api-badge{border-radius:999px;align-items:center;gap:.25rem;padding:.1rem .5rem;font-size:.7rem;font-weight:600;display:inline-flex}.api-badge-sent{background:var(--success-bg);color:var(--success-text)}.api-badge-error{background:var(--danger-bg);color:var(--danger-text)}.api-badge-pending{color:var(--text-muted);background:#f3f4f6}.app-footer{border-top:1px solid var(--border);text-align:center;padding:1.5rem 0}.app-footer p{color:var(--text-light);text-transform:uppercase;letter-spacing:.2em;font-size:.7rem}.loading-screen{min-height:300px;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:3px solid var(--border);border-top-color:var(--secondary);border-radius:50%;width:24px;height:24px;animation:.6s linear infinite spin}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 2rem}.empty-state-title{color:var(--text);margin-bottom:.25rem;font-size:1rem;font-weight:600}.empty-state-desc{font-size:.85rem}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media (max-width:768px){.stat-grid{grid-template-columns:repeat(2,1fr)}.filter-bar,.form-grid{grid-template-columns:1fr}.detail-container{flex-direction:column}.pdf-panel,.form-panel{width:100%;height:50%}.navbar-nav{display:none}}
