/* Imagens do carousel */
.carousel-image {
    width: 100%;
    max-height: 70vh;      /* Ajusta conforme a altura da tela */
    min-height: 300px;
    object-fit: contain;   /* Mantém a imagem inteira */
    object-position: center;
    border-radius: 24px;
}

/* Controles do Bootstrap */
.carousel-control-prev,
.carousel-control-next {
    width: 8%;
    opacity: 0;
    border: none;
    transition: opacity 0.3s ease;
}

/* Exibe os botões ao passar o mouse */
.carousel:hover .carousel-control-prev,
.carousel:hover .carousel-control-next {
    opacity: 1;
}

/* Remove outline padrão */
.carousel-control-prev:focus,
.carousel-control-next:focus {
    outline: none;
    box-shadow: none;
}

/* Ícones */
.control-circle i {
    font-size: 1.4rem;
    color: white;
    opacity: 0.9;
}

/* Hover */
.control-circle:hover {
    background: rgba(255, 255, 255, 0.4);
    transform: scale(1.08);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12);
}

/* Indicadores */
.carousel-indicators {
    bottom: -50px;
}

.carousel-indicators button {
    width: 10px !important;
    height: 10px !important;

    margin: 0 5px !important;
    border: none !important;
    border-radius: 50%;

    background-color: rgba(0, 0, 0, 0.25) !important;

    transition: all 0.3s ease;
}

.carousel-indicators button.active {
    width: 28px !important;
    border-radius: 20px;

    background-color: rgba(13, 110, 253, 0.9) !important;
}

/* Responsividade */
@media (max-width: 768px) {

    .carousel-image {
        height: 300px;
    }

    /* Mantém os botões visíveis em dispositivos touch */
    .carousel-control-prev,
    .carousel-control-next {
        opacity: 1;
    }

    .control-circle {
        width: 45px;
        height: 45px;
    }

    .control-circle i {
        font-size: 1.2rem;
    }
}
}
