@import url('https://fonts.googleapis.com/css2?family=Concert+One&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Titan+One&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Passion+One:wght@400;700;900&family=Titan+One&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Concert+One&family=Passion+One:wght@400;700;900&family=Russo+One&family=Titan+One&display=swap');


*{
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    text-decoration: none;
    list-style: none;
    font-family: "Poppins", sans-serif;
}

html{
    scroll-behavior: smooth; /*Rolagem do menu suave*/
}

:root{
    --cor-white: #fff;
    --cor-banner: #001542;
    --cor-bolinhas: #1D52C4;
    --cor-header: #ebdb00;
    --cor-headerGradient: linear-gradient(#FF9800, #FFCF00, #FF9800);
    --cor-body: #EDF1F7;
    --cor-servicos:#00063D;
    --cor-div-conteudo: #061d4e;



    --color-neutral-0: #0e0c0c;
    --color-neutral-10: #171717;
    --color-neutral-30: #a8a29e;
    --color-neutral-40: #f5f5f5;

    --cor-white: #fff;
    --cor-botao-header: #1D52C4;
    --color-primary: #ffbf00;
    --cor-botao-footer: #001033;
    --cor-botao-copyright: #000a20;
}

header{
    margin-top: 20px;
    padding-top: 10px;
    padding-bottom: 10px;
    width: 80vw;
    background-image: linear-gradient(to right, #fcc100, #FFCF00, #fcc100);
    border-radius: 10px;
    box-shadow: #00063D 4px 4px 12px 2px;
}
header .logo img{
    height: 50px;
    padding-right: 50px;
}
header nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0px 50px;
  /*padding: 1.5rem 6rem;*/
}
header nav .nav-list{
  display: flex;
  align-items: center;
}
header nav .nav-list ul{
  display: flex;
  justify-content: center;
  gap: 20px;
}
header nav .nav-list ul li a{
  font-size: 18pt;
  font-weight: 500;
  font-family: "Passion One", sans-serif;
  color: rgb(238, 238, 238);
  filter: drop-shadow(1px 1px 1px rgb(0, 0, 121));
  color: white;
}
header nav .nav-link{
  text-decoration: none;
}

.mobile-menu-icon{
  display: none;
}
.mobile-menu{
  display: none;
}
.mobile-menu ul li a{
  display: flex;
  flex-direction: column;
  gap: 10px;
  font-size: 18pt;
  font-weight: 500;
  font-family: "Passion One", sans-serif;
  color: rgb(238, 238, 238);
  filter: drop-shadow(1px 1px 1px rgb(0, 0, 121));
  color: white;
}


@media screen and (max-width: 836px) {
  header .logo img{
    height: 30px;
    padding-right: 30px;

  }
  .nav-bar{
    pad: 1.5rem 4rem;
  }
  .nav-item{
    display: none;
  }
  .login-button{
    display: none;
  }
  .mobile-menu-icon{
    display: block;
  }

  .mobile-menu-icon button{
    background-color: transparent;
    border: none;
    cursor: pointer;
  }

  .mobile-menu ul{
    display: flex;
    flex-direction: column;
    text-align: center;
    padding: 1rem;
  }
  .mobile-menu .nav-item{
    display: block;
    padding-top: 1.2rem;
  }
  .mobile-menu .login-button{
    display: block;
    padding: 1rem 2rem;
  }
  .mobile-menu .login-button button{
    width: 100%;
  }
  .open{
    display: block;
  }
}

/*
header nav{
    display: flex;
    gap: 20px;
}
header nav a{
    font-size: 15pt;
    font-weight: 500;
    font-family: "Passion One", sans-serif;
    color: rgb(238, 238, 238);
    filter: drop-shadow(1px 1px 1px rgb(0, 0, 121));
    
}
*/





body .banner{
    background-image: url(banner.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
}

body .banner div{
    position: absolute;
    height: 80px;
    display: flex;
    flex-direction: column;
    align-items: center;
    bottom: 50px;
}
body .banner div:hover{
    cursor: pointer;
}
body .banner div img{
    height: 80px;
    bottom: 0px;
    filter: drop-shadow(1px 1px 10px yellow);
}
body .banner div img:hover{
    height: 90px;
    transition: 1s;
}
body .banner div a{
    font-family: Verdana, Geneva, Tahoma, 'Gill Sans', 'Gill Sans MT', Calibri, 'Trebuchet MS', sans-serif;
    font-size: 11pt;
    font-weight: 600;
    color: white;
}


body {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background-color: var(--cor-banner);
}
body .banner{
    height: 100vh;
    width: 100vw;
    background-color: var(--cor-banner);
}



body .servicos{
    height: auto;
    width: 100vw;
    background-color: var(--cor-servicos);
    display: flex;
    justify-content: space-around;
    align-items: center;
    padding-top: 20px;
    padding-bottom: 50px;
}
body .servicos .pai{
    height: 100%;
    width: 80%;
    background-color: var(--cor-servicos);
    display: flex;
    justify-content: space-between;
    padding-top: 20px;
    padding-bottom: 20px;
}
body .servicos .pai .esquerda{
    width: 50%;
}
body .servicos .pai .esquerda h2{
    font-family: "Russo One", sans-serif;
}
body .servicos .pai .esquerda #grande{
    font-size: 30pt;
    color: var(--cor-header);
}
body .servicos .pai .esquerda #medio{
    font-size: 18pt;
    font-weight: 400;
    color: white;
}
body .servicos .pai .esquerda p{
    padding-top: 10px;
    font-family: "Concert One", sans-serif;
    width: 80%;
    color: white;
}


