*{margin:0;padding:0;box-sizing:border-box}:root{--sat-blue: #0066CC;--sat-blue-hover: #0052A3;--sat-blue-light: rgba(0, 102, 204, .1);--bg-dark: #0A1929;--bg-darker: #071318;--bg-card: #132F4C;--bg-card-hover: #1A3A52;--text-primary: #E7EBF0;--text-secondary: #B2BAC2;--border-color: #1E3A52;--status-pendiente: #FF6B6B;--status-reconocimiento: #FFA500;--status-concluido: #4ECDC4;--status-liberado: #00D68F;--status-eliminado: #94a3b8;--alert-danger: #FF5252;--alert-warning: #FFB74D;--success: #00D68F}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-dark);color:var(--text-primary)}.layout{display:flex;min-height:100vh}.sidebar{width:240px;background:linear-gradient(180deg,#0a1628,#071318 60%,#050d14);border-right:1px solid rgba(0,102,204,.2);padding:0;display:flex;flex-direction:column;transition:width .28s cubic-bezier(.4,0,.2,1);overflow:visible;clip-path:none;position:relative;flex-shrink:0;box-shadow:4px 0 24px #0006}.sidebar:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,#06c,#00a8ff,#06c);opacity:.8}.sidebar-toggle{position:absolute;top:22px;right:-16px;width:32px;height:32px;border-radius:50%;background:#06c;border:2.5px solid #0a1628;color:#fff;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:20;transition:all .2s ease;line-height:1;box-shadow:0 0 0 3px #0066cc4d,0 4px 12px #00000080}.sidebar-toggle:hover{background:#0080ff;transform:scale(1.15);box-shadow:0 0 0 4px #0080ff66,0 6px 16px #00000080}.sidebar-collapsed{width:60px!important}.sidebar-collapsed .logo{padding:24px 0 20px;justify-content:center;border-bottom:1px solid rgba(0,102,204,.15)}.sidebar-collapsed .logo-text,.sidebar-collapsed .nav-item span,.sidebar-collapsed .sidebar-section-label{display:none}.sidebar-collapsed .nav-menu{padding:12px 8px;align-items:center}.sidebar-collapsed .nav-item{justify-content:center;padding:11px 8px;width:100%}.sidebar-collapsed .nav-item.active:before{display:none}.sidebar-collapsed .nav-item.active{border-radius:8px;background:#0066cc40}.sidebar-section-label{margin:10px 14px 4px;font-size:10px;color:#1e3a52;text-transform:uppercase;letter-spacing:1px;font-weight:700}.logo{display:flex;align-items:center;gap:12px;padding:24px 20px 20px 24px;margin-bottom:8px;border-bottom:1px solid rgba(0,102,204,.15);overflow:hidden}.logo-icon{width:40px;height:40px;background:#000;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px #0066cc59;overflow:hidden;padding:0}.logo-text h1{font-size:14px;font-weight:700;color:#e2e8f0;line-height:1.2;white-space:nowrap}.logo-text p{font-size:10px;color:#4a90d9;text-transform:uppercase;letter-spacing:1px;font-weight:600;margin-top:2px;white-space:nowrap}.nav-menu{display:flex;flex-direction:column;gap:2px;padding:12px;flex:1;overflow:hidden}.nav-item{padding:10px 14px;border-radius:8px;cursor:pointer;transition:all .18s ease;display:flex;align-items:center;gap:12px;color:#64748b;font-size:13.5px;font-weight:500;position:relative;white-space:nowrap}.nav-item:hover{background:#0066cc1f;color:#94a3b8}.nav-item.active{background:#0066cc2e;color:#60a5fa;font-weight:600}.nav-item.active:before{content:"";position:absolute;left:-2px;top:50%;transform:translateY(-50%);width:3px;height:60%;background:#3b82f6;border-radius:0 2px 2px 0}.nav-item svg{width:18px;height:18px;flex-shrink:0;opacity:.7;transition:opacity .18s}.nav-item.active svg,.nav-item:hover svg{opacity:1}.main-content{flex:1;padding:20px 24px;overflow-y:auto;background:var(--bg-dark)}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.header-title h2{font-size:24px;margin-bottom:2px;color:var(--text-primary)}.header-subtitle{color:var(--text-secondary);font-size:13px}.header-actions{display:flex;gap:10px;align-items:center}.quick-search-input{padding:10px 16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;width:280px;transition:all .2s}.quick-search-input:focus{outline:none;border-color:var(--sat-blue);box-shadow:0 0 0 3px var(--sat-blue-light)}.quick-search-input::-moz-placeholder{color:var(--text-secondary)}.quick-search-input::placeholder{color:var(--text-secondary)}.btn{padding:10px 18px;border-radius:8px;border:none;cursor:pointer;font-weight:500;font-size:14px;transition:all .2s;display:flex;align-items:center;gap:8px}.btn-primary{background:var(--sat-blue);color:#fff}.btn-primary:hover{background:var(--sat-blue-hover);transform:translateY(-1px);box-shadow:0 4px 12px #0066cc4d}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--sat-blue)}.btn svg{width:18px;height:18px}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;padding:18px;transition:all .2s}.stat-card:hover{border-color:var(--sat-blue);transform:translateY(-2px);box-shadow:0 4px 12px #0066cc26}.stat-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.stat-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:20px;background:var(--sat-blue-light)}.stat-content{flex:1}.stat-value{font-size:28px;font-weight:700;color:var(--text-primary);line-height:1}.stat-label{color:var(--text-secondary);font-size:13px;margin-top:4px}.stat-change{font-size:12px;font-weight:600;padding:4px 8px;border-radius:4px;display:inline-block;margin-top:8px}.stat-change.positive{background:#00d68f26;color:var(--success)}.stat-change.negative{background:#ff6b6b26;color:var(--status-pendiente)}.filters-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;padding:16px;margin-bottom:20px}.filters-row{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{font-size:12px;color:var(--text-secondary);font-weight:600}.filter-input{padding:8px 12px;background:var(--bg-darker);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:13px;transition:all .2s}.filter-input:focus{outline:none;border-color:var(--sat-blue);box-shadow:0 0 0 2px var(--sat-blue-light)}.table-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;overflow:hidden}.table-header{padding:16px 20px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;background:var(--bg-darker)}.table-title{font-size:16px;font-weight:600;color:var(--text-primary)}.table-wrapper{overflow-x:auto}table{width:100%;border-collapse:collapse}thead{background:var(--bg-darker)}th{padding:12px 16px;text-align:left;font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color)}.sortable-th{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:background .2s ease}.sortable-th:hover{background:#ffffff0a}.sort-arrows{display:inline-flex;flex-direction:column;vertical-align:middle;margin-left:4px;line-height:1;gap:0px}.sort-arrow{font-size:8px;color:#ffffff26;line-height:8px;transition:color .2s ease}.sort-arrow.active{color:var(--accent-primary)}td{padding:14px 16px;border-bottom:1px solid var(--border-color);font-size:13px;color:var(--text-primary)}tbody tr{transition:all .15s}tbody tr:hover{background:var(--bg-card-hover)}tbody tr:last-child td{border-bottom:none}.editable-cell{cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s}.editable-cell:hover{background:var(--bg-darker)}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}.status-dot{width:6px;height:6px;border-radius:50%}.status-pendiente{background:#ff6b6b26;color:var(--status-pendiente);border:1px solid rgba(255,107,107,.3)}.status-pendiente .status-dot{background:var(--status-pendiente)}.status-reconocimiento{background:#ffa50026;color:var(--status-reconocimiento);border:1px solid rgba(255,165,0,.3)}.status-reconocimiento .status-dot{background:var(--status-reconocimiento)}.status-concluido{background:#4ecdc426;color:var(--status-concluido);border:1px solid rgba(78,205,196,.3)}.status-concluido .status-dot{background:var(--status-concluido)}.status-liberado{background:#00d68f26;color:var(--status-liberado);border:1px solid rgba(0,214,143,.3)}.status-liberado .status-dot{background:var(--status-liberado)}.status-eliminado{background:#94a3b81f;color:var(--status-eliminado);border:1px solid rgba(148,163,184,.25);text-decoration:line-through}.status-eliminado .status-dot{background:var(--status-eliminado)}.action-buttons{display:flex;gap:6px}.action-btn{width:30px;height:30px;border-radius:6px;background:var(--bg-darker);border:1px solid var(--border-color);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--text-secondary)}.action-btn:hover{background:var(--sat-blue);border-color:var(--sat-blue);color:#fff;transform:translateY(-1px)}.action-btn svg{width:14px;height:14px}.expiry-warning{color:var(--alert-warning);font-weight:600;font-size:12px}.expiry-danger{color:var(--alert-danger);font-weight:600;font-size:12px}.detail-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;z-index:2000;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.detail-modal.active{display:flex}.detail-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;width:90%;max-width:900px;max-height:85vh;overflow-y:auto;padding:28px}.detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--border-color)}.detail-title h2{font-size:20px;margin-bottom:4px;color:var(--text-primary)}.detail-subtitle{font-size:13px;color:var(--text-secondary)}.close-btn{width:36px;height:36px;border-radius:8px;background:var(--bg-darker);border:1px solid var(--border-color);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--text-secondary)}.close-btn:hover{background:var(--alert-danger);border-color:var(--alert-danger);color:#fff}.detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.detail-field{padding:14px;background:var(--bg-darker);border:1px solid var(--border-color);border-radius:8px}.detail-label{font-size:11px;color:var(--text-secondary);margin-bottom:6px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.detail-value{font-size:14px;font-weight:500;color:var(--text-primary)}.detail-actions{display:flex;gap:10px;padding-top:20px;border-top:1px solid var(--border-color)}@media(max-width:1400px){.stats-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:1024px){.sidebar{width:70px}.logo-text,.nav-item span{display:none}.stats-grid{grid-template-columns:repeat(2,1fr)}.filters-row{grid-template-columns:repeat(3,1fr)}.detail-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.stats-grid,.filters-row{grid-template-columns:1fr}.header-actions{flex-direction:column}.quick-search-input{width:100%}}.aduana-hero{background:linear-gradient(180deg,#0c1e30,#132f4c 40%,#1a3550,#0f2840);border:1px solid var(--border-color);border-radius:12px;padding:0;margin-bottom:20px;position:relative;overflow:hidden;height:260px}.aduana-hero:before{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#f33,#fc0,#0d4)}.highway-sign{position:absolute;top:10px;left:50%;transform:translate(-50%);z-index:30;display:flex;flex-direction:column;align-items:center}.highway-sign-board{background:linear-gradient(180deg,#006341,#004d31);color:#fff;padding:6px 32px 8px;border-radius:6px;border:3px solid #c0c0c0;box-shadow:0 4px 16px #00000080;text-align:center;position:relative}.highway-sign-board:before{content:"";position:absolute;top:3px;right:3px;bottom:3px;left:3px;border:1px solid rgba(255,255,255,.15);border-radius:3px;pointer-events:none}.highway-sign-title{font-size:16px;font-weight:800;letter-spacing:4px;text-transform:uppercase;text-shadow:0 1px 3px rgba(0,0,0,.5)}.highway-sign-sub{font-size:9px;letter-spacing:2px;opacity:.8;margin-top:1px}.highway-sign-poles{display:flex;gap:60px}.highway-sign-pole{width:4px;height:14px;background:linear-gradient(180deg,silver,#888);border-radius:0 0 1px 1px}.scene-ground{position:absolute;bottom:0;left:0;right:0;height:80px;background:linear-gradient(180deg,#3a5a3a,#2d4a2d 30%,#1e3a1e)}.road{position:absolute;bottom:20px;left:0;right:0;height:44px;background:#333;border-top:2px solid #555;border-bottom:2px solid #222}.road-line{position:absolute;top:50%;left:0;right:0;transform:translateY(-50%);height:2px;background:repeating-linear-gradient(90deg,#FFD700 0,#FFD700 20px,transparent 20px,transparent 40px)}.road-edge-top{position:absolute;top:2px;left:0;right:0;height:1px;background:repeating-linear-gradient(90deg,#fff 0,#fff 10px,transparent 10px,transparent 20px);opacity:.3}.road-edge-bottom{position:absolute;bottom:2px;left:0;right:0;height:1px;background:repeating-linear-gradient(90deg,#fff 0,#fff 10px,transparent 10px,transparent 20px);opacity:.3}.truck-group{position:absolute;bottom:26px;z-index:10;transition:none}.truck-svg{width:75px;height:44px;filter:drop-shadow(0 3px 6px rgba(0,0,0,.6))}.semaforo-container{position:absolute;left:18%;bottom:64px;z-index:20;display:flex;flex-direction:column;align-items:center}.semaforo-label{font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin-bottom:3px}.semaforo{width:32px;background:linear-gradient(180deg,#2a2a2a,#1a1a1a);border:2px solid #444;border-radius:8px;padding:4px;display:flex;flex-direction:column;align-items:center;gap:3px;box-shadow:0 4px 16px #000000b3,inset 0 1px #ffffff14}.semaforo-light{width:20px;height:20px;border-radius:50%;border:1px solid rgba(255,255,255,.08);transition:all .6s ease}.semaforo-light.red{background:#300;box-shadow:none}.semaforo-light.red.active{background:#f22;box-shadow:0 0 10px #f22,0 0 20px #ff222280}.semaforo-light.yellow{background:#320;box-shadow:none}.semaforo-light.yellow.active{background:#fc0;box-shadow:0 0 10px #fc0,0 0 20px #ffcc0080}.semaforo-light.green{background:#030;box-shadow:none}.semaforo-light.green.active{background:#0d4;box-shadow:0 0 10px #0d4,0 0 20px #00dd4480}.semaforo-pole{width:4px;height:22px;background:linear-gradient(180deg,#888,#555);border-radius:0 0 2px 2px}.semaforo-row{display:flex;flex-direction:row;align-items:stretch;gap:5px}.semaforo-labels{display:flex;flex-direction:column;justify-content:space-around;align-items:flex-end;padding:4px 0}.semaforo-side-label{font-size:7px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:#ffffff26;transition:all .6s ease;white-space:nowrap;line-height:20px}.semaforo-side-label.active-red{color:#f33;text-shadow:0 0 8px rgba(255,51,51,.6)}.semaforo-side-label.active-yellow{color:#fc0;text-shadow:0 0 8px rgba(255,204,0,.6)}.semaforo-side-label.active-green{color:#0d4;text-shadow:0 0 8px rgba(0,221,68,.6)}.flag-container{position:absolute;bottom:10px;z-index:8}.flag-container.flag-mx{left:3%}.flag-container.flag-us{right:3%}.flag-svg{filter:drop-shadow(2px 3px 5px rgba(0,0,0,.5))}.inspection-module{position:absolute;left:calc(50% - 68px);bottom:64px;z-index:18;width:90px}.module-building{width:90px;height:65px;background:linear-gradient(180deg,#4a6a8a,#3a5a7a,#2a4a6a);border:1px solid #5a7a9a;border-radius:4px 4px 0 0;position:relative;box-shadow:0 4px 12px #0006}.module-roof{position:absolute;top:-6px;left:-4px;right:-4px;height:8px;background:linear-gradient(180deg,#6a8aaa,#5a7a9a);border-radius:3px 3px 0 0;border:1px solid #7a9aba}.module-window{position:absolute;left:8px;top:12px;width:38px;height:30px;background:linear-gradient(180deg,#87ceeb,#5dade2);border:2px solid #7a9aba;border-radius:2px;overflow:hidden;box-shadow:inset 0 0 8px #0000004d}.module-window-glare{position:absolute;top:0;left:0;width:15px;height:100%;background:linear-gradient(90deg,rgba(255,255,255,.3),transparent)}.sat-person-inside{position:absolute;bottom:2px;left:10px}.driver-outside{position:absolute;bottom:0;right:-28px}.scanner-beam{position:absolute;right:12px;top:18px;width:22px;height:3px;background:#f22;border-radius:2px;box-shadow:0 0 6px #f22,0 0 12px #f226;animation:scanPulse 1.5s ease-in-out infinite;transform-origin:left center}@keyframes scanPulse{0%,to{opacity:1;transform:scaleX(1)}50%{opacity:.4;transform:scaleX(.6)}}.module-label{position:absolute;bottom:4px;left:0;right:0;text-align:center;font-size:7px;font-weight:700;color:#ffffffb3;letter-spacing:.5px}.module-door{position:absolute;right:10px;top:14px;width:20px;height:28px;background:linear-gradient(180deg,#3a5a7a,#2a4a6a);border:1px solid #5a7a9a;border-radius:2px 2px 0 0}.module-door-handle{position:absolute;right:3px;top:12px;width:3px;height:3px;background:#fc0;border-radius:50%}.gate-assembly{position:absolute;left:calc(50% + 30px);bottom:20px;z-index:16}.gate-post-main{width:8px;height:54px;background:linear-gradient(180deg,#ddd,#999,#777);border-radius:2px;position:relative;box-shadow:2px 0 6px #0000004d}.gate-post-light{position:absolute;top:-4px;left:50%;transform:translate(-50%);width:8px;height:8px;border-radius:50%;transition:all .5s}.gate-post-light.red{background:#f22;box-shadow:0 0 8px #f22}.gate-post-light.green{background:#0d4;box-shadow:0 0 8px #0d4}.gate-arm-pivot{position:absolute;top:4px;left:4px;width:120px;height:8px;transform-origin:left center;transition:transform 1s cubic-bezier(.4,0,.2,1)}.gate-arm-pivot.closed{transform:rotate(0)}.gate-arm-pivot.open{transform:rotate(-82deg)}.gate-arm-bar{width:100%;height:100%;background:repeating-linear-gradient(90deg,#f33 0,#f33 10px,#fff 10px,#fff 20px);border-radius:4px;box-shadow:0 2px 6px #0006;border:1px solid rgba(0,0,0,.2)}.gate-arm-tip{position:absolute;right:-2px;top:-2px;width:12px;height:12px;background:#f33;border-radius:50%;border:1px solid #cc0000}.btn-sat-sync{background:linear-gradient(135deg,#006341,#00843d);color:#fff;border:1px solid #00A94F;position:relative;overflow:hidden}.btn-sat-sync:hover{background:linear-gradient(135deg,#00843d,#00a94f);transform:translateY(-1px);box-shadow:0 4px 12px #00843d66}.btn-sat-sync.syncing{pointer-events:none}.btn-sat-sync.syncing .sync-icon{animation:spinSync 1s linear infinite}@keyframes spinSync{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sync-status-dot{width:6px;height:6px;border-radius:50%;background:#0f8;box-shadow:0 0 6px #0f8;display:inline-block}.robot-container{position:relative;display:flex;align-items:center;gap:4px}.robot-btn{background:linear-gradient(135deg,#1a2d4a,#1e4a6e);border:1px solid #4da6ff;color:#4da6ff;padding:10px 14px;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;transition:all .3s;position:relative;overflow:visible}.robot-btn:hover{background:linear-gradient(135deg,#1e4a6e,#2970b0);color:#fff;transform:translateY(-1px);box-shadow:0 4px 16px #4da6ff66}.robot-svg{width:24px;height:24px}.robot-bits{position:absolute;top:-10px;right:-10px;width:55px;height:35px;pointer-events:none;overflow:visible}.bit{position:absolute;font-family:Courier New,monospace;font-size:10px;font-weight:800;opacity:0;animation:floatBit 2.5s ease-out infinite}.bit:nth-child(1){left:0;top:0;animation-delay:0s;color:#4da6ff}.bit:nth-child(2){left:14px;top:6px;animation-delay:.3s;color:#0d4}.bit:nth-child(3){left:28px;top:-3px;animation-delay:.6s;color:#fc0}.bit:nth-child(4){left:40px;top:4px;animation-delay:.9s;color:#ff6b6b}.bit:nth-child(5){left:8px;top:14px;animation-delay:1.2s;color:#4ecdc4}.bit:nth-child(6){left:32px;top:12px;animation-delay:1.5s;color:#bb86fc}@keyframes floatBit{0%{opacity:0;transform:translateY(5px) scale(.8)}15%{opacity:.9;transform:translateY(0) scale(1)}50%{opacity:.5;transform:translateY(-12px)}to{opacity:0;transform:translateY(-22px) translate(4px) scale(.6)}}.robot-btn:hover .bit{filter:brightness(1.3)}.upload-modal-content{background:var(--bg-card);border-radius:16px;border:1px solid var(--border-color);max-width:720px;width:95%;max-height:90vh;overflow-y:auto;padding:24px}.upload-dropzone{border:2px dashed var(--border-color);border-radius:12px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .3s;margin:16px 0;background:#00000026}.upload-dropzone:hover,.upload-dropzone.drag-over{border-color:var(--sat-blue);background:#0066cc14}.upload-dropzone.has-file{border-color:var(--alert-success);background:#00c8500d}.upload-placeholder p{color:var(--text-secondary);margin:12px 0 4px;font-size:14px}.upload-placeholder span{color:#ffffff4d;font-size:12px}.upload-file-info{display:flex;flex-direction:column;align-items:center;gap:8px}.upload-filename{color:var(--text-primary);font-weight:600;font-size:14px}.upload-filesize{color:var(--text-secondary);font-size:12px}.upload-manual-fields{margin:16px 0 8px}.upload-field-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.upload-field-group{display:flex;flex-direction:column;gap:4px}.upload-field-group label{font-size:12px;color:var(--text-secondary);font-weight:500}.upload-field-group .filter-input{width:100%}.inline-edit-input{background:#0066cc1a;border:1px solid var(--accent-blue);color:var(--text-primary);padding:4px 8px;border-radius:4px;font-size:13px;width:100%;outline:none}.inline-edit-input:focus{box-shadow:0 0 0 2px #0066cc4d}.upload-error{background:#ff4d4d1a;border:1px solid rgba(255,77,77,.3);color:var(--alert-danger);padding:10px 16px;border-radius:8px;font-size:13px;margin:8px 0}.upload-actions{display:flex;gap:12px;margin-top:16px}.upload-actions .btn{flex:1;justify-content:center}.upload-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;margin-right:8px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%) translateY(16px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.upload-result{margin-top:8px}.upload-result-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.upload-result-badge{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:700;letter-spacing:.5px}.badge-ok{background:#00c85026;color:#0d4;border:1px solid rgba(0,200,80,.3)}.badge-warning{background:#ffaa0026;color:#fa0;border:1px solid rgba(255,170,0,.3)}.upload-result-file{color:var(--text-secondary);font-size:13px}.upload-result-section{margin-bottom:16px}.upload-result-section h3{color:var(--sat-blue);font-size:13px;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border-color)}.upload-fields-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.upload-field{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#0003;border-radius:6px;border:1px solid rgba(255,255,255,.05)}.upload-field-label{color:var(--text-secondary);font-size:12px}.upload-field-value{color:var(--text-primary);font-size:13px;font-weight:500;text-align:right;max-width:55%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.field-ok{color:#0d4}.field-error{color:var(--alert-danger)}.upload-sat-status{padding:12px 16px;background:#0003;border-radius:8px}.sat-status-ok{color:#0d4;font-weight:600;font-size:14px}.sat-status-error{color:var(--text-secondary);font-size:14px}.upload-discrepancias-table{width:100%;border-collapse:collapse;font-size:13px}.upload-discrepancias-table th{background:#0000004d;color:var(--text-secondary);padding:8px 12px;text-align:left;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.3px}.upload-discrepancias-table td{padding:8px 12px;border-bottom:1px solid rgba(255,255,255,.05);color:var(--text-primary)}.disc-critico{background:#ff4d4d14}.disc-alerta{background:#ffaa000f}.disc-badge{padding:2px 8px;border-radius:10px;font-size:10px;font-weight:700}.disc-badge.critico{background:#ff4d4d33;color:var(--alert-danger)}.disc-badge.alerta{background:#fa03;color:#fa0}.upload-qr-link{display:block;color:var(--sat-blue);font-size:12px;word-break:break-all;padding:10px 14px;background:#0003;border-radius:6px;text-decoration:none}.upload-qr-link:hover{text-decoration:underline;background:#0066cc1a}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-darker);padding:20px}.login-card{background:var(--bg-dark);border:1px solid var(--border-color);border-radius:16px;padding:40px;width:100%;max-width:400px;box-shadow:0 20px 60px #00000080}.login-header{text-align:center;margin-bottom:32px}.login-logo{margin-bottom:16px}.login-header h1{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.login-header p{color:var(--text-secondary);font-size:14px}.login-form{display:flex;flex-direction:column;gap:16px}.login-field{display:flex;flex-direction:column;gap:6px}.login-field label{font-size:13px;font-weight:500;color:var(--text-secondary)}.login-field input{padding:12px 14px;background:var(--bg-darker);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;outline:none;transition:border-color .2s}.login-field input:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #0066cc26}.login-btn{padding:12px;background:var(--accent-blue);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s;margin-top:8px}.login-btn:hover{background:#05a}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{background:#ff4d4d1a;border:1px solid rgba(255,77,77,.3);color:var(--alert-danger);padding:10px 14px;border-radius:8px;font-size:13px}.login-session-msg{background:#ffb74d1a;border:1px solid rgba(255,183,77,.35);color:#ffb74d;padding:10px 14px;border-radius:8px;font-size:13px;display:flex;gap:8px;align-items:flex-start;line-height:1.5}.login-footer{text-align:center;margin-top:24px;color:var(--text-muted);font-size:12px}.user-menu{display:flex;align-items:center;gap:8px;padding-left:12px;border-left:1px solid var(--border-color);margin-left:4px}.user-name{font-size:13px;font-weight:500;color:var(--text-primary)}.user-role{font-size:11px;padding:2px 8px;background:#0066cc26;color:var(--accent-blue);border-radius:4px;font-weight:600}.btn-logout{background:transparent;border:1px solid var(--border-color);border-radius:6px;padding:6px;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;transition:all .2s}.btn-logout:hover{background:#ff4d4d1a;border-color:#ff4d4d4d;color:var(--alert-danger)}.historial-section{padding:0}.historial-header{margin-bottom:1rem}.historial-header h2{color:var(--text-primary);font-size:1.25rem;margin-bottom:.25rem}.status-badge{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-libre{background:#00dd4426;color:#0d4}.status-reconocimiento{background:#ffa50026;color:orange}.status-pendiente{background:#4da6ff26;color:#4da6ff}.clientes-section{padding:0}.clientes-toolbar{display:flex;justify-content:flex-end;margin-bottom:1rem}.btn-table-action{background:transparent;border:1px solid var(--border-color);border-radius:6px;padding:6px 8px;cursor:pointer;color:var(--text-secondary);display:inline-flex;align-items:center;transition:all .2s}.btn-table-action:hover{background:#4da6ff1a;border-color:var(--accent-blue);color:var(--accent-blue)}.cliente-form{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.form-field{display:flex;flex-direction:column;gap:4px}.form-field label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.form-field input{padding:10px 12px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-darker);color:var(--text-primary);font-size:14px;transition:border-color .2s}.form-field input:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #4da6ff1a}.form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:.5rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;z-index:3000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;width:90%;max-width:380px;box-shadow:0 24px 64px #0000008c;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:18px 20px 14px;border-bottom:1px solid var(--border-color);background:var(--bg-darker)}.modal-title{font-size:15px;font-weight:700;color:var(--text-primary);margin:0}.modal-close{width:28px;height:28px;border-radius:6px;background:transparent;border:1px solid var(--border-color);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-size:13px;flex-shrink:0;transition:all .2s;line-height:1}.modal-close:hover{background:var(--alert-danger);border-color:var(--alert-danger);color:#fff}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-darker)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--sat-blue)}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}
