:root {
  --azul: #0E2A47;
  --azul-osc: #0a1f36;
  --naranja: #FF6B2C;
  --naranja-osc: #e85d1f;
  --tinta: #1a1f29;
  --gris: #f4f5f7;
  --linea: #e3e6ea;
  --verde: #137333;
  --ambar: #9a6700;
  --rojo: #b3261e;
}
* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  color: var(--tinta);
  background: var(--gris);
}
a { color: var(--azul); text-decoration: none; }
a:hover { text-decoration: underline; }

/* Layout: barra lateral + (topbar + contenido) */
.app { display: grid; grid-template-columns: 240px 1fr; min-height: 100vh; }
.sidebar {
  background: linear-gradient(180deg, #0E2A47, #0a1d33); color: #cdd9e8;
  display: flex; flex-direction: column; padding: .9rem .7rem;
}
.brand { display: flex; align-items: center; gap: .55rem; font-weight: 700; font-size: 1.1rem; color: #fff; padding: .45rem .5rem 1rem; }
.brand-mark { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px; border-radius: 9px; background: linear-gradient(135deg, var(--azul), #3b82f6); color: #fff; font-size: .78rem; font-weight: 800; }
/* Marca Cocopit en el sidebar (backend) */
.brand-ico { width: 30px; height: 30px; flex: 0 0 auto; }
.brand-txt { font-weight: 800; letter-spacing: -.02em; color: #fff; font-size: 1.18rem; }
.brand-pit { color: var(--naranja); }

.ico { width: 20px; height: 20px; display: inline-block; vertical-align: middle; flex: 0 0 auto; }
.sidebar nav { display: flex; flex-direction: column; gap: .12rem; }
.nav-grupo { padding: .9rem .6rem .3rem; font-size: .67rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: #6f86a0; }
.nav-item { display: flex; align-items: center; gap: .65rem; color: #cdd9e8; padding: .52rem .6rem; border-radius: 9px; font-size: .92rem; position: relative; }
.nav-item:hover { background: rgba(255,255,255,.07); color: #fff; text-decoration: none; }
.nav-item .ico { width: 19px; height: 19px; opacity: .85; }
.nav-item.activo { background: rgba(255,107,44,.15); color: #fff; font-weight: 600; }
.nav-item.activo .ico { opacity: 1; color: #ff9b6b; }
.nav-item.activo::before { content: ""; position: absolute; left: -.7rem; top: 18%; bottom: 18%; width: 3px; border-radius: 0 3px 3px 0; background: var(--naranja); }
.sidebar-pie { margin-top: auto; padding-top: .5rem; }

/* Indicador de sincronización (solo escritorio): estado del servidor + cola offline-first */
.sync-box { margin: .4rem .15rem .2rem; padding: .5rem .6rem; border-radius: 8px; background: rgba(255,255,255,.06); display: flex; flex-wrap: wrap; align-items: center; gap: .35rem .5rem; font-size: .8rem; color: #cfe0f0; }
.sync-dot { width: 9px; height: 9px; border-radius: 50%; flex: 0 0 auto; background: #93a7bd; }
.sync-ok .sync-dot { background: #34d399; }     /* verde: en línea */
.sync-off .sync-dot { background: #f59e0b; }    /* ámbar: sin conexión */
.sync-local .sync-dot { background: #93a7bd; }  /* gris: solo local */
.sync-txt { font-weight: 600; }
.sync-cola { width: 100%; color: #ffd9a8; font-size: .78rem; }  /* cambios en cola */
.sync-cola-ok { color: #93a7bd; }
.sync-btn { background: rgba(255,255,255,.12); color: #fff; border: 0; padding: .2rem .55rem; border-radius: 6px; font-size: .78rem; cursor: pointer; }
.sync-btn:hover { background: rgba(255,255,255,.22); text-decoration: none; }
.sync-btn[disabled] { opacity: .5; cursor: default; }
/* Mini-form para pegar el token de dispositivo (M2) cuando el servidor lo exige. */
.sync-token-form { width: 100%; display: flex; flex-wrap: wrap; gap: .35rem; margin-top: .2rem; }
.sync-token-aviso { width: 100%; margin: 0 0 .15rem; color: #ffd9a8; font-size: .76rem; }
.sync-token-input { flex: 1 1 8rem; min-width: 0; background: rgba(255,255,255,.1); color: #fff; border: 1px solid rgba(255,255,255,.2); border-radius: 6px; padding: .2rem .4rem; font-size: .76rem; }

/* main = topbar pegajosa + contenido */
.main { display: flex; flex-direction: column; min-width: 0; }
.topbar { position: sticky; top: 0; z-index: 30; display: flex; align-items: center; gap: 1rem; padding: .6rem 1.4rem; background: rgba(255,255,255,.9); backdrop-filter: blur(8px); border-bottom: 1px solid var(--linea); }
.content { padding: 1.6rem 2rem; max-width: 1560px; width: 100%; }

/* Búsqueda global (topbar) */
.buscador-global { position: relative; display: flex; align-items: center; gap: .5rem; flex: 1; max-width: 560px; background: #fff; border: 1px solid var(--linea); border-radius: 10px; padding: 0 .7rem; }
.buscador-global:focus-within { border-color: var(--azul); box-shadow: 0 0 0 3px rgba(14,42,71,.12); }
.buscador-global .ico-buscar { width: 18px; height: 18px; color: #8595a8; }
.buscador-global input { flex: 1; min-width: 0; border: 0; outline: 0; padding: .55rem 0; font-size: .95rem; background: transparent; color: var(--tinta); }
.buscar-resultados:empty { display: none; }
.buscar-resultados { position: absolute; top: calc(100% + .5rem); left: 0; right: 0; background: #fff; border: 1px solid var(--linea); border-radius: 12px; box-shadow: 0 12px 30px rgba(16,32,56,.16); max-height: 70vh; overflow: hidden auto; z-index: 40; }
.res-grupo { padding: .5rem .8rem .25rem; font-size: .7rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: #8595a8; background: #fafbfc; }
.res-item { display: flex; align-items: center; gap: .7rem; padding: .55rem .8rem; border-top: 1px solid #f0f2f5; color: var(--tinta); }
.res-item:hover { background: #f3f8ff; text-decoration: none; }
.res-item .ico { width: 18px; height: 18px; color: #8595a8; }
.res-titulo { font-weight: 600; }
.res-sub { color: #6b7891; font-size: .85rem; }
.res-vacio { padding: .9rem; color: #6b7891; font-size: .9rem; }
/* Glóbulo de notificaciones del portal (topbar, A5) */
.globulo-portal { display: inline-flex; align-items: center; position: relative; padding: .25rem .3rem; border-radius: 8px; color: #5b6675; text-decoration: none; }
.globulo-portal:hover { background: #f0f2f5; text-decoration: none; }
.globulo-con-badge .ico { color: var(--azul); }
.globulo-sin-badge .ico { color: #8595a8; }
.globulo-badge { position: absolute; top: -.1rem; right: -.25rem; background: var(--rojo); color: #fff; font-size: .68rem; font-weight: 700; min-width: 18px; height: 18px; border-radius: 9px; display: flex; align-items: center; justify-content: center; padding: 0 .3rem; line-height: 1; }

/* Mensajes cliente↔taller (pestaña Mensajes de la ficha de cliente) */
/* El bloque entero se acota a ancho de "chat": en pantallas grandes el hilo a página
   completa dejaba la burbuja del taller perdida en el borde derecho. */
#mensajes-cliente { max-width: 760px; }
.mensajes-hilo { display: flex; flex-direction: column; gap: .6rem; padding: .6rem 0 1rem; max-height: 480px; overflow-y: auto; }
.mensaje-burbuja { max-width: 75%; padding: .5rem .85rem; border-radius: 12px; font-size: .93rem; }
.mensaje-taller { align-self: flex-end; background: var(--azul); color: #fff; border-bottom-right-radius: 4px; }
.mensaje-cliente { align-self: flex-start; background: #f0f2f5; color: var(--tinta); border-bottom-left-radius: 4px; }
.mensaje-meta { font-size: .76rem; margin-top: .3rem; opacity: .75; }
.mensaje-taller .mensaje-meta { color: rgba(255, 255, 255, .88); opacity: 1; }
.mensajes-form { border-top: 1px solid var(--linea); padding-top: .8rem; display: flex; flex-direction: column; gap: .5rem; }
.mensajes-label { font-size: .82rem; font-weight: 600; color: #5b6675; }
.mensajes-form textarea { width: 100%; box-sizing: border-box; font: inherit; font-size: .95rem; padding: .55rem .7rem; border: 1px solid var(--linea); border-radius: 10px; resize: vertical; background: #fff; }
.mensajes-form textarea:focus { border-color: var(--azul); outline: 1px solid var(--azul); }
.mensajes-acciones { display: flex; justify-content: flex-end; }

.topbar-taller { display: flex; align-items: center; gap: .4rem; font-size: .88rem; color: #5b6675; white-space: nowrap; margin-left: auto; }
.punto-taller { width: 8px; height: 8px; border-radius: 50%; background: var(--verde); }

h1 { margin: 0 0 1rem; font-size: 1.5rem; color: var(--tinta); }
h2 { margin: 1.6rem 0 .6rem; font-size: 1.15rem; }

.cabecera { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }

/* KPIs (web del TALLER) — escritorio: una sola fila que se reparte el ancho (flex:1 por
   tarjeta); móvil (≤700px): rejilla 3×3 (decisión del dueño: 9 KPIs, 3 por línea).
   El portal del CLIENTE usa sus propias tarjetas (`.portal-tarjetas`, portal.css), NO esto. */
.kpis { display: flex; gap: 1rem; flex-wrap: wrap; }
.kpi {
  background: #fff; border: 1px solid var(--linea); border-radius: 12px;
  padding: 1rem .6rem; display: flex; flex-direction: column; align-items: center;
  text-align: center; min-width: 0; flex: 1 1 0;
}
@media (max-width: 700px) {
  .kpis { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: .6rem; }
  .kpi { padding: .7rem .3rem; }
  .kpi .num { font-size: 1.5rem; }
  .kpi .lbl { font-size: .75rem; }
}
.kpi .kpi-ico { font-size: 1.6rem; line-height: 1; margin-bottom: .3rem; }
.kpi .num { font-size: 2rem; font-weight: 700; color: var(--azul); line-height: 1; }
.kpi .lbl { color: #5b6675; font-size: .9rem; margin-top: .3rem; }
/* KPI clicable (enlace a su apartado) */
a.kpi { transition: border-color .15s, box-shadow .15s, transform .15s; }
a.kpi:hover {
  text-decoration: none; border-color: var(--azul);
  box-shadow: 0 2px 10px rgba(14,42,71,.12); transform: translateY(-1px);
}

/* Tablas */
.tabla { width: 100%; border-collapse: collapse; background: #fff; border: 1px solid var(--linea); border-radius: 10px; overflow: hidden; margin-top: .6rem; }
.tabla th, .tabla td { text-align: left; padding: .55rem .8rem; border-bottom: 1px solid var(--linea); }
.tabla thead th { background: #fafbfc; font-size: .85rem; color: #5b6675; text-transform: uppercase; letter-spacing: .02em; }
.tabla tbody tr:hover { background: #f8fafc; }
.tabla .num { text-align: right; font-variant-numeric: tabular-nums; }
.tabla tfoot th { background: #fafbfc; }
.tabla tfoot .total-final th { font-size: 1.05rem; color: var(--azul); }

/* Estados */
.estado { padding: .1rem .55rem; border-radius: 999px; font-size: .8rem; font-weight: 600; background: #eef1f5; color: #5b6675; }
.estado-abierta, .estado-en_curso { background: #e7f0fb; color: var(--azul); }
.estado-terminada, .estado-entregada { background: #e6f4ea; color: var(--verde); }
.estado-facturada { background: #fff4e5; color: var(--ambar); }
.estado-anulada { background: #fde8e6; color: var(--rojo); }
/* Estados de cita (agenda) */
.estado-pendiente { background: #fff4e5; color: var(--ambar); }
.estado-propuesta { background: #fff0d6; color: #b36b00; }
.estado-confirmada { background: #e7f0fb; color: var(--azul); }
.estado-cumplida { background: #e6f4ea; color: var(--verde); }
.estado-cancelada { background: #eef1f5; color: #5b6675; }
/* Mini-form «Proponer otra fecha» en la bandeja */
.cita-proponer-form { padding: .6rem .2rem; }
.proponer-campos { display: flex; flex-wrap: wrap; gap: .6rem; align-items: flex-end; }
.form-label-mini { display: flex; flex-direction: column; font-size: .9rem; gap: .2rem; }
.input-mini { font-size: .9rem; padding: .3rem .5rem; border: 1px solid var(--borde); border-radius: 6px; }
.proponer-acciones { display: flex; gap: .5rem; align-items: center; }
/* Logo / monograma de marca de vehículo (assets en static/adm_ui/marcas/) */
.marca-logo, .marca-mono { display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; vertical-align: middle; border-radius: 8px; overflow: hidden; }
.marca-logo { background: #fff; border: 1px solid var(--linea); }
.marca-logo img { width: 100%; height: 100%; object-fit: contain; padding: 2px; }
.marca-mono { color: #fff; font-weight: 700; line-height: 1; }
.marca-logo-sm, .marca-mono.marca-logo-sm { width: 24px; height: 24px; font-size: .8rem; border-radius: 6px; }
.marca-logo-md, .marca-mono.marca-logo-md { width: 36px; height: 36px; font-size: 1rem; }
.marca-logo-lg, .marca-mono.marca-logo-lg { width: 56px; height: 56px; font-size: 1.5rem; border-radius: 12px; }
.titulo-marca { display: flex; align-items: center; gap: .7rem; }
.titulo-marca h1 { margin: 0; }
.titulo-marca .nota { margin: .1rem 0 0; }
.celda-marca { display: inline-flex; align-items: center; gap: .5rem; }

/* Ficha de marca: cabecera (editar + logo) */
.marca-cabecera { margin-bottom: 1.6rem; }

/* Tarjeta única al ancho del contenido, con dos columnas (datos | logo). */
.marca-editor {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; margin-top: 1rem;
  background: #fff; border: 1px solid var(--linea); border-radius: 12px; padding: 1.2rem 1.4rem;
}
.marca-editor-col { display: flex; flex-direction: column; gap: .7rem; min-width: 0; }
.marca-editor .panel-titulo { margin: 0; font-size: 1rem; color: var(--tinta); }
.marca-editor form { margin: 0; }
.marca-editor .marca-campo { display: flex; flex-direction: column; gap: .25rem; font-size: .9rem; color: #5b6675; margin-bottom: .7rem; }
.marca-editor .marca-campo input {
  width: 100%; box-sizing: border-box; padding: .5rem .7rem; border: 1px solid var(--linea);
  border-radius: 8px; font-size: 1rem; color: var(--tinta);
}
.marca-editor .marca-campo input:focus { outline: 0; border-color: var(--azul); box-shadow: 0 0 0 3px rgba(14,42,71,.12); }
.marca-editor .acciones { margin-top: 1rem; }
.marca-editor .check-inline { margin-bottom: .2rem; }
.marca-logo-quitar { display: flex; align-items: center; gap: .6rem; flex-wrap: wrap; margin-top: .8rem; }

/* Zona de arrastrar y soltar (logo): label clicable + drag&drop. */
.dropzone {
  display: flex; flex-direction: row; align-items: center; gap: .9rem; text-align: left;
  border: 2px dashed var(--linea); border-radius: 10px; background: #fafbfc;
  padding: .8rem 1rem; cursor: pointer; transition: border-color .15s, background .15s;
}
.dropzone:hover, .dropzone:focus-within { border-color: var(--azul); background: #f3f8ff; }
.dropzone.dragover { border-color: var(--azul); border-style: solid; background: #eaf2fd; }
.dropzone-preview { pointer-events: none; flex: 0 0 auto; }
.dropzone-txt { display: flex; flex-direction: column; gap: .12rem; min-width: 0; }
.dropzone-texto { margin: 0; font-size: .9rem; font-weight: 600; color: var(--tinta); }
.dropzone-nota { margin: 0; font-size: .8rem; color: #8595a8; }

.check-inline, .form label.check-inline { display: flex; flex-direction: row; align-items: center; gap: .4rem; white-space: nowrap; }
.check-inline input { width: auto; }
.en-produccion { color: var(--verde); font-style: italic; }
@media (max-width: 720px) { .marca-editor { grid-template-columns: 1fr; } }

/* Combustibles del modelo: abreviaturas (vista) + checklist (edición) */
.combustibles-abrev { display: inline-flex; gap: .25rem; flex-wrap: wrap; }
.combustible-chip {
  display: inline-block; min-width: 1.5rem; padding: .1rem .3rem; border-radius: 5px;
  font-size: .72rem; font-weight: 600; text-align: center; letter-spacing: .02em;
  background: #eef1f5; color: #aab4c0; border: 1px solid transparent;
}
.combustible-chip.on { background: var(--azul); color: #fff; }
.combustibles-check { display: flex; gap: .3rem; flex-wrap: wrap; }
.combustible-opcion {
  display: inline-flex; align-items: center; gap: .2rem; padding: .1rem .35rem; cursor: pointer;
  border: 1px solid #cdddf1; border-radius: 5px; background: #fff; font-size: .72rem; font-weight: 600;
  white-space: nowrap; user-select: none;
}
/* No estirar los checkboxes con la regla genérica de `.fila-edicion input` */
.combustibles-check input[type="checkbox"] { width: auto; margin: 0; padding: 0; }
.combustible-opcion:has(input:checked) { background: var(--azul); color: #fff; border-color: var(--azul); }

/* Alta de línea (presupuesto / OR): bloque ENCIMA de la tabla, cada campo ETIQUETADO y alineado. */
.linea-nueva { margin: 0 0 1rem; padding: 1rem 1.2rem; background: #f7faff; border: 1px solid var(--linea); border-radius: 12px; }
.linea-nueva-titulo { margin: 0 0 .8rem; font-size: 1rem; color: var(--tinta); }
.linea-nueva-campos { display: flex; flex-wrap: wrap; align-items: flex-end; gap: .7rem .9rem; }
.linea-nueva label { display: flex; flex-direction: column; gap: .25rem; font-size: .78rem; font-weight: 600; color: #5b6675; }
.linea-nueva input, .linea-nueva select { padding: .45rem .6rem; border: 1px solid var(--linea); border-radius: 8px; font-size: .95rem; color: var(--tinta); background: #fff; }
.linea-nueva input:focus, .linea-nueva select:focus { outline: 0; border-color: var(--azul); box-shadow: 0 0 0 3px rgba(14,42,71,.12); }
.linea-nueva .campo-desc { flex: 1 1 260px; position: relative; }
.linea-nueva .campo-desc input { width: 100%; }
.linea-nueva .campo-num input { width: 5.5rem; text-align: right; }
.linea-nueva button[type=submit] { margin-left: auto; }
@media (max-width: 720px) { .linea-nueva .campo-desc { flex-basis: 100%; } .linea-nueva button[type=submit] { margin-left: 0; } }

/* Stepper de cantidad: input + botones −/+ (alta de línea y edición inline). */
.stepper { display: inline-flex; align-items: stretch; }
.stepper > button { flex: 0 0 auto; width: 1.9rem; padding: 0; border: 1px solid var(--linea); background: #fff; color: var(--tinta); font-size: 1.05rem; line-height: 1; cursor: pointer; }
.stepper > button:first-child { border-radius: 8px 0 0 8px; }
.stepper > button:last-child { border-radius: 0 8px 8px 0; }
.stepper > button:hover { background: #eef3fb; border-color: var(--azul); color: var(--azul); }
.stepper > input { width: 3rem !important; text-align: center; border-radius: 0 !important; border-left: 0 !important; border-right: 0 !important; }
.fila-edicion .stepper > button { padding: .25rem 0; }
.fila-edicion .stepper > input { width: 2.6rem !important; }

/* Sugerencias de artículo en el campo Descripción de "Añadir línea" (lineas.js). */
.articulo-sugerencias { position: absolute; top: calc(100% + .25rem); left: 0; right: 0; z-index: 60; margin: 0; padding: .25rem; list-style: none; background: #fff; border: 1px solid var(--linea); border-radius: 10px; box-shadow: 0 12px 30px rgba(16,32,56,.16); max-height: 260px; overflow: auto; }
.articulo-sugerencia { display: flex; align-items: baseline; gap: .55rem; padding: .4rem .55rem; border-radius: 7px; cursor: pointer; font-size: .9rem; font-weight: 400; }
.articulo-sugerencia:hover { background: #f3f8ff; }
.articulo-sugerencia .art-desc { flex: 1 1 auto; color: var(--tinta); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.articulo-sugerencia .art-ref { flex: 0 0 auto; color: #8595a8; font-size: .8rem; }
.articulo-sugerencia .art-pvp { flex: 0 0 auto; color: var(--azul); font-weight: 600; }

/* Prioridad de la OR (cola de trabajo: baja / normal / alta / urgente) */
.prioridad { padding: .1rem .55rem; border-radius: 999px; font-size: .8rem; font-weight: 600; background: #eef1f5; color: #5b6675; }
.prioridad-baja { background: #eef1f5; color: #5b6675; }
.prioridad-normal { background: #e7f0fb; color: var(--azul); }
.prioridad-alta { background: #fff4e5; color: var(--ambar); }
.prioridad-urgente { background: #fde8e6; color: var(--rojo); }

/* Tipo de orden (categoría predefinida: mantenimiento / avería / pre-ITV…) */
.chip-tipo { padding: .1rem .55rem; border-radius: 999px; font-size: .8rem; font-weight: 600; background: #ede9fe; color: #6d28d9; }
.filtro-tipo { margin: .4rem 0 .2rem; }
.filtro-tipo label { display: inline-flex; align-items: center; gap: .5rem; font-size: .9rem; color: #5b6675; }
.filtro-tipo select { padding: .4rem .6rem; border: 1px solid var(--linea); border-radius: 8px; font-size: .95rem; }

/* Estados de presupuesto */
.estado-borrador { background: #eef1f5; color: #5b6675; }
.estado-enviado { background: #e7f0fb; color: var(--azul); }
.estado-aceptado { background: #e6f4ea; color: var(--verde); }
.estado-rechazado { background: #fde8e6; color: var(--rojo); }
.estado-convertido { background: #e6f4ea; color: var(--verde); }
/* Estado de pedido a proveedor (recibido = compra cerrada, verde) */
.estado-recibido { background: #e6f4ea; color: var(--verde); }
/* Estados nuevos de OR/presupuesto (coordinación con agente dominio) */
.estado-pendiente_pieza { background: #fff0d6; color: #b36b00; }
.estado-pieza_pedida { background: #fff4e5; color: var(--ambar); }
.estado-pendiente_contactar { background: #fef0e4; color: #9a4a00; }
.estado-servicio_externo { background: #ede9fe; color: #5b21b6; }

/* Pedidos a proveedor: indicadores de control + líneas de devolución
   ------------------------------------------------------------------ */
.pedido-resumen { display: flex; flex-wrap: wrap; gap: .5rem; margin: .4rem 0 1rem; }
.badge-pendiente { background: #fff4e5; color: var(--ambar); padding: .12rem .6rem; border-radius: 999px; font-size: .82rem; font-weight: 600; }
.badge-ok { background: #e6f4ea; color: var(--verde); padding: .12rem .6rem; border-radius: 999px; font-size: .82rem; font-weight: 600; }
.badge-devolucion { background: #fde8e6; color: var(--rojo); padding: .12rem .6rem; border-radius: 999px; font-size: .82rem; font-weight: 600; }
.tabla.tabla-pedido .fila-devolucion td { background: #fef5f4; }
.tag-devolucion { display: inline-block; font-weight: 700; color: var(--rojo); }
.nota-ref { color: #8595a8; font-size: .85rem; }
.nota-motivo { display: block; color: #8595a8; font-size: .78rem; margin-top: .15rem; }
.celda-estado-linea { white-space: nowrap; }
/* Mini-form de "marcar devolución" (select de motivo + botón) dentro de una celda de acciones */
.form-devolucion { display: inline-flex; align-items: center; gap: .25rem; margin: 0; }
.form-devolucion select { padding: .15rem .35rem; border: 1px solid #cdddf1; border-radius: 6px; font-size: .8rem; background: #fff; color: var(--tinta); }
/* Alta de línea de pedido: el select de artículo ocupa una fila ancha */
.linea-nueva .campo-articulo { flex: 1 1 320px; }
.linea-nueva .campo-articulo select { width: 100%; }
.linea-nueva .nota { flex-basis: 100%; margin-top: .4rem; }
@media (max-width: 720px) { .linea-nueva .campo-articulo { flex-basis: 100%; } }

/* Acciones de documento (presupuesto: enviar/aceptar/rechazar/convertir) */
.acciones-doc { display: flex; flex-wrap: wrap; gap: .6rem; align-items: center; margin: 1rem 0; }
.acciones-doc form { margin: 0; }

/* Botones */
.btn, button { background: var(--azul); color: #fff; border: 0; padding: .55rem 1rem; border-radius: 8px; font-size: .95rem; cursor: pointer; }
.btn:hover, button:hover { background: var(--azul-osc); text-decoration: none; }
/* btn-sec en <a> = enlace secundario: texto azul sobre el fondo claro de la página.
   En <button> hereda el fondo azul de la regla `button`, así que AHÍ el texto debe ser blanco
   (antes era azul sobre azul = invisible, p. ej. el botón "Subir imagen" / "Posponer"). */
.btn-sec { display: inline-block; margin-top: 1rem; color: var(--azul); }
button.btn-sec { color: #fff; }
/* Botón secundario (fondo claro, buen contraste; p. ej. "Autocompletar") */
.btn-claro { background: #eef3fb; color: var(--azul); border: 1px solid #cdddf1; white-space: nowrap; }
.btn-claro:hover { background: #e0eaf8; }

/* Búsqueda */
.buscador { width: 100%; max-width: 420px; padding: .55rem .8rem; border: 1px solid var(--linea); border-radius: 8px; font-size: 1rem; margin: .4rem 0; }
.htmx-indicator { opacity: 0; transition: opacity .2s; color: #5b6675; font-size: .85rem; margin-left: .5rem; }
.htmx-request .htmx-indicator, .htmx-indicator.htmx-request { opacity: 1; }

/* Formularios */
.form { display: flex; flex-direction: column; gap: .7rem; max-width: 420px; width: 100%; background: #fff; border: 1px solid var(--linea); border-radius: 12px; padding: 1.2rem; }
.form label { display: flex; flex-direction: column; gap: .25rem; font-size: .9rem; color: #5b6675; }
.form input, .form select { width: 100%; padding: .5rem .7rem; border: 1px solid var(--linea); border-radius: 8px; font-size: 1rem; color: var(--tinta); }
.form input[type="checkbox"], .form input[type="radio"] { width: auto; padding: 0; border: none; }
.form .acciones { display: flex; gap: 1rem; align-items: center; margin-top: .4rem; }

.aviso { background: #fff4e5; border: 1px solid #ffe0b2; color: var(--ambar); padding: .8rem 1rem; border-radius: 10px; }
.nota { color: #5b6675; font-size: .85rem; margin: 0; }
.averia { color: #5b6675; }
.con-boton { display: flex; gap: .5rem; }
.con-boton input { flex: 1; width: auto; min-width: 0; }

/* Desplegables dependientes Marca→Modelo en el alta de vehículo */
.catalogo-rapido { display: flex; gap: 1rem; flex-wrap: wrap; }
.catalogo-rapido label { flex: 1; min-width: 160px; }
@media (max-width: 720px) {
  .catalogo-rapido { flex-direction: column; }
  .catalogo-rapido label { min-width: 0; flex: none; width: 100%; }
  .catalogo-rapido select { width: 100%; }
}

/* Ficha (tabla etiqueta/valor) */
.tabla.ficha th { background: #fafbfc; color: #5b6675; font-weight: 600; width: 140px; text-transform: none; letter-spacing: 0; font-size: .9rem; }
.tabla.ficha td { font-size: .95rem; }
.acciones-cab { display: flex; gap: .5rem; align-items: center; }

/* Form ancho (ficha de edición): grid de 12 columnas; cada campo ocupa el ancho
   que le corresponde por su contenido (clases .campo-* abajo). Ver templatetag
   `anchos.py` (mapa name→clase). En estrecho colapsa todo a una columna. */
.form.form-ancho { max-width: 820px; display: grid; grid-template-columns: repeat(12, 1fr); gap: .7rem 1rem; }
/* Por defecto cada hijo directo ocupa la fila entera; las clases .campo-* lo estrechan. */
.form.form-ancho > * { grid-column: 1 / -1; }
.form textarea { padding: .5rem .7rem; border: 1px solid var(--linea); border-radius: 8px; font: inherit; color: var(--tinta); resize: vertical; }
.error { color: var(--rojo); font-size: .85rem; }

/* Anchos de campo (span sobre el grid de 12 columnas de .form-ancho / .form-grupo).
   xs: códigos/%/años (≈2 caben en media fila) · sm: NIF/teléfono/fechas/precios ·
   md: media columna · lg: campo largo casi entero · full: fila completa.
   Aplican a cualquier hijo directo (label, p.aviso, div.catalogo-rapido…). */
.form.form-ancho > .campo-xs, .form-grupo > .campo-xs { grid-column: span 3; }
.form.form-ancho > .campo-sm, .form-grupo > .campo-sm { grid-column: span 4; }
.form.form-ancho > .campo-md, .form-grupo > .campo-md { grid-column: span 6; }
.form.form-ancho > .campo-lg, .form-grupo > .campo-lg { grid-column: span 8; }
.form.form-ancho > .campo-full, .form-grupo > .campo-full { grid-column: span 12; }
/* Toggle (checkbox): la etiqueta va en horizontal, ocupa media fila (input a la izda, texto a la dcha) */
.form.form-ancho > label.campo-check { grid-column: span 6; }
.form-grupo > label.campo-check { grid-column: span 12; }
.form.form-ancho > label.campo-check, .form-grupo > label.campo-check { flex-direction: row-reverse; align-items: center; justify-content: flex-end; gap: .5rem; }
.form.form-ancho > label.campo-check input, .form-grupo > label.campo-check input { width: auto; flex: 0 0 auto; }

/* Bloque agrupado dentro de un formulario ancho (dirección, RGPD, técnica…):
   fieldset sobrio que abarca toda la fila y contiene su propio sub-grid de 12. */
.form.form-ancho > .form-grupo { display: grid; grid-template-columns: repeat(12, 1fr); gap: .7rem 1rem; border: 1px solid var(--linea); border-radius: 10px; padding: .9rem 1rem 1rem; margin: 0; }
.form-grupo > legend { padding: 0 .4rem; font-size: .78rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: #8595a8; }
.form-grupo > * { grid-column: 1 / -1; }

/* Responsive: en pantallas estrechas, un solo campo por fila. */
@media (max-width: 720px) {
  .form.form-ancho, .form-grupo { grid-template-columns: 1fr; }
  .form.form-ancho > *, .form-grupo > * { grid-column: 1 / -1 !important; }
}

/* Atajo: programar próxima ITV / revisión */
.programar { display: flex; flex-wrap: wrap; gap: .8rem; align-items: end; margin-top: .6rem; padding: .8rem; background: #fff; border: 1px solid var(--linea); border-radius: 10px; }
.programar label { display: flex; flex-direction: column; gap: .25rem; font-size: .85rem; color: #5b6675; }
.programar input { padding: .45rem .6rem; border: 1px solid var(--linea); border-radius: 8px; font-size: .95rem; }

/* Zona de peligro / botón destructivo */
.zona-peligro { margin-top: 1.6rem; padding-top: 1rem; border-top: 1px solid var(--linea); }
.btn-peligro { background: var(--rojo); }
.btn-peligro:hover { background: #8f1e17; }

/* Mini botón (borrar línea / cancelar cita): acción destructiva pequeña */
.btn-mini { background: #fde8e6; color: var(--rojo); padding: .15rem .5rem; border-radius: 6px; font-size: .9rem; line-height: 1.4; }
.btn-mini:hover { background: #f9d2ce; }
/* Chip de acción positiva pequeña (confirmar/cumplir/crear cita) */
.btn-chip { background: #e7f0fb; color: var(--azul); border: 1px solid #cdddf1; padding: .15rem .55rem; border-radius: 6px; font-size: .85rem; line-height: 1.4; }
.btn-chip:hover { background: #d8e6f8; }

/* Agenda: acciones en línea */
.acciones-fila { display: flex; gap: .4rem; flex-wrap: wrap; }
.acciones-fila form { margin: 0; }

/* Agenda: calendario mensual
   ------------------------------------------------------------------ */
/* Filtros (motivo / estado) */
.agenda-filtros { display: flex; flex-wrap: wrap; align-items: end; gap: 1rem; margin: .4rem 0 1.1rem; }
.agenda-filtros label { display: flex; flex-direction: column; gap: .3rem; font-size: .8rem; font-weight: 600; color: #5b6675; }
.agenda-filtros select { padding: .45rem .6rem; border: 1px solid var(--linea); border-radius: 8px; font-size: .92rem; background: #fff; min-width: 170px; }
.agenda-filtros select:focus { outline: 0; border-color: var(--azul); box-shadow: 0 0 0 3px rgba(14,42,71,.12); }
.agenda-limpiar { font-size: .85rem; padding-bottom: .55rem; }

/* Contenedor del calendario */
.calendario { background: #fff; border: 1px solid var(--linea); border-radius: 14px; overflow: hidden; box-shadow: 0 1px 3px rgba(16,32,56,.05); }
.cal-cabecera { display: flex; align-items: center; gap: .6rem; padding: .9rem 1.1rem; border-bottom: 1px solid var(--linea); }
.cal-titulo { margin: 0; font-size: 1.25rem; font-weight: 700; min-width: 12rem; text-align: center; }
.cal-nav {
  display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px;
  border-radius: 9px; border: 1px solid var(--linea); background: #fff; color: var(--tinta);
  font-size: 1.4rem; line-height: 1; font-weight: 600;
}
.cal-nav:hover { background: var(--gris); text-decoration: none; border-color: #cdddf1; }
.cal-hoy { margin-left: auto; padding: .4rem .85rem; border: 1px solid #cdddf1; border-radius: 8px; background: #eef3fb; color: var(--azul); font-size: .85rem; font-weight: 600; }
.cal-hoy:hover { background: #d8e6f8; text-decoration: none; }

/* Rejilla 7×N */
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); }
.cal-dow { padding: .55rem .6rem; text-align: center; font-size: .72rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: #8595a8; background: #fafbfc; border-bottom: 1px solid var(--linea); }

.cal-dia {
  display: flex; flex-direction: column; gap: .25rem; min-height: 116px; padding: .4rem .45rem;
  border-right: 1px solid var(--linea); border-bottom: 1px solid var(--linea);
  color: var(--tinta); background: #fff; overflow: hidden;
}
.cal-dia:nth-child(7n) { border-right: 0; }   /* columna domingo */
.cal-dia:hover { background: #f3f8ff; text-decoration: none; }
.cal-dia.otro-mes { background: #fafbfc; color: #aab4c2; }
.cal-dia.otro-mes:hover { background: #f1f4f8; }
.cal-dia.sel { background: #eaf2fd; box-shadow: inset 0 0 0 2px var(--azul); }

.cal-num { font-size: .92rem; font-weight: 600; align-self: flex-start; line-height: 1.5; min-width: 1.6rem; text-align: center; }
.cal-dia.hoy .cal-num { background: var(--azul); color: #fff; border-radius: 50%; height: 1.6rem; }
.cal-dia.otro-mes .cal-num { color: #aab4c2; }

.cal-citas { display: flex; flex-direction: column; gap: .18rem; min-width: 0; }
.cal-chip {
  display: flex; align-items: center; gap: .3rem; font-size: .72rem; font-weight: 600;
  padding: .1rem .35rem; border-radius: 5px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  /* hereda los colores del estado vía .estado-<estado> */
}
.cal-chip-punto { width: 7px; height: 7px; border-radius: 50%; flex: 0 0 auto; background: currentColor; opacity: .85; }
.cal-mas { font-size: .7rem; color: #6b7891; font-weight: 600; padding-left: .2rem; }

/* Detalle del día seleccionado */
.agenda-dia { margin-top: 1.6rem; }
.agenda-dia h2 { text-transform: capitalize; }
.agenda-pista { margin-top: 1.4rem; color: #6b7891; }
.vacio-dia { color: #6b7891; }

/* Editar / mover una cita: resumen de contexto sobre el formulario. */
.cita-editar-resumen { margin: .4rem 0 1.2rem; }
.cita-editar-resumen p { margin: .2rem 0; }
.cita-editar-resumen .nota { color: #6b7891; font-size: .9rem; }

/* Responsive: en móvil la rejilla se rompe; pasamos a una lista vertical por día. */
@media (max-width: 720px) {
  .cal-grid { grid-template-columns: 1fr; }
  .cal-dow { display: none; }
  .cal-dia { min-height: auto; flex-direction: row; align-items: flex-start; gap: .7rem; border-right: 0; }
  .cal-dia.otro-mes { display: none; }   /* en lista no aportan los días vecinos */
  .cal-num { min-width: 2.2rem; }
  .cal-citas { flex: 1; }
  .cal-chip { white-space: normal; }
}

/* Avisos: plazos y filas vencidas */
tr.fila-vencida td { background: #fdf3f2; }
.badge-vencido { background: #fde8e6; color: var(--rojo); padding: .1rem .5rem; border-radius: 999px; font-size: .8rem; font-weight: 600; }
.badge-hoy { background: #fff4e5; color: var(--ambar); padding: .1rem .5rem; border-radius: 999px; font-size: .8rem; font-weight: 600; }
.kpi-alerta .num { color: var(--rojo); }

/* Pestañas (fichas de detalle). Reutilizable: ".tabs" envuelve ".tabs-barra"
   (los botones [role=tab]) + uno o varios ".tab-panel". Barra tipo "underline".
   Todos los paneles quedan en el DOM (HTMX dentro de un panel oculto sigue ok). */
.tabs { margin-top: 1.2rem; }
.tabs-barra { display: flex; flex-wrap: wrap; gap: .2rem; border-bottom: 1px solid var(--linea); margin-bottom: 1.1rem; }
.tabs-barra [role=tab] {
  background: none; border: 0; border-bottom: 2px solid transparent; color: #5b6675;
  padding: .55rem .9rem; font-size: .95rem; font-weight: 600; cursor: pointer; border-radius: 0;
  margin-bottom: -1px;
}
.tabs-barra [role=tab]:hover { background: var(--gris); color: var(--tinta); }
.tabs-barra [role=tab][aria-selected="true"] { color: var(--azul); border-bottom-color: var(--azul); background: none; }
.tabs-barra [role=tab]:focus-visible { outline: 2px solid var(--azul); outline-offset: -2px; border-radius: 6px 6px 0 0; }
.tab-panel[hidden] { display: none; }
/* El primer h2 de un panel no necesita el margen superior (ya hay separación). */
.tab-panel > h2:first-child { margin-top: 0; }

/* Ficha de OR: layout en dos columnas (documento | vehículo + pestañas)
   ------------------------------------------------------------------
   Izquierda (flexible, min 0) = el "documento": cabecera + líneas + totales.
   Derecha (ancho fijo) = tarjeta del vehículo + bloque de pestañas.
   En pantallas <=1100px colapsa a una columna (derecha debajo). */
.or-layout { display: grid; grid-template-columns: minmax(0, 1fr) 440px; gap: 1.6rem; align-items: start; }
.or-doc { min-width: 0; }
.or-doc-meta {
  display: flex; flex-wrap: wrap; gap: .4rem 1.6rem; margin: .9rem 0 .2rem;
  padding: .8rem 1.1rem; background: #fff; border: 1px solid var(--linea);
  border-radius: 12px; box-shadow: 0 1px 3px rgba(16,32,56,.05);
}
.or-doc-dato { display: inline-flex; align-items: baseline; gap: .45rem; font-size: .92rem; min-width: 0; }
.or-doc-lbl { font-size: .7rem; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; color: #8595a8; }
.or-doc-averia { flex-basis: 100%; color: #5b6675; }
.or-lateral { display: flex; flex-direction: column; gap: 1.2rem; min-width: 0; }

/* Tarjeta del vehículo (cabecera de la columna derecha, estilo ficha técnica) */
.vehiculo-card {
  display: flex; align-items: center; gap: 1rem; background: #fff;
  border: 1px solid var(--linea); border-radius: 14px; padding: 1rem 1.2rem;
  box-shadow: 0 1px 3px rgba(16,32,56,.05);
}
.vehiculo-card-datos { display: flex; flex-direction: column; gap: .25rem; min-width: 0; }
.vehiculo-card-nombre { font-size: 1.08rem; font-weight: 700; line-height: 1.25; }
.vehiculo-card-matricula {
  align-self: flex-start; font-family: ui-monospace, "Cascadia Code", monospace;
  font-weight: 700; letter-spacing: .06em; font-size: .92rem;
  border: 2px solid var(--tinta); border-radius: 6px; padding: .05rem .5rem; background: #fff;
}
.vehiculo-card-meta { color: #5b6675; font-size: .88rem; }
.vehiculo-card-meta:empty { display: none; }
.vehiculo-card-enlace { font-size: .88rem; font-weight: 600; }

/* El bloque de pestañas de la derecha va en su propia tarjeta; tabs algo más compactas
   (caben Vehículo · Tareas · Informe · Fotos · Detalles… y las que vengan). */
.or-lateral .tabs {
  margin-top: 0; background: #fff; border: 1px solid var(--linea); border-radius: 14px;
  padding: 1.1rem 1.2rem 1.3rem; box-shadow: 0 1px 3px rgba(16,32,56,.05);
}
.or-tabs .tabs-barra { gap: .1rem; }
.or-tabs .tabs-barra [role=tab] { padding: .5rem .65rem; font-size: .9rem; }

/* Pestaña Vehículo: recepción (km, combustible, estado general, inventario) */
.recepcion-bloque { margin-bottom: 1.2rem; }
.recepcion-bloque:last-child { margin-bottom: 0; }
.bloque-titulo { margin: 0 0 .45rem; font-size: .74rem; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; color: #8595a8; }
.km-ingreso { display: flex; gap: .5rem; align-items: center; }
.km-ingreso input { flex: 1; min-width: 0; padding: .45rem .6rem; border: 1px solid var(--linea); border-radius: 8px; font-size: .95rem; color: var(--tinta); }
.km-ingreso input:focus { outline: 0; border-color: var(--azul); box-shadow: 0 0 0 3px rgba(14,42,71,.12); }
.recepcion-ro { margin: 0; font-weight: 600; }

/* Barra de combustible E→F: 8 segmentos clicables + porcentaje en verde */
.combustible-medidor { display: flex; align-items: center; gap: .6rem; }
.combustible-barra { display: flex; gap: 3px; flex: 1; min-width: 0; }
.combustible-seg { flex: 1 1 0; height: 26px; padding: 0; border: 1px solid var(--linea); border-radius: 4px; background: #eef1f5; }
button.combustible-seg { cursor: pointer; }
button.combustible-seg:hover { background: #d9efe1; border-color: var(--verde); }
.combustible-seg.lleno, button.combustible-seg.lleno:hover { background: linear-gradient(180deg, #34a85e, var(--verde)); border-color: #0f5e2a; }
.combustible-pct { flex: 0 0 auto; min-width: 2.8rem; text-align: right; font-weight: 700; color: var(--verde); font-variant-numeric: tabular-nums; }
.combustible-escala { display: flex; justify-content: space-between; margin-top: .3rem; font-size: .72rem; font-weight: 700; color: #8595a8; }

/* Estado general del vehículo (textarea + guardar) */
.estado-vehiculo-form { display: flex; flex-direction: column; gap: .5rem; align-items: flex-start; }
.estado-vehiculo-form textarea { width: 100%; padding: .5rem .7rem; border: 1px solid var(--linea); border-radius: 8px; font: inherit; color: var(--tinta); resize: vertical; }
.estado-vehiculo-form textarea:focus { outline: 0; border-color: var(--azul); box-shadow: 0 0 0 3px rgba(14,42,71,.12); }

/* Inventario del vehículo: checklist en rejilla (se guarda al cambiar) */
.inventario-check { display: grid; grid-template-columns: repeat(2, 1fr); gap: .25rem .9rem; margin: 0; }
.inventario-item { display: flex; align-items: center; gap: .45rem; padding: .18rem 0; font-size: .9rem; color: var(--tinta); cursor: pointer; }
.inventario-item input[type="checkbox"] { width: 1rem; height: 1rem; margin: 0; flex: 0 0 auto; accent-color: var(--azul); cursor: pointer; }
.inventario-item input[type="checkbox"][disabled] { cursor: default; }

@media (max-width: 1100px) {
  .or-layout { grid-template-columns: 1fr; }
  .inventario-check { grid-template-columns: repeat(3, 1fr); }  /* a todo el ancho caben 3 */
}
@media (max-width: 720px) {
  .inventario-check { grid-template-columns: 1fr 1fr; }
}

/* Pestaña Inspección: pins de daños sobre los dibujos del vehículo
   Las píldoras cambian la vista (la activa en azul, con mini-contador de pins);
   el lienzo es position:relative y cada pin va absoluto en left/top % del viewBox,
   centrado en el punto clicado vía translate(-50%,-50%) (mismo criterio que el JS). */
.inspeccion-cabecera { display: flex; align-items: flex-start; justify-content: space-between; gap: .6rem; margin-bottom: .7rem; }
.inspeccion-vistas { display: flex; flex-wrap: wrap; gap: .3rem; }
.vista-pill {
  border: 1px solid var(--linea); background: #fff; color: #5b6675; border-radius: 999px;
  padding: .28rem .65rem; font-size: .82rem; font-weight: 600; cursor: pointer;
}
.vista-pill:hover { border-color: var(--azul); color: var(--azul); }
.vista-pill.activa { background: var(--azul); border-color: var(--azul); color: #fff; }
.vista-pill .pill-num {
  display: inline-block; min-width: 1.1rem; padding: 0 .25rem; margin-left: .15rem;
  border-radius: 999px; background: rgba(14,42,71,.12); color: var(--azul);
  font-size: .72rem; text-align: center; font-variant-numeric: tabular-nums;
}
.vista-pill.activa .pill-num { background: rgba(255,255,255,.25); color: #fff; }
.inspeccion-lienzo {
  position: relative; background: #fff; border: 1px solid var(--linea); border-radius: 12px;
  overflow: hidden; box-shadow: 0 1px 3px rgba(16,32,56,.05);
}
.inspeccion-lienzo.editable { cursor: crosshair; }
.inspeccion-svg { display: block; width: 100%; height: auto; user-select: none; }
.inspeccion-pin {
  position: absolute; transform: translate(-50%, -50%);
  width: 22px; height: 22px; border-radius: 50%;
  background: #d62828; color: #fff; border: 2px solid #fff;
  box-shadow: 0 1px 4px rgba(16,32,56,.35);
  display: flex; align-items: center; justify-content: center;
  font-size: .72rem; font-weight: 700; line-height: 1;
  transition: transform .12s ease;
}
.inspeccion-pin:hover { transform: translate(-50%, -50%) scale(1.15); z-index: 2; }
.inspeccion-ayuda { margin: .5rem 0 0; color: #8595a8; font-size: .82rem; }
.inspeccion-lista { list-style: none; margin: .8rem 0 0; padding: 0; display: flex; flex-direction: column; gap: .35rem; }
.inspeccion-punto {
  display: flex; align-items: center; gap: .55rem; padding: .4rem .6rem;
  border: 1px solid var(--linea); border-radius: 8px; background: #fff;
}
.inspeccion-punto.resaltada { border-color: #d62828; background: #fdf1f1; }
.pin-mini {
  flex: 0 0 auto; width: 18px; height: 18px; border-radius: 50%;
  background: #d62828; color: #fff; font-size: .68rem; font-weight: 700;
  display: inline-flex; align-items: center; justify-content: center; line-height: 1;
}
.inspeccion-vista-lbl { flex: 0 0 auto; color: #8595a8; font-size: .76rem; font-weight: 600; }
.inspeccion-desc { flex: 1; min-width: 0; padding: .35rem .5rem; border: 1px solid var(--linea); border-radius: 6px; font-size: .88rem; color: var(--tinta); }
.inspeccion-desc:focus { outline: 0; border-color: var(--azul); box-shadow: 0 0 0 3px rgba(14,42,71,.12); }
.inspeccion-desc-ro { flex: 1; min-width: 0; font-size: .9rem; }
.inspeccion-vacio { margin: .8rem 0 0; color: #5b6675; font-size: .9rem; }

/* Edición inline de una línea de OR */
.fila-edicion td { background: #f3f8ff; }
.fila-edicion input, .fila-edicion select { width: 100%; padding: .35rem .45rem; border: 1px solid #cdddf1; border-radius: 6px; font-size: .9rem; }
.fila-edicion .num input { text-align: right; }

/* Alta de línea en la OR */
.form-linea { display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; margin-top: .8rem; padding: .8rem; background: #fff; border: 1px solid var(--linea); border-radius: 10px; }
.form-linea select, .form-linea input { padding: .45rem .6rem; border: 1px solid var(--linea); border-radius: 8px; font-size: .95rem; }
.form-linea input[name="descripcion"] { flex: 1; min-width: 180px; }

/* Maestros de Configuración (Familias/Tipos/Ubicaciones): código estable e inmutable */
.codigo-fijo { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: .85rem; color: #5a636e; background: #f1f3f6; padding: .1rem .4rem; border-radius: 6px; }
.form-linea .campo-codigo { display: inline-flex; flex-direction: column; gap: 2px; }
.ayuda-campo { color: #6b7891; font-size: .72rem; }

/* Checklist de tareas de la OR */
.checklist { list-style: none; margin: .5rem 0 0; padding: 0; }
.checklist-item { display: flex; align-items: center; gap: .6rem; padding: .45rem .6rem; border: 1px solid var(--linea); border-radius: 8px; background: #fff; margin-bottom: .4rem; }
.checklist-item input[type="checkbox"] { width: 1.1rem; height: 1.1rem; flex: 0 0 auto; accent-color: var(--azul); cursor: pointer; }
.checklist-item .checklist-texto { flex: 1; }
.checklist-item.hecha .checklist-texto { text-decoration: line-through; color: #8a93a0; }
.checklist-vacio { color: #5b6675; padding: .45rem .6rem; }
.form-tarea { display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; margin-top: .8rem; padding: .8rem; background: #fff; border: 1px solid var(--linea); border-radius: 10px; }
.form-tarea input { flex: 1; min-width: 200px; padding: .45rem .6rem; border: 1px solid var(--linea); border-radius: 8px; font-size: .95rem; }
.informe-texto { white-space: pre-wrap; }

/* Galería de fotos de la OR */
.galeria-fotos { list-style: none; margin: .5rem 0 0; padding: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: .7rem; }
.foto-item { position: relative; display: flex; flex-direction: column; gap: .3rem; }
.foto-enlace { display: block; border: 1px solid var(--linea); border-radius: 10px; overflow: hidden; background: #fff; }
.foto-item img { display: block; width: 100%; height: 120px; object-fit: cover; }
.foto-item img.foto-rota { display: flex; align-items: center; justify-content: center; }
.foto-enlace:has(img.foto-rota) { position: relative; }
.foto-enlace:has(img.foto-rota)::after { content: "Imagen no disponible"; display: flex; align-items: center; justify-content: center; height: 120px; padding: .4rem; font-size: .78rem; color: #8a93a0; background: repeating-linear-gradient(45deg, #f4f5f7, #f4f5f7 8px, #eceef2 8px, #eceef2 16px); text-align: center; }
.foto-pie { font-size: .8rem; color: #5b6675; }
.foto-borrar { position: absolute; top: .35rem; right: .35rem; }
.form-foto { display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; margin-top: .8rem; padding: .8rem; background: #fff; border: 1px solid var(--linea); border-radius: 10px; }
.form-foto input[name="descripcion"] { flex: 1; min-width: 180px; padding: .45rem .6rem; border: 1px solid var(--linea); border-radius: 8px; font-size: .95rem; }
.form-foto input[type="file"] { font-size: .9rem; }

/* Aprobación del cliente por línea (OR): chips ✓/⊘. Informativa: la fila rechazada
   se atenúa y la descripción se tacha, pero los importes y los totales NO cambian. */
.aprobacion-col { width: 4rem; text-align: center; }
td.aprobacion { white-space: nowrap; text-align: center; }
.chip-aprobacion {
  display: inline-flex; align-items: center; justify-content: center;
  width: 1.55rem; height: 1.55rem; padding: 0; border-radius: 999px;
  border: 1px solid var(--linea); background: #f3f5f8; color: #9aa6b5;
  font-size: .85rem; line-height: 1;
}
button.chip-aprobacion { cursor: pointer; }
button.chip-aprobacion:hover { border-color: #9aa6b5; color: #5b6675; }
.chip-aprobacion.chip-ok.activo { background: var(--verde); border-color: var(--verde); color: #fff; }
.chip-aprobacion.chip-no.activo { background: var(--rojo); border-color: var(--rojo); color: #fff; }
.fila-rechazada { opacity: .55; }
.fila-rechazada td:first-child { text-decoration: line-through; }

/* Notas internas de la OR (pestaña Notas): alta arriba + timeline sutil */
.form-nota { display: flex; flex-direction: column; gap: .5rem; align-items: flex-start; }
.form-nota textarea { width: 100%; padding: .5rem .7rem; border: 1px solid var(--linea); border-radius: 8px; font: inherit; color: var(--tinta); resize: vertical; }
.form-nota textarea:focus { outline: 0; border-color: var(--azul); box-shadow: 0 0 0 3px rgba(14,42,71,.12); }
.notas-timeline { list-style: none; margin: 1rem 0 0 .25rem; padding: 0 0 0 .95rem; border-left: 2px solid var(--linea); display: flex; flex-direction: column; gap: .65rem; }
.nota-item { position: relative; padding-bottom: .65rem; border-bottom: 1px dashed var(--linea); }
.nota-item:last-child { border-bottom: 0; padding-bottom: 0; }
.nota-item::before { content: ""; position: absolute; left: -1.28rem; top: .4rem; width: 8px; height: 8px; border-radius: 50%; background: var(--azul); }
.nota-meta { display: flex; align-items: center; justify-content: space-between; gap: .5rem; }
.nota-fecha { font-size: .76rem; color: #8595a8; font-variant-numeric: tabular-nums; }
.nota-texto { margin: .15rem 0 0; font-size: .92rem; }
.notas-vacio { margin: .9rem 0 0; color: #5b6675; font-size: .9rem; }

/* Citas del vehículo en la ficha de OR (pestaña Citas): alta rápida + historial */
.form-cita-or { display: flex; flex-wrap: wrap; gap: .5rem .6rem; align-items: flex-end; padding: .8rem; background: #fff; border: 1px solid var(--linea); border-radius: 10px; }
.form-cita-or label { display: flex; flex-direction: column; gap: .25rem; font-size: .78rem; font-weight: 600; color: #5b6675; }
.form-cita-or input, .form-cita-or select { padding: .4rem .55rem; border: 1px solid var(--linea); border-radius: 8px; font-size: .9rem; color: var(--tinta); }
.form-cita-or .campo-desc { flex: 1 1 100%; }
.form-cita-or .campo-desc input { width: 100%; }
.form-cita-or .btn-chip { margin-left: auto; }
.citas-or-lista { list-style: none; margin: .9rem 0 0; padding: 0; display: flex; flex-direction: column; gap: .5rem; }
.cita-or-item { padding: .55rem .7rem; border: 1px solid var(--linea); border-radius: 10px; background: #fff; }
.cita-or-linea { display: flex; flex-wrap: wrap; align-items: center; gap: .5rem; }
.cita-or-fecha { font-weight: 700; font-variant-numeric: tabular-nums; }
.cita-or-motivo { color: #5b6675; font-size: .9rem; }
.cita-or-linea .estado { margin-left: auto; }
.cita-or-desc { margin: .3rem 0 0; font-size: .85rem; color: #5b6675; }
.cita-or-acciones { display: flex; gap: .4rem; margin-top: .45rem; }
.cita-or-acciones form { display: inline; }
.citas-or-vacio { margin: .9rem 0 0; color: #5b6675; font-size: .9rem; }

code { background: #eef1f5; padding: .1rem .35rem; border-radius: 5px; font-family: ui-monospace, "Cascadia Code", monospace; }

/* Informes y estadísticas
   ----------------------------------------------------------------------------- */
.acciones-cabecera { display: flex; gap: .5rem; flex-wrap: wrap; }
.acciones-cabecera .btn-claro { margin-top: 0; }

/* Filtro de fechas (presets + rango) */
.informe-filtro {
  display: flex; flex-wrap: wrap; align-items: flex-end; gap: 1rem 1.5rem;
  background: #fff; border: 1px solid var(--linea); border-radius: 12px;
  padding: .9rem 1.1rem; margin: 1rem 0 1.4rem;
}
.informe-presets { display: flex; gap: .4rem; flex-wrap: wrap; }
.informe-presets .btn-chip { cursor: pointer; }
.informe-presets .btn-chip.activo { background: var(--azul); color: #fff; border-color: var(--azul); }
.informe-rango { display: flex; flex-wrap: wrap; align-items: flex-end; gap: .8rem; }
.informe-rango label { display: flex; flex-direction: column; gap: .25rem; font-size: .85rem; color: #5b6675; }
.informe-rango input[type="date"] {
  padding: .45rem .6rem; border: 1px solid var(--linea); border-radius: 8px;
  font-size: .95rem; color: var(--tinta); background: #fff;
}

/* Secciones del informe */
.informe-seccion { margin-bottom: 2rem; }
.informe-seccion h2 { margin-top: 1.4rem; }
.informe-bloque h3 { font-size: 1rem; color: #5b6675; margin: .6rem 0 .4rem; }

/* Rejilla gráfica + tabla; en órdenes, dos bloques lado a lado */
.informe-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr); gap: 1.5rem; align-items: start; }
.informe-grid-2 { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); }
.informe-lateral { display: flex; flex-direction: column; gap: .8rem; }

/* Columnas a la misma altura (la gráfica crece para igualar la tabla del otro lado). */
.informe-grid-stretch { align-items: stretch; }
.informe-lateral-graf { min-width: 0; }
/* Fila de dos KPIs (aceptados / rechazados) sobre el donut, misma altura que el KPI destacado. */
.informe-kpi-fila { display: grid; grid-template-columns: 1fr 1fr; gap: .8rem; }
.informe-kpi-fila .kpi { min-width: 0; }

/* Caja de la gráfica (altura acotada para que Chart.js no crezca sin fin) */
.informe-grafica {
  background: #fff; border: 1px solid var(--linea); border-radius: 12px;
  padding: 1rem; position: relative; height: 260px;
}
/* La gráfica crece para llenar el alto restante de la columna (columnas equilibradas). */
.informe-grafica-crece { flex: 1 1 auto; height: auto; min-height: 240px; }
.informe-grafica-ancha { height: 300px; margin-top: .6rem; }
.informe-grafica canvas { max-width: 100%; }

/* Tarjeta envolvente de un bloque de órdenes (por estado / por tipo): ambas igual de altas. */
.informe-card {
  display: flex; flex-direction: column; gap: .2rem;
  background: #fff; border: 1px solid var(--linea); border-radius: 12px; padding: 1rem 1.1rem;
}
.informe-card h3 { margin: 0 0 .4rem; }
.informe-card .informe-grafica { border: 0; padding: 0; background: none; }
.informe-card .tabla { margin-top: .8rem; }

/* KPI destacado (tasa de conversión) */
.kpi-destacado { background: linear-gradient(135deg, #eef5ff, #fff); border-color: #cdddf1; }
.kpi-destacado .num { font-size: 2.4rem; }

@media (max-width: 900px) {
  .informe-grid, .informe-grid-2 { grid-template-columns: minmax(0, 1fr); }
  .informe-grafica-crece { min-height: 260px; }
}

/* Dashboard de Inicio (filtros + gráficas + 'Próximos')
   ----------------------------------------------------------------------------- */
/* Filtros (rango de fechas + estados). Form GET que recarga (robusto con Chart.js). */
.dash-filtro {
  display: flex; flex-wrap: wrap; align-items: flex-end; gap: 1rem 1.8rem;
  background: #fff; border: 1px solid var(--linea); border-radius: 12px;
  padding: .9rem 1.1rem; margin: 1.2rem 0 1.4rem;
}
.dash-rango, .dash-estados { display: flex; flex-wrap: wrap; align-items: flex-end; gap: .8rem; }
.dash-filtro label { display: flex; flex-direction: column; gap: .25rem; font-size: .85rem; color: #5b6675; }
.dash-filtro input[type="date"], .dash-filtro select {
  padding: .45rem .6rem; border: 1px solid var(--linea); border-radius: 8px;
  font-size: .95rem; color: var(--tinta); background: #fff;
}

/* Rejilla de gráficas: 2 columnas en escritorio, 1 en móvil. minmax(0,1fr) para que
   el min-content de canvas/tablas no infle la pista (overflow global en móvil). */
.dash-graficas { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1.3rem; margin-bottom: 1.8rem; }
.dash-card {
  background: #fff; border: 1px solid var(--linea); border-radius: 12px; padding: 1rem 1.1rem;
}
.dash-card h3 { margin: 0 0 .6rem; font-size: 1rem; color: #5b6675; }
/* Caja de gráfica con alto acotado (Chart.js con maintainAspectRatio:false crece a este alto). */
.dash-grafica { position: relative; height: 260px; }
.dash-grafica canvas { max-width: 100%; }

/* 'Próximos': dos tarjetas (citas + avisos) lado a lado. */
.dash-proximos { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1.3rem; margin-bottom: 1.8rem; }
.dash-proximos .cabecera { margin-bottom: .4rem; }
.dash-proximos .cabecera h3 { margin: 0; font-size: 1rem; color: #5b6675; }
.dash-proximos .btn-claro { margin-top: 0; }

@media (max-width: 900px) {
  .dash-graficas, .dash-proximos { grid-template-columns: minmax(0, 1fr); }
}

/* Home operativa del taller (Avisos · Órdenes abiertas · Citas · Explorador)
   ----------------------------------------------------------------------------- */
.home-seccion { margin-bottom: 1.6rem; }
.home-seccion > h2 { margin: 0 0 .8rem; }
.home-seccion .dash-card .cabecera { margin-bottom: .5rem; }
.home-seccion .dash-card .cabecera h3 { margin: 0; font-size: 1rem; color: #5b6675; }
.home-seccion .dash-card .btn-claro { margin-top: 0; }

/* Acciones por aviso (crear cita / posponer / descartar). En fila, con wrap en móvil. */
.aviso-acciones { display: flex; flex-wrap: wrap; align-items: center; gap: .4rem; }
.aviso-acciones form { margin: 0; }
/* Menú "Posponer" = POPOVER nativo (top layer): no lo recorta el overflow de la tabla y se
   centra/adapta en cualquier pantalla (móvil/tablet/desktop). Cierra al tocar fuera o con Esc. */
.aviso-posponer-menu {
  width: min(340px, 92vw); box-sizing: border-box; margin: auto;  /* margin:auto centra el popover */
  background: #fff; border: 1px solid var(--linea); border-radius: 14px;
  box-shadow: 0 16px 48px rgba(15, 30, 55, 0.24); padding: 1.1rem;
}
.aviso-posponer-menu:popover-open { display: flex; flex-direction: column; gap: .8rem; }
.aviso-posponer-menu::backdrop { background: rgba(15, 30, 55, 0.4); }
.aviso-posponer-titulo { margin: 0; font-weight: 700; color: var(--tinta); }
.aviso-posponer-menu form { display: flex; flex-direction: column; gap: .8rem; }
.aviso-posponer-rapido { display: flex; gap: .5rem; }
.aviso-posponer-rapido .btn-chip { flex: 1; text-align: center; }
.aviso-posponer-fecha { display: flex; flex-direction: column; gap: .3rem; font-size: .85rem; color: #5b6675; }
.aviso-posponer-fecha input[type="date"] {
  width: 100%; box-sizing: border-box; padding: .55rem .6rem; border: 1px solid var(--linea);
  border-radius: 8px; font-size: 16px; color: var(--tinta); background: #fff;
  -webkit-appearance: none; appearance: none; min-width: 0;
}
.aviso-posponer-pie { display: flex; gap: .6rem; justify-content: flex-end; }
.aviso-posponer-menu .btn-sec { margin-top: 0; }

/* Explorador: filtro de fecha COMPARTIDO + subpestañas (Presupuestos / Órdenes). */
.explorador-fechas { margin: 0 0 1rem; }
.explorador-controles { margin-bottom: 1rem; }
.explorador-controles label {
  display: inline-flex; flex-direction: column; gap: .25rem; font-size: .85rem; color: #5b6675;
}
.explorador-controles select {
  padding: .45rem .6rem; border: 1px solid var(--linea); border-radius: 8px;
  font-size: .95rem; color: var(--tinta); background: #fff;
}
.explorador-tabs .dash-card { margin-bottom: 1.1rem; }
.explorador-tabs .dash-grafica { height: 300px; }

/* Combobox con búsqueda (marca/modelo del catálogo). Lo monta combobox.js encima del
   <select> nativo (que se oculta con .combobox-nativo pero sigue siendo la fuente del POST).
   Sin JS no se ve ".combobox" (no existe en el DOM) y se muestra el <select> normal. */
.combobox { position: relative; }
.combobox-nativo { display: none !important; }
.combobox-input { width: 100%; padding: .5rem .7rem; border: 1px solid var(--linea); border-radius: 8px; font-size: 1rem; color: var(--tinta); background: #fff; }
.combobox-input:focus { outline: 0; border-color: var(--azul); box-shadow: 0 0 0 3px rgba(14,42,71,.12); }
.combobox-panel { position: absolute; top: calc(100% + .3rem); left: 0; right: 0; margin: 0; padding: .25rem; list-style: none; background: #fff; border: 1px solid var(--linea); border-radius: 10px; box-shadow: 0 12px 30px rgba(16,32,56,.16); max-height: 280px; overflow: auto; z-index: 50; }
.combobox-panel[hidden] { display: none; }
.combobox-item { display: flex; align-items: center; gap: .55rem; padding: .4rem .55rem; border-radius: 7px; cursor: pointer; color: var(--tinta); font-size: .95rem; }
.combobox-item:hover, .combobox-item.activo { background: #f3f8ff; }
.combobox-item[aria-selected="true"] { font-weight: 600; }
.combobox-item .marca-logo, .combobox-item .marca-mono { flex: 0 0 auto; }
.combobox-nombre { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.combobox-vacio { padding: .5rem .55rem; color: #8595a8; font-size: .9rem; }
/* Lista hermana de items (data-combobox-items): la usa el JS; sin JS no estorba. */
ul[data-combobox-items] { display: none; }

/* Inventario / kardex (ficha de producto, pestaña Inventario) */
.estado-entrada { background: #e6f4ea; color: var(--verde); }
.estado-salida { background: #fde8e6; color: var(--rojo); }
.estado-ajuste { background: #e7f0fb; color: var(--azul); }
.inv-resumen { display: flex; flex-wrap: wrap; gap: 1rem; margin-bottom: 1.2rem; }
.inv-dato { flex: 1 1 160px; background: #fff; border: 1px solid var(--linea); border-radius: 12px; padding: .9rem 1.1rem; }
.inv-dato-alerta { border-color: #f0c9c5; background: #fff7f6; }
.inv-num { display: block; font-size: 1.6rem; font-weight: 700; color: var(--azul); line-height: 1; }
.inv-dato-alerta .inv-num { color: var(--rojo); }
.inv-lbl { display: block; color: #5b6675; font-size: .85rem; margin-top: .35rem; }
.linea-nueva .campo-mov select { min-width: 9rem; }

/* Aviso / resaltado de bajo stock (listado de productos) */
.aviso-bajo-stock { background: #fff7f6; border: 1px solid #f0c9c5; border-radius: 10px; padding: .6rem .9rem; margin: 0 0 1rem; color: var(--tinta); }
.fila-bajo-stock { background: #fff7f6; }
.tag-bajo-stock { color: var(--rojo); font-weight: 700; }

/* Resumen de importación de tarifas */
.resumen-importacion { margin-top: 1.4rem; background: #fff; border: 1px solid var(--linea); border-radius: 12px; padding: 1rem 1.2rem; max-width: 760px; }
.resumen-importacion h2 { margin-top: 0; }
.resumen-importacion ul { margin: 0; padding-left: 1.1rem; line-height: 1.7; }

/* ============================================================================
   Móvil / drawer
   ----------------------------------------------------------------------------
   ≤960px: el sidebar fijo de 240px no cabe → pasa a drawer off-canvas sobre un
   overlay (botón ☰ en la topbar, clase `menu-abierto` en <body>, ver movil.js).
   En escritorio (>960px) NADA cambia: sidebar fijo, sin ☰ ni overlay.
   ============================================================================ */

/* Tablas anchas: patrón único `.tabla-scroll`. La tabla se desplaza DENTRO de su
   contenedor (con inercia táctil); la página nunca tiene scroll horizontal global. */
.tabla-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }

/* Botón hamburguesa (topbar) y ✕ del drawer: ocultos en escritorio. */
.menu-btn {
  display: none; flex: 0 0 auto; align-items: center; justify-content: center;
  width: 44px; height: 44px; padding: 0; border-radius: 10px;
  background: #fff; border: 1px solid var(--linea); color: var(--tinta);
}
.menu-btn:hover { background: var(--gris); }
.menu-btn .ico { width: 22px; height: 22px; }
.sidebar-cerrar { display: none; }
.sidebar-overlay { display: none; }
.sidebar-cabecera { display: flex; align-items: flex-start; justify-content: space-between; gap: .4rem; }

@media (max-width: 960px) {
  .app { grid-template-columns: 1fr; }
  .sidebar {
    position: fixed; top: 0; bottom: 0; left: 0; z-index: 100;
    width: min(280px, 85vw); overflow-y: auto;
    transform: translateX(-100%); transition: transform .2s ease;
  }
  body.menu-abierto .sidebar { transform: translateX(0); box-shadow: 0 0 42px rgba(5, 12, 22, .45); }
  body.menu-abierto { overflow: hidden; }  /* sin scroll de fondo con el drawer abierto */
  .sidebar-overlay {
    display: block; position: fixed; inset: 0; z-index: 99;
    background: rgba(8, 16, 28, .45); opacity: 0; pointer-events: none;
    transition: opacity .2s ease;
  }
  body.menu-abierto .sidebar-overlay { opacity: 1; pointer-events: auto; }
  .menu-btn { display: inline-flex; }
  .sidebar-cerrar {
    display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto;
    width: 44px; height: 44px; padding: 0; border: 0; border-radius: 10px;
    background: transparent; color: #cdd9e8;
  }
  .sidebar-cerrar:hover { background: rgba(255,255,255,.1); color: #fff; }
  .sidebar-cerrar .ico { width: 20px; height: 20px; }
  .topbar { padding: .55rem .8rem; gap: .6rem; }
  /* La barra de pestañas (ficha de OR, producto…) hace scroll horizontal si no cabe. */
  .tabs-barra { flex-wrap: nowrap; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .tabs-barra [role=tab] { white-space: nowrap; }
}
@media (prefers-reduced-motion: reduce) {
  .sidebar, .sidebar-overlay { transition: none; }
}

/* Pantallas táctiles: área táctil cómoda (≥40px) en chips, steppers y segmentos
   sin tocar el escritorio (puntero fino y >960px quedan igual). */
@media (max-width: 960px), (pointer: coarse) {
  .btn-chip, .btn-mini {
    min-width: 40px; min-height: 40px;
    display: inline-flex; align-items: center; justify-content: center;
  }
  .chip-aprobacion { width: 2.5rem; height: 2.5rem; font-size: 1rem; }
  .stepper > button { width: 2.6rem; min-height: 40px; }
  .combustible-seg { height: 40px; }
  .vista-pill { padding: .5rem .8rem; }
  .cal-nav { width: 44px; height: 44px; }
  .inventario-item { padding: .4rem 0; }
  .inventario-item input[type="checkbox"], .checklist-item input[type="checkbox"] { width: 1.3rem; height: 1.3rem; }
  /* iOS hace zoom al enfocar inputs con fuente <16px: la fijamos en táctil. */
  input, select, textarea { font-size: 16px; }
}

/* Móvil estrecho: contenido a sangre, cabeceras que envuelven, topbar compacta. */
@media (max-width: 720px) {
  .content { padding: 1rem .8rem; }
  .cabecera { flex-wrap: wrap; }
  .acciones-cab { flex-wrap: wrap; }
  .topbar-taller { display: none; }  /* no cabe junto al buscador */
  .topbar-usuario .usuario-nombre, .topbar-usuario .usuario-rol { display: none; }
  .buscador-global { max-width: none; }
  /* el "buscando…" ocupa sitio aunque sea invisible (opacity 0) y desborda el topbar */
  .buscador-global .htmx-indicator { display: none; }
}

/* --- Autenticación: login, usuario en la topbar, credenciales, 403 --- */

/* Página de login (sin sidebar): tarjeta centrada sobre fondo gris. */
.login-body { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: 100vh; padding: 1.5rem; }
.login-caja { width: 100%; max-width: 380px; }
.login-marca { text-align: center; margin-bottom: 1.4rem; }
.login-marca h1 { font-size: 1.4rem; margin: .6rem 0 .15rem; color: var(--tinta); }
.login-mark { width: 48px; height: 48px; font-size: 1.1rem; border-radius: 13px; }
.login-logo { width: 60px; height: 60px; }
.login-wordmark { font-weight: 800; letter-spacing: -.02em; }
.login-form { max-width: none; }
.login-form .acciones button { width: 100%; padding: .6rem 1rem; }
/* Marca Cocopit disimulada al pie del login (sin protagonismo). */
.login-pie { margin-top: 1.6rem; text-align: center; color: #aab4c0; font-size: .76rem; }
.login-error { background: #fdecea; border: 1px solid #f3c2bd; color: var(--rojo); border-radius: 8px; padding: .6rem .8rem; font-size: .9rem; margin-bottom: 1rem; }

/* Usuario autenticado en la topbar: nombre + rol + botón Salir. */
.topbar-usuario { display: flex; align-items: center; gap: .55rem; margin-left: auto; }
.topbar-usuario .usuario-nombre { font-size: .88rem; font-weight: 600; color: var(--tinta); white-space: nowrap; }
.topbar-usuario .usuario-rol { font-size: .76rem; color: #5b6675; background: var(--gris); border: 1px solid var(--linea); padding: .08rem .4rem; border-radius: 6px; white-space: nowrap; }
.topbar-usuario .salir-form { margin: 0; }
.btn-salir { background: #eef3fb; color: var(--azul); border: 1px solid #cdddf1; padding: .32rem .7rem; border-radius: 7px; font-size: .82rem; cursor: pointer; }
.btn-salir:hover { background: #e0eaf8; }

/* Recuadro destacado de contraseña recién generada (se muestra una sola vez). */
.credencial-aviso { display: flex; flex-wrap: wrap; align-items: center; gap: .4rem .6rem; background: #fff7e6; border: 1px solid #f0d28a; border-radius: 10px; padding: .8rem 1rem; margin-bottom: 1rem; }
.credencial-pass { font-size: 1.05rem; font-weight: 700; letter-spacing: .03em; background: #fff; border: 1px solid #e0d4a8; border-radius: 6px; padding: .15rem .5rem; }
.fila-inactiva { opacity: .55; }

.aviso-403 { max-width: 540px; }
.aviso-403 h1 { margin-top: .4rem; }

/* Bloque "Acceso al portal" en la ficha del cliente (fase A3) */
.acceso-portal { margin-top: 1.6rem; padding-top: 1.2rem; border-top: 1px solid var(--borde); }
.acceso-portal h3 { margin: 0 0 .8rem; font-size: 1rem; font-weight: 600; color: var(--texto-suave); text-transform: uppercase; letter-spacing: .04em; }

/* M4 — Facturación: asistente AEAT + ficha de factura */
.aviso-fiscal { color: #5b6675; font-size: .9rem; background: #f3f8ff; border: 1px solid #cdddf1; border-radius: 8px; padding: .6rem .9rem; margin-bottom: 1rem; }
.avisos-asistente { display: flex; flex-direction: column; gap: .5rem; margin-bottom: 1rem; }
.aviso-asistente { margin: 0; padding: .6rem .9rem; border-radius: 8px; background: #fff8e7; border: 1px solid #f0d28a; color: #7a5100; font-size: .9rem; }
.asistente-sede { display: flex; align-items: center; gap: 1rem; margin-bottom: 1.4rem; }
.btn-sede { font-size: 1rem; padding: .65rem 1.4rem; }
.asistente-sede-nota { font-size: .85rem; color: #5b6675; }
.asistente-bloques { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1rem; margin-bottom: 2rem; }
.asistente-bloque { background: #fff; border: 1px solid var(--linea); border-radius: 12px; padding: 1rem 1.1rem; }
.asistente-bloque .bloque-titulo { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: #8595a8; margin: 0 0 .7rem; }
.bloque-campos { display: flex; flex-direction: column; gap: .5rem; }
.campo-copiable { display: flex; align-items: center; gap: .5rem; }
.campo-etiqueta { flex: 0 0 auto; min-width: 130px; font-size: .82rem; color: #5b6675; }
.campo-valor { flex: 1 1 0; min-width: 0; font-weight: 600; font-size: .95rem; word-break: break-all; }
.btn-copiar { flex: 0 0 auto; padding: .18rem .55rem; font-size: .78rem; border: 1px solid var(--linea); border-radius: 6px; background: #f4f5f7; cursor: pointer; color: var(--tinta); }
.btn-copiar:hover { background: var(--azul); color: #fff; border-color: var(--azul); }
.btn-copiar.copiado { background: var(--verde); color: #fff; border-color: var(--verde); }
/* Ficha de factura: meta en 2 columnas */
.ficha-factura { max-width: 900px; }
.factura-meta { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; margin-bottom: 1.4rem; }
.factura-meta-col {}
.dl-factura { display: grid; grid-template-columns: auto 1fr; gap: .3rem .8rem; font-size: .93rem; margin: 0; }
.dl-factura dt { color: #5b6675; font-weight: 500; }
.dl-factura dd { margin: 0; font-weight: 600; word-break: break-word; }
/* Banners de anulación / rectificativa */
.banner-anulada { background: #fde8e6; border: 1px solid #f3bfbb; color: var(--rojo); border-radius: 8px; padding: .6rem .9rem; margin-bottom: 1rem; font-size: .9rem; }
.banner-rectificativa { background: #fff4e5; border: 1px solid #f0d28a; color: #7a5100; border-radius: 8px; padding: .6rem .9rem; margin-bottom: 1rem; font-size: .9rem; }
.btn-peligro { background: var(--rojo); border-color: var(--rojo); }
.btn-peligro:hover { background: #9a1e18; border-color: #9a1e18; }
/* Filtros en fila (para listados con búsqueda + select) */
.filtros-fila { display: flex; gap: .8rem; align-items: flex-end; flex-wrap: wrap; margin-bottom: 1rem; }
.filtros-fila label { display: flex; flex-direction: column; gap: .25rem; font-size: .85rem; color: #5b6675; }
.filtros-fila input, .filtros-fila select { padding: .45rem .7rem; border: 1px solid var(--linea); border-radius: 8px; font-size: .93rem; color: var(--tinta); background: #fff; }
@media (max-width: 720px) { .factura-meta { grid-template-columns: 1fr; } .asistente-bloques { grid-template-columns: 1fr; } }
/* Mensajes de éxito en la ficha del vehículo (citas creadas al programar) */
.mensajes-exito { list-style: none; margin: 0 0 1rem; padding: 0; display: flex; flex-direction: column; gap: .35rem; }
.aviso-ok { background: #e8f8ee; border: 1px solid #a4d9b5; color: #1a5c31; border-radius: 8px; padding: .45rem .8rem; font-size: .92rem; }
.aviso-warn { background: #fdf3e0; border: 1px solid #f5d5a0; color: #7a4400; border-radius: 8px; padding: .45rem .8rem; font-size: .92rem; }
/* Evidencia de firma electrónica del presupuesto (decisión del cliente desde el portal) */
.portal-evidencia { margin-top: .6rem; margin-bottom: .6rem; font-weight: 500; }
/* Checkbox "Crear cita" en el formulario de programar ITV/revisión */
.crear-cita-check { display: flex; align-items: center; gap: .45rem; font-size: .93rem; cursor: pointer; }
.crear-cita-check input[type="checkbox"] { width: 1.1rem; height: 1.1rem; cursor: pointer; }
/* Conmutador de vista Calendario / Lista en la Agenda */
.agenda-vista-toggle { display: flex; gap: .4rem; margin-bottom: .8rem; }
.agenda-vista-toggle .btn-chip.activo { background: var(--azul); color: #fff; border-color: var(--azul); }
/* Cobro de facturas */
.chip { display: inline-block; padding: .1rem .55rem; border-radius: 999px; font-size: .8rem; font-weight: 600; }
.chip-cobro-pendiente { background: #fff4e5; color: #7a5100; }
.chip-cobro-pagada { background: #e8f8ee; color: #1a5c31; }
.chip-aeat { background: #e6f0ff; color: #1a3a80; font-size: .75rem; }
.cobro-estado { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; margin-bottom: .6rem; }
.cobro-fecha { font-size: .88rem; color: #5b6675; }
.cobro-medio { font-size: .88rem; color: #5b6675; }
.cobro-form .cobro-campos { display: flex; align-items: flex-end; gap: .8rem; flex-wrap: wrap; margin-top: .5rem; }
.cobro-form .cobro-campos label { display: flex; flex-direction: column; gap: .2rem; font-size: .9rem; }
#cobro-section { background: #f9fafb; border: 1px solid #e2e8f0; border-radius: 10px; padding: 1rem 1.2rem; margin-bottom: 1.4rem; max-width: 700px; }
/* Selector de tipo en Informes */
.informes-tipo-selector { display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: 1.2rem; }
.informes-tipo-selector .btn-chip.activo { background: var(--azul); color: #fff; border-color: var(--azul); }
.informe-kpi-fila-4 { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 1.2rem; }
/* Autocompletado de dirección postal (proxy Photon/OSM) */
.dir-sugerencias { position: absolute; top: 100%; left: 0; right: 0; z-index: 50; margin: .15rem 0 0; padding: 0; list-style: none; background: #fff; border: 1px solid var(--linea); border-radius: 10px; box-shadow: 0 8px 24px rgba(16,32,56,.14); max-height: 280px; overflow-y: auto; }
.dir-sugerencia { display: flex; flex-direction: column; gap: .1rem; padding: .55rem .8rem; cursor: pointer; border-top: 1px solid #f0f2f5; font-size: .93rem; }
.dir-sugerencia:first-child { border-top: 0; }
.dir-sugerencia:hover, .dir-sugerencia:focus { background: #f3f8ff; outline: none; }
.dir-sug-dir { font-weight: 600; color: var(--tinta); }
.dir-sug-meta { font-size: .82rem; color: #6b7891; }
/* Backup Nube */
.chip-info { background: #e6f0ff; color: #1a3a80; }
.chip-nube { background: #ede9fe; color: #4c1d95; }
.tabla .mono { font-family: ui-monospace, "Cascadia Code", "Courier New", monospace; font-size: .85rem; }
.backup-circuito { margin-top: 1.8rem; border: 1px solid var(--linea); border-radius: 10px; padding: .7rem 1rem; max-width: 800px; }
.backup-circuito summary { cursor: pointer; font-weight: 600; color: var(--azul); font-size: .93rem; }
.backup-circuito-cuerpo { margin-top: .6rem; }
.backup-circuito-cuerpo ul { margin: 0; padding-left: 1.4rem; display: flex; flex-direction: column; gap: .4rem; font-size: .9rem; color: var(--tinta); }
.aviso-origen { margin-bottom: .5rem; }

/* Branding (galería + asignaciones)
   --------------------------------------------------------------------------- */
.branding-seccion { margin-bottom: 2.4rem; }
.branding-subir { display: flex; flex-direction: column; gap: .8rem; max-width: 640px; margin-bottom: 1.4rem; }
.branding-nombre-fila { display: flex; align-items: flex-end; gap: .8rem; flex-wrap: wrap; }
.branding-nombre-label { display: flex; flex-direction: column; gap: .25rem; font-size: .88rem; flex: 1 1 200px; }
.branding-nombre-input { padding: .45rem .65rem; border: 1px solid var(--linea); border-radius: 8px; font-size: .95rem; background: #fff; }
.branding-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 1rem; margin-top: .8rem; }
.branding-item { background: #fff; border: 1px solid var(--linea); border-radius: 10px; overflow: hidden; display: flex; flex-direction: column; }
.branding-thumb { height: 110px; display: flex; align-items: center; justify-content: center; background: #f4f5f7; padding: .5rem; }
.branding-img { max-width: 100%; max-height: 100%; object-fit: contain; }
.branding-sin-img { font-size: .8rem; color: #8595a8; }
.branding-item-info { padding: .5rem .65rem; flex: 1; display: flex; flex-direction: column; gap: .15rem; }
.branding-item-nombre { font-size: .88rem; font-weight: 600; word-break: break-word; }
.branding-item-fecha { font-size: .78rem; color: #8595a8; }
.branding-item form { padding: .4rem .65rem .55rem; border-top: 1px solid var(--linea); display: flex; justify-content: flex-end; }
.branding-vacio { margin-top: .8rem; }
.branding-asignaciones-lista { display: flex; flex-direction: column; gap: .8rem; margin-top: .6rem; }
.branding-asig-fila { background: #fff; border: 1px solid var(--linea); border-radius: 10px; padding: .85rem 1rem; display: grid; grid-template-columns: minmax(0,2fr) minmax(0,1fr) auto; align-items: center; gap: 1rem; }
.branding-asig-info { display: flex; flex-direction: column; gap: .2rem; }
.branding-asig-info strong { font-size: .95rem; }
.branding-asig-info .nota { margin: 0; }
.branding-asig-actual { display: flex; align-items: center; gap: .5rem; }
.branding-asig-preview { display: flex; align-items: center; gap: .5rem; }
.branding-asig-thumb { width: 40px; height: 40px; object-fit: contain; border-radius: 6px; background: #f4f5f7; border: 1px solid var(--linea); }
.branding-asig-nombre { font-size: .88rem; font-weight: 600; }
.branding-sin-asig { color: #8595a8; font-size: .88rem; }
.branding-asig-form { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; }
.branding-asig-select { padding: .38rem .55rem; border: 1px solid var(--linea); border-radius: 8px; font-size: .9rem; background: #fff; color: var(--tinta); }
.branding-asig-btn { white-space: nowrap; }
@media (max-width: 800px) { .branding-asig-fila { grid-template-columns: 1fr; } }

/* Logo de branding en el sidebar (LOGO_WEB asignado) */
.brand-logo { padding: .45rem .5rem 1rem; }
.brand-logo-img { height: 36px; width: auto; object-fit: contain; display: block; max-width: 190px; }
.brand-logo-fallback { display: flex; align-items: center; gap: .55rem; font-weight: 700; font-size: 1.1rem; color: #fff; }

/* Importar / Exportar (Configuración) */
.importexport-tabs { margin-top: 1rem; }
.importexport-muestra { margin-bottom: 1.2rem; }
.importexport-muestra table { font-size: .88rem; }
.importexport-mapeo { max-width: 760px; }
.importexport-mapeo th[scope=row] { text-align: left; font-weight: 500; white-space: normal; }
.importexport-mapeo select { width: 100%; }
.importexport-errores { margin-top: 1rem; }
.importexport-errores summary { cursor: pointer; font-weight: 600; }
.importexport-errores table { margin-top: .6rem; font-size: .9rem; }
.obligatorio { color: #c0392b; font-weight: 700; }
.aviso-proximamente { background: #fff; border: 1px dashed var(--linea); border-radius: 12px; padding: 1.4rem 1.6rem; max-width: 640px; color: #5a6b80; }
.aviso-proximamente h2 { margin-top: 0; color: var(--tinta); }

/* Pestaña Exportar (F5): selector de entidad/formato/fechas + lista de columnas reordenable. */
.export-config { display: flex; flex-wrap: wrap; gap: 1rem; align-items: flex-end; margin-bottom: 1rem; }
.export-config label { display: flex; flex-direction: column; gap: .25rem; font-size: .9rem; }
.export-config select, .export-config input[type=date] { min-width: 180px; }
.export-columnas { list-style: none; margin: .4rem 0 1rem; padding: 0; max-width: 620px; border: 1px solid var(--linea); border-radius: 10px; overflow: hidden; }
.export-columna { display: flex; align-items: center; justify-content: space-between; gap: .6rem; padding: .4rem .8rem; border-bottom: 1px solid var(--linea); }
.export-columna:last-child { border-bottom: 0; }
.export-columna-check { display: flex; align-items: center; gap: .55rem; flex: 1; font-size: .95rem; cursor: pointer; }
.export-columna-check input[type=checkbox] { width: auto; }
.export-columna-orden { display: inline-flex; gap: .25rem; }
.export-columna-orden .btn-mini { background: #eef2f7; color: var(--azul); }
.export-columna-orden .btn-mini:hover { background: #dde6f1; }
.export-acciones { margin: .6rem 0 1.4rem; }
.export-guardar { margin-top: 1rem; padding-top: 1rem; border-top: 1px solid var(--linea); max-width: 620px; }

/* Conexión al cloud (escritorio) */
.ayuda-bloque { background: var(--gris); border: 1px solid var(--linea); border-radius: 8px; padding: .7rem .9rem; margin: 0 0 1rem; color: var(--tinta); max-width: 720px; font-size: .9rem; }
.aviso-reinicio { background: #fff7e6; border: 1px solid #e7c98a; color: var(--ambar); border-radius: 8px; padding: .7rem .9rem; margin: 0 0 1rem; max-width: 720px; }
.campo-radio { display: inline-flex; align-items: center; gap: .4rem; margin-right: 1.4rem; cursor: pointer; }
.campo-radio input { width: auto; margin: 0; }
.form-acciones { margin: 1rem 0 1.4rem; }

/* Pantallas de programa: Acerca de, EULA, Aviso legal, Privacidad del software */
.doc-legal { max-width: 760px; }
.doc-legal h2 { margin: 1.4rem 0 .4rem; font-size: 1.1rem; }
.doc-legal p, .doc-legal li { line-height: 1.6; }
.doc-legal ul { padding-left: 1.3rem; }

/* Pie del sidebar con versión y enlaces legales (solo escritorio) */
.pie-legal { font-size: .7rem; color: #9fb2cc; padding: .4rem .6rem .25rem; }
.pie-legal a { color: #9fb2cc; text-decoration: underline; }
.pie-legal a:hover { color: #cde; }
.pie-legal-sep { margin: 0 .25rem; }
