@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');
@import url('https://maxcdn.bootstrapcdn.com/font-awesome/4.4.0/css/font-awesome.min.css');

* {
    font-family: "Poppins", sans-serif;

}

:root {
    --azul: #3A4594;
    --amarelo: #FFF110;
}

::-webkit-scrollbar {
    width: 8px;
}

::-webkit-scrollbar-track {
    background: transparent
}

::-webkit-scrollbar-thumb {
    background-image: linear-gradient(4deg, #ba9140, #cdb53a, #dfda2f, #f0ff16);
    border-radius: 8px;
}

::-webkit-scrollbar-thumb:hover {
    background-image: linear-gradient(4deg, #ba9140, #cdb53a, #dfda2f, #f0ff16);
}

/*Popup*/
#bio_ep_close {
    width: 25px !important;
    height: 25px !important;
    background-color: #3a4692e6 !important;
    padding-top: 3px;
}

/*Topbar*/
.bg-topbar {
    background: var(--azul);
}

.bg-topbar ul li,
.bg-topbar ul li a {
    transition: .5s;
}

.bg-topbar ul li a {
    color: var(--marrom);
    text-decoration: none;
}

.btn-area{
    padding: 16px 33px;
}
.btn-area:hover{
    border-color: var(--amarelo);
}

.link-topbar:hover{
    color: var(--amarelo);
}
.navegacao {
    transition: top 0.3s;
}

.btn-matricula {
    padding: 16px 33px;
    border-radius: 9px;
    background: var(--amarelo);
    border: none;
    font-family: inherit;
    text-align: center;
    cursor: pointer;
    transition: 0.4s;
    font-weight: 700;
   }
   
   .btn-matricula:hover {
    box-shadow: 7px 5px 56px -14px #FFF110;
    background-color: var(--amarelo);
   }
   
   .btn-matricula:active {
    transform: scale(0.97);
    background-color: var(--amarelo) !important;
    box-shadow: 7px 5px 56px -10px #FFF110;
   }


.nav-item,
.link-redes {
    position: relative;
}

.nav-item:hover::before {
    scale: 1;
}

.nav-item::before {
    content: '';
    position: absolute;
    left: 2px;
    bottom: 4px;
    width: 90%;
    height: 3px;
    background-color: var(--azul);
    border-radius: 4px;
    scale: 0 1;
    transform-origin: left;
    transition: scale 0.35s;
}

.dropdown-menu {
    border: none;
}

.dropdown-item:hover {
    border-color: var(--azul) !important;
    border-left: solid;
    background-color: #e6e9ff;
}


/*Carousel*/
.banner.carousel-indicators [data-bs-target].active {
    background-color: var(--amarelo);
    border-radius: 20em;
    width: 45px;
    height: 12px;
    transition: .5s;
}

.banner.carousel-indicators [data-bs-target] {
    background-color: var(--amarelo);
    border-radius: 50%;
    width: 12px;
    height: 12px;
    transition: .5s;
    margin-left: 10px;
}

.banner.carousel-indicators [data-bs-target] {
    border-top: 0 solid transparent;
    border-bottom: 0 solid transparent;
}

.carousel-control-next,
.carousel-control-prev {
    width: 10%;
    color: var(--amarelo) !important;
}

.bi-arrow-left-circle-fill,
.bi-arrow-right-circle-fill {
    font-size: 32px;
}

.bi-arrow-left-circle-fill:hover,
.bi-arrow-right-circle-fill:hover {
    color: #000;
}

.banner.carousel-item img, .img-matricula-sig {
    height: calc(100vh - 100px);
}

/*Sobre nos*/
.secao {
    padding-top: 6em;
}

.secao-bottom {
    padding-bottom: 6em;
}

.titulo-amarelo,
.titulo,
.titulo-instagram {
    font-weight: 900;
    font-size: clamp(3rem, -5.1124rem + 11.4833vw, 3.5rem);
}

.titulo {
    color: var(--azul);
    background: -webkit-linear-gradient(110deg, #22285e, #363673, #3A4594);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.titulo-amarelo {
    color: var(--amarelo);
}

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

/*turma*/
.bg-fundo {
    min-height: 100%;
    position: relative;
}

.bg-fundo::before {
    background-image: url(../img/fundo.png);
    background-repeat: no-repeat;
    background-position: center top;
    background-size: cover;
    content: '';
    height: 100%;
    position: fixed;
    top: 0;
    width: 100%;
    will-change: transform;
    z-index: -1;
}

.bg-cinza {
    background-color: #f9f9f9;
}

.bg-azul {
    background: -webkit-linear-gradient(110deg, #22285e, #363673, #3A4594);
    width: 100%;
}

.bg-amarelo {
    background-image: linear-gradient(118deg, #ecbc0b, #f6d800, #FFF110)
}


.card-container {
    width: 100%;
    height: 248px;
    position: relative;
    border-radius: 10px;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.2);
    overflow: hidden;
}

.card-segmento {
    width: 100%;
    height: 100%;
    border-radius: inherit;
}

.card-segmento .front-content {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.6s cubic-bezier(0.23, 1, 0.320, 1)
}

.card-segmento .front-content p {
    font-size: 32px;
    font-weight: 700;
    opacity: 1;
    background: -webkit-linear-gradient(110deg, #ffffff, #ffffff, #ffffff);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    transition: all 0.6s cubic-bezier(0.23, 1, 0.320, 1)
}

.card-segmento .content {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: 4px;
    background: -webkit-linear-gradient(110deg, #22285e, #363673, #3A4594);
    color: #e8e8e8;
    padding: 20px;
    line-height: 1.5;
    border-radius: 5px;
    transform: translateX(-98%);
    transition: all 0.6s cubic-bezier(0.23, 1, 0.320, 1);
}

.card-segmento .content .heading {
    font-size: 32px;
    font-weight: 700;
}

.card-segmento:hover .content {
    transform: translateY(0);
}

.card-segmento:hover .front-content {
    transform: translateX(-30%);
}

.card-segmento:hover .front-content p {
    opacity: 0;
}

.btn-segmento-color {
    border-color: var(--amarelo) !important;
    color: var(--azul) !important;
    font-weight: 700;
    line-height: 1;
}

/*Diferenciais*/
.border-radius10 {
    border-radius: 10px;
}

.color-amarelo {
    color: var(--amarelo);
}

.card-body-diferenciais, .modal-content {
    background: -webkit-linear-gradient(110deg, #22285e, #363673, #3A4594);
}

.card-body-diferenciais p {
    color: #e6e9ff;
}

.link-diferenciais, .color-azul {
    color: var(--azul);
}

.link-diferenciais::after {
    content: "\F138";
    font-family: bootstrap-icons;
    opacity: 0;
    transition: .5s;
    color: var(--azul);
}

.link-diferenciais:hover::after {
    opacity: 1;
    padding-left: 8px;
}

.btn-diferenciais {
    transition: .5s;
}

.btn-diferenciais:hover {
    transform: scale(1.05);
}

/*Estrutura*/
.bg-estrutura {
    background-image: url(../img/estrutura/bg-estrutura-home.jpg);
    width: 100%;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: right;
}

.swiper {
    width: 100%;
    height: 100%;
}

.swiper-slide {
    text-align: center;
    font-size: 18px;
    background: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
}

.swiper-slide img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.swiper {
    width: 100%;
    height: 300px;
    margin-left: auto;
    margin-right: auto;
}

.swiper-slide {
    background-size: cover;
    background-position: center;
}

.mySwiper2 {
    height: 80%;
    width: 100%;

}

.mySwiper {
    height: 20%;
    box-sizing: border-box;
    padding: 10px 0;
    cursor: pointer;
}

.mySwiper .swiper-slide {
    width: 25%;
    height: 100%;
    opacity: 0.6;
}

.mySwiper .swiper-slide-thumb-active {
    opacity: 1;
}

.swiper-slide img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.swiper-button-next,
.swiper-button-prev {
    color: var(--amarelo) !important;
}

/*Instagram*/
.titulo-instagram {
    color: var(--azul);
}

.instagram, .instagram-icon {
    background: #f09433;
    background: -moz-linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
    background: -webkit-linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
    background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    transition: .5s;
}

.instagram::after {
    content: url(../img/instagram.png);
    padding-left: 8px;
}

.instagram:hover {
    text-decoration: underline;
    text-decoration-color: #bc1888
}

/*Depoimento*/

.bg-depoimentos, .bg-historia {
    width: 100%;
    background: -webkit-linear-gradient(110deg, #22285e, #363673, #3A4594);
    height: 400px;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: -1;
}

.bg-depoimentos {
    height: 400px;
}

.bg-historia{
    height: 310px;
    bottom: 3.5vh;
}


.secao-depoimentos h2 {
    font-weight: 900;
    font-size: 2em;
    color: #f2f2f2;
    text-align: end;
}

.secao-depoimentos h3 {
    font-weight: 900;
    font-size: 1.6em;
    color: var(--amarelo);
    text-align: end;
}

.secao-depoimentos p {
    color: #f2f2f2;
    font-family: 'Montserrat', sans-serif;
}

.aspas {
    box-shadow: none !important;
    filter: drop-shadow(0px 0px 15px #b1ee78);
}

.carousel-indicators-depoimento [data-bs-target].active {
    background-color: var(--azul);
    border-radius: 20em;
    width: 45px;
    height: 12px;
    transition: .5s;
}

.carousel-indicators-depoimento [data-bs-target] {
    background-color: var(--azul);
    border-radius: 50%;
    width: 12px;
    height: 12px;
    transition: .5s;
}

.carousel-indicators-depoimento [data-bs-target] {
    border-top: 0 solid transparent;
    border-bottom: 0 solid transparent;
}

.img-depoimento {
    max-width: 500px;
}

/*contato*/
.icon-color::before {
    color: var(--color-btn) !important;
    text-shadow: 0px 0 black;
}

.color-form-address {
    color: var(--color-secundary);
    font-weight: 700;
    font-size: 1.3em;
}

.color-form-address:hover {
    color: #172d42
}

.formulario-shadow {
    padding: 4rem 3rem;
    border-radius: 10px;
    box-shadow: 0 8px 16px 0 rgba(31, 38, 135, 0.37);
    backdrop-filter: blur(5px);
    width: 100%;
}


.form-control {
    border: none !important;
    box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;
    ;
}

.form-nome {
    position: relative;
}

.bi-person-fill,
.bi-envelope-fill,
.bi-pencil-square,
.bi-telephone-fill {
    position: absolute;
    right: 10px;
    top: 0px;
    font-size: 1.5rem;
    color: var(--azul);
}

.btn-contato{
    color: #fff;
    border-color: var(--azul) !important;
    background-color: var(--azul);
}

.btn-contato :hover{
    color: var(--azul);
    border-color: var(--azul) !important;
}

.bi-whatsapp{
    color: var(--azul);
}

.icon-contato, .icon-footer{
    position: static;
    font-size: clamp(.8rem, -5.1124rem + 11.4833vw, 1rem);
}

.icon-footer{
    color: var(--amarelo);
    
}

.info-contato{
    color: var(--azul);
    transition: .5s;
}

.info-contato:hover{
    color: #5e66ac;
}

.youtube-icon{
    color: #FF0000;
}

.youtube-icon:hover{
    color: #920e0e;
}

.facebook-icon{
    color: #0866FF;
}

.facebook-icon:hover{
    color: #1b55b3;
}

/*Redes Sociais*/
.secao-redes{
    position: fixed;
    top: 40%;
    left: -0.5%;

    border-top-right-radius: 10px;
    border-bottom-right-radius: 10px;
    z-index: 1;
}
.secao-redes .row{
    width: 85px;
    padding-left: 1em;
}

/*Footer*/
.bg-footer{
    background: -webkit-linear-gradient(110deg, #22285e, #363673, #3A4594);
}

.icon-nav{
    font-size: 1.5em;
    padding-left: .5em;
}

.titulo-footer{
    font-weight: 900;
    color: var(--amarelo);
}

footer a {
    text-decoration: none;
    color: var(--marrom);
    transition: 0.3s;
    font-weight: 600;
}

footer a:hover {
    text-decoration: none;
    opacity: 0.8;
    color: var(--amarelo);
}

hr {
    border-bottom: 1px solid var(--amarelo) !important;
    line-height: 1px;
}
#historia{
    scroll-margin-top: 2em;
}

#contato{
    scroll-margin-top: 10em;
}

/*Area Reservado*/

.link-reservado{
    transition: .5s;
}
.link-reservado:hover{
    transform: scale(1.05);
}
/*Sobre nos  Interno*/

.mySwiper-historia{
    height: auto !important;
    border-radius: 10px;
}

.timeline{
    background-color: #FFF110; 
    width: 5px; 
    height: 100px; 
    margin: 3em auto;
}


/*Diferencial*/

.atividade {
    --bg-color: #d0d4ee;
    --bg-color-light: #eeeab1;
    --text-color-hover: #fff;
    --box-shadow-color: #1f35e0;
  }
  
  
  .card-atividade {
    width: 100%;
    height: 321px;
    background: #fff;
    border-radius: 10px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    position: relative;
    box-shadow: 0 14px 26px rgba(0, 0, 0, 0.04);
    transition: all 0.3s ease-out;
    text-decoration: none;
  }
  
  .card-atividade:hover {
    transform: translateY(-5px) scale(1.005) translateZ(0);
    box-shadow: 0 24px 36px rgba(0, 0, 0, 0.11),
      0 24px 46px var(--box-shadow-color);
  }
  
  .card-atividade:hover .overlay {
    transform: scale(5) translateZ(0);
  }
  
  .card-atividade:hover .circle {
    border-color: var(--bg-color-light);
    background: var(--bg-color);
  }
  
  .card-atividade:hover .circle:after {
    background: var(--bg-color-light);
  }
  
  .card-atividade:hover p {
    color: var(--text-color-hover);
  }
  
  .card-atividade p {
    font-size: 17px;
    font-weight: 700;
    color: var(--azul);
    margin-top: 30px;
    z-index: 1000;
    transition: color 0.3s ease-out;
  }
  
  .circle {
    width: 131px;
    height: 131px;
    border-radius: 50%;
    background: #fff;
    border: 2px solid #a6aee0;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    z-index: 1;
    transition: all 0.3s ease-out;
  }
  
  .circle:after {
    content: "";
    width: 118px;
    height: 118px;
    display: block;
    position: absolute;
    background: var(--bg-color);
    border-radius: 50%;
    top: 7px;
    left: 7px;
    transition: opacity 0.3s ease-out;
  }
  
  .circle svg, .circle img {
    z-index: 10000;
    transform: translateZ(0);
  }
  
  .overlay {
    width: 122px;
    position: absolute;
    height: 122px;
    border-radius: 50%;
    background: #a6aee0;
    top: 67px;
    left: 94px;
    z-index: 0;
    transition: transform 0.3s ease-out;
  }

  .btn-close {
    background: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3e%3cpath d='M.293.293a1 1 0 0 1 1.414 0L8 6.586 14.293.293a1 1 0 1 1 1.414 1.414L9.414 8l6.293 6.293a1 1 0 0 1-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 0 1-1.414-1.414L6.586 8 .293 1.707a1 1 0 0 1 0-1.414z'/%3e%3c/svg%3e") !important;
    width: .3em;
    height: .3em;
}


/*Infantil*/

.card{
    border: none;
    border-radius: 32px;
    background: -webkit-linear-gradient(110deg, #22285e, #363673f1, #3a4494);
    /* background-image: linear-gradient(25deg, #3e397d, #424a97, #445cb2, #456ece) */
}

.card-title-diferencial{
    font-size: 20px;
    color: var(--amarelo);
}
.diferenciais-icone{
    padding-top: 16px;
    padding-left: 24px;
    width: 72px;
    height: auto;
}

.card-diferencial{
    width: 100%;
    height: 330px;
    margin-top: 1em;
    margin-bottom: 2em;
    box-shadow: 0px 30px 18px -8px rgba(0, 0, 0, 0.1);
}

.card-body-diferencial{
    padding: 0 24px;
}

/*Fundamentel 2*/
.lista-grade li::marker{
    color: var(--amarelo);
}

/*Matricula*/
.blur{
    backdrop-filter: blur(8px) saturate(180%);
}
.lista-documento li::marker{
    color: var(--azul);
}

@media screen and (max-width: 9999px) {
    .depoimentos-mobile {
        width: 14ch;
    }
}

@media screen and (max-width:1199px) {
    .btn-matricula {
        line-height: 1.5em;
    }

    .bg-depoimentos {
        height: 460px;
    }

    .titulo-depoimento {
        text-align: center !important;
    }
}

@media screen and (max-width:1024px) {
    .bg-historia{
        height: 320px;
        bottom: 0vh;
    }
}



@media screen and (max-width:991px) {
    .carousel-item img {
        height: auto;
    }

    .bg-depoimentos {
        height: 100%;
    }

    .secao-depoimentos video {
        width: 330px !important;
    }

    .depoimentos-mobile {
        width: 100% !important;
    }

    .container-interno-depoimento {
        justify-content: center !important;
    }

    .img-depoimento {
        padding-top: 32px;
    }
}



@media screen and (min-width:769px) {
    .secao-redes-mobile{
        display: none !important;
    }
}

@media screen and (max-width:768px) {
    .banner.carousel-item img, .img-matricula-sig {
        height: auto;
    }
    .secao-desktop{
        display: none !important;
    }
    footer{
        margin-bottom: 80px;
    }

    .bg-historia {
        height: 100%;
        bottom: 0px;
    }

    .mySwiper-historia{
        padding-bottom: 4em !important;
    }

    .carousel-indicators{
        display: none;
    }
}





@media screen and (max-width:425px) {

    .bg-depoimentos {
        height: 100%;
        padding-top: 2em;
    }

    .carousel-indicators-depoimento [data-bs-target].active {
        background-color: var(--amarelo);
    }

    .carousel-indicators-depoimento [data-bs-target] {
        background-color: var(--amarelo);
    }

    .depoimento-arrow-mobile {
        display: none;
    }
}

.linha-pco img{
    width: 100%;
    aspect-ratio: 3/2;
    object-fit: contain;
    filter:grayscale(1);
    transition: .5s;
}

.linha-pco img:hover{
    filter:grayscale(0)
}


/*Mapa Mental*/
.card-mapa-mental {
    box-sizing: border-box;
    width: 100%;
    height: 200px;
    background: transparent;
    border: 1px solid white;
    box-shadow: 12px 17px 51px rgba(0, 0, 0, 0.22);
    backdrop-filter: blur(6px);
    border-radius: 17px;
    text-align: center;
    cursor: pointer;
    transition: all 0.5s;
    display: flex;
    align-items: center;
    justify-content: center;
    user-select: none;
    font-weight: bolder;
    color: black;
  }
  
  .card-mapa-mental:hover {
    border: 1px solid var(--azul);
    transform: scale(1.05);
  }
  
  .card-mapa-mental:active {
    transform: scale(0.95) rotateZ(1.7deg);
  }


  .youtube-thumbnail {
            position: relative;
            width: 100%;
            max-width: 800px;
            margin: 0 auto;
            cursor: pointer;
            border-radius: 20px;
            overflow: hidden;
            box-shadow: 0 4px 8px rgba(0,0,0,0.2);
        }
        
        .youtube-thumbnail img {
            width: 100%;
            height: auto;
            display: block;
            transition: transform 0.3s;
        }
        
        .youtube-thumbnail:hover img {
            transform: scale(1.02);
        }
        
        .play-button {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            background: rgba(255, 0, 0, 0.8);
            width: 80px;
            height: 80px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: all 0.3s;
        }
        
        .play-button::before {
            content: "";
            display: block;
            width: 0;
            height: 0;
            border-top: 15px solid transparent;
            border-bottom: 15px solid transparent;
            border-left: 25px solid white;
            margin-left: 5px;
        }
        
        .youtube-thumbnail:hover .play-button {
            background: rgba(255, 0, 0, 0.9);
            transform: translate(-50%, -50%) scale(1.1);
        }
        
        /* Estilos do Modal */
        .modal-overlay {
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: rgba(0, 0, 0, 0.9);
            display: none;
            justify-content: center;
            align-items: center;
            z-index: 1000;
            opacity: 0;
            transition: opacity 0.3s;
        }
        
        .modal-content {
            position: relative;
            width: 90%;
            max-width: 900px;
        }
        
        .close-button {
            position: absolute;
            top: -40px;
            right: 0;
            color: white;
            font-size: 24px;
            cursor: pointer;
            background: none;
            border: none;
        }
        
        .modal-iframe {
            width: 100%;
            height: 0;
            padding-bottom: 56.25%; /* Proporção 16:9 */
            position: relative;
            border-radius: 10px;
            overflow: hidden;
        }
        
        .modal-iframe iframe {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            border: none;
        }