/* Configurações customizadas do NovoNed */

/* Fontes Graphie */
@font-face {
    font-family: 'Graphie';
    src: url('/fonts/fonnts.com-Graphie_Thin.otf') format('opentype');
    font-weight: 100;
    font-style: normal;
}

@font-face {
    font-family: 'Graphie';
    src: url('/fonts/fonnts.com-Graphie_Thin_Italic.otf') format('opentype');
    font-weight: 100;
    font-style: italic;
}

@font-face {
    font-family: 'Graphie';
    src: url('/fonts/fonnts.com-Graphie_ExtraLight.otf') format('opentype');
    font-weight: 200;
    font-style: normal;
}

@font-face {
    font-family: 'Graphie';
    src: url('/fonts/fonnts.com-Graphie_ExtraLight_Italic.otf') format('opentype');
    font-weight: 200;
    font-style: italic;
}

@font-face {
    font-family: 'Graphie';
    src: url('/fonts/fonnts.com-Graphie_Light.otf') format('opentype');
    font-weight: 300;
    font-style: normal;
}

@font-face {
    font-family: 'Graphie';
    src: url('/fonts/fonnts.com-Graphie_Light_Italic.otf') format('opentype');
    font-weight: 300;
    font-style: italic;
}

@font-face {
    font-family: 'Graphie';
    src: url('/fonts/fonnts.com-Graphie.otf') format('opentype');
    font-weight: 400;
    font-style: normal;
}

@font-face {
    font-family: 'Graphie';
    src: url('/fonts/fonnts.com-Graphie_Italic.otf') format('opentype');
    font-weight: 400;
    font-style: italic;
}

@font-face {
    font-family: 'Graphie';
    src: url('/fonts/fonnts.com-Graphie_Book.otf') format('opentype');
    font-weight: 450;
    font-style: normal;
}

@font-face {
    font-family: 'Graphie';
    src: url('/fonts/fonnts.com-Graphie_Book_Italic.otf') format('opentype');
    font-weight: 450;
    font-style: italic;
}

@font-face {
    font-family: 'Graphie';
    src: url('/fonts/fonnts.com-Graphie_SemiBold.otf') format('opentype');
    font-weight: 600;
    font-style: normal;
}

@font-face {
    font-family: 'Graphie';
    src: url('/fonts/fonnts.com-Graphie_SemiBold_Italic.otf') format('opentype');
    font-weight: 600;
    font-style: italic;
}

@font-face {
    font-family: 'Graphie';
    src: url('/fonts/fonnts.com-Graphie_Bold.otf') format('opentype');
    font-weight: 700;
    font-style: normal;
}

@font-face {
    font-family: 'Graphie';
    src: url('/fonts/fonnts.com-Graphie_Bold_Italic.otf') format('opentype');
    font-weight: 700;
    font-style: italic;
}

@font-face {
    font-family: 'Graphie';
    src: url('/fonts/fonnts.com-Graphie_ExtraBold.otf') format('opentype');
    font-weight: 800;
    font-style: normal;
}

@font-face {
    font-family: 'Graphie';
    src: url('/fonts/fonnts.com-Graphie_ExtraBold_Italic.otf') format('opentype');
    font-weight: 800;
    font-style: italic;
}

html,
body {
    width: 100vw;
    overflow-x: hidden;
}

:root {
    --bs-primary: #f17140;
    --bs-primary-rgb: 241, 113, 64;
    --bs-font-sans-serif: 'Graphie', system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif;
}

/* Configuração da fonte padrão */
body {
    font-family: 'Graphie', system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif;
    margin-top: 84px;
    /* Adiciona margem superior para evitar sobreposição do header dinâmico */
}

/* Classes utilitárias para diferentes pesos da Graphie */
.font-thin {
    font-weight: 100;
}

.font-extralight {
    font-weight: 200;
}

.font-light {
    font-weight: 300;
}

.font-normal {
    font-weight: 400;
}

.font-book {
    font-weight: 450;
}

.font-semibold {
    font-weight: 600;
}

.font-bold {
    font-weight: 700;
}

.font-extrabold {
    font-weight: 800;
}

@media(max-width: 1400px) {
    .navbar-nav .nav-link{
        font-size: 1rem !important;
    }
}

/* Estilos da Seção CTA */

