/* =====================================================
   Bus Escolar PWA — Estilos
   ===================================================== */

:root {
    --azul:       #1a56a0;
    --azul-dark:  #0f3d7a;
    --azul-light: #e8f0fb;
    --verde:      #1a7a4a;
    --verde-light:#e6f4ed;
    --rojo:       #c0392b;
    --rojo-light: #fdecea;
    --naranja:    #d4680a;
    --naranja-light: #fef0e3;
    --gris:       #64748b;
    --gris-light: #f1f5f9;
    --borde:      #e2e8f0;
    --texto:      #1e293b;
    --texto-sub:  #64748b;
    --blanco:     #ffffff;
    --radio:      12px;
    --radio-sm:   8px;
    --sombra:     0 2px 8px rgba(0,0,0,0.08);
}

* { box-sizing: border-box; margin: 0; padding: 0; -webkit-tap-highlight-color: transparent; }

html, body {
    height: 100%;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    background: var(--gris-light);
    color: var(--texto);
    font-size: 15px;
    line-height: 1.5;
}

#app { min-height: 100vh; display: flex; flex-direction: column; }

/* ---- Pantallas ---- */
.pantalla { display: none; flex-direction: column; min-height: 100vh; }
.pantalla.activa { display: flex; }

/* ---- Header ---- */
.header {
    background: var(--azul);
    color: var(--blanco);
    padding: 16px 20px;
    padding-top: calc(16px + env(safe-area-inset-top));
    display: flex;
    align-items: center;
    gap: 12px;
}

.header-icon { font-size: 24px; }
.header-titulo { font-size: 17px; font-weight: 600; }
.header-sub { font-size: 13px; opacity: 0.8; }

.header-btn {
    margin-left: auto;
    background: rgba(255,255,255,0.15);
    border: none;
    color: var(--blanco);
    padding: 6px 14px;
    border-radius: 20px;
    font-size: 13px;
    cursor: pointer;
}

/* ---- Contenido ---- */
.contenido {
    flex: 1;
    padding: 20px 16px;
    padding-bottom: calc(20px + env(safe-area-inset-bottom));
    max-width: 480px;
    width: 100%;
    margin: 0 auto;
}

/* ---- Cards ---- */
.card {
    background: var(--blanco);
    border-radius: var(--radio);
    box-shadow: var(--sombra);
    padding: 20px;
    margin-bottom: 16px;
}

.card-titulo {
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--gris);
    margin-bottom: 14px;
}

/* ---- Login ---- */
.login-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    padding: 32px 24px;
    background: var(--blanco);
}

.login-logo {
    width: 80px;
    height: 80px;
    background: var(--azul-light);
    border-radius: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 36px;
    margin-bottom: 24px;
}

.login-titulo {
    font-size: 22px;
    font-weight: 700;
    color: var(--texto);
    margin-bottom: 6px;
    text-align: center;
}

.login-sub {
    font-size: 14px;
    color: var(--gris);
    text-align: center;
    margin-bottom: 32px;
}

.input-group { margin-bottom: 16px; width: 100%; }
.input-group label { display: block; font-size: 13px; font-weight: 500; margin-bottom: 6px; color: var(--texto); }
.input-group input {
    width: 100%;
    padding: 13px 16px;
    border: 1.5px solid var(--borde);
    border-radius: var(--radio-sm);
    font-size: 16px;
    color: var(--texto);
    background: var(--blanco);
    transition: border-color 0.15s;
    -webkit-appearance: none;
}
.input-group input:focus { outline: none; border-color: var(--azul); }

/* ---- Botones ---- */
.btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 14px 20px;
    border-radius: var(--radio-sm);
    border: none;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: opacity 0.15s, transform 0.1s;
}
.btn:active { transform: scale(0.98); }
.btn:disabled { opacity: 0.5; pointer-events: none; }