body .servicos .pai .esquerda #footer_social_media{
  display: flex;
  gap: 2rem;
  margin-top: 1.5rem;
}
body .servicos .pai .esquerda #footer_social_media .footer-link{
  display: flex;
  align-items: center;
  justify-content: center;
  height: 3.5rem;
  width: 3.5rem;
  color: var(--color-neutral-40);
  border-radius: 50%;
  transition: all 0.4s;
}
body .servicos .pai .esquerda #footer_social_media .footer-link:hover{
  opacity: 0.8;
}
body .servicos .pai .esquerda #footer_social_media .footer-link a i{
  font-size: 3.0rem;
}
body .servicos .pai .esquerda #instagram{
  background: linear-gradient(#7f37c9, #ff2992, #ff9807);
}
body .servicos .pai .esquerda #facebook{
  background-color: #4267b3;
}
body .servicos .pai .esquerda #whatsapp{
  background-color: #25d366;
}


@media screen and (max-width: 1020px){
  body .servicos .pai .esquerda{
    width: 80vw;
    text-align: justify;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
  body .servicos .pai .direita{
    width: 80vw;
    justify-content: center;
    align-items: center;
  }
  body .servicos .pai .esquerda p{
    text-align: justify;
    width: 80vw;
  }
  body .servicos .pai .esquerda #medio{
    width: 80vw;
    text-align: center;
  }

  /*
  body .servicos .pai .direita{ 
    width: 80vw;
    height: auto;
    background-color: #ff00c8;

    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: repeat(3, 1fr);

    grid-gap: 10px;
    grid-template-areas: 
    "um um tres"
    "quatro cinco seis";
  }
  body .servicos .pai .direita .servicosum {
    grid-area: um;
  }
  body .servicos .pai .direita .servicosdois {
    grid-area: dois;
  }
  body .servicos .pai .direita .servicostres {
    grid-area: tres;
  }
  body .servicos .pai .direita .servicosquatro {
    grid-area: quatro;
  }
  body .servicos .pai .direita .servicoscinco {
    grid-area: cinco;
  }
  body .servicos .pai .direita .servicosseis {
    grid-area: seis;
  }*/
}
@media screen and (max-width: 768px){
  body .servicos .pai{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
  body .servicos .pai .esquerda #grande{
    width: 80vw;
    text-align: center;
    font-size: 35pt;
  }
  body .servicos .pai .esquerda #medio{
    width: 80vw;
    text-align: center;
  }
  body .servicos .pai .esquerda{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
  body .servicos .pai .esquerda p{
    text-align: center;
    width: 80vw;
    font-size: 12pt;
    padding-bottom: 10px;
  }
  body .servicos .pai .direita{ 
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
}
@media screen and (max-width: 480px){

  body .servicos .pai .esquerda #grande{
    width: 80vw;
    text-align: center;
    font-size: 28pt;
  }
  body .servicos .pai .esquerda #medio{
    width: 80vw;
    text-align: center;
  }
  body .servicos .pai .esquerda{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
  body .servicos .pai .esquerda p{
    text-align: center;
    width: 80vw;
    font-size: 12pt;
    padding-bottom: 10px;
  }
}




