*,
*::before,
*::after {
    outline: none !important;
    box-shadow: none !important;
}

a:focus,
button:focus,
input:focus,
textarea:focus,
select:focus {
    outline: none !important;
    box-shadow: none !important;
}

.carousel-inner {
    margin-top: 90px !important;
}

.custom-margin {
    margin-left: 100px;
}

#header-carousel {
    height: 100vh !important;
    overflow: hidden !important;
    position: relative !important;
}

.carousel-item {
    height: 100vh !important;
    position: relative !important;
    width: 100% !important;
}

.carousel-item iframe, 
.carousel-item video,
.carousel-item img {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    z-index: 1 !important;
}

.carousel-caption {
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    text-align: center !important;
    width: 100% !important;
    z-index: 2 !important;
    background: transparent !important;
}

.carousel-caption h1, 
.carousel-caption h3 {
    margin: 0 !important;
}

.carousel-caption .btn {
    margin-top: 20px !important;
    text-transform: uppercase !important;
    font-weight: bold !important;
}

@media (max-width: 767px) {
    .carousel-caption h1 {
        font-size: 2rem !important;
    }

    .carousel-caption h3 {
        font-size: 1.2rem !important;
    }

    .carousel-caption .btn {
        padding: 10px 20px !important;
    }
}

@media only screen and (max-width: 375px) {
    .carousel-inner {
        margin-top: 0 !important;
    }

    .titulo__banner {
        font-size: 34px !important;
    }

    .descricao__banner {
        font-size: 16px !important;
    }

    #header-carousel {
        height: 50vh !important;
    }

    .carousel-item iframe, 
    .carousel-item video,
    .carousel-item img {
        height: 100vh !important;
    }
}

@media only screen and (max-width: 640px) {
    .carousel-inner {
        display: block !important;
    }
    .carousel-indicators {
        display: block !important;
    }

    #header-carousel {
        height: 50vh !important;
    }

    .carousel-item iframe, 
    .carousel-item video,
    .carousel-item img {
        height: 50vh !important;
    }
}

@media only screen and (min-width: 376px) and (max-width: 1000px) {
    .carousel-inner {
        margin-top: 0 !important;
    }

    #header-carousel {
        height: 100vh !important;
    }

    .carousel-item iframe, 
    .carousel-item video,
    .carousel-item img {
        height: 100% !important;
    }
}
