/**
 * Estilos del Plugin Próximos Autobuses
 * Basado en el plugin horarios_autobus
 */

* {
    font-family: 'Nunito', sans-serif;
}

.pa-proximos-wrapper {
    max-width: 900px !important;
    margin: 40px auto !important;
    padding: 0 !important;
    background: transparent !important;
}

/* Tabs */
.pa-tabs-container {
    display: flex !important;
    gap: 10px !important;
    margin-bottom: 0 !important;
}

.pa-tablink {
    background-color: #f1f1f1 !important;
    border: none !important;
    padding: 18px 25px !important;
    cursor: pointer !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    color: #cc417a !important;
    /* Rosa/Granate para inactivos */
    border-radius: 8px 8px 0 0 !important;
    flex: 1 !important;
    text-align: center !important;
    transition: all 0.3s ease !important;
    position: relative !important;
    text-transform: uppercase !important;
    box-shadow: none !important;
    outline: none !important;
}

.pa-tablink.active {
    background-color: #8fc33a !important;
    color: white !important;
}

/* Triángulo debajo del tab activo */
.pa-tablink.active::after {
    content: "" !important;
    position: absolute !important;
    bottom: -12px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    border-width: 8px !important;
    border-style: solid !important;
    border-color: #8fc33a transparent transparent transparent !important;
    z-index: 20 !important;
}

/* Contenido de Tabs */
.pa-tabcontent {
    display: none !important;
}

.pa-tabcontent.active {
    display: block !important;
}

/* Tarjeta (Card) */
.pa-info-card {
    background-color: #ffffff !important;
    border-radius: 0 10px 10px 10px !important;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1) !important;
    overflow: hidden !important;
    border: 1px solid #eee !important;
    position: relative !important;
    z-index: 10 !important;
}

.pa-scroll-container {
    max-height: 480px !important;
    overflow-y: auto !important;
}

/* Tabla */
.pa-tabla-proximos {
    width: 100% !important;
    border-collapse: collapse !important;
    margin: 0 !important;
    background-color: #ffffff !important;
}

.pa-tabla-proximos thead {
    border-bottom: 2px solid #f1f1f1 !important;
    background-color: #ffffff !important;
}

.pa-tabla-proximos th {
    padding: 15px 20px !important;
    text-align: left !important;
    color: #8fc33a !important;
    font-weight: 700 !important;
    font-size: 13px !important;
    text-transform: uppercase !important;
    border: none !important;
    background-color: #ffffff !important;
}

.pa-tabla-proximos td {
    padding: 16px 20px !important;
    font-weight: 500 !important;
    font-size: 15px !important;
    color: #004c97 !important;
    /* Azul para el destino */
    vertical-align: middle !important;
    border: none !important;
}

/* Centrar la columna de hora/tiempo */
.pa-tabla-proximos th:first-child,
.pa-tabla-proximos td:first-child {
    text-align: center !important;
}

/* Fila Zebra sutil */
.pa-tabla-proximos tbody tr:nth-child(even) {
    background-color: #f8f9fa !important;
}

.pa-tabla-proximos tbody tr:nth-child(odd) {
    background-color: #ffffff !important;
}

/* El texto de la última celda (hora) puede ser diferente si se desea */
.pa-tabla-proximos td:last-child {
    font-weight: 600 !important;
    text-align: center !important;
}

/* Chips circulares para Línea y Andén */
.pa-celda-chip {
    text-align: center !important;
}

.pa-chip-circulo {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 34px !important;
    height: 34px !important;
    padding: 0 10px !important;
    border-radius: 999px !important;
    background-color: #8fc33a !important;
    color: #ffffff !important;
    font-weight: 700 !important;
    font-size: 13px !important;
    line-height: 1 !important;
}

.pa-chip-linea {
    width: auto !important;
    min-width: 44px !important;
    height: 28px !important;
    padding: 0 10px !important;
    border-radius: 8px !important;
    font-size: 12px !important;
}

.pa-linea-compania {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
}

.pa-linea-logo {
    width: 72px !important;
    height: 28px !important;
    border-radius: 6px !important;
    background: #ffffff !important;
    border: 1px solid #e2e8f0 !important;
    overflow: hidden !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 3px 5px !important;
}

.pa-linea-logo img {
    width: auto !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: 100% !important;
    object-fit: contain !important;
    object-position: center center !important;
    display: block !important;
}

/* Scrollbar */
.pa-scroll-container::-webkit-scrollbar {
    width: 6px !important;
}

.pa-scroll-container::-webkit-scrollbar-track {
    background: #f1f1f1 !important;
}

.pa-scroll-container::-webkit-scrollbar-thumb {
    background: #8fc33a !important;
    border-radius: 10px !important;
}

.pa-no-results {
    padding: 30px !important;
    text-align: center !important;
    color: #666 !important;
}

/* Hora con retraso */
.pa-hora-retraso {
    color: #d9534f !important;
}

.pa-retraso {
    font-size: 12px !important;
    color: #d9534f !important;
    font-weight: 600 !important;
}

/* Nuevo estilo de hora con tiempo restante */
.pa-hora-container {
    display: inline-flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    line-height: 1.2 !important;
    text-align: center !important;
    width: 100% !important;
    gap: 2px !important;
}

.pa-tiempo-restante {
    font-size: 9px !important;
    font-weight: 400 !important;
    /*text-transform: uppercase;*/
}

/* Colores del tiempo restante */
.pa-tiempo-rojo {
    color: #dc3545 !important;
}