body .servicos .pai .direita{
    /*width: 45%;
    display: grid;
    align-items: center;


    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: repeat(2, 1fr);

    gap: 20px;
    background-color: #7f37c9;

    grid-gap: 10px;
    grid-template-areas: 
    "um um tres"
    "quatro cinco seis";*/
    height: auto;
    width: 45%;

    display: flex;
    flex-direction: column;
    gap: 20px;
    align-items: center;
}
body .servicos .pai .direita .um{
  display: flex;
  flex-direction: row;
  width: 100%;
  gap: 20px;
  
  justify-content: center;
  align-items: center
}
body .servicos .pai .direita .dois{
  display: flex;
  flex-direction: row;
  width: 100%;
  gap: 20px;

  justify-content: center;
  align-items: center
}


/*
body .servicos .pai .direita .servicosum {
  grid-area: um;
}
body .servicos .pai .direita .servicosdois {
  grid-area: dois;
}
body .servicos .pai .direita .servicostres {
  grid-area: tres;
}
body .servicos .pai .direita .servicosquatro {
  grid-area: quatro;
}
body .servicos .pai .direita .servicoscinco {
  grid-area: cinco;
}
body .servicos .pai .direita .servicosseis {
  grid-area: seis;
}
*/

body .servicos .pai .direita .um a{
    height: 120px;
    width: 150px;
    background-color: var(--cor-div-conteudo);
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 20px;
}
body .servicos .pai .direita .um a:hover{
    background-color: #1D52C4;
    cursor: pointer;
}
body .servicos .pai .direita .um a h3{
    font-size: 9pt;
    text-align: center;
    color: white;
    
}
body .servicos .pai .direita .um a img{
    height: 60px;
}

/*=====*/
body .servicos .pai .direita .dois a{
  height: 120px;
  width: 150px;
  background-color: var(--cor-div-conteudo);
  border-radius: 10px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 20px;
}
body .servicos .pai .direita .dois a:hover{
  background-color: #1D52C4;
  cursor: pointer;
}
body .servicos .pai .direita .dois a h3{
  font-size: 9pt;
  text-align: center;
  color: white;
  
}
body .servicos .pai .direita .dois a img{
  height: 60px;
}

/*SECTION SERVIÇOS*/
@media screen and (max-width: 1020px){


  body .servicos .pai{
    display: flex;
    flex-direction: column;
}

  body .servicos{
    width: 100vw;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
}
@media screen and (max-width: 768px){

  body .servicos .direitadois{
    display: flex;
    flex-direction: column;
  }

  body .servicos{
    width: 100vw;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
}
@media screen and (max-width: 480px){


  body .servicos{
    width: 100vw;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  body .servicos .direitadois{
    display: flex;
    flex-direction: column;
  }
}





/*BOTÕES PRINCIPAIS*/
@media screen and (max-width: 1020px){
  body .servicos .pai .direita{
    grid-template-columns: repeat(3, 1fr);
    width: 80vw;
    padding-top: 20px;
  }
}
@media screen and (max-width: 768px){
  body .servicos .pai .direita{
    grid-template-columns: repeat(3, 1fr);
    width: 80vw;
  }
}
@media screen and (max-width: 480px){
  body .servicos .pai .direita{
    grid-template-columns: repeat(2, 1fr);
    width: 80vw;
  }
}







body .programacoes{
    height: 400px;
    width: 100vw;
    background-color: var(--cor-servicos);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.programacoes img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
  }
  .programacoes img:hover{
    width: 105%;
    height: 105%;
    display: block;
    object-fit: cover;
    transition: 1s;
  }
  .programacoes .gallery {
    width: 100%;
    max-width: 1100px;
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    grid-template-rows: repeat(2, 180px);
    gap: 10px;
    margin-inline: 30px;
    
  }
  .programacoes .gallery > .card {
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid rgb(77, 77, 77);
  }
  .programacoes .gallery > .card:hover{
    box-shadow: 1px 1px 10px 10px rgb(255, 255, 0);
  }
  .programacoes .card:nth-child(1) {
    grid-area: 1 / 1 / 2 / 2;
  }
  .programacoes .card:nth-child(2) {
    grid-area: 2 / 1 / span 1 / span 1;
  }
  .programacoes .card:nth-child(3) {
    grid-area: 1 / 2 / span 2 / span 2;
  }
  .programacoes .card:nth-child(4) {
    grid-area: 1 / 4 / span 1 / span 1;
  }
  .programacoes .card:nth-child(5) {
    grid-area: 1 / 5 / span 1 / span 1;
  }
  .programacoes .card:nth-child(6) {
    grid-area: 2 / 4 / span 1 / span 2;
  }
  
  @media screen and (max-width: 800px) {
    .programacoes .gallery {
      grid-template-columns: repeat(3, 1fr);
      grid-template-rows: repeat(2, 220px);
    }
    .programacoes .card:nth-child(1) {
      grid-area: 1 / 1 / span 1 / span 1;
    }
    .programacoes .card:nth-child(2) {
      grid-area: 2 / 1 / span 1 / span 1;
    }
    .programacoes .card:nth-child(3) {
      display: none;
    }
    .programacoes .card:nth-child(4) {
      grid-area: 1 / 2 / span 1 / span 1;
    }
    .programacoes .card:nth-child(5) {
      grid-area: 1 / 3 / span 1 / span 1;
    }
    .programacoes .card:nth-child(6) {
      grid-area: 2 / 2 / span 1 / span 2;
    }
  }
  
  @media screen and (max-width: 500px) {
    .programacoes .gallery {
      grid-template-columns: repeat(2, 1fr);
      grid-template-rows: repeat(2, 150px);
    }
    .programacoes .card:nth-child(1) {
      grid-area: 1 / 1 / span 1 / span 1;
    }
    .programacoes .card:nth-child(2) {
      grid-area: 2 / 1 / span 1 / span 1;
    }
    .programacoes .card:nth-child(3) {
      display: none;
    }
    .programacoes .card:nth-child(4) {
      grid-area: 1 / 2 / span 1 / span 1;
    }
    .programacoes .card:nth-child(5) {
      display: none;
    }
    .programacoes .card:nth-child(6) {
      grid-area: 2 / 2 / span 1 / span 1;
    }
  }
 



  .localizacao{
    padding-top: 30px;
    width: 100%;
    display: flex;
    justify-content: center;
    height: auto;
    background-color: var(--cor-servicos);
  }
  .localizacao .pai{
    display: flex;
    justify-content: space-between;
    width: 80%;
  }
  .localizacao .pai .esquerda{
    font-family: "Russo One", sans-serif;
    color: white;
  }
  .localizacao .pai .esquerda #grande{
    color: yellow;
    font-size: 25pt;
    font-family: "Russo One", sans-serif;
  }
  .localizacao .pai .esquerda button{
    margin-top: 30px;
    height: 40px;
    border-radius: 10px;
    padding: 5px;
    background-color: yellow;
    font-family: "Russo One", sans-serif;
    color: var(--cor-banner);
    cursor: pointer;
  }
  .localizacao .pai .direita iframe{
    border-radius: 10px;
    border: none;
  }

/*LOCALIZAÇÃO*/
@media screen and (max-width: 1020px){
  body .localizacao .pai{
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  body .localizacao .pai .esquerda{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
  body .localizacao .pai .esquerda #grande{
    width: 80vw;
    text-align: center;
    font-size: 20pt;
    padding-bottom: 10px;
  }
  body .localizacao .pai .esquerda #medio{
    width: 80vw;
    text-align: center;
  }
  body .localizacao .pai .esquerda button{
    width: 50vw;
    height: 50px;
  }
}
@media screen and (max-width: 768px){
  body .localizacao .pai{
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  body .localizacao .pai .esquerda{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
  body .localizacao .pai .esquerda #grande{
    width: 80vw;
    text-align: center;
    font-size: 20pt;
    padding-bottom: 10px;
  }
  body .localizacao .pai .esquerda #medio{
    width: 80vw;
    text-align: center;
  }
  body .localizacao .pai .esquerda button{
    width: 50vw;
    height: 50px;
  }
}
@media screen and (max-width: 480px){
  body .localizacao .pai{
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  body .localizacao .pai .esquerda{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
  body .localizacao .pai .esquerda #grande{
    width: 80vw;
    text-align: center;
    font-size: 20pt;
    padding-bottom: 10px;
  }
  body .localizacao .pai .esquerda #medio{
    width: 80vw;
    text-align: center;
  }
  body .localizacao .pai .esquerda button{
    width: 50vw;
    height: 50px;
  }
}


/*IFRAME*/
@media screen and (max-width: 1020px){
  body .localizacao .pai .direita iframe{
    padding-top: 20px;
    width: 80vw;
    padding-top: 20px;
  }
}
@media screen and (max-width: 768px){
  body .localizacao .pai .direita iframe{
    padding-top: 20px;
    display: flex;
    flex-direction: column;
  }
}
@media screen and (max-width: 480px){
  body .localizacao .pai .direita iframe{
    padding-top: 20px;
    display: flex;
    flex-direction: column;
  }
}  








footer{
    width: 100%;
    color: var(--color-neutral-40);

    padding-top: 40px;
}
.footer-link{
    text-decoration: none;
}

#footer_content {
    background-color: var(--cor-botao-footer);
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    padding: 3rem 9rem; /*anteriormente 3rem 3.5rem*/
}

#footer_contacts h1{
    margin-bottom: 0.75rem;
}
#footer_contacts img{
    height: 150px;
    margin-top: 0px;
}
#footer_social_media{
    display: flex;
    gap: 2rem;
    margin-top: 1.5rem;
}
#footer_social_media .footer-link{
    display: flex;
    align-items: center;
    justify-content: center;
    height: 2.5rem;
    width: 2.5rem;
    color: var(--color-neutral-40);
    border-radius: 50%;
    transition: all 0.4s;
}
#footer_social_media .footer-link:hover{
    opacity: 0.8;
}
#footer_social_media .footer-link i{
    font-size: 1.25rem;
}

