@import "https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800&family=Open+Sans:wght@400;600;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-navy:#102a4e;--color-navy-700:#0c233f;--color-navy-800:#0a1f3c;--color-bg:#eef3f9;--color-surface:#fff;--color-primary:#1f7fc2;--color-primary-hover:#166aa6;--color-text:#1b2a3d;--color-muted:#64748b;--color-border:#e2e8f0;--color-error:#dc2626;--radius:14px;--shadow:0 8px 30px #102a4e1a;--font-head:"Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-body:"Open Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;font-family:var(--font-body)}body{background:radial-gradient(1200px 500px at 100% -10%, #dbeafe 0%, #dbeafe00 55%), var(--color-bg);color:var(--color-text);min-height:100dvh;font-family:var(--font-body)}h1,h2,h3,.brand-name{font-family:var(--font-head)}.page-center{justify-content:center;align-items:center;min-height:100dvh;padding:1.5rem;display:flex}.login-firma{text-align:center;color:var(--color-muted);pointer-events:none;margin:0;font-size:.8rem;position:fixed;bottom:1rem;left:0;right:0}.login-firma a{color:var(--color-primary);pointer-events:auto;font-weight:600;text-decoration:none}.login-firma a:hover{text-decoration:underline}.card{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);border-top:4px solid var(--color-primary);width:100%;max-width:410px;padding:2.5rem 2rem;position:relative;overflow:hidden}.login-brand{flex-direction:column;align-items:center;gap:1rem;margin-bottom:1.75rem;display:flex}.login-brand img{width:230px;max-width:80%;height:auto}.login-brand h1{color:var(--color-navy);text-align:center;font-size:1.25rem;font-weight:700}.login-brand p{color:var(--color-muted);text-align:center;margin-top:.15rem;font-size:.88rem}.input-group{flex-direction:column;gap:.4rem;margin-bottom:1rem;display:flex}.input-group label{color:var(--color-text);font-size:.85rem;font-weight:600}.input-wrapper{background:var(--color-bg);border:1.5px solid var(--color-border);border-radius:10px;align-items:center;gap:.6rem;padding:.75rem 1rem;transition:border-color .2s;display:flex}.input-wrapper:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #1f7fc21f}.input-wrapper svg{color:var(--color-muted);flex-shrink:0}.input-wrapper input{width:100%;color:var(--color-text);background:0 0;border:none;outline:none;font-size:1rem}.btn-primary{background:var(--color-navy);color:#fff;width:100%;font-size:1rem;font-weight:600;font-family:var(--font-head);letter-spacing:.02em;cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:.5rem;margin-top:.5rem;padding:.85rem;transition:background .2s,opacity .2s,transform .1s;display:flex}.btn-primary:hover:not(:disabled){background:var(--color-primary)}.btn-primary:active:not(:disabled){transform:translateY(1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.error-msg{color:var(--color-error);background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:1rem;padding:.65rem 1rem;font-size:.875rem}.dashboard{flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;min-height:100dvh;padding:2rem;display:flex}.dashboard h1{text-align:center;color:var(--color-navy);font-size:clamp(1.4rem,4vw,2rem)}.dashboard p{color:var(--color-muted);text-align:center}.dashboard .brand-logo{width:240px;max-width:70%;height:auto}.dashboard-card{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);border-top:4px solid var(--color-primary);flex-direction:column;align-items:center;gap:1.25rem;width:100%;max-width:440px;padding:2.5rem 2rem;display:flex}.btn-logout{border:1.5px solid var(--color-border);background:var(--color-surface);cursor:pointer;color:var(--color-muted);border-radius:8px;padding:.55rem 1.4rem;font-size:.9rem;transition:border-color .2s}.btn-logout:hover{border-color:var(--color-primary);color:var(--color-primary)}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin}@media (width<=480px){.card{padding:2rem 1.25rem}}.admin-layout{background:var(--color-bg);flex-direction:column;height:100dvh;display:flex;overflow:hidden}.admin-header{background:var(--color-surface);border-bottom:3px solid var(--color-primary);z-index:5;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1.25rem;display:flex;position:sticky;top:0;box-shadow:0 2px 10px #102a4e0f}.admin-header-title{align-items:center;gap:1rem;display:flex}.admin-brand-logo{width:auto;height:46px}.admin-header-divider{background:var(--color-border);width:1px;height:38px}.admin-logo{font-size:1.8rem}.admin-header-title h1{color:var(--color-navy);font-size:clamp(1.05rem,3vw,1.35rem);line-height:1.2}.admin-header-title p{color:var(--color-muted);font-size:.82rem}.admin-toolbar{flex-wrap:wrap;align-items:center;gap:1rem;padding:1rem 1.25rem .5rem;display:flex}.admin-search{border:1.5px solid var(--color-border);background:var(--color-surface);border-radius:10px;outline:none;flex:280px;max-width:460px;padding:.65rem 1rem;font-size:.95rem;transition:border-color .2s}.admin-search:focus{border-color:var(--color-primary)}.admin-filtro{border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer;border-radius:10px;outline:none;flex:none;padding:.65rem 1rem;font-size:.95rem;transition:border-color .2s}.admin-filtro:focus{border-color:var(--color-primary)}.admin-count{color:var(--color-muted);white-space:nowrap;font-size:.85rem}.table-wrapper{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);min-height:0;box-shadow:var(--shadow);-webkit-overflow-scrolling:touch;flex:1;margin:.5rem 1.25rem 0;overflow:auto visible}.tabla-maquinas{border-collapse:collapse;white-space:nowrap;width:100%;font-size:.85rem}.tabla-maquinas thead th{background:var(--color-navy);color:#fff;font-family:var(--font-head);letter-spacing:.02em;text-align:left;white-space:nowrap;z-index:2;padding:.75rem .8rem;font-size:.78rem;font-weight:600;position:sticky;top:0}.tabla-maquinas tbody td{border-bottom:1px solid var(--color-border);color:var(--color-text);padding:.6rem .8rem}.tabla-maquinas tbody tr:nth-child(2n){background:#f6f9fc}.tabla-maquinas tbody tr:hover{background:#e8f1fa}.tabla-maquinas tbody tr.fila-clic{cursor:pointer}.tabla-maquinas .col-num{text-align:right;font-variant-numeric:tabular-nums}.tabla-maquinas .col-codigo{color:var(--color-primary);font-weight:700}.tabla-vacia{color:var(--color-muted);text-align:center!important;padding:2rem!important}.badge{white-space:nowrap;border-radius:999px;padding:.2rem .55rem;font-size:.72rem;font-weight:600;display:inline-block}.badge-activa{color:#166534;background:#dcfce7}.badge-falta{color:#854d0e;background:#fef9c3}.badge-parado{color:#374151;background:#e5e7eb}.badge-reparacion{color:#9a3412;background:#ffedd5}.badge-baja{color:#991b1b;background:#fee2e2}.paginacion{flex-wrap:wrap;justify-content:center;align-items:center;gap:.4rem;padding:0 1.25rem 1.75rem;display:flex}.paginacion-info{text-align:center;width:100%;color:var(--color-muted);margin-bottom:.5rem;font-size:.82rem}.pag-btn{border:1.5px solid var(--color-border);background:var(--color-surface);min-width:38px;color:var(--color-navy);cursor:pointer;border-radius:8px;padding:.45rem .7rem;font-size:.85rem;font-weight:600;transition:background .15s,border-color .15s,color .15s}.pag-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.pag-btn:disabled{opacity:.45;cursor:not-allowed}.pag-btn.activo{background:var(--color-navy);border-color:var(--color-navy);color:#fff}.pag-ellipsis{color:var(--color-muted);padding:.45rem .3rem}@media (width<=640px){.table-wrapper{margin:.5rem .75rem 1rem}.admin-toolbar{padding:.75rem .75rem .25rem}.admin-header{padding:.7rem .8rem}.admin-brand-logo{height:38px}.paginacion{padding:0 .75rem 1.25rem}}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;background:#0a1f3c8c;justify-content:center;align-items:center;padding:1rem;animation:.15s modal-fade;display:flex;position:fixed;inset:0}@keyframes modal-fade{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-surface);border-radius:14px;flex-direction:column;width:100%;max-width:760px;max-height:90vh;animation:.18s modal-pop;display:flex;overflow:hidden;box-shadow:0 20px 60px #0a1f3c59}@keyframes modal-pop{0%{opacity:0;transform:translateY(12px)scale(.98)}to{opacity:1;transform:none}}.modal-header{background:var(--color-navy);color:#fff;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.4rem;display:flex}.modal-header h2{font-family:var(--font-head);font-size:1.25rem;line-height:1.1}.modal-header p{color:#ffffffbf;font-size:.82rem}.modal-cerrar{color:#fff;cursor:pointer;background:#ffffff1f;border:none;border-radius:9px;width:34px;height:34px;font-size:1rem;transition:background .15s}.modal-cerrar:hover{background:#ffffff40}.modal-error{margin:.9rem 1.4rem 0}.modal-body{grid-template-columns:repeat(2,1fr);gap:.9rem 1.2rem;padding:1.2rem 1.4rem;display:grid;overflow-y:auto}.campo{flex-direction:column;gap:.3rem;display:flex}.campo.campo-ancho{grid-column:1/-1}.campo label{text-transform:uppercase;letter-spacing:.03em;color:var(--color-muted);font-size:.72rem;font-weight:700}.campo-valor{color:var(--color-text);word-break:break-word;padding:.15rem 0;font-size:.95rem}.campo-bloqueado{color:var(--color-muted)}.campo input,.campo select,.campo textarea{border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text);border-radius:9px;outline:none;padding:.55rem .7rem;font-family:inherit;font-size:.92rem;transition:border-color .2s}.campo input:focus,.campo select:focus,.campo textarea:focus{border-color:var(--color-primary)}.campo textarea{resize:vertical}.modal-footer{border-top:1px solid var(--color-border);background:#f6f9fc;justify-content:flex-end;gap:.7rem;padding:1rem 1.4rem;display:flex}.btn-primario,.btn-secundario{cursor:pointer;border-radius:9px;padding:.6rem 1.3rem;font-size:.9rem;font-weight:600;transition:background .15s,border-color .15s,color .15s,opacity .15s}.btn-primario{background:var(--color-primary);border:1.5px solid var(--color-primary);color:#fff}.btn-primario:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn-primario:disabled{opacity:.6;cursor:not-allowed}.btn-secundario{border:1.5px solid var(--color-border);color:var(--color-navy);background:0 0}.btn-secundario:hover:not(:disabled){border-color:var(--color-navy)}.btn-secundario:disabled{opacity:.6;cursor:not-allowed}@media (width<=560px){.modal-body{grid-template-columns:1fr}}.campo-app{background:var(--color-bg);flex-direction:column;min-height:100dvh;display:flex}.campo-topbar{background:var(--color-navy);color:#fff;z-index:20;justify-content:space-between;align-items:center;gap:.75rem;padding:.85rem 1.1rem;display:flex;position:sticky;top:0}.campo-topbar .ct-maquina{flex-direction:column;line-height:1.15;display:flex}.campo-topbar .ct-maquina strong{font-size:1.15rem;font-family:var(--font-head)}.campo-topbar .ct-maquina span{color:#ffffffbf;font-size:.82rem}.campo-topbar .ct-salir{color:#fff;cursor:pointer;background:#ffffff24;border:none;border-radius:10px;padding:.6rem .9rem;font-size:1rem;font-weight:600}.campo-main{flex-direction:column;flex:1;width:100%;max-width:560px;margin:0 auto;padding:1.25rem 1.1rem 2.5rem;display:flex}.campo-pasos{gap:.5rem;margin-bottom:1.5rem;display:flex}.campo-pasos .paso{background:var(--color-border);border-radius:99px;flex:1;height:8px}.campo-pasos .paso.activo{background:var(--color-primary)}.campo-pasos .paso.hecho{background:#16a34a}.campo-titulo{font-family:var(--font-head);color:var(--color-navy);margin-bottom:.35rem;font-size:1.5rem}.campo-sub{color:var(--color-muted);margin-bottom:1.5rem;font-size:1rem}.campo-input{text-align:center;border:2px solid var(--color-border);width:100%;color:var(--color-navy);background:#fff;border-radius:14px;margin-bottom:1.25rem;padding:1rem;font-size:2rem;font-weight:700}.campo-input:focus{border-color:var(--color-primary);outline:none}.campo-dato{border:1px solid var(--color-border);background:#fff;border-radius:14px;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:1rem 1.1rem;font-size:1.05rem;display:flex}.campo-dato .etq{color:var(--color-muted)}.campo-dato .val{color:var(--color-navy);font-size:1.2rem;font-weight:700}.btn-campo{cursor:pointer;border:none;border-radius:14px;justify-content:center;align-items:center;gap:.6rem;width:100%;min-height:56px;padding:0 1rem;font-size:1.15rem;font-weight:700;transition:transform 50ms,background .15s;display:flex}.btn-campo:active:not(:disabled){transform:scale(.98)}.btn-campo:disabled{opacity:.55;cursor:not-allowed}.btn-campo.primario{background:var(--color-primary);color:#fff}.btn-campo.primario:hover:not(:disabled){background:var(--color-primary-hover)}.btn-campo.ok{color:#fff;background:#16a34a}.btn-campo.ok:hover:not(:disabled){background:#15803d}.btn-campo.alerta{color:#fff;background:#dc2626}.btn-campo.alerta:hover:not(:disabled){background:#b91c1c}.btn-campo.gris{color:var(--color-navy);border:2px solid var(--color-border);background:#fff}.campo-acciones{flex-direction:column;gap:.85rem;margin-top:.5rem;display:flex}.foto-zona{border:2px dashed var(--color-border);text-align:center;background:#fff;border-radius:14px;margin-bottom:1.25rem;padding:1.5rem}.foto-zona img{object-fit:cover;border-radius:12px;width:100%;max-height:260px}.foto-zona .icono{font-size:2.5rem}.foto-zona .foto-icono{color:var(--color-muted);justify-content:center;margin-bottom:.4rem;display:flex}.falla-lista{flex-direction:column;gap:.65rem;margin-bottom:1.25rem;display:flex}.falla-item{text-align:left;border:2px solid var(--color-border);cursor:pointer;width:100%;min-height:54px;color:var(--color-text);background:#fff;border-radius:12px;align-items:center;gap:.75rem;padding:.75rem 1rem;font-size:1.05rem;font-weight:600;display:flex}.falla-item.sel{color:#b91c1c;background:#fef2f2;border-color:#dc2626}.falla-item .check{border:2px solid var(--color-border);border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:1rem;display:flex}.falla-item.sel .check{color:#fff;background:#dc2626;border-color:#dc2626}.campo-nota{border:2px solid var(--color-border);resize:vertical;width:100%;min-height:90px;font-size:1.05rem;font-family:var(--font-body);border-radius:12px;margin-bottom:1.25rem;padding:.9rem 1rem}.campo-nota:focus{border-color:var(--color-primary);outline:none}.resultado{text-align:center;padding:2rem 1.25rem}.resultado .icono{margin-bottom:1rem;font-size:4rem}.resultado h2{font-family:var(--font-head);margin-bottom:.5rem;font-size:1.6rem}.resultado.exito h2{color:#16a34a}.resultado.error h2{color:#dc2626}.resultado p{color:var(--color-muted);font-size:1.05rem}.aviso-servicio{border-radius:12px;align-items:center;gap:.6rem;margin-bottom:1.25rem;padding:.85rem 1rem;font-size:1rem;font-weight:600;display:flex}.aviso-servicio.amarillo{color:#854d0e;background:#fef9c3;border:1px solid #fde047}.aviso-servicio.rojo{color:#991b1b;background:#fee2e2;border:1px solid #fca5a5}.campo-feedback{border-radius:10px;margin-bottom:1rem;padding:.8rem 1rem;font-size:1rem;font-weight:600}.campo-feedback.err{color:#991b1b;background:#fee2e2}.campo-feedback.ok{color:#166534;background:#dcfce7}.campo-vacio{text-align:center;color:var(--color-muted);padding:3rem 1.5rem}.campo-vacio .icono{margin-bottom:1rem;font-size:3.5rem}.mec-main{flex:1;width:100%;max-width:920px;margin:0 auto;padding:1.25rem 1.1rem 3rem}.mec-tabs{flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem;display:flex}.mec-tab{border:2px solid var(--color-border);min-width:130px;min-height:48px;color:var(--color-navy);cursor:pointer;background:#fff;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:.4rem;font-size:1rem;font-weight:700;display:flex}.mec-tab.activo{background:var(--color-navy);color:#fff;border-color:var(--color-navy)}.mec-tab .cuenta{color:#fff;background:#dc2626;border-radius:99px;min-width:20px;padding:.05rem .45rem;font-size:.8rem}.mec-tab.activo .cuenta{background:#ffffff40}.orden-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;display:grid}.orden-card{border:1px solid var(--color-border);border-left:5px solid var(--color-primary);background:#fff;border-radius:14px;flex-direction:column;gap:.6rem;padding:1.1rem;display:flex}.orden-card.critica{border-left-color:#dc2626}.orden-card.alta{border-left-color:#ea580c}.orden-card.media{border-left-color:#d97706}.orden-card.preventivo{border-left-color:#2563eb}.orden-card.proceso{border-left-color:#16a34a}.orden-card .oc-top{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.orden-card .oc-codigo{font-family:var(--font-head);color:var(--color-navy);font-size:1.2rem;font-weight:800}.orden-card .oc-tipo{color:var(--color-muted);font-size:.9rem}.orden-card .oc-falla{font-size:1.05rem;font-weight:700}.orden-card .oc-desc{color:var(--color-muted);font-size:.92rem}.orden-card .oc-meta{color:var(--color-muted);font-size:.82rem}.badge-sev{text-transform:uppercase;letter-spacing:.03em;border-radius:99px;padding:.2rem .55rem;font-size:.72rem;font-weight:800}.badge-sev.critica{color:#b91c1c;background:#fee2e2}.badge-sev.alta{color:#c2410c;background:#ffedd5}.badge-sev.media{color:#a16207;background:#fef9c3}.badge-sev.baja{color:#075985;background:#e0f2fe}.mec-seccion-titulo{font-family:var(--font-head);color:var(--color-navy);margin:1.5rem 0 .75rem;font-size:1.1rem}.cierre-foto-grid{flex-wrap:wrap;gap:.6rem;margin:.5rem 0 1rem;display:flex}.cierre-foto-grid img{object-fit:cover;border:1px solid var(--color-border);border-radius:10px;width:84px;height:84px}.campana{position:relative}.campana-btn{color:#fff;cursor:pointer;background:#ffffff24;border:none;border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.3rem;display:flex;position:relative}.campana-badge{color:#fff;background:#dc2626;border-radius:99px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:.7rem;font-weight:800;display:flex;position:absolute;top:-4px;right:-4px}.campana-panel{border:1px solid var(--color-border);z-index:50;background:#fff;border-radius:14px;flex-direction:column;width:320px;max-width:86vw;max-height:70vh;display:flex;position:absolute;top:52px;right:0;overflow:hidden;box-shadow:0 18px 50px #0a1f3c47}.campana-head{border-bottom:1px solid var(--color-border);color:var(--color-navy);justify-content:space-between;align-items:center;padding:.85rem 1rem;display:flex}.campana-head button{color:var(--color-primary);cursor:pointer;background:0 0;border:none;font-size:.85rem;font-weight:700}.campana-lista{overflow-y:auto}.campana-vacio{text-align:center;color:var(--color-muted);padding:2rem 1rem}.campana-item{text-align:left;border:none;border-bottom:1px solid var(--color-border);cursor:pointer;background:#fff;width:100%;padding:.8rem 1rem}.campana-item.nueva{background:#eff6ff}.campana-item .ci-titulo{color:var(--color-navy);font-size:.92rem;font-weight:700}.campana-item .ci-msg{color:var(--color-muted);margin-top:.15rem;font-size:.84rem}.campana-item .ci-fecha{color:var(--color-muted);margin-top:.25rem;font-size:.74rem}.admin-metricas{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;padding:1rem 1rem 0;display:grid}.metrica-card{background:var(--color-surface);border:1px solid var(--color-border);border-left:5px solid var(--color-primary);box-shadow:var(--shadow);border-radius:12px;flex-direction:column;gap:.15rem;padding:.8rem 1rem;display:flex}.metrica-valor{font-family:var(--font-head);color:var(--color-navy);font-size:1.7rem;font-weight:800;line-height:1}.metrica-etiqueta{color:var(--color-muted);font-size:.8rem;font-weight:600}.metrica-card.m-total{border-left-color:var(--color-navy)}.metrica-card.m-activa{border-left-color:#16a34a}.metrica-card.m-reparacion{border-left-color:#d97706}.metrica-card.m-parado{border-left-color:#64748b}.metrica-card.m-falta{border-left-color:#2563eb}.metrica-card.m-baja{border-left-color:#dc2626}.op-panel{border:1px solid var(--color-border);background:#f8fafc;border-radius:12px;padding:.9rem 1rem}.op-actual{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.op-actual strong{color:var(--color-navy);font-size:1.05rem;display:block}.op-cred{color:var(--color-muted);margin-top:.2rem;font-size:.82rem;display:block}.op-cred code{color:var(--color-navy);background:#e2e8f0;border-radius:5px;padding:.05rem .35rem;font-weight:700}.op-botones{flex-wrap:wrap;gap:.5rem;display:flex}.op-form{border-top:1px dashed var(--color-border);margin-top:.9rem;padding-top:.9rem}.op-hint{color:var(--color-muted);margin-bottom:.6rem;font-size:.82rem;line-height:1.4}.op-form-fila{grid-template-columns:1fr 1fr;gap:.6rem;margin-bottom:.7rem;display:grid}.op-form-fila input{border:1px solid var(--color-border);border-radius:9px;padding:.65rem .7rem;font-size:.95rem}.btn-peligro{color:#b91c1c;cursor:pointer;font-weight:700;font-family:var(--font-head);background:#fee2e2;border:1px solid #fecaca;border-radius:9px;padding:.55rem .9rem}.btn-peligro:hover{background:#fecaca}.btn-peligro:disabled{opacity:.6;cursor:not-allowed}.ok-msg{color:#166534;background:#dcfce7;border:1px solid #bbf7d0;border-radius:9px;padding:.6rem .8rem;font-size:.88rem;font-weight:600}@media (width<=560px){.op-form-fila{grid-template-columns:1fr}}.admin-toolbar{flex-wrap:wrap;gap:.6rem}.admin-toolbar-acciones{flex-shrink:0;gap:.5rem;margin-left:auto;display:flex}.btn-nueva-maquina{background:var(--color-navy);color:#fff;cursor:pointer;font-weight:700;font-family:var(--font-head);white-space:nowrap;border:none;border-radius:9px;padding:.55rem 1.1rem;font-size:.9rem}.btn-nueva-maquina:hover{background:var(--color-navy-700)}.btn-reporte{color:#166534;cursor:pointer;font-weight:700;font-family:var(--font-head);white-space:nowrap;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:9px;padding:.55rem 1rem;font-size:.9rem}.btn-reporte:hover{background:#dcfce7}.btn-reporte:disabled{opacity:.5;cursor:not-allowed}.modal-nueva{max-width:700px}.modal-nueva .modal-body{grid-template-columns:1fr 1fr}.modal-nueva .campo-req label:after{content:" *";color:var(--color-error)}@media (width<=560px){.modal-nueva .modal-body{grid-template-columns:1fr}}.admin-tabs{border-bottom:2px solid var(--color-border);flex-shrink:0;gap:.3rem;padding:.6rem 1rem 0;display:flex;overflow-x:auto}.admin-tab{font-family:var(--font-head);color:var(--color-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:3px solid #0000;align-items:center;gap:.4rem;margin-bottom:-2px;padding:.6rem .95rem;font-size:.9rem;font-weight:700;transition:color .15s,border-color .15s;display:flex}.admin-tab:hover{color:var(--color-navy)}.admin-tab.activa{color:var(--color-navy);border-bottom-color:var(--color-primary)}.tab-badge{color:#fff;text-align:center;background:#dc2626;border-radius:999px;min-width:1.2rem;padding:.05rem .45rem;font-size:.72rem;font-weight:800}.reporte-wrap{flex-direction:column;flex:1;min-height:0;padding:.8rem 1rem;display:flex;overflow:hidden}.reporte-cab{flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.5rem;display:flex}.reporte-cab-txt{min-width:0}.reporte-cab h2{font-family:var(--font-head);color:var(--color-navy);margin:0;font-size:1.15rem}.reporte-cab p{color:var(--color-muted);margin:.2rem 0 0;font-size:.86rem}.btn-pdf{color:#b91c1c;cursor:pointer;font-weight:700;font-family:var(--font-head);white-space:nowrap;background:#fef2f2;border:1px solid #fecaca;border-radius:9px;flex-shrink:0;padding:.5rem .9rem;font-size:.85rem}.btn-pdf:hover{background:#fee2e2}.btn-pdf:disabled{opacity:.55;cursor:not-allowed}.reporte-cargando,.reporte-vacio{text-align:center;color:var(--color-muted);padding:2rem 1rem;font-size:.95rem}.modal-usuario{max-width:480px}.modal-usuario .modal-body{flex-direction:column;gap:1rem;padding:1.25rem 1.5rem;display:flex}.modal-usuario .campo-hint{color:var(--color-muted);margin-top:.25rem;font-size:.8rem}.td-acciones{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex;padding:.35rem .5rem!important}.btn-accion{font-size:.78rem;font-family:var(--font-head);color:#334155;cursor:pointer;white-space:nowrap;background:#f1f5f9;border:1px solid #cbd5e1;border-radius:6px;padding:.25rem .65rem;font-weight:600;transition:background .15s,color .15s}.btn-accion:hover{background:#e2e8f0}.btn-accion:disabled{opacity:.5;cursor:not-allowed}.btn-accion-peligro{color:#b91c1c;background:#fef2f2;border-color:#fca5a5}.btn-accion-peligro:hover{background:#fee2e2}.btn-accion-ok{color:#166534;background:#f0fdf4;border-color:#86efac}.btn-accion-ok:hover{background:#dcfce7}.reporte-subt{font-family:var(--font-head);color:var(--color-navy);margin:0 0 .4rem;font-size:.98rem}.reporte-doble{flex:1;grid-template-rows:1fr 1fr;gap:.8rem;min-height:0;display:grid;overflow:hidden}.reporte-doble>div{flex-direction:column;min-height:0;display:flex}.reporte-doble .table-wrapper{flex:1;min-height:0;margin:0}.rep-link{color:var(--color-primary);font-weight:700;text-decoration:none}.rep-link:hover{text-decoration:underline}.reporte-toolbar{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:.6rem;margin-bottom:.5rem;display:flex}.reporte-toolbar .admin-search{flex:240px}.reporte-wrap .table-wrapper{flex:1;min-height:0;margin:0}.reporte-wrap .paginacion{flex-shrink:0;margin:0}.modal-reporte{width:100%;max-width:880px}.modal-reporte-cuerpo{grid-template-columns:1fr 1fr;gap:1.2rem;padding:1.25rem 1.4rem;display:grid}.reporte-detalle{flex-direction:column;gap:.55rem;display:flex}.dato-reporte{border-bottom:1px solid var(--color-border);flex-direction:column;gap:.1rem;padding-bottom:.45rem;display:flex}.dato-label{color:var(--color-muted);text-transform:uppercase;letter-spacing:.02em;font-size:.76rem;font-weight:600}.dato-valor{color:var(--color-navy);font-size:.98rem;font-weight:600}.reporte-imagenes{flex-direction:column;min-width:0;display:flex}.reporte-img-titulo{font-family:var(--font-head);color:var(--color-navy);margin:0 0 .6rem;font-size:.95rem}.carrusel{flex-direction:column;gap:.6rem;display:flex}.carrusel-visor{background:#0f172a;border-radius:12px;justify-content:center;align-items:center;min-height:260px;max-height:360px;display:flex;overflow:hidden}.carrusel-img{object-fit:contain;width:100%;height:100%;max-height:360px;display:block}.carrusel-estado,.carrusel-vacio{color:var(--color-muted);text-align:center;padding:2rem 1rem;font-size:.9rem}.carrusel-vacio{border:1px dashed var(--color-border);background:#f8fafc;border-radius:12px}.carrusel-ctrl{justify-content:center;align-items:center;gap:1rem;display:flex}.carrusel-flecha{border:1px solid var(--color-border);background:var(--color-surface);width:36px;height:36px;color:var(--color-navy);cursor:pointer;border-radius:50%;font-size:1.3rem;line-height:1}.carrusel-flecha:hover{background:var(--color-bg)}.carrusel-cont{color:var(--color-muted);font-size:.85rem;font-weight:600}@media (width<=640px){.modal-reporte-cuerpo{grid-template-columns:1fr}}.servicio-grid{flex:1;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));align-content:start;gap:.8rem;min-height:0;padding-bottom:1rem;display:grid;overflow:auto}.servicio-card{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow);border-left:5px solid #2563eb;border-radius:12px;padding:.85rem 1rem}.servicio-card.vencido{background:#fff5f5;border-left-color:#dc2626}.sc-cab{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.sc-codigo{font-family:var(--font-head);color:var(--color-navy);font-size:1.05rem;font-weight:800}.sc-tipo{color:var(--color-muted);margin:.3rem 0 .5rem;font-size:.85rem}.sc-barra{background:#e2e8f0;border-radius:999px;height:8px;overflow:hidden}.sc-barra-fill{background:linear-gradient(90deg,#2563eb,#1f7fc2);height:100%}.servicio-card.vencido .sc-barra-fill{background:linear-gradient(90deg,#dc2626,#ef4444)}.sc-horas{color:var(--color-navy);margin:.45rem 0 .25rem;font-size:.82rem;font-weight:600}.sc-op{color:var(--color-muted);margin:0;font-size:.8rem}