.btn-primary   { background: var(--azul);   color: var(--blanco); }
.btn-verde     { background: var(--verde);   color: var(--blanco); }
.btn-rojo      { background: var(--rojo);    color: var(--blanco); }
.btn-outline   { background: var(--blanco);  color: var(--azul); border: 1.5px solid var(--azul); }
.btn-gris      { background: var(--gris-light); color: var(--texto); }
.btn-sm        { padding: 9px 16px; font-size: 13px; width: auto; }

/* ---- Opciones de confirmación ---- */
.opciones { display: grid; gap: 10px; }

.opcion {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px;
    border-radius: var(--radio);
    border: 2px solid var(--borde);
    background: var(--blanco);
    cursor: pointer;
    transition: all 0.15s;
    text-align: left;
}
.opcion:active { transform: scale(0.98); }

.opcion-icono {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    flex-shrink: 0;
}

.opcion-texto strong { display: block; font-size: 15px; font-weight: 600; }
.opcion-texto span   { font-size: 13px; color: var(--gris); }

.opcion.sel-va     { border-color: var(--verde); background: var(--verde-light); }
.opcion.sel-no     { border-color: var(--rojo);  background: var(--rojo-light);  }
.opcion.sel-cambio { border-color: var(--naranja); background: var(--naranja-light); }

.opcion-va     .opcion-icono { background: var(--verde-light); }
.opcion-no     .opcion-icono { background: var(--rojo-light); }
.opcion-cambio .opcion-icono { background: var(--naranja-light); }

/* ---- Selector de viaje ---- */
.viaje-selector { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 10px; }
.viaje-btn {
    padding: 12px;
    border-radius: var(--radio-sm);
    border: 2px solid var(--borde);
    background: var(--blanco);
    cursor: pointer;
    text-align: center;
    font-size: 14px;
    font-weight: 500;
    transition: all 0.15s;
}
.viaje-btn.sel { border-color: var(--naranja); background: var(--naranja-light); color: var(--naranja); }

/* ---- Confirmado banner ---- */
.confirmado-banner {
    background: var(--verde-light);
    border: 1.5px solid var(--verde);
    border-radius: var(--radio);
    padding: 14px 16px;
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    color: var(--verde);
    font-weight: 500;
}

/* ---- Estadísticas conductor ---- */
.stats-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin-bottom: 16px; }
.stat {
    background: var(--blanco);
    border-radius: var(--radio);
    padding: 14px 16px;
    box-shadow: var(--sombra);
}
.stat-num  { font-size: 28px; font-weight: 700; line-height: 1; }
.stat-lbl  { font-size: 12px; color: var(--gris); margin-top: 4px; }
.stat-azul .stat-num   { color: var(--azul); }
.stat-verde .stat-num  { color: var(--verde); }
.stat-rojo .stat-num   { color: var(--rojo); }
.stat-naranja .stat-num{ color: var(--naranja); }

/* ---- Tabla de ruta ---- */
.ruta-grupo { margin-bottom: 16px; }

.ruta-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    background: var(--azul);
    border-radius: var(--radio) var(--radio) 0 0;
    color: var(--blanco);
}
.ruta-header-titulo { font-size: 14px; font-weight: 600; flex: 1; }
.ruta-header-count  { font-size: 13px; opacity: 0.8; }

.ruta-header-rojo { background: var(--rojo); }
.ruta-header-naranja { background: var(--naranja); }

.alumno-fila {
    display: flex;
    align-items: center;
    padding: 11px 14px;
    background: var(--blanco);
    border-bottom: 1px solid var(--borde);
    gap: 12px;
}
.alumno-fila:last-child { border-bottom: none; border-radius: 0 0 var(--radio) var(--radio); }

.alumno-num  { font-size: 12px; color: var(--gris); width: 20px; text-align: center; flex-shrink: 0; }
.alumno-nombre { flex: 1; font-size: 14px; font-weight: 500; }
.alumno-hora { font-size: 13px; color: var(--gris); }
.alumno-tag  { font-size: 11px; padding: 2px 8px; border-radius: 20px; font-weight: 500; }
.tag-cambio  { background: var(--naranja-light); color: var(--naranja); }
.tag-nova    { background: var(--rojo-light); color: var(--rojo); }