.pa-tiempo-amarillo {
    color: #ffc107 !important;
}

.pa-tiempo-verde {
    color: #28a745 !important;
}

.pa-tiempo-ahora {
    font-size: 11px !important;
    color: #28a745 !important;
    font-weight: 700 !important;
    text-transform: uppercase;
}

.pa-tiempo-retraso {
    font-size: 11px !important;
    color: #dc3545 !important;
    font-weight: 700 !important;
    text-transform: uppercase;
}

.pa-hora-texto {
    font-size: 15px !important;
    color: #004c97 !important;
    font-weight: 600 !important;
}

.pa-destino-container {
    display: flex;
    flex-direction: column;
    gap: 3px !important;
}

.pa-paradas-list {
    font-size: 9px !important;
    color: #64748b !important;
    font-weight: 500 !important;
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    width: fit-content !important;
    cursor: pointer !important;
    padding: 1px 0 !important;
}

.pa-paradas-list::after {
    content: attr(data-tooltip) !important;
    position: absolute !important;
    left: 50% !important;
    bottom: calc(100% + 10px) !important;
    transform: translateX(-50%) translateY(4px) !important;
    width: min(320px, 80vw) !important;
    max-height: 220px !important;
    overflow-y: auto !important;
    padding: 12px 14px !important;
    border-radius: 12px !important;
    background: linear-gradient(155deg, rgba(15, 23, 42, 0.98) 0%, rgba(30, 41, 59, 0.98) 100%) !important;
    color: #f8fafc !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    line-height: 1.45 !important;
    white-space: pre-line !important;
    text-align: left !important;
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.35) !important;
    border: 1px solid rgba(148, 163, 184, 0.25) !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    transition: opacity 0.2s ease, transform 0.2s ease !important;
    z-index: 60 !important;
}

.pa-paradas-list:hover::after,
.pa-paradas-list:focus::after {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateX(-50%) translateY(0) !important;
}

/* Evita recorte en primeras filas: mostrar tooltip hacia abajo */
.pa-tabla-proximos tbody tr:nth-child(-n+2) .pa-paradas-list::after {
    top: calc(100% + 10px) !important;
    bottom: auto !important;
    transform: translateX(-50%) translateY(-4px) !important;
}

.pa-tabla-proximos tbody tr:nth-child(-n+2) .pa-paradas-list:hover::after,
.pa-tabla-proximos tbody tr:nth-child(-n+2) .pa-paradas-list:focus::after {
    transform: translateX(-50%) translateY(0) !important;
}

/* Avisos */
.pa-aviso-icon {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 28px !important;
    height: 28px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(255, 255, 255, 0.55) !important;
    box-shadow: 0 6px 14px rgba(31, 42, 55, 0.16) !important;
    cursor: help !important;
    user-select: none !important;
    transition: transform 0.2s ease, box-shadow 0.2s ease !important;
}

.pa-aviso-icon::before {
    font-size: 14px !important;
    font-weight: 800 !important;
    line-height: 1 !important;
}

.pa-aviso-retraso {
    background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%) !important;
    color: #ffffff !important;
}

.pa-aviso-retraso::before {
    content: "\26A0" !important;
}

.pa-aviso-refuerzo {
    background: linear-gradient(135deg, #facc15 0%, #eab308 100%) !important;
    color: #1f2937 !important;
}

.pa-aviso-refuerzo::before {
    content: "+" !important;
}

.pa-aviso-express {
    background: linear-gradient(135deg, #22d3ee 0%, #0891b2 100%) !important;
    color: #ffffff !important;
}

.pa-aviso-express::before {
    content: "\26A1" !important;
}

.pa-aviso-info {
    background: linear-gradient(135deg, #64748b 0%, #334155 100%) !important;
    color: #ffffff !important;
}

.pa-aviso-info::before {
    content: "i" !important;
}

.pa-aviso-icon::after {
    content: attr(data-tooltip) !important;
    position: absolute !important;
    bottom: calc(100% + 10px) !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    background: rgba(15, 23, 42, 0.96) !important;
    color: #ffffff !important;
    padding: 10px 12px !important;
    border-radius: 10px !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    white-space: normal !important;
    max-width: 260px !important;
    min-width: 160px !important;
    text-align: left !important;
    line-height: 1.35 !important;
    box-shadow: 0 10px 26px rgba(15, 23, 42, 0.28) !important;
    z-index: 50 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    transition: opacity 0.2s ease, transform 0.2s ease !important;
}

.pa-aviso-icon:hover,
.pa-aviso-icon:focus {
    transform: translateY(-1px) !important;
    box-shadow: 0 10px 20px rgba(31, 42, 55, 0.22) !important;
}

.pa-aviso-icon:hover::after,
.pa-aviso-icon:focus::after {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateX(-50%) translateY(-2px) !important;
}

/* Responsivo para Próximas */
@media only screen and (max-width: 768px) {
    .pa-tabs-container {
        flex-direction: column !important;
        gap: 5px !important;
    }

    .pa-tablink {
        border-radius: 8px !important;
        padding: 15px !important;
    }

    .pa-info-card {
        border-radius: 10px !important;
    }

    .pa-tabla-proximos th,
    .pa-tabla-proximos td {
        padding: 10px 12px !important;
        font-size: 13px !important;
    }

    .pa-paradas-list::after {
        left: 0 !important;
        transform: translateY(4px) !important;
        width: min(300px, 86vw) !important;
    }

    .pa-paradas-list:hover::after,
    .pa-paradas-list:focus::after {
        transform: translateY(0) !important;
    }
}