/* Estilos base para mobile */
.cta-title {
    font-size: 3rem;
    font-weight: 500;
    text-align: start;
}

.cta-subtitle {
    font-weight: 800;
}

.cta-content {
    padding: 1rem 0;
    text-align: start;
}

.cta-image {
    margin-top: 5rem;
    height: 200px;
}

.cta-image img {
    width: 100%;
    height: 100%;
    object-fit: scale-down;
}

.cta-section {
    padding-left: 1rem;
}

.cta-wave {
    position: absolute;
    bottom: 5rem;
    z-index: -1;
}

.cta_background,
.secao-sobre-gente_background {
    position: absolute;
    top: -9rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: -1;
    width: 300%;
    height: 150%;
    display: flex;
    justify-content: center;
    align-items: center;
}

@media(min-width: 1400px) {
    .secao-sobre-gente_background {
        top: -25rem;
        width: 120%;
    }
}

.cta_background svg,
.secao-sobre-gente_background svg {
    width: 100%;
    height: auto;
    min-height: 100%;
}

.cta-wave path {
    fill: #f17140;
}

.cta-button {
    position: relative;
    font-weight: 800;
    top: 2rem;
    border-radius: 1rem;
    border: 3px solid #ffffff !important;
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.15);
    transform: translateZ(0);
    transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.cta-button:hover,
.cta-button:focus {
    transform: scale(1.04);
    box-shadow: 0 10px 22px rgba(0, 0, 0, 0.2);
}

.cta-button:active {
    transform: scale(0.98);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.18);
}

.cta-content h1 {
    line-height: 1;
    letter-spacing: -0.02em;
}

.cta-content h2 {
    line-height: 1.3;
}

@media (min-width: 992px) {
    .cta-content {
        text-align: left;
        padding: 2rem 0;
    }

    .cta-image {
        margin-top: 0;
        height: 480px;
    }

    .cta-section {
        padding-left: 0;
    }

    .cta_background {
        left: 50%;
        width: 150%;
        transform: translateX(-50%);
    }

    .cta_background svg {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .cta-title {
        font-size: 4rem;
    }

    .cta-button {
        font-size: 1.5rem;
    }

    .cta-wave {
        position: absolute;
        bottom: -7rem;
        z-index: -1;
    }

    .cta_background svg {
        width: 100%;
        height: 100%;
    }
}

@media (min-width: 1401px) {
    .cta_background {
        position: absolute;
        top: -4rem;
        left: 50%;
        transform: translateX(-50%);
        z-index: -1;
        width: 150%;
        height: 150%;
        display: flex;
        justify-content: center;
        align-items: center;
    }
}

/* Estilos da Seção "Encontre" */
.secao-encontre {
    position: relative;
}

.secao-encontre h2 {
    font-size: 2.5rem;
    line-height: 1.2;
    letter-spacing: -0.02em;
    font-weight: 800;
    color: #768d9d;
}

.secao-encontre .lead {
    font-size: 1.25rem;
    line-height: 1.6;
    color: #768d9d;
    font-weight: 700;
}

.secao-encontre .btn {
    margin-top: -2rem;
}

.secao-encontre .cta-button {
    border: 3px solid #ffffff !important;
}

/* Estilos da imagem da nova seção */
.secao-encontre img {
    max-width: 100%;
    height: auto;
    border-radius: 1rem;
    transition: transform 0.3s ease;
}

.secao-encontre img:hover {
    transform: scale(1.02);
}

/* Estilos da Seção Siga-nos */
.secao-siga-nos_texto {
    font-size: 1.25rem;
    font-weight: 600;
}

.secao-siga-nos_conteudo {
    position: relative;
    background-color: #f17140;
    border-radius: 1.5rem;
}

.secao-siga-nos_fundo {
    display: none;
    position: absolute;
    top: 0;
    bottom: 0;
    z-index: -1;
    width: 100%;
    height: 100%;
}

@media(min-width: 992px) {
    .secao-siga-nos_fundo {
        display: block;
    }

    .secao-siga-nos_conteudo {
        background-color: transparent;
    }
}

.secao-siga-nos_fundo svg {
    width: 100%;
    height: 100%;
    fill: #f17140;
}

.secao-siga-nos_rede {
    font-size: 1.5rem;
    font-weight: 800;
}

/* Estilos da Seção Transformamos Vidas */
.carousel-item-content {
    background-color: #fff;
    border: 3px solid #f17140;
    border-radius: 4rem;
    padding: 2rem 1.5rem;
    margin: 0 0.5rem;
    min-height: 280px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease;
}

/* Responsividade dos itens do carrossel */
@media (max-width: 767.98px) {
    .carousel-item-content {
        margin: 0 1rem;
        padding: 2rem 1.5rem;
        min-height: 150px;
    }
}

.carousel-item-content:hover {
    transform: translateY(-5px);
}

.carousel-item-content h3 {
    color: #f17140;
    font-weight: 600;
    font-size: 1.5rem;
    margin: 0;
}


/* Estilos dos elementos decorativos da seção Transformamos Vidas */
.secao-transformamos-vidas {
    position: relative;
}

.secao-transformamos-vidas_titulo,
.secao-beneficios_titulo,
.secao-comecar_titulo,
.secao-pilares_titulo {
    color: #b34e30;
    font-weight: 800;
    font-size: 2.25rem;
    line-height: 1;
    letter-spacing: -2px;
    text-align: center;
}

.secao-beneficios_titulo {
    padding: 0 3rem;
}

@media (min-width: 768px) {

    .secao-transformamos-vidas_titulo,
    .secao-beneficios_titulo,
    .secao-comecar_titulo,
    .secao-pilares_titulo {
        font-size: 3rem;
    }
}

.secao-transformamos-vidas_fundo {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    display: flex;
    justify-content: space-between;
    align-items: center;
    pointer-events: none;
}

.secao-transformamos-vidas_verde {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%) translateX(-80%);
}

