/* CSS mínimo para index.php (Consulta Individual) */

:root {
  --bg: #000000;
  --card: #097237;
  --btn: #0b3d1f;
  --btnHover: #062713;
  --text: #ffffff;
  --error: #ffcccc;
  --success: #d4ffd4;
}

html,
body {
  height: 100%;
}

/* Cuando hay resultados extensos, evitamos centrar verticalmente para no “cortar” contenido */
body.has-results {
  align-items: flex-start;
  justify-content: center;
  padding-top: 16px;
  padding-bottom: 16px;
}

body {
  margin: 0;
  padding: 0;
  font-family: Arial, Helvetica, sans-serif;
  background-color: var(--bg);

  /* Mejor altura real en mobile */
  min-height: 100vh;
  min-height: 100dvh;

  /* Centrado tipo app */
  display: flex;
  align-items: center;
  justify-content: center;

  /* Safe areas */
  padding: env(safe-area-inset-top) env(safe-area-inset-right)
           env(safe-area-inset-bottom) env(safe-area-inset-left);
}

.container {
  width: calc(100% - 24px);
  margin: 12px;
  padding: 28px 22px;
  background-color: var(--card);
  border-radius: 16px;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.45);
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 72dvh;
  color: var(--text);
}

/* Contenedor ancho para resultados (desktop) */
.container--wide {
  text-align: left;
  padding: 22px 18px;
}

.logo img {
  max-width: 190px;
  margin: 0 auto 18px auto;
  display: block;
}

h1 {
  margin: 0 0 22px 0;
  font-size: 22px;
  line-height: 1.2;
  color: var(--text);
}

.formulario {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 14px;
}

.grupo-campo {
  width: 100%;
  display: flex;
  flex-direction: column;
  margin: 0;
}

.grupo-campo label {
  margin-bottom: 8px;
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
  text-align: left;
  opacity: 0.95;
}

.formulario .campo {
  width: 100%;
  box-sizing: border-box;
  font-size: 16px; /* evita zoom iOS */
  padding: 14px 14px;
  border: none;
  border-radius: 12px;
  outline: none;
  background: rgba(255, 255, 255, 0.95);
}

.formulario .campo:focus {
  box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.18);
}

.formulario button {
  width: 100%;
  box-sizing: border-box;
  font-size: 17px;
  font-weight: 800;
  padding: 16px 14px;
  border: none;
  border-radius: 14px;
  cursor: pointer;
}

.formulario .btn-validar {
  background-color: var(--btn);
  color: var(--text);
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.25);
}

.formulario .btn-validar:hover {
  background-color: var(--btnHover);
}

.formulario .btn-validar:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

.formulario .btn-nueva {
  background: rgba(255, 255, 255, 0.15);
  color: var(--text);
}

.formulario .btn-nueva:hover {
  background: rgba(255, 255, 255, 0.22);
}

.error {
  color: var(--error);
  margin-top: 10px;
  font-weight: 800;
}

.success {
  color: var(--success);
  margin-top: 10px;
  font-weight: 800;
}

/* El bloque del pasajero se imprime con success + pasajero-card */
.pasajero-card {
  margin-top: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(0, 0, 0, 0.15);
  text-align: left;
}

/* ==========================
   Resultados (SP): Cards (mobile) / Tabla (desktop)
   ========================== */

.results-section {
  margin-top: 16px;
}

.results-header {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 12px;
}

.results-title {
  font-size: 18px;
  font-weight: 900;
}

.results-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 14px;
  opacity: 0.95;
}

.results-btn {
  width: 100%;
}

/* Badge Estado */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  font-weight: 900;
  font-size: 12px;
  line-height: 1;
  background: rgba(255, 255, 255, 0.18);
  color: #fff;
  white-space: nowrap;
}

.estado-paga { background: rgba(255, 255, 255, 0.22); }
.estado-atrasada { background: rgba(0, 0, 0, 0.25); }
.estado-pendiente { background: rgba(255, 255, 255, 0.16); }
.estado-otro { background: rgba(255, 255, 255, 0.14); }

/* Mobile cards */
.results-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

.deuda-card {
  background: rgba(0, 0, 0, 0.15);
  border-radius: 14px;
  padding: 12px 12px;
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.18);
}

.deuda-card__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.deuda-card__viaje {
  font-weight: 900;
  font-size: 16px;
  line-height: 1.2;
}

.deuda-card__main {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  padding: 10px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.08);
  margin-bottom: 10px;
}

.deuda-card__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.kv .k {
  font-size: 12px;
  opacity: 0.9;
  font-weight: 800;
}

.kv .v {
  font-size: 14px;
  font-weight: 900;
  margin-top: 2px;
}

.v--money {
  font-variant-numeric: tabular-nums;
}

/* Desktop table (se oculta en mobile) */
.results-table {
  display: none;
}

.results-table-wrap {
  background: rgba(255, 255, 255, 0.06);
  border-radius: 14px;
  padding: 8px;
  overflow: auto;
  max-height: 62vh;
}

.deuda-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 760px;
}

.deuda-table th,
.deuda-table td {
  padding: 10px 10px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  vertical-align: top;
}

.deuda-table th {
  position: sticky;
  top: 0;
  z-index: 1;
  text-align: left;
  font-size: 13px;
  font-weight: 900;
  background: rgba(0, 0, 0, 0.18);
}

.th-right, .td-right { text-align: right; }
.th-center, .td-center { text-align: center; }

.deuda-table tbody tr:hover {
  background: rgba(0, 0, 0, 0.10);
}

/* ==========================
   Loader / Spinner (index.php)
   ========================== */

#loader-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.65);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
}

.loader-box {
  background: var(--card);
  border-radius: 16px;
  padding: 28px 32px;
  text-align: center;
  box-shadow: 0 12px 35px rgba(0, 0, 0, 0.6);
}

.spinner {
  width: 46px;
  height: 46px;
  margin: 0 auto 14px auto;
  border: 4px solid rgba(255, 255, 255, 0.25);
  border-top-color: #ffffff;
  border-radius: 50%;
  animation: spin 0.9s linear infinite;
}

.loader-text {
  color: #ffffff;
  font-size: 15px;
  font-weight: 700;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* Desktop */
@media (min-width: 768px) {
  .container {
    width: 420px;
    padding: 30px;
    border-radius: 12px;
    min-height: auto;
    display: block;
    box-shadow: 0 12px 35px rgba(0, 0, 0, 0.6);
  }

  .logo img {
    max-width: 220px;
    margin-bottom: 20px;
  }

  h1 {
    font-size: 24px;
    margin-bottom: 25px;
  }

  .formulario {
    gap: 12px;
    align-items: center;
  }

  .formulario .campo {
    font-size: 14px;
    padding: 10px 10px;
    border-radius: 10px;
  }

  .formulario button {
    font-size: 15px;
    padding: 12px;
    border-radius: 10px;
  }

  .formulario .btn-validar {
    box-shadow: none;
  }

  /* Resultados: tabla en desktop, cards ocultas */
  .container--wide {
    width: min(980px, 96vw);
    padding: 24px 22px;
    text-align: left;
  }

  .results-header {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }

  .results-meta {
    justify-content: flex-end;
  }

  .results-cards {
    display: none;
  }

  .results-table {
    display: block;
  }
}


#btnNueva2 {
    padding: 12px 16px;
    max-width: 160px;
}

#btnNueva {
    padding: 12px 16px;
    max-width: 160px;
}