#instagram{
    background: linear-gradient(#7f37c9, #ff2992, #ff9807);
}
#facebook{
    background-color: #4267b3;
}
#whatsapp{
    background-color: #25d366;
}


.footer-list{
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    list-style: none;
}
.footer-list .footer-link{
    color: var(--color-neutral-30);
    transition: all 0.4s;
}
.footer-list .footer-link:hover{
    color: #7f37c9;
}

#footer_subscribe{
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}
#footer_subscribe p{
    color: var(--color-neutral-30);
}

#input_group{
    display: flex;
    align-items: center;
    background-color: var(--cor-botao-copyright);
    border-radius: 4px;
}
#input_group input{
    all: unset; /*tirar costumização padrão*/
    padding: 0.75rem;
    width: 100%;
}
#input_group button{
    background-color: var(--color-primary);
    border: none;
    color: var(--color-neutral-40);
    padding: 0px 1.25rem;
    font-size: 1.125rem;
    height: 100%;
    border-radius: 0px 4px 4px 0px;
    cursor: pointer;
    transition: all 0.4s;
}
#input_group button:hover{
    opacity: 0.8;
}

#footer_copyright{
    display: flex;
    justify-content: center;
    background-color: var(--cor-botao-copyright);
    font-size: 0.9rem;
    padding: 1.5rem;
    font-weight: 100;
}
#footer_copyright a{
    text-decoration: none;
    color: yellow;
}
@media screen and (max-width: 768px){
  #footer_content{
      grid-template-columns: repeat(2, 1fr);
      gap: 2rem;
  }
}
@media screen and (max-width: 500px){
  #footer_content{
      grid-template-columns: repeat(1, 1fr);
      padding: 3rem 2rem;
  }
  #footer_copyright{
      text-align: center;
  }

  #footer_contacts img{
      height: 150px;
  }
}