/* ---- Textarea WhatsApp ---- */
.wa-box {
    background: var(--gris-light);
    border: 1.5px solid var(--borde);
    border-radius: var(--radio-sm);
    padding: 14px;
    font-family: monospace;
    font-size: 13px;
    line-height: 1.8;
    white-space: pre-wrap;
    word-break: break-word;
    margin-bottom: 10px;
    max-height: 320px;
    overflow-y: auto;
}

/* ---- Tabs del conductor ---- */
.tabs {
    display: flex;
    background: var(--blanco);
    border-top: 1px solid var(--borde);
    padding-bottom: env(safe-area-inset-bottom);
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 100;
}
.tab-btn {
    flex: 1;
    padding: 10px 0 8px;
    border: none;
    background: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 3px;
    cursor: pointer;
    font-size: 11px;
    color: var(--gris);
    transition: color 0.15s;
}
.tab-btn .tab-icon { font-size: 20px; }
.tab-btn.activo { color: var(--azul); }

.con-tabs { padding-bottom: 72px; }

/* ---- Loading ---- */
.loading {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px;
    color: var(--gris);
    font-size: 14px;
    gap: 10px;
}
.spinner {
    width: 20px; height: 20px;
    border: 2px solid var(--borde);
    border-top-color: var(--azul);
    border-radius: 50%;
    animation: spin 0.6s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ---- Error / info ---- */
.alerta {
    padding: 12px 16px;
    border-radius: var(--radio-sm);
    font-size: 13px;
    margin-bottom: 14px;
}
.alerta-error { background: var(--rojo-light); color: var(--rojo); border: 1px solid #f5c6cb; }
.alerta-info  { background: var(--azul-light);  color: var(--azul); border: 1px solid #bee3f8; }

/* ---- Install banner ---- */
.install-banner {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    background: var(--azul);
    color: var(--blanco);
    padding: 14px 20px;
    display: flex;
    align-items: center;
    gap: 12px;
    z-index: 200;
    padding-bottom: calc(14px + env(safe-area-inset-bottom));
}
.install-banner p { flex: 1; font-size: 13px; }
.install-banner button {
    background: var(--blanco);
    color: var(--azul);
    border: none;
    padding: 8px 16px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
}

/* ---- Responsive ---- */
@media (min-width: 480px) {
    .contenido { padding: 24px 20px; }
}

/* ---- Cards de alumnos ---- */
.alumno-card {
    background: var(--blanco);
    border-radius: var(--radio);
    box-shadow: var(--sombra);
    margin-bottom: 10px;
    overflow: hidden;
}

.alumno-card-header {
    display: flex;
    align-items: center;
    padding: 12px 14px;
    gap: 10px;
}

.alumno-card-num {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--azul-light);
    color: var(--azul);
    font-size: 11px;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.alumno-card-info { flex: 1; min-width: 0; }
.alumno-card-nombre { font-size: 14px; font-weight: 600; }
.alumno-card-det { font-size: 12px; color: var(--gris); margin-top: 2px; }

.alumno-card-toggle {
    background: none;
    border: none;
    font-size: 16px;
    color: var(--gris);
    cursor: pointer;
    padding: 4px 8px;
}

.alumno-card-detalle {
    border-top: 1px solid var(--borde);
    padding: 12px 14px;
}

.pin-box {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--gris-light);
    border-radius: var(--radio-sm);
    padding: 10px 12px;
    margin-bottom: 10px;
    flex-wrap: wrap;
}

.pin-label { font-size: 12px; color: var(--gris); flex-shrink: 0; }
.pin-valor {
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 4px;
    color: var(--azul);
    flex: 1;
}

.alumno-card-acciones { display: flex; gap: 8px; flex-wrap: wrap; }

.btn-row { display: flex; gap: 8px; flex-wrap: wrap; }