.secao-transformamos-vidas_azul {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%) translateX(80%);
}

.secao-transformamos-vidas_verde img,
.secao-transformamos-vidas_azul img {
    width: 100%;
    height: auto;
}

.secao-siga-nos_clique {
    width: 1.25rem;
    height: 1.25rem;
    margin-top: .75rem;
}

.carousel-item-content h3 {
    color: #b34e30;
    font-weight: 800;
}

/* Estilos dos ícones do carrossel */
.carousel-icon {
    width: 8rem;
    height: 8rem;
}

.cta-button-carousel {
    margin-top: .5rem;
    border-radius: 2rem;
    font-weight: bold;
    padding: .25rem 1rem;
}

/* Seção Quero */
.secao-quero {
    position: relative;
}

.secao-quero_wrapper {
    position: relative;
}

.secao-quero_box {
    background-color: #c9ca76;
    border-radius: 1.5rem;
    flex: 1;
    padding: 2rem 1rem;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.secao-quero_titulo {
    color: white;
    font-weight: 800;
    margin: 0;
    font-size: 2rem;
}

.secao-quero_cta_wrapper {
    position: relative;
}

.secao-quero_cta {
    background-color: #b34e30;
    border-color: #b34e30;
    border-radius: 2rem;
    font-weight: 700;
    font-size: 1rem;
}

.secao-quero_icone {
    position: absolute;
    bottom: -.75rem;
    right: -.75rem;
    transform: scaleX(-1);
}

/* Estilos da Seção "Pilares que nos destacam" */
.secao-pilares {
    background-color: #f6efe3;
}

.secao-pilares_pilar {
    margin-top: 1rem;
    display: flex;
    align-items: center;
}

.secao-pilares_wrapper {
    display: flex;
}

.secao-pilares_titulo {
    margin-bottom: 2rem;
}

.secao-pilares_fundo {
    display: none
}

.secao-pilares_pilar_conteudo {
    margin-left: 1rem;
}

.secao-pilares_pilar_titulo {
    color: #b34e30;
    font-weight: 800;
    line-height: 1;
}

.secao-pilares_pilar_texto {
    color: #b34e30;
    font-weight: 400;
}

@media (min-width: 992px) {
    .secao-quero_box {
        padding-right: 2rem !important;
        flex: none;
        width: 80%;
    }

    .secao-quero_titulo {
        color: white;
        font-weight: 800;
        margin: 0;
        font-size: 3rem;
    }

    .secao-quero_cta {
        background-color: #b34e30;
        border-color: #b34e30;
        border-radius: 2rem;
        font-weight: 700;
    }

    .secao-pilares_pilar_texto {
        color: #b34e30;
        font-weight: 400;
        font-size: 1.25rem;
    }

    .secao-pilares_fundo {
        display: block;
        width: 85%;
        margin-right: 1rem;
        position: relative;
    }

    .secao-pilares_fundo img {
        position: absolute;
        right: 0;
        height: 100%;
    }
}

@media (min-width: 1200px) {
    .secao-quero_box {
        width: 85%;
    }
}

@media (min-width: 1400px) {
    .secao-quero_box {
        width: 87%;
    }
}

.secao-quero_cta:hover,
.secao-quero_cta:focus {
    background-color: #6e2812;
    border-color: #6e2812;
}

.secao-quero_icone {
    width: 1.25rem;
    height: 1.25rem;
}

.secao-quero_ilustracao {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    z-index: 1;
    max-width: 300px;
}

/* Estilos da Seção Benefícios e Como Começar */
.beneficio-item,
.comecar-item {
    padding: 1rem 1rem;
}

.beneficio-icon,
.comecar-icon,
.pilar_icon {
    width: 6rem;
    height: 6rem;
    margin: 0 auto;
}

.beneficio-titulo,
.comecar-titulo {
    color: #b34e30;
    font-weight: 800;
    font-size: 1.5rem;
    margin-bottom: 1rem;
}

.beneficio-texto,
.comecar-texto {
    color: #b34e30;
    font-size: 1rem;
    line-height: 1.6;
    margin: 0;
    font-weight: 700;
}

.comecar-texto {
    padding: 0 .5rem;
}

.secao-comecar {
    position: relative;
}

.secao-comecar_fundo {
    position: absolute;
    right: 0;
    top: 0;
    height: 80%;
    margin-top: 30%;
    z-index: -1;
}

.secao-comecar_fundo img {
    width: 100%;
    height: 100%;
    object-fit: scale-down;
    transform: scaleY(-1) translateX(40%);
}

.secao-comecar_titulo {
    text-align: start;
    width: 60%;
    margin-bottom: 0;
}

.secao-comecar_detalhe {
    width: 40%;
}

.secao-comecar_detalhe img {
    margin-bottom: 3rem;
    width: 100%;
    height: 100%;
    object-fit: scale-down;
}

.secao-comecar_wrapper {
    width: 90%;
}

@media (min-width: 664px) {
    .secao-comecar_fundo {
        position: absolute;
        right: 0;
        top: 0;
        height: 100%;
        margin-top: 0;
        z-index: -1;
    }

    .secao-comecar_fundo img {
        transform: scaleY(-1) translateX(20%);
    }
}

@media (min-width: 992px) {

    .beneficio-item,
    .comecar-item {
        padding: 2rem 1rem;
    }

    .beneficio-icon,
    .comecar-icon,
    .pilar_icon {
        width: 8rem;
        height: 8rem;
    }

    .beneficio-titulo,
    .comecar-titulo {
        font-size: 1.75rem;
    }

    .beneficio-texto,
    .comecar-texto {
        font-size: 1.1rem;
    }

    .secao-comecar_titulo {
        width: 33%;
    }

    .secao-comecar_detalhe {
        width: 33%;
        margin-left: 1rem;
    }

    .secao-comecar_detalhe img {
        object-fit: inherit;
        margin-bottom: 3rem;
    }

    .secao-comecar_fundo {
        position: absolute;
        right: 0;
        top: 0;
        height: 100%;
        z-index: -1;
    }

    .secao-comecar_fundo img {
        transform: skewY(0) translateY(0);
    }
}

@media (min-width: 1120px) {
    .secao-comecar_wrapper {
        width: 100%;
    }
}


/* Estilos da página sobre nós */

.secao-sobre-gente {
    background-color: #f17140;
    padding: 4rem 0;
    position: relative;
    overflow: hidden;
}

.secao-sobre-gente_texto {
    margin-top: 3rem;
}

.secao-sobre-gente_texto h1 {
    font-weight: 800;
}

.secao-nossa-historia {
    color: #738e9d;
    text-align: center;
}

.secao-nossa-historia h2 {
    margin-top: 2rem;
    font-weight: 800;
}

.secao-nossa-historia_conteudo {
    flex-direction: column-reverse;
}

.secao-nossa-equipe {
    background-color: #c9ca76;
    padding-bottom: 10rem;
    margin-bottom: -10rem;
}

.secao-nossa-equipe h2 {
    color: white;
    font-weight: 800;
    text-align: center;   
}

.secao-nossa-equipe_conteudo {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.secao-nossa-equipe_conteudo h3 {
    color: white;
    font-weight: 700;
    margin-top: 1rem;
}

.secao-nossa-equipe_conteudo p {
    color: white;
}

.secao-nossa-equipe_avatar {
    display: block;    
    width: 15rem;
    height: 15rem;
    border-radius: 1rem;
    border: 2px solid white;
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.15);
    overflow: hidden;
}

.secao-nossa-equipe_avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;  
}

