.tarifas-wrap {
    background-color: #f7a83d;
}

.section-tarifas-page {
    /* Forzamos que en esta página el padding superior sea adecuado */
    min-height: auto;
    padding-bottom: 8rem;
}

.text-center {
    text-align: center;
}

.mb-5 {
    margin-bottom: 3rem;
}

.font-heading {
    font-family: var(--font-heading);
    font-weight: 700;
    font-style: italic;
}

/* Contenedor en Columna para las 2 tarifas */
.cards-container-vertical {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6rem;
    max-width: 1200px;
    margin: 0 auto;
    position: relative;
    z-index: 5;
    animation: pulseVerticalCards 8s ease-in-out infinite;
}

@keyframes pulseVerticalCards {
    0% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-10px);
    }
    100% {
        transform: translateY(0);
    }
}

.tarifa-vertical {
    width: 600px;
    max-width: 90%;
    transform: scale(1.1);
    margin: 0 auto;
    transition:
        filter 0.4s ease,
        box-shadow 0.4s ease;
    border-radius: 20px;
    /* box-shadow: 0 15px 35px rgba(0, 0, 0, 0.2); */
}

.tarifa-vertical:hover {
    z-index: 10;
    box-shadow: 0 25px 50px rgba(0, 0, 0, 0.3);
}

/* Modificar el tamaño del ribbon de precio de index si la tarjeta es muy grande */
.tarifa-vertical .price-ribbon {
    bottom: -90px;
    transform: translateX(-50%) rotate(-3deg);
    padding: 10px 40px;
}

.tarifa-vertical .price-text {
    font-size: 4rem;
}

.tarifa-vertical .p-mes {
    font-size: 1.8rem;
}

/* Ajustes Responsivos especiales para página tarifas móviles */
@media (max-width: 768px) {
    .tarifa-vertical {
        width: 100%;
        transform: scale(1);
    }
    .tarifa-vertical:hover {
        transform: scale(1.05);
    }
    .cards-container-vertical {
        gap: 5rem;
    }
    .tarifa-vertical .price-ribbon {
        bottom: -70px;
        padding: 5px 20px;
    }
    .tarifa-vertical .price-text {
        font-size: 3rem;
    }
    .tarifa-vertical .p-mes {
        font-size: 1.2rem;
    }
}
