/* CLIENTES (Alquileres) — page-specific styles */

/* ── KPI bar ── */
.kpi-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:22px}
.kpi-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:16px 18px;display:flex;flex-direction:column;gap:4px}
.kpi-label{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-light)}
.kpi-val{font-size:1.55rem;font-weight:700;color:var(--text-dark)}
.kpi-sub{font-size:.72rem;color:var(--text-light)}

/* ── Grid de clientes ── */
.clientes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:16px}
.cliente-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:20px;display:flex;flex-direction:column;gap:12px;transition:box-shadow .2s,border-color .2s;cursor:pointer}
.cliente-card:hover{box-shadow:0 4px 20px rgba(0,30,87,.10);border-color:var(--volvo-accent)}
.cliente-card.empresa-talleres{border-left:4px solid var(--volvo-blue)}
.cliente-card.empresa-truck{border-left:4px solid #1a5276}
.cliente-card.empresa-ambas{border-left:4px solid #6b21a8}
.cc-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.cc-avatar{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;color:#fff;flex-shrink:0}
.cc-avatar.talleres{background:var(--volvo-blue)}
.cc-avatar.truck{background:#1a5276}
.cc-avatar.ambas{background:#6b21a8}
.cc-info{flex:1;min-width:0}
.cc-nombre{font-size:.9rem;font-weight:700;color:var(--text-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cc-sub{font-size:.73rem;color:var(--text-light);margin-top:2px}
.cc-actions{display:flex;gap:4px;flex-shrink:0}
.cc-datos{display:flex;flex-direction:column;gap:5px}
.cc-dato{display:flex;align-items:center;gap:7px;font-size:.78rem;color:var(--text-mid)}
.cc-dato i{width:14px;color:var(--text-light);font-size:.75rem}
.cc-footer{display:flex;gap:7px;flex-wrap:wrap;margin-top:2px}
.cc-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:10px;font-size:.68rem;font-weight:700}
.cc-badge.talleres{background:#e8f0fe;color:var(--volvo-blue)}
.cc-badge.truck{background:#d6eaf8;color:#1a5276}
.cc-badge.contratos{background:#d1fae5;color:#065f46}
.cc-badge.historico{background:#fef3c7;color:#92400e}

/* ── Botones ── */
.btn-danger{background:#e53e3e;color:#fff}
.btn-danger:hover{background:#c53030}
.btn-icon.danger:hover{color:#e53e3e;background:#fff5f5}

/* ── Form grid (compact) ── */
.fg{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fg .full{grid-column:1/-1}
.ff{display:flex;flex-direction:column}
.ff label{font-size:.68rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-mid);margin-bottom:4px}
.ff input,.ff select,.ff textarea{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;box-sizing:border-box}
.ff input:focus,.ff select:focus,.ff textarea:focus{border-color:var(--volvo-accent)}
.ff textarea{resize:vertical;min-height:70px}

/* ── Modal detalle ── */
.det-header{display:flex;align-items:center;gap:14px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}
.det-avatar{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:700;color:#fff}
.det-nombre{font-size:1.1rem;font-weight:700;color:var(--text-dark)}
.det-sub{font-size:.78rem;color:var(--text-light);margin-top:2px}
.det-section{margin-bottom:18px}
.det-section-title{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-light);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.det-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.det-item{display:flex;flex-direction:column;gap:2px}
.det-item-label{font-size:.65rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-light)}
.det-item-val{font-size:.85rem;color:var(--text-dark);font-weight:500}
.contrato-mini{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:9px 12px;display:flex;align-items:center;justify-content:space-between;font-size:.78rem;margin-bottom:6px}
.contrato-mini:last-child{margin-bottom:0}
.badge-activo{background:#d1fae5;color:#065f46;padding:2px 8px;border-radius:8px;font-size:.7rem;font-weight:700}
.badge-hist{background:#fef3c7;color:#92400e;padding:2px 8px;border-radius:8px;font-size:.7rem;font-weight:700}

/* ── Toast ── */
#toast-cnt{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{padding:11px 18px;border-radius:10px;font-size:.84rem;font-weight:600;font-family:'Montserrat',sans-serif;box-shadow:0 4px 16px rgba(0,0,0,.15);color:#fff;transition:opacity .3s}
.toast.success{background:#38a169}
.toast.error{background:#e53e3e}
.toast.info{background:#3182ce}

/* ── Toggle vista ── */
.vista-toggle{display:flex;gap:6px}
.vista-btn{background:var(--bg);border:1.5px solid var(--border);border-radius:7px;padding:6px 10px;cursor:pointer;color:var(--text-light);font-size:.85rem;transition:all .2s}
.vista-btn.active{background:var(--volvo-accent);border-color:var(--volvo-accent);color:#fff}

@media(max-width:768px){.clientes-grid{grid-template-columns:1fr}.fg{grid-template-columns:1fr}.det-grid{grid-template-columns:1fr}}

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE ADDITIONS — alq-clientes.css
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  .clientes-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .kpi-strip { grid-template-columns: repeat(2, 1fr); }
  .clientes-grid { grid-template-columns: 1fr; }
  .fg { grid-template-columns: 1fr; }
  .det-grid { grid-template-columns: 1fr; }
  .det-header { flex-direction: column; align-items: flex-start; gap: 10px; }
  .det-avatar { width: 44px; height: 44px; font-size: 1.1rem; }
  .cc-head { flex-wrap: wrap; }
  .cc-actions { flex-shrink: 0; }
  .cc-badge { font-size: .63rem; padding: 2px 7px; }
  .vista-toggle { display: none; }
}
@media (max-width: 480px) {
  .kpi-strip { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .kpi-val { font-size: 1.3rem; }
  .cliente-card { padding: 14px 16px; }
  .cc-nombre { font-size: .85rem; }
  .fg { gap: 8px; }
  .ff input, .ff select, .ff textarea { padding: 7px 10px; font-size: .83rem; }
  .contrato-mini { padding: 7px 10px; font-size: .75rem; }
  #toast-cnt { right: 12px; left: 12px; bottom: 12px; }
}