.secao-nossa-equipe_imagem {
    border-radius: 1rem;
}

@media (min-width: 992px) {
    .secao-nossa-historia {
        color: #738e9d;
        text-align: start;
    }

    .secao-nossa-historia_conteudo {
        flex-direction: row;
    }

    .secao-nossa-historia p {
        font-size: 1.25rem;
    }

    .secao-nossa-historia h2, .secao-nossa-equipe h2 {
        font-size: 2.5rem;
    }

    .secao-nossa-historia_inferior {
        text-align: end;
    }
}

.secao-diversidade {
    place-items: center;
    position: relative;
    margin-top: 4rem;
    margin-bottom: 4rem;
}

.secao-diversidade_wrapper {
    background-color: #f17140;
    color: white;
    border-radius: 2rem;
    padding: 2rem 1rem;
}

.secao-diversidade_titulo {
    font-weight: 300;
}

.secao-diversidade_cta {
    background-color: #f17140;
    color: white;
    border-radius: 10rem;
    font-weight: 800;
    font-size: 1rem;
    transition: transform 0.3s ease;
}

.secao-diversidade_cta:hover {
    background-color: #b34e30;
    color: white;
    transform: scale(1.02);    
}

/* Página psicólogos */
.secao-como-fazer-parte, .secao-perguntas-frequentes {
    background-color: #f6efe3;    
    padding: 4rem 0;
    position: relative;
    overflow: hidden;
    text-align: center; 
}

