@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{flex-shrink:0;align-items:center;gap:.5rem;margin-right:1rem;display:flex}.navbar-logo img{width:auto;max-height:38px;display:block}.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;position:relative}.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;cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:.75rem;font-weight:700;transition:box-shadow .15s;display:flex}.navbar-avatar:hover{box-shadow:0 0 0 3px #0ea5e933}.navbar-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:200;min-width:180px;padding:.25rem;animation:.15s dropdownFade;position:absolute;top:calc(100% + .5rem);right:0}@keyframes dropdownFade{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.navbar-dropdown-item{width:100%;color:var(--text);cursor:pointer;border-radius:calc(var(--radius) - 2px);background:0 0;border:none;align-items:center;gap:.5rem;padding:.6rem .75rem;font-family:inherit;font-size:.85rem;transition:background .1s;display:flex}.navbar-dropdown-item:hover{background:var(--border-light);color:var(--danger)}.main-container{flex:1;width:100%;max-width:1280px;margin:0 auto;padding:2rem}.content-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);min-height:200px;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{background:var(--danger-bg);color:var(--danger-text)}.badge-manual_review,.badge-revision{background:var(--warning-bg);color:var(--warning-text)}.badge-admin,.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-left:1px solid var(--border);background:#d1d5db;flex-direction:column;order:2;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;order:1;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(--warning-bg);border-color:var(--warning)}.alert-bar.warning .material-icons{color:var(--warning)}.alert-bar.warning .alert-title{color:var(--warning-text);font-size:.9rem;font-weight:600}.alert-bar.warning .alert-desc{color:var(--warning-text);margin-top:.25rem;font-size:.85rem}.alert-bar.danger{background:var(--danger-bg);border-color:var(--danger)}.alert-bar.danger .material-icons{color:var(--danger)}.alert-bar.danger .alert-title{color:var(--danger-text);font-size:.9rem;font-weight:600}.alert-bar.danger .alert-desc{color:var(--danger-text);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}.totals-boxes{grid-template-columns:repeat(4,1fr);gap:.75rem;display:grid}.total-box{border:1px solid var(--border);border-radius:var(--radius);text-align:center;background:var(--surface);padding:.75rem}.total-box-label{text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;margin-bottom:.25rem;font-size:.65rem;font-weight:700}.total-box-value{color:var(--secondary);font-variant-numeric:tabular-nums;font-size:1.1rem;font-weight:700}.total-box-highlight{background:var(--secondary);border-color:var(--secondary)}.total-box-highlight .total-box-label{color:#fffc}.total-box-highlight .total-box-value{color:#fff}.total-box-danger{background:var(--danger-bg);border-color:var(--danger)}.total-box-danger .total-box-label{color:var(--danger-text)}.total-box-danger .total-box-value{color:var(--danger)}.section-divider{border:none;border-top:1px solid var(--border);margin:1.25rem 0}.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}.login-page{justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-bg-gradient{z-index:0;background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 40%,#0284c7 100%);position:fixed;inset:0}.login-bg-pattern{z-index:1;background:radial-gradient(circle at 20% 30%,#009fe326 0%,#0000 50%),radial-gradient(circle at 80% 70%,#fbbf241a 0%,#0000 50%);position:fixed;inset:0}.login-card{z-index:2;background:#fff;border-radius:1rem;width:100%;max-width:420px;padding:2.5rem 2.5rem 2rem;animation:.4s loginSlideUp;position:relative;box-shadow:0 20px 60px #0000004d,0 0 0 1px #ffffff1a}@keyframes loginSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-logo{justify-content:center;margin-bottom:1.5rem;display:flex}.login-logo img{width:auto;max-height:60px}.login-header{text-align:center;margin-bottom:1.75rem}.login-header h1{color:var(--text);margin-bottom:.35rem;font-size:1.4rem;font-weight:700}.login-header p{color:var(--text-muted);font-size:.9rem}.login-error{background:var(--danger-bg);color:var(--danger-text);border-radius:var(--radius);align-items:center;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem;font-size:.85rem;font-weight:500;display:flex}.login-form .form-group{margin-bottom:1.25rem}.login-form .form-control{padding:.65rem .75rem;font-size:.9rem}.login-footer-text{text-align:center;color:var(--text-light);text-transform:uppercase;letter-spacing:.15em;margin-top:2rem;font-size:.7rem}@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}.login-card{margin:1rem;padding:2rem 1.5rem}}
