:root{--forca-blue:#001689;--forca-green:#00953b;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;--bg:#f4f6f9;--surface:#fff;--surface-2:#eef1f5;--text:#14161f;--text-muted:#5b6472;--border:#e2e5ea;--accent:#001689;--accent-hover:#00239e;--accent-contrast:#fff;--success:#00953b;--warning:#c08a00;--danger:#c0392b;--link:#001689;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:24px;--space-6:32px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-pill:999px;--radius:var(--radius-md);--shadow-sm:#14161f0f 0 1px 3px;--shadow-md:#14161f14 0 4px 14px;--shadow-lg:#14161f29 0 12px 32px;--shadow:var(--shadow-md);--text-xs:12px;--text-sm:13px;--text-base:15px;--text-md:16px;--text-lg:18px;--text-xl:22px;--text-2xl:26px;font:16px/1.5 var(--sans);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root[data-theme=dark]{--bg:#0a0a0b;--surface:#161618;--surface-2:#202023;--text:#ececee;--text-muted:#9a9aa2;--border:#2a2a2e;--accent:#2742d6;--accent-hover:#3a57f0;--accent-contrast:#fff;--success:#18b558;--warning:#e0a82e;--danger:#ff6b6b;--link:#8aa6ff;--shadow-sm:#0006 0 1px 3px;--shadow-md:#0000008c 0 4px 16px;--shadow-lg:#000000a6 0 14px 36px;--shadow:var(--shadow-md);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);min-height:100vh;margin:0}#root{min-height:100vh}h1,h2,h3{color:var(--text);margin:0 0 12px;font-weight:600}h2{font-size:22px}h3{font-size:17px}p{margin:0}a{color:var(--link)}a:focus-visible,button:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.brand-bar{background:linear-gradient(90deg, var(--forca-blue), var(--forca-green));height:3px}.app-header{background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow);justify-content:space-between;align-items:center;gap:16px;padding:6px 24px;display:flex}.header-right{align-items:center;gap:12px;display:flex}.app-layout{align-items:stretch;min-height:calc(100vh - 3px);display:flex}.sidebar{background:var(--surface);border-right:1px solid var(--border);width:184px;padding:var(--space-3) var(--space-2);gap:var(--space-2);flex-direction:column;flex-shrink:0;display:flex}.sidebar-brand{align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);margin-bottom:var(--space-2);display:flex}.brand-mark{border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;flex-shrink:0;justify-content:center;align-items:center;padding:3px;display:inline-flex}.brand-mark img{height:24px;display:block}.brand-name{font-size:var(--text-lg);letter-spacing:.06em;background:linear-gradient(90deg, var(--accent), var(--success));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:800}.sidebar-nav{flex-direction:column;gap:3px;display:flex}.sidebar-section{font-size:var(--text-xs);letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);padding:var(--space-3) var(--space-2) var(--space-1);margin-top:var(--space-1);border-top:1px solid var(--border);font-weight:700}.main{flex-direction:column;flex:1;min-width:0;display:flex}.topbar{justify-content:flex-end;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-5);background:var(--surface);border-bottom:1px solid var(--border);display:flex}.topbar .btn{padding:6px 12px}.topbar .empresa-select{font-size:var(--text-sm);padding:5px 9px}.topbar .header-email{font-size:var(--text-sm)}.content{flex:1}.nav-link{font:inherit;font-size:var(--text-base);align-items:center;gap:var(--space-2);text-align:left;width:100%;padding:var(--space-2) var(--space-3);color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;transition:background .15s,color .15s;display:flex}.nav-link svg{flex-shrink:0}.nav-link{position:relative}.nav-link:hover{background:var(--surface-2);color:var(--text)}.nav-link.active{background:color-mix(in srgb, var(--forca-blue) 10%, transparent);color:var(--accent);font-weight:600}.nav-link.active:before{content:"";background:linear-gradient(180deg, var(--forca-blue), var(--forca-green));border-radius:0 3px 3px 0;width:3px;position:absolute;top:7px;bottom:7px;left:0}.muted{color:var(--text-muted);font-size:13px}.widget-mensajes{margin-bottom:20px}.mensaje{border-bottom:1px solid var(--border);padding:9px 0}.mensaje:last-child{border-bottom:none}.mensaje-texto{color:var(--text)}.mensaje-meta{color:var(--text-muted);justify-content:space-between;align-items:center;gap:8px;margin-top:3px;font-size:12px;display:flex}.widget-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}.widget-head{color:var(--text-muted);cursor:grab;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:14px;font-weight:600;display:flex}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:16px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;text-align:left;box-shadow:var(--shadow);border-radius:12px;align-items:center;gap:14px;padding:18px;transition:transform .12s,border-color .12s;display:flex}.stat-card:hover{border-color:var(--accent);transform:translateY(-2px)}.stat-icon{color:#fff;background:linear-gradient(135deg, var(--forca-blue), var(--forca-green));border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;display:inline-flex}.stat-num{color:var(--text);font-size:26px;font-weight:700;line-height:1.1;display:block}.stat-label{color:var(--text-muted);font-size:13px;display:block}.modulo-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:14px;display:grid}.badge{white-space:nowrap;border-radius:999px;padding:2px 10px;font-size:12px;font-weight:600;display:inline-block}.badge-hecho{background:color-mix(in srgb, var(--forca-green) 18%, transparent);color:var(--forca-green)}.badge-en_curso{background:color-mix(in srgb, var(--warning) 18%, transparent);color:var(--warning)}.badge-pendiente{background:var(--surface-2);color:var(--text-muted)}.chip{border-radius:var(--radius-pill);font-size:var(--text-xs);white-space:nowrap;padding:2px 10px;font-weight:600;display:inline-block}.chip-ok{background:color-mix(in srgb, var(--success) 16%, transparent);color:var(--success)}.chip-off{background:var(--surface-2);color:var(--text-muted)}.chip-info{background:color-mix(in srgb, var(--link) 14%, transparent);color:var(--link)}.chip-warn{background:color-mix(in srgb, var(--warning) 20%, transparent);color:var(--warning)}:root[data-theme=dark] .chip-ok{color:#34d399;background:#34d39929}.progress{background:var(--surface-2);border-radius:999px;height:10px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--forca-blue), var(--forca-green));border-radius:999px;height:100%;transition:width .3s}.header-email{color:var(--text-muted);font-size:14px}.empresa-select{font:inherit;border:1px solid var(--border);background:var(--surface-2);color:var(--text);cursor:pointer;border-radius:8px;padding:6px 10px;font-size:14px}.logo-badge{border:1px solid var(--border);background:#fff;border-radius:5px;align-items:center;padding:2px 5px;display:inline-flex}.logo-badge img{height:56px;display:block}.login-bg{background:linear-gradient(135deg, var(--forca-blue) 0%, var(--forca-green) 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{text-align:center;background:#fff;border-radius:16px;width:100%;max-width:380px;padding:34px 30px;box-shadow:0 18px 50px #00000047}.login-logo-badge{background:#fff;border-radius:10px;margin-bottom:12px;padding:4px 8px;display:inline-flex}.login-logo-badge img{height:74px;display:block}.login-card h1{color:#14161f;margin:0 0 2px;font-size:22px}.login-sub{color:#6b7280;margin:0 0 24px;font-size:14px}.login-card .field{text-align:left;margin-bottom:14px}.login-card label{color:#5b6472}.login-card .input{color:#14161f;background:#f4f6f9;border:1px solid #e2e5ea}.login-card .input:focus{border-color:var(--forca-blue);box-shadow:0 0 0 3px #00168926}.login-btn{background:var(--forca-blue);border:1px solid var(--forca-blue);color:#fff;width:100%;margin-top:6px;padding:11px;font-weight:600}.login-btn:hover{background:#00239e;border-color:#00239e}.login-btn:disabled{opacity:.7;cursor:default}.page{margin:0;padding:24px 28px}.page h2{padding-left:var(--space-3);font-size:var(--text-lg);margin-bottom:var(--space-2);position:relative}.page h2:before{content:"";border-radius:var(--radius-sm);background:linear-gradient(180deg, var(--forca-blue), var(--forca-green));width:4px;position:absolute;top:2px;bottom:2px;left:0}.page-narrow{max-width:360px;margin:64px auto;padding:0 20px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.field{margin-bottom:14px}.field label{color:var(--text-muted);margin-bottom:6px;font-size:13px;display:block}.input{width:100%;font:inherit;color:var(--text);background:var(--surface-2);border:1px solid var(--border);border-radius:8px;outline:none;padding:9px 11px;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 25%, transparent)}.field-row{flex-wrap:wrap;align-items:flex-end;gap:14px;margin-bottom:14px;display:flex}.field-row .field{flex:200px;margin-bottom:0}.subsection-title{color:var(--text-muted);border-top:1px solid var(--border);margin:20px 0 12px;padding-top:16px;font-size:14px;font-weight:600}.checks{flex-wrap:wrap;gap:18px;margin-bottom:14px;display:flex}.check{cursor:pointer;align-items:center;gap:7px;font-size:14px;display:flex}.check input{width:16px;height:16px;accent-color:var(--accent)}.ayuda{background:var(--surface-2);width:15px;height:15px;color:var(--text-muted);border:1px solid var(--border);cursor:help;-webkit-user-select:none;user-select:none;vertical-align:middle;border-radius:50%;justify-content:center;align-items:center;margin-left:5px;font-size:11px;font-weight:700;display:inline-flex;position:relative}.ayuda-bubble{visibility:hidden;opacity:0;background:var(--text);width:max-content;max-width:240px;color:var(--bg);text-align:left;box-shadow:var(--shadow);z-index:10;pointer-events:none;border-radius:6px;padding:7px 10px;font-size:12px;font-weight:400;line-height:1.35;transition:opacity .15s;position:absolute;bottom:135%;left:50%;transform:translate(-50%)}.ayuda:hover .ayuda-bubble,.ayuda:focus .ayuda-bubble{visibility:visible;opacity:1}.converter{background:var(--surface-2);border:1px dashed var(--border);border-radius:8px;flex-wrap:wrap;gap:18px;margin-bottom:14px;padding:12px 14px;font-size:14px;display:flex}.converter .conv-item b{color:var(--accent)}.converter .conv-empty{color:var(--text-muted)}.btn{font:inherit;border:1px solid var(--border);background:var(--surface-2);color:var(--text);cursor:pointer;border-radius:8px;padding:9px 16px;font-weight:500;transition:background .15s,border-color .15s,opacity .15s}.btn:hover{border-color:var(--accent)}.btn-primary{background:linear-gradient(135deg, var(--forca-blue), var(--forca-green));color:#fff;border-color:#0000}.btn-primary:hover{filter:brightness(1.07)}.btn-icon{padding:8px 10px;font-size:16px;line-height:1}.table{border-collapse:collapse;table-layout:fixed;width:100%;margin-top:8px}.table th,.table td{text-align:left;padding:5px 12px}.table thead th{color:var(--text-muted);border-bottom:2px solid var(--border);font-size:13px;font-weight:600}.table tbody tr{border-bottom:1px solid var(--border)}.table tbody tr:hover{background:var(--surface-2)}.table td{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.tabla-toolbar{gap:var(--space-2);margin-bottom:var(--space-2);flex-wrap:wrap;align-items:center;display:flex}.tabla-toolbar .input,.tabla-toolbar .empresa-select,.tabla-toolbar select{font-size:var(--text-sm);padding:6px 10px}.tabla-toolbar .btn{font-size:var(--text-sm);padding:6px 12px}.table-scroll{overflow-x:auto}.table thead th{-webkit-user-select:none;user-select:none;white-space:nowrap}.cols-menu{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);z-index:20;border-radius:8px;flex-direction:column;gap:2px;min-width:180px;max-height:320px;padding:8px;display:flex;position:absolute;top:calc(100% + 4px);right:0;overflow:auto}.table th{border-right:1px solid var(--border)}.table th:last-child{border-right:none}.table td{border-right:1px solid color-mix(in srgb, var(--border) 50%, transparent)}.table td:last-child{border-right:none}.col-resizer{cursor:col-resize;-webkit-user-select:none;user-select:none;touch-action:none;width:6px;height:100%;position:absolute;top:0;right:0}.col-resizer:hover,.col-resizer.resizing{background:var(--accent)}.th-expander,.td-expander{text-align:center;width:36px;padding:0 0 0 6px;border-right:none!important}.expander-btn{cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;padding:3px;display:inline-flex}.expander-btn:hover{color:var(--accent);background:var(--surface-2)}.detalle-row>td{background:var(--surface-2);padding:var(--space-3) var(--space-4) var(--space-4);white-space:normal;text-overflow:clip;overflow:visible}.detalle-row:hover>td{background:var(--surface-2)}.row-link{font:inherit;color:var(--link);cursor:pointer;text-align:left;background:0 0;border:none;padding:0;font-weight:500}.row-link:hover{text-decoration:underline}.icon-btn{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);background:0 0;justify-content:center;align-items:center;padding:5px 8px;font-size:14px;line-height:1;display:inline-flex}.icon-btn:hover{border-color:var(--accent);color:var(--accent)}.icon-btn:disabled{opacity:.35;cursor:default}.icon-btn:disabled:hover{border-color:var(--border);color:var(--text-muted)}.icon-btn.xs{border-radius:4px;padding:1px 3px}.detalle-grid{gap:var(--space-4) var(--space-5);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.detalle-item{flex-direction:column;gap:2px;min-width:0;display:flex}.detalle-item.ancho{grid-column:1/-1}.detalle-item .lbl{font-size:var(--text-xs);color:var(--text-muted);font-weight:600}.detalle-item .val{font-size:var(--text-base);color:var(--text);word-break:break-word}.detalle-item .val.vacio{color:var(--text-muted)}.chips-row{gap:var(--space-2);margin-bottom:var(--space-4);flex-wrap:wrap;display:flex}.error-msg{color:var(--danger);margin-top:12px;font-size:14px}.empty{color:var(--text-muted);padding:12px}.maquina-tipo-card{text-align:left;cursor:pointer;width:100%;transition:border-color .15s,box-shadow .15s}.maquina-tipo-card:hover{border-color:var(--brand);box-shadow:0 2px 8px #0000001f}.maquina-grid{gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(210px,1fr));display:grid}.maquina-card{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);cursor:pointer;text-align:left;flex-direction:column;gap:2px;width:100%;transition:border-color .15s,box-shadow .15s;display:flex}.maquina-card:hover{border-color:var(--brand);box-shadow:0 2px 8px #0000001f}.maquina-card-numero{font-size:var(--text-lg);font-weight:700;font-family:var(--mono);color:var(--text);letter-spacing:.02em}.maquina-card-marca{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:6px}.maquina-card-datos{font-size:var(--text-xs);color:var(--text-muted);border-top:1px solid var(--border);flex-wrap:wrap;gap:4px 10px;margin-top:2px;padding-top:6px;display:flex}.maquina-card-jacquard{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px;font-style:italic}.modal-overlay{z-index:50;padding:var(--space-4);background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px #00000052}.modal-header{margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}