.secao-como-fazer-parte h2, .secao-perguntas-frequentes h2 {
    margin-bottom: 3rem;
    font-size: 3rem;
    line-height: 1.25;
    color: #b34e30;
    font-weight: 800;
}

.secao-perguntas-frequentes {
    text-align: center;
    padding-bottom: 10rem;
    margin-bottom: -10rem;
}

.secao-perguntas-frequentes h2 {
    margin-bottom: 0;
}

.secao-perguntas-frequentes .accordion {
    margin-top: 3rem;
    color: #b34e30;
    font-weight: 600;
}

.secao-perguntas-frequentes .accordion-button {
    color: #b34e30;
    font-weight: 800;
}

.secao-como-fazer-parte p {
    margin-top: 1rem;
    font-size: 1.25rem;
    line-height: 1.25;
    color: #b34e30;
    font-weight: 600;
}

/* Estilos para as setas do carouselNossaEquipe */
#carouselNossaEquipe .slick-prev,
#carouselNossaEquipe .slick-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 1;
    width: 40px; /* Ajuste o tamanho conforme necessário */
    height: 40px; /* Ajuste o tamanho conforme necessário */
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    border-radius: 50%;
    color: white;
    font-size: 0; /* Oculta o texto "Previous" e "Next" */
    line-height: 0; /* Garante que a altura da linha não afete o espaçamento */
}

#carouselNossaEquipe .slick-prev::before,
#carouselNossaEquipe .slick-next::before {
    font-family: 'slick'; /* Usa a fonte de ícones do Slick Carousel */
    font-size: 20px; /* Tamanho do ícone */
    line-height: 1;
    color: white;
    opacity: 0.75;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

#carouselNossaEquipe .slick-prev::before {
    content: '←'; /* Ícone de seta para a esquerda */
}

#carouselNossaEquipe .slick-next::before {
    content: '→'; /* Ícone de seta para a direita */
}

#carouselNossaEquipe .slick-prev {
    left: 10px; /* Ajuste a distância da esquerda */
}

#carouselNossaEquipe .slick-next {
    right: 10px; /* Ajuste a distância da direita */
}

#carouselNossaEquipe .slick-prev:hover,
#carouselNossaEquipe .slick-next:hover {
    background-color: rgba(0, 0, 0, 0.7);
}