/*
Theme Name: Viero Odontologia
Theme URI: http://example.com/viero-odontologia
Author: Your Name
Author URI: http://example.com
Description: A custom theme for Viero Odontologia
Version: 1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: viero-odontologia
Tags: custom-theme, responsive, dental
*/

/*Estilos para mobile - tablet*/

@media (max-width: 991px) {
    .header {
        height: 100vh;
        /* Ajuste conforme necessário */
        overflow: hidden;
        /* Garante que o conteúdo não ultrapasse a área visível */

    }

    .header .sorriso-header-mobile {
        position: relative !important;
        top: auto !important;
        border-top-right-radius: 50% !important;
        border-top-left-radius: 50% !important;
        border-bottom-right-radius: 0% !important;
        border-bottom-left-radius: 0% !important;
        width: 100% !important;
        height: 100% !important;
        object-fit: cover;
    }

    .img-header-mask-mobile {
        display: flex !important;
        width: 100% !important;
        height: 100% !important;
        align-items: center;
        justify-content: center;
    }

    .img-header-mask-desktop {
        display: none;
    }

    .header .slogan {
        font-size: 40px;
        font-weight: 500;
        color: white;
    }

    .navbar-toggler {
        background-color: #ffffff;
    }

    .mt-4 {
        margin-bottom: 15px !important;
    }

    .btn {
        font-size: small;
    }

    .map {
        height: 200px !important;
    }

    .footer-logo {
        display: flex;
        justify-content: center;
        align-items: center !important;

    }

    .footer-logo img {
        width: 50%;
    }

    .contact-box {
        height: 100% !important;
        overflow: scroll;
        max-width: 400px !important;
        transform: none !important;
        margin-top: 20px !important;
        top: -10px !important;
    }


}


/*Estilos somente para mobile */
@media (max-width: 768px) {
    .contact-box {
        max-width: 100% !important;
        position: static !important;
        transform: none !important;
        margin-top: 20px !important;
    }
    .contact-image{
        display: none;
    }
}


/*Estilos para desktop*/

/* Custom styles that are not covered by Bootstrap */
body {
    color: white;
}

.hero-image img {
    max-width: 200px;
    /* Ajuste conforme necessário */
    margin-bottom: 10px;
    /* Espaçamento entre a imagem e o menu */
}

.hero-text h1 {
    font-size: 40px;
    margin-bottom: 20px6
}

.btn.green {
    background-color: #20C35A;
    color: white;
}

.btn.phone {
    background-color: white;
    color: #002D56;
}

.hero-image img {
    max-width: 400px;
    border-radius: 15px;
}

.text-withe {
    color: white;
}

.text-black {
    color: black;
}

.header {
    position: relative;
    height: 60vh;
    /* Ajuste conforme necessário */
    /*height: 20% !important;*/
    background-color: #002D56;
}

.sorriso-header-descktop {
    top: 0px;
    position: absolute;
    width: 28%;
    height: 100%;
    z-index: 0;
    object-fit: cover;
    border-bottom-right-radius: 50%;
    border-bottom-left-radius: 50%;
}

.img-header-mask-mobile {
    display: none;
}

#navbarNav {
    z-index: 1;
}

.degrade {
    background: linear-gradient(to bottom, #034279 19%, rgba(3, 46, 84, 0) 81%);
    z-index: 1;
}

.slogan {
    font-size: 80px;
    font-weight: 700;
    color: white;
}


.card-img-top {
    width: 20%;
    height: 20%;
}

section {
    padding-top: 1%;
}

.carousel-control-prev {
    color: black !important;
}

.carousel-control-next {
    color: black !important;
}

.card {
    border: none;
}

.map {
    height: 300px;
}

.footer {
    background-color: #0c2c4b;
    padding: 40px 0;
}

.footer-logo {
    font-size: 32px;
    font-weight: bold;
    color: #c9985c;
    font-family: serif;
}

.footer-logo span {
    color: white;
}

.footer a {
    color: white;
    text-decoration: none;
}

.footer a:hover {
    text-decoration: underline;
}

.social-icons i {
    font-size: 20px;
    margin-right: 10px;
    color: white;
}

.container-footer {
    padding-bottom: 15px !important;
}

footer {
    padding-bottom: 0px !important;
}

footer .list {
    list-style: none !important;
    /* Remove as bolinhas do menu */
    padding: 0 !important;
    /* Remove o padding padrão */
    margin: 0 !important;
    /* Remove a margem padrão */
}

footer .list li {
    margin-bottom: 10px !important;
    /* Adiciona espaçamento entre os itens do menu, se necessário */
}

.title-section {
    font-size: 2rem;
    font-weight: bold;
    color: #002D56;
    /* Azul profissional */
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 10px;
}

.h6 {
    font-size: 1.2rem;
    color: #555;
    font-weight: 400;
    margin-bottom: 30px !important;
}

/**Estilos para a section 1 - procedimentos */
.section-1 {
    padding-bottom: 2.5%;
}

/*stylus para cads procedimentos*/
.custom-card {
    border-radius: 15px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
    overflow: hidden;
    border: none;
    padding: 20px;
    text-align: left;
    background-color: #002d560f;
    min-height: 310px;
}

.custom-card img {
    border-radius: 10px;
    display: block;
    width: 100%;
    margin: 0 auto;
}

.custom-card .card-body {
    padding: 5% 0;
}

.custom-card .card-title {
    font-weight: bold;
    font-size: 1.2rem;
}

.custom-card .card-text {
    color: #6c757d;
    font-size: 0.9rem;
}

/**Estilos para a section 2 - contato */
.section-2 {
    background-color: #CCDDE4;
    padding: 5% 0;
}

/* Estilização geral */
.contact-container {
    background-color: #d4e6f1;
    padding: 60px 0;
    position: relative;
}

/* Imagem */
.contact-image {
    position: relative;
    max-width: 100%;
    border-radius: 12px;
}

/* Formulário sobreposto */
.contact-box {
    background: white;
    padding: 30px;
    border-radius: 12px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    position: absolute;
    right: 10%;
    top: 50%;
    transform: translateY(-50%);
    max-width: 700px;
    width: 100%;
}

/* Inputs com ícones */
.input-group-text {
    background: white;
    border-right: none;
}

.form-control {
    border-left: none;
}

/* Botão estilizado */
.btn-custom {
    background-color: #0c2340;
    color: white;
    border-radius: 8px;
    width: 100%;
}

.btn-custom:hover {
    background-color: #09172d;
}

/**Estilos para a section 3 - por que */
.section-3 {
    padding: 1.5% 0;
}