.header{background:var(--bg-elevated);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);position:relative}.header:after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:linear-gradient(90deg,var(--accent) 0%,var(--accent-orange) 100%);opacity:.85}.header-inner{max-width:1280px;margin:0 auto;padding:var(--space-md) var(--space-lg);display:flex;align-items:center;justify-content:space-between;gap:var(--space-lg);flex-wrap:wrap}.header-title{margin:0;font-family:var(--font-heading);font-weight:700;font-size:1.35rem;letter-spacing:-.02em;color:var(--text)}.header-brand{display:flex;align-items:center;gap:var(--space-md)}.header-logo{flex-shrink:0}.header-title-main{display:block;color:var(--text)}.header-title-sub{display:block;color:var(--accent);font-size:1.1rem;font-weight:600;margin-top:.1em}.header-nav{display:flex;align-items:center;background:var(--bg);padding:var(--space-xs);border-radius:var(--radius);gap:var(--space-xs)}.nav-link{display:inline-flex;align-items:center;gap:.4rem;padding:var(--space-sm) var(--space-md);border:none;background:transparent;font-family:var(--font-body);font-size:.9rem;font-weight:500;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:color .15s,background .15s}.nav-link svg{flex-shrink:0;opacity:.85}.nav-link.active svg{opacity:1}.nav-link:hover{color:var(--text);background:var(--bg-elevated)}.nav-link.active{color:var(--accent);background:var(--bg-elevated);box-shadow:var(--shadow-sm)}.header-actions{display:flex;align-items:center;gap:var(--space-sm)}.header-user-wrap{position:relative;margin-left:var(--space-sm);padding-left:var(--space-sm);border-left:1px solid var(--border)}.header-user-trigger{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .75rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.9rem;font-weight:500;color:var(--text);cursor:pointer;transition:background .15s,border-color .15s}.header-user-trigger:hover{background:var(--accent-subtle);border-color:var(--accent)}.header-username{color:var(--text-secondary)}.header-user-chevron{font-size:.65rem;color:var(--text-tertiary);transition:transform .2s}.header-user-trigger[aria-expanded=true] .header-user-chevron{transform:rotate(180deg)}.header-user-menu{position:absolute;top:100%;right:0;margin-top:var(--space-xs);min-width:180px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);padding:var(--space-xs);z-index:100}.header-user-menu-head{display:flex;flex-direction:column;gap:.15rem;padding:var(--space-sm) var(--space-md);font-size:.8rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--border);margin-bottom:var(--space-xs)}.header-user-role{font-size:.7rem;font-weight:500;text-transform:none;color:var(--accent)}.header-user-menu-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:var(--space-sm) var(--space-md);border:none;background:none;font-family:var(--font-body);font-size:.9rem;color:var(--text);cursor:pointer;border-radius:var(--radius-sm);text-align:left;transition:background .15s}.header-user-menu-item:hover{background:var(--danger-bg);color:var(--danger)}.header-user-menu-item:first-of-type:hover{background:var(--accent-subtle);color:var(--accent)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.55rem 1rem;font-family:var(--font-body);font-size:.9rem;font-weight:600;border-radius:var(--radius-sm);border:none;text-decoration:none;transition:background .15s,color .15s,transform .1s}.btn svg{flex-shrink:0}.btn-primary{background:linear-gradient(135deg,var(--accent-orange) 0%,#f97316 100%);color:#fff;box-shadow:0 2px 8px #ea580c59}.btn-primary:hover{background:linear-gradient(135deg,var(--accent-orange-hover) 0%,#ea580c 100%);box-shadow:0 4px 12px #ea580c66}.btn:active{transform:scale(.98)}.btn-ghost{background:transparent;color:var(--accent);border:1px solid var(--border-strong)}.btn-ghost:hover{background:var(--accent-subtle);border-color:var(--accent)}.btn-secondary{background:var(--accent);color:#fff;border:1px solid var(--accent)}.btn-secondary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}@media (max-width: 768px){.header-inner{padding:var(--space-sm) var(--space-md)}.header-nav{order:3;width:100%;justify-content:center}.header-title{font-size:1.2rem}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-md);animation:overlayIn .2s ease}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-elevated);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:520px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:modalIn .25s ease}@keyframes modalIn{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--border)}.modal-title{margin:0;font-family:var(--font-heading);font-size:1.15rem;font-weight:700;color:var(--text)}.modal-close{width:2.25rem;height:2.25rem;border:none;background:var(--bg);font-size:1.35rem;line-height:1;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:background .15s,color .15s}.modal-close:hover{background:var(--accent-light);color:var(--accent)}.modal-tabs{display:flex;padding:0 var(--space-xl);gap:var(--space-xs);background:var(--bg);border-bottom:1px solid var(--border)}.modal-tab{display:inline-flex;align-items:center;gap:.4rem;padding:.75rem 1.1rem;border:none;background:transparent;font-family:var(--font-body);font-size:.9rem;font-weight:500;color:var(--text-secondary);border-radius:var(--radius-sm);margin-bottom:-1px;cursor:pointer;transition:color .15s,background .15s}.modal-tab:hover{color:var(--text)}.modal-tab.active{color:var(--accent);background:var(--bg-elevated);box-shadow:0 -1px 0 0 var(--bg-elevated)}.modal-body{padding:var(--space-xl);overflow-y:auto}.modal-desc{margin:0 0 var(--space-md);font-size:.9rem;color:var(--text-secondary);line-height:1.55}.modal-desc kbd{padding:.15em .4em;font-size:.85em;background:var(--border);border-radius:4px}.paste-textarea{width:100%;min-height:160px;padding:.75rem 1rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.9rem;line-height:1.45;color:var(--text);background:var(--bg);resize:vertical;margin-bottom:var(--space-md)}.paste-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.paste-textarea::placeholder{color:var(--text-tertiary)}.file-zone{margin-bottom:var(--space-md)}.file-input{position:absolute;width:0;height:0;opacity:0}.file-label{display:inline-flex;align-items:center;gap:var(--space-sm);padding:.65rem 1.1rem;background:var(--accent-subtle);color:var(--accent);border:1px dashed var(--accent);border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.file-label:hover{background:var(--accent-light);border-color:var(--accent)}.template-hint{margin:0 0 var(--space-md);font-size:.85rem;color:var(--text-secondary)}.link{color:var(--accent);text-decoration:none;font-weight:500}.link:hover{text-decoration:underline}.modal-error{margin:0 0 var(--space-md);padding:.6rem .85rem;background:var(--danger-bg);color:var(--danger);font-size:.9rem;border-radius:var(--radius-sm)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-lg)}.modal-actions .btn{min-width:100px}.table-section{background:var(--bg-elevated);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-md);overflow:hidden}.table-wrap{overflow-x:auto;min-height:220px}.table-loading,.table-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xl) var(--space-lg);color:var(--text-secondary);text-align:center}.spinner{width:2rem;height:2rem;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;margin-bottom:var(--space-md)}@keyframes spin{to{transform:rotate(360deg)}}.table-loading p,.table-empty p{margin:0;font-size:.95rem}.table-empty-icon{color:var(--text-tertiary);margin-bottom:var(--space-md);opacity:.7}.table-empty-hint{font-size:.9rem!important;color:var(--text-secondary)!important;margin-top:.35rem!important}.inventory-table{width:100%;border-collapse:collapse;font-size:.9rem}.inventory-table th{text-align:left;padding:.75rem 1rem;background:var(--bg);color:var(--text-secondary);font-family:var(--font-heading);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);white-space:nowrap}.inventory-table th.num{text-align:right}.inventory-table td{padding:.85rem 1rem;border-bottom:1px solid var(--border);vertical-align:middle}.inventory-table tbody tr{transition:background .12s}.inventory-table tbody tr:nth-child(2n){background:#00000005}.inventory-table tbody tr:hover{background:var(--accent-subtle)}.inventory-table td.num{text-align:right;font-variant-numeric:tabular-nums;font-weight:500}.cell-code{font-weight:600;color:var(--accent)}.cell-desc{max-width:320px;color:var(--text)}.th-acciones{width:1%;white-space:nowrap;text-align:center;padding-right:var(--space-md)}.cell-acciones{text-align:center;vertical-align:middle;white-space:nowrap}.acciones-group{display:flex;align-items:center;justify-content:center;gap:var(--space-xs);flex-wrap:wrap}.btn-accion{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .65rem;border:none;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s,transform .1s}.btn-accion:hover{transform:translateY(-1px)}.btn-accion:active{transform:translateY(0)}.btn-entrada{background:var(--success-bg);color:var(--success)}.btn-entrada:hover{background:var(--success);color:#fff}.btn-salida{background:var(--danger-bg);color:var(--danger)}.btn-salida:hover{background:var(--danger);color:#fff}.btn-ajuste{background:var(--warning-bg);color:var(--warning)}.btn-ajuste:hover{background:var(--warning);color:#1c2530}.table-footer{display:flex;align-items:center;justify-content:space-between;padding:.7rem 1rem;border-top:1px solid var(--border);background:var(--bg);font-size:.85rem;color:var(--text-secondary)}.table-pagination{display:flex;gap:var(--space-sm)}.btn-sm{padding:.4rem .75rem;font-size:.85rem}.btn-sm:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 900px){.inventory-table th:nth-child(n+5),.inventory-table td:nth-child(n+5){display:none}.btn-accion span{display:none}.btn-accion{padding:.5rem}}@media (max-width: 640px){.inventory-table th,.inventory-table td{padding:.6rem .75rem;font-size:.85rem}.table-footer{flex-wrap:wrap;gap:var(--space-sm)}}.movimiento-modal .movimiento-item-info{margin:0 var(--space-xl) var(--space-md);padding:.75rem 1rem;background:var(--accent-subtle);border-left:3px solid var(--accent);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:.9rem;color:var(--text)}.movimiento-modal .field{display:block;margin-bottom:var(--space-md)}.movimiento-modal .field span{display:block;font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:.35rem;text-transform:uppercase;letter-spacing:.03em}.movimiento-modal .field input,.movimiento-modal .field textarea{width:100%;padding:.6rem .85rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem;background:var(--bg-elevated);transition:border-color .2s,box-shadow .2s}.movimiento-modal .field input:focus,.movimiento-modal .field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.movimiento-modal .field textarea{resize:vertical;min-height:64px}.alta-producto-modal .field{display:block;margin-bottom:var(--space-md)}.alta-producto-modal .field span{display:block;font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:.35rem;text-transform:uppercase;letter-spacing:.03em}.alta-producto-modal .field input,.alta-producto-modal .field select{width:100%;padding:.6rem .85rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem;background:var(--bg-elevated);font-family:var(--font-body);transition:border-color .2s,box-shadow .2s}.alta-producto-modal .field input:focus,.alta-producto-modal .field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.alta-producto-modal .field select{cursor:pointer}.alta-producto-modal .field-otro{margin-top:var(--space-sm)}.crear-usuario-modal .field{display:block;margin-bottom:var(--space-md)}.crear-usuario-modal .field span{display:block;font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:.35rem;text-transform:uppercase;letter-spacing:.03em}.crear-usuario-modal .field input,.crear-usuario-modal .field select{width:100%;padding:.6rem .85rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem;background:var(--bg-elevated);font-family:var(--font-body)}.crear-usuario-modal .field input:focus,.crear-usuario-modal .field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.crear-usuario-modal .field select{cursor:pointer}.movimientos-view{background:var(--bg-elevated);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden;padding:var(--space-xl)}.movimientos-view .view-title{margin:0 0 var(--space-lg);font-family:var(--font-heading);font-size:1.25rem;font-weight:700;color:var(--text);display:flex;align-items:center;gap:.5rem}.movimientos-view .view-title svg{color:var(--accent)}.movimientos-filters{display:flex;flex-wrap:wrap;gap:var(--space-md);margin-bottom:var(--space-lg)}.movimientos-filters label{display:flex;flex-direction:column;gap:.25rem}.movimientos-filters label span{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.movimientos-filters input,.movimientos-filters select{padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;background:var(--bg-elevated)}.movimientos-table{font-size:.875rem}.movimientos-table td{padding:.6rem .85rem}.movimientos-table .cell-code{font-weight:600;color:var(--accent)}.badge{display:inline-block;padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.badge-entrada{background:var(--accent-light);color:var(--accent)}.badge-salida{background:var(--danger-bg);color:var(--danger)}.badge-ajuste{background:var(--warning-bg);color:#8b6914}.movimientos-total{margin:var(--space-md) 0 0;font-size:.9rem;color:var(--text-secondary)}.informes-view{padding-bottom:var(--space-xl)}.informes-view .view-title{margin:0 0 var(--space-lg);font-family:var(--font-heading);font-size:1.25rem;font-weight:700;color:var(--text);display:flex;align-items:center;gap:.5rem}.informes-view .view-title svg{color:var(--accent)}.informe-block{background:var(--bg-elevated);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow);padding:var(--space-xl);margin-bottom:var(--space-lg)}.informe-block h3{margin:0 0 var(--space-md);font-family:var(--font-heading);font-size:1rem;font-weight:600;color:var(--text);display:flex;align-items:center;gap:.4rem}.informe-block h3 svg{color:var(--accent)}.informe-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-md);margin-bottom:var(--space-lg)}.informe-card{padding:var(--space-lg);background:var(--bg);border-radius:var(--radius);border:1px solid var(--border);text-align:center;transition:border-color .15s,box-shadow .15s}.informe-card:hover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-subtle)}.informe-card-value{display:block;font-family:var(--font-heading);font-size:1.75rem;font-weight:700;color:var(--accent);line-height:1.2}.informe-card-label{font-size:.8rem;color:var(--text-secondary);margin-top:.25rem}.informe-table{width:100%;max-width:400px;border-collapse:collapse;font-size:.9rem}.informe-table th,.informe-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--border)}.informe-table th{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary)}.informe-table th.num,.informe-table td.num{text-align:right}.informe-filters{display:flex;gap:var(--space-md);margin-bottom:var(--space-md)}.informe-filters label{display:flex;flex-direction:column;gap:.25rem}.informe-filters label span{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.informe-filters input{padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-elevated)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-lg)}.login-card{width:100%;max-width:400px;background:var(--bg-elevated);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--space-xl)}.login-brand{text-align:center;margin-bottom:var(--space-xl)}.login-logo{display:block;margin:0 auto var(--space-md)}.login-title{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;color:var(--text);margin:0 0 var(--space-xs)}.login-subtitle{font-size:.9rem;color:var(--text-secondary);margin:0}.login-loading{text-align:center;color:var(--text-secondary);margin:0;padding:var(--space-xl)}.login-form{display:flex;flex-direction:column;gap:var(--space-md)}.login-error{padding:var(--space-sm) var(--space-md);background:var(--danger-bg);color:var(--danger);border-radius:var(--radius-sm);font-size:.9rem;margin:0}.login-label{display:flex;flex-direction:column;gap:var(--space-xs);font-size:.9rem;font-weight:500;color:var(--text)}.login-input{padding:var(--space-sm) var(--space-md);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;font-family:inherit}.login-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-light)}.login-hint{font-size:.8rem;color:var(--text-tertiary);margin:-var(--space-xs) 0 0}.login-btn{margin-top:var(--space-sm)}.login-toggle{background:none;border:none;color:var(--accent);font-size:.9rem;cursor:pointer;padding:var(--space-sm);text-decoration:underline}.login-toggle:hover{color:var(--accent-hover)}.app{min-height:100vh;display:flex;flex-direction:column}.app-loading{align-items:center;justify-content:center;color:var(--text-secondary)}.main{flex:1;max-width:1280px;margin:0 auto;width:100%;padding:var(--space-lg)}.toolbar{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap}.search-wrap{flex:1;min-width:280px;max-width:420px;position:relative}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);font-size:1rem;color:var(--text-tertiary);pointer-events:none}.search-input{width:100%;padding:.65rem 1rem .65rem 2.5rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-elevated);font-size:.95rem;color:var(--text);transition:border-color .2s,box-shadow .2s}.search-input::placeholder{color:var(--text-tertiary)}.search-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.total-badge{display:inline-flex;align-items:center;gap:.4rem;margin:0;padding:.45rem .9rem;background:linear-gradient(135deg,var(--accent-light) 0%,var(--accent-subtle) 100%);color:var(--accent);font-size:.875rem;font-weight:600;border-radius:var(--radius);white-space:nowrap;border:1px solid rgba(13,148,136,.2)}@media (max-width: 640px){.main{padding:var(--space-md)}.toolbar{flex-direction:column;align-items:stretch}.search-wrap{max-width:none}}:root{--bg: #f0fdfa;--bg-end: #fefce8;--bg-elevated: #ffffff;--bg-overlay: rgba(15, 23, 42, .5);--text: #0f172a;--text-secondary: #475569;--text-tertiary: #94a3b8;--accent: #0d9488;--accent-hover: #0f766e;--accent-light: #ccfbf1;--accent-subtle: #f0fdfa;--accent-orange: #ea580c;--accent-orange-hover: #c2410c;--accent-orange-bg: #fff7ed;--border: #e2e8f0;--border-strong: #cbd5e1;--success: #16a34a;--success-bg: #dcfce7;--danger: #dc2626;--danger-bg: #fee2e2;--warning: #ca8a04;--warning-bg: #fef9c3;--radius: 10px;--radius-sm: 6px;--radius-lg: 14px;--font-heading: "Sora", system-ui, sans-serif;--font-body: "Plus Jakarta Sans", system-ui, sans-serif;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow: 0 2px 8px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(13, 148, 136, .12);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .12);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem}*{box-sizing:border-box}body{margin:0;font-family:var(--font-body);font-size:15px;line-height:1.5;color:var(--text);background:linear-gradient(160deg,var(--bg) 0%,var(--bg-end) 100%);background-attachment:fixed;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit;font-size:inherit}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button:focus:not(:focus-visible),a:focus:not(:focus-visible),input:focus:not(:focus-visible){outline:none}
