/* ITV-TACÓGRAFO (Alquileres) — page-specific styles */

/* ── Módulo tag / switcher ── */
.module-tag{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.12);color:rgba(255,255,255,.75);font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:3px 9px;border-radius:12px;border:1px solid rgba(255,255,255,.18);margin-top:6px}
.module-tag-dot{width:6px;height:6px;border-radius:50%;background:#4db8ff;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.module-switcher{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:6px 12px;text-decoration:none;color:var(--text-mid);font-size:.8rem;font-weight:600;transition:all .2s}
.module-switcher:hover{background:var(--volvo-light);color:var(--volvo-accent);border-color:var(--volvo-accent)}
.module-switcher svg{width:15px;height:15px}
.empresa-tabs{display:flex;gap:8px;margin-bottom:24px}
.empresa-tab{padding:8px 20px;border-radius:30px;border:2px solid var(--border);background:#fff;font-family:'Montserrat',sans-serif;font-size:.82rem;font-weight:700;cursor:pointer;transition:all .2s;color:var(--text-mid)}
.empresa-tab.active.talleres{background:var(--volvo-blue);border-color:var(--volvo-blue);color:#fff}
.empresa-tab.active.truck{background:#1a5276;border-color:#1a5276;color:#fff}
.empresa-tab:not(.active):hover{border-color:var(--volvo-accent);color:var(--volvo-accent)}
.tbl{width:100%;border-collapse:collapse;font-size:.85rem}
.tbl th{padding:10px 14px;text-align:left;font-size:.7rem;font-weight:700;letter-spacing:.08em;color:var(--text-light);text-transform:uppercase;background:var(--bg);border-bottom:2px solid var(--border)}
.tbl td{padding:12px 14px;border-bottom:1px solid var(--border);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:#f7f9fc}

/* SEMÁFORO */
.semaforo{display:inline-flex;align-items:center;gap:8px;padding:5px 12px;border-radius:20px;font-size:.78rem;font-weight:700}
.semaforo.ok{background:#d1fae5;color:#065f46}
.semaforo.proxima{background:#fef9c3;color:#92400e}
.semaforo.urgente{background:#fef3c7;color:#b45309}
.semaforo.vencida{background:#fed7d7;color:#c53030}
.semaforo.sin-datos{background:#e2e8f0;color:#718096}
.semaforo-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.semaforo.ok .semaforo-dot{background:#10b981}
.semaforo.proxima .semaforo-dot{background:#f59e0b}
.semaforo.urgente .semaforo-dot{background:#f59e0b;animation:pulser 1s infinite}
.semaforo.vencida .semaforo-dot{background:#ef4444;animation:pulser .7s infinite}
.semaforo.sin-datos .semaforo-dot{background:#a0aec0}
@keyframes pulser{0%,100%{opacity:1}50%{opacity:.2}}

.leyenda{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:20px}
.leyenda-item{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--text-mid)}
.leyenda-dot{width:10px;height:10px;border-radius:50%}

.resp-quien{font-size:.75rem;padding:2px 8px;border-radius:10px;font-weight:600}
.resp-sanfer{background:#dbeafe;color:#1d4ed8}
.resp-cliente{background:#f0fdf4;color:#16a34a}
.resp-na{background:#f1f5f9;color:#94a3b8}

.btn-icon-tbl{background:none;border:none;cursor:pointer;color:var(--text-light);padding:3px;font-size:.85rem;transition:color .2s}
.btn-icon-tbl:hover{color:var(--volvo-accent)}
.itv-modal{position:fixed;inset:0;background:rgba(0,30,60,.55);backdrop-filter:blur(4px);z-index:500;display:none;align-items:center;justify-content:center}
.itv-modal.open{display:flex}
.itv-mbox{background:#fff;border-radius:16px;padding:28px 32px;width:100%;max-width:560px;box-shadow:0 24px 60px rgba(0,30,87,.2);max-height:90vh;overflow-y:auto}
.itv-mhdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.itv-mhdr h3{font-size:1.05rem;font-weight:700}
.itv-mcls{background:none;border:none;cursor:pointer;color:var(--text-light);font-size:1.3rem}
.itv-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.itv-ff label{display:block;font-size:.68rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-mid);margin-bottom:4px}
.itv-ff input,.itv-ff select{width:100%;padding:8px 11px;border:1.5px solid var(--border);border-radius:8px;font-family:'Montserrat',sans-serif;font-size:.87rem;outline:none;transition:border-color .2s}
.itv-ff input:focus,.itv-ff select:focus{border-color:var(--volvo-accent)}
.itv-mftr{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}
.itv-full{grid-column:1/-1}
#itv-toast{position:fixed;bottom:24px;right:24px;z-index:9999}

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE ADDITIONS — alq-itv.css
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  .empresa-tabs { flex-wrap: wrap; gap: 6px; margin-bottom: 16px; }
  .empresa-tab { padding: 6px 14px; font-size: .78rem; }
  .leyenda { gap: 10px; }
  .leyenda-item { font-size: .72rem; }
  .tbl th { padding: 8px 10px; font-size: .62rem; }
  .tbl td { padding: 9px 10px; font-size: .8rem; }
  .semaforo { padding: 3px 9px; font-size: .72rem; }
  .itv-mbox { padding: 20px 18px; margin: 12px; width: calc(100% - 24px); max-height: 88vh; }
  .itv-grid { grid-template-columns: 1fr; }
  .itv-mhdr h3 { font-size: .95rem; }
  .module-switcher { font-size: .75rem; padding: 5px 10px; }
}
@media (max-width: 480px) {
  .empresa-tab { flex: 1; text-align: center; padding: 5px 8px; font-size: .72rem; }
  .empresa-tabs { gap: 4px; }
  .tbl th:nth-child(4), .tbl td:nth-child(4),
  .tbl th:nth-child(5), .tbl td:nth-child(5) { display: none; }
  .semaforo-dot { width: 6px; height: 6px; }
  .leyenda { gap: 8px; }
  .resp-sanfer, .resp-cliente, .resp-na { font-size: .68rem; padding: 1px 6px; }
}
