@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--bg-primary:#09090b;--bg-secondary:#18181b;--bg-card:#18181bbf;--border-color:#ffffff14;--border-focus:#6366f180;--text-primary:#f4f4f5;--text-secondary:#a1a1aa;--text-muted:#71717a;--color-accent:#6366f1;--color-accent-hover:#4f46e5;--color-accent-glow:#6366f140;--color-success:#10b981;--color-warning:#f59e0b;--color-danger:#ef4444;--color-expired:#b91c1c;--font-sans:"Outfit", "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--transition-smooth:all .3s cubic-bezier(.4, 0, .2, 1);--shadow-lg:0 10px 25px -5px #0000004d, 0 8px 10px -6px #0000004d;--shadow-glow:0 0 20px #6366f126}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);background-image:radial-gradient(circle at 10% 20%,#6366f10d 0%,#0000 40%),radial-gradient(circle at 90% 80%,#a855f70d 0%,#0000 40%);background-attachment:fixed;min-height:100vh;line-height:1.5;overflow-x:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:#27272a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#3f3f46}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 15px #6366f133}50%{box-shadow:0 0 25px #6366f173}}@media print{body{color:#000!important;background:#fff!important}.no-print{display:none!important}}.app-container{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:2rem;animation:.4s ease-out fadeIn}.header-bar{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:2.5rem;padding-bottom:1.5rem;display:flex}.brand-section{align-items:center;gap:.75rem;display:flex}.brand-icon{color:var(--color-accent);filter:drop-shadow(0 0 8px var(--color-accent))}.brand-title{letter-spacing:-.025em;background:linear-gradient(135deg, #fff 30%, var(--text-secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.8rem;font-weight:700}.brand-subtitle{color:var(--text-muted);margin-top:.1rem;font-size:.85rem}.user-controls{align-items:center;gap:1rem;display:flex}.user-badge{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);border-radius:20px;align-items:center;gap:.5rem;padding:.5rem .85rem;font-size:.85rem;display:flex}.user-dot{background-color:var(--color-success);width:8px;height:8px;box-shadow:0 0 8px var(--color-success);border-radius:50%}.btn{font-family:var(--font-sans);cursor:pointer;transition:var(--transition-smooth);border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.6rem 1.2rem;font-size:.9rem;font-weight:500;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--color-accent) 0%, var(--color-accent-hover) 100%);color:#fff;box-shadow:var(--shadow-glow)}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 0 25px #6366f166}.btn-secondary{background:var(--bg-secondary);border-color:var(--border-color);color:var(--text-primary)}.btn-secondary:hover{border-color:var(--text-secondary);background:#27272a}.btn-danger{color:var(--color-danger);background:#ef44441a;border-color:#ef444433}.btn-danger:hover{background:var(--color-danger);color:#fff}.btn-icon-only{border-radius:6px;padding:.5rem}.login-screen{background-image:radial-gradient(circle,#6366f114 0%,#0000 60%);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.login-card{background:var(--bg-card);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border-color);width:100%;max-width:420px;box-shadow:var(--shadow-lg);border-radius:16px;padding:2.5rem;animation:.5s cubic-bezier(.16,1,.3,1) fadeIn}.login-logo{color:var(--color-accent);filter:drop-shadow(0 0 10px var(--color-accent-glow));justify-content:center;margin-bottom:1.5rem;display:flex}.login-header{text-align:center;margin-bottom:2rem}.login-title{margin-bottom:.5rem;font-size:1.75rem;font-weight:700}.login-subtitle{color:var(--text-secondary);font-size:.9rem}.form-group{flex-direction:column;gap:.4rem;margin-bottom:1.25rem;display:flex}.form-label{color:var(--text-secondary);font-size:.85rem;font-weight:500}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:var(--text-muted);position:absolute;left:.85rem}.form-input{border:1px solid var(--border-color);width:100%;color:var(--text-primary);font-family:var(--font-sans);transition:var(--transition-smooth);background:#0003;border-radius:8px;padding:.7rem .85rem .7rem 2.5rem;font-size:.95rem}.form-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-glow);background:#0006;outline:none}.form-input-noicon{padding-left:.85rem}.action-bar{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:12px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1rem;display:flex}.filters-group{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.search-input-wrapper{align-items:center;min-width:260px;display:flex;position:relative}.supplier-selector{border:1px solid var(--border-color);background:#0000004d;border-radius:8px;padding:.25rem;display:flex}.supplier-tab{color:var(--text-secondary);cursor:pointer;transition:var(--transition-smooth);border-radius:6px;padding:.45rem 1rem;font-size:.85rem;font-weight:500}.supplier-tab.active{background:var(--color-accent);color:#fff;box-shadow:0 2px 8px #6366f14d}.form-select{border:1px solid var(--border-color);color:var(--text-primary);font-family:var(--font-sans);cursor:pointer;appearance:none;background:#0000004d url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23a1a1aa'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E") right .75rem center/1rem no-repeat;border-radius:8px;min-width:130px;padding:.5rem 2rem .5rem .75rem;font-size:.85rem}.form-select:focus{border-color:var(--color-accent);outline:none}.table-container{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);border-radius:12px;margin-bottom:2rem;overflow:hidden}.table-wrapper{overflow-x:auto}.rma-table{border-collapse:collapse;text-align:left;width:100%;font-size:.9rem}.rma-table th{color:var(--text-primary);border-bottom:1px solid var(--border-color);white-space:nowrap;background:#0006;padding:1rem 1.25rem;font-weight:600}.rma-table td{border-bottom:1px solid var(--border-color);color:var(--text-secondary);vertical-align:middle;padding:1rem 1.25rem}.rma-table tbody tr{transition:var(--transition-smooth)}.rma-table tbody tr:hover{background:#ffffff05}.badge{text-transform:uppercase;letter-spacing:.025em;border-radius:12px;align-items:center;gap:.35rem;padding:.25rem .6rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge-pendiente{color:#818cf8;background:#6366f126}.badge-preparado{color:#fbbf24;background:#f59e0b26}.badge-enviado{color:#34d399;background:#10b98126}.badge-completado{color:#a1a1aa;background:#71717a26}.alert-pill{border-radius:6px;align-items:center;gap:.35rem;padding:.25rem .6rem;font-size:.75rem;font-weight:500;display:inline-flex}.alert-safe{color:var(--color-success);background:#10b9811a;border:1px solid #10b98133}.alert-warning{color:var(--color-warning);background:#f59e0b1a;border:1px solid #f59e0b33}.alert-danger{color:var(--color-danger);background:#ef44441a;border:1px solid #ef444433}.alert-expired{color:#fca5a5;background:#b91c1c33;border:1px solid #b91c1c4d;font-weight:700;animation:2s infinite pulse-glow}.actions-cell{gap:.5rem;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;background:#09090bcc;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);width:100%;max-width:550px;box-shadow:var(--shadow-lg);border-radius:16px;animation:.3s cubic-bezier(.16,1,.3,1) fadeIn;overflow:hidden}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.modal-title{color:var(--text-primary);font-size:1.25rem;font-weight:600}.modal-close{color:var(--text-secondary);cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none}.modal-close:hover{color:#fff}.modal-body{max-height:70vh;padding:1.5rem;overflow-y:auto}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:.75rem;padding:1.25rem 1.5rem;display:flex}.form-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}@media (width<=640px){.form-grid{grid-template-columns:1fr}}.toast-container{z-index:200;pointer-events:none;flex-direction:column;gap:.75rem;display:flex;position:fixed;bottom:2rem;right:2rem}.toast{pointer-events:auto;border:1px solid var(--border-color);border-left:4px solid var(--color-accent);color:var(--text-primary);box-shadow:var(--shadow-lg);background:#18181b;border-radius:8px;align-items:center;gap:.75rem;min-width:320px;max-width:450px;padding:1rem 1.25rem;font-size:.9rem;animation:.3s cubic-bezier(.16,1,.3,1) fadeIn;display:flex}.toast-success{border-left-color:var(--color-success)}.toast-warning{border-left-color:var(--color-warning)}.toast-error{border-left-color:var(--color-danger)}#binary-pdf-container{color:#000;box-sizing:border-box;background:#fff;width:297mm;min-height:210mm;padding:15mm;font-family:Outfit,Arial,sans-serif;position:absolute;top:-9999px;left:-9999px}.pdf-header{border-bottom:2px solid #000;justify-content:space-between;align-items:flex-start;margin-bottom:8mm;padding-bottom:4mm;display:flex}.pdf-client-info{flex-direction:column;gap:2mm;display:flex}.pdf-field-line{font-size:11pt;font-weight:700}.pdf-field-line span{border-bottom:1px solid #333;min-width:150px;padding-left:5px;font-weight:400;display:inline-block}.pdf-title{text-align:right;letter-spacing:1px;font-size:26pt;font-weight:800}.pdf-table{border-collapse:collapse;width:100%;margin-bottom:8mm}.pdf-table th{text-transform:uppercase;text-align:left;border:1px solid #1e1e1e;padding:3mm 2mm;font-size:10pt;font-weight:700;color:#fff!important;background:#1e1e1e!important}.pdf-table td{color:#111;border:1px solid #ccc;height:9mm;padding:3.5mm 2mm;font-size:9.5pt}.pdf-footer{justify-content:space-between;align-items:flex-end;margin-top:auto;display:flex}.pdf-disclaimer{color:#333;border-top:1px solid #ccc;max-width:70%;padding-top:2mm;font-size:8pt;line-height:1.4}.pdf-logo-box{flex-direction:column;align-items:center;display:flex}.pdf-logo-image{width:auto;height:25mm}.pdf-table tr.empty-row td{color:#0000}.inner-tabs{border:1px solid var(--border-color);background:#0000004d;border-radius:10px;gap:0;width:fit-content;margin-bottom:1.5rem;padding:.25rem;display:flex}.inner-tab{color:var(--text-secondary);cursor:pointer;transition:var(--transition-smooth);-webkit-user-select:none;user-select:none;border-radius:8px;align-items:center;gap:.4rem;padding:.5rem 1.25rem;font-size:.875rem;font-weight:500;display:flex}.inner-tab.active{background:var(--color-accent);color:#fff;box-shadow:0 2px 10px #6366f159}.inner-tab:not(.active):hover{color:var(--text-primary);background:#ffffff0d}.tab-count-badge{color:#fff;text-align:center;background:#ffffff26;border-radius:12px;min-width:20px;padding:.1rem .45rem;font-size:.7rem;font-weight:700}.inner-tab:not(.active) .tab-count-badge{color:var(--color-accent);background:#6366f126}.batches-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.batch-card{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-color);transition:var(--transition-smooth);border-radius:12px;animation:.4s ease-out fadeIn;overflow:hidden}.batch-card:hover{border-color:#6366f14d;transform:translateY(-2px);box-shadow:0 4px 20px #0003}.batch-card.batch-sent{opacity:.85;border-color:#10b98133}.batch-card-header{border-bottom:1px solid var(--border-color);background:#0003;justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.batch-code{color:var(--text-primary);letter-spacing:.02em;font-size:1rem;font-weight:700}.batch-card-body{flex-direction:column;gap:.6rem;padding:1rem 1.25rem;display:flex}.batch-meta-row{color:var(--text-secondary);justify-content:space-between;font-size:.85rem;display:flex}.batch-meta-label{color:var(--text-muted);font-size:.8rem}.batch-item-list{border:1px solid var(--border-color);background:#0003;border-radius:8px;max-height:180px;margin-top:.5rem;padding:.75rem;font-size:.82rem;overflow-y:auto}.batch-item-entry{border-bottom:1px solid #ffffff0a;align-items:flex-start;gap:.5rem;padding:.4rem 0;display:flex}.batch-item-entry:last-child{border-bottom:none}.batch-item-number{color:var(--color-accent);min-width:20px;font-weight:700}.batch-item-name{color:var(--text-primary);font-weight:500}.batch-item-sn{color:var(--text-muted);font-family:monospace;font-size:.78rem}.batch-card-footer{border-top:1px solid var(--border-color);flex-wrap:wrap;justify-content:flex-end;gap:.6rem;padding:.875rem 1.25rem;display:flex}.badge-abierto{color:#818cf8;background:#6366f126}.badge-enviado-batch{color:#34d399;background:#10b98126}.batch-tag{color:#818cf8;white-space:nowrap;background:#6366f11a;border:1px solid #6366f133;border-radius:10px;align-items:center;gap:.3rem;margin-left:.4rem;padding:.15rem .5rem;font-size:.72rem;font-weight:600;display:inline-flex}.btn-unify{color:#fff;background:linear-gradient(135deg,#7c3aed 0%,#6366f1 100%);border-color:#0000;box-shadow:0 0 15px #7c3aed4d}.btn-unify:hover{transform:translateY(-1px);box-shadow:0 0 25px #7c3aed80}.batches-empty{text-align:center;color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:4rem 2rem}.batches-empty svg{opacity:.3;margin-bottom:1rem}
