/* Seu css/responsivo-cursos.css */

/* Regras gerais para o menu mobile */
.nav-area {
  transition: transform 0.3s ease-in-out, opacity 0.3s ease-in-out, visibility 0.3s ease-in-out;
}

/* Esconde o menu de navegação por padrão em mobile */
.nav-area.nav-mobile-hidden {
  display: none;
}

/* Estilos para o botão de hambúrguer (escondido por padrão em desktop, visível em mobile) */
.hamburger-menu {
  display: none;
  /* Ocultar por padrão em desktop */
}

/* Mostrar o menu quando a classe 'nav-mobile-visible' for adicionada via JS */
.nav-area.nav-mobile-visible {
  display: flex !important;
  flex-direction: column;
  position: fixed;
  /* Use fixed para cobrir toda a tela */
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(30, 41, 59, 0.9);
  /* Fundo do menu mobile */
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.4);
  z-index: 1000;
  padding: 80px 0 20px;
  /* Ajuste para dar espaço ao header fixo */
  align-items: center;
  /* Centraliza itens no menu mobile */
  overflow-y: auto;
  /* Permite rolagem se o menu for longo */
  opacity: 1;
  visibility: visible;
}

.nav-area.nav-mobile-visible nav ul {
  flex-direction: column;
  /* Itens da lista em coluna */
  width: 100%;
  /* Ocupa a largura total do menu mobile */
  align-items: center;
}

.nav-area.nav-mobile-visible nav ul li {
  width: 90%;
  /* Largura dos itens do menu */
  text-align: center;
  margin: 8px 0;
  /* Espaçamento entre os itens */
}

.nav-area.nav-mobile-visible nav ul li a {
  padding: 12px 0;
  display: block;
  width: 100%;
  box-sizing: border-box;
  font-size: 1.3rem;
  /* Tamanho da fonte para mobile */
}

.nav-area.nav-mobile-visible hr {
  display: none;
  /* Esconder as linhas de separação no menu mobile */
}

/* Estilos para o submenu no mobile */
.nav-area.nav-mobile-visible .submenu {
  position: static;
  /* Tira a posição absoluta */
  visibility: hidden;
  /* Oculta por padrão no mobile */
  opacity: 0;
  /* Oculta por padrão no mobile */
  pointer-events: none;
  /* Desativa eventos de clique */
  width: 100%;
  /* Largura total */
  background-color: #1a2233;
  /* Fundo diferente para o submenu */
  border: none;
  box-shadow: none;
  padding: 0;
  overflow: hidden;
  /* Para a animação de altura */
  max-height: 0;
  /* Para a animação de altura */
  transition: max-height 0.4s ease-out, opacity 0.3s ease;
  /* Animação suave */
}

.nav-area.nav-mobile-visible .submenu.active {
  visibility: visible;
  /* Mostra quando ativo */
  opacity: 1;
  /* Mostra quando ativo */
  pointer-events: auto;
  /* Ativa eventos de clique */
  max-height: 800px;
  /* Um valor grande o suficiente para exibir todo o submenu */
  padding: 10px 0;
  /* Preenchimento quando aberto */
}

.nav-area.nav-mobile-visible .submenu li a {
  font-size: 1.1rem;
  /* Tamanho da fonte dos itens do submenu */
  padding: 10px 20px;
  text-align: center;
  /* Alinhar itens do submenu ao centro */
  justify-content: center;
  /* Centraliza o ícone e o texto */
}

.nav-area.nav-mobile-visible .submenu li a:hover {
  background-color: var(--cor-primaria);
  color: var(--cor-secundaria);
  padding-left: 20px;
  /* Mantém o padding centralizado no hover */
}

/* Remove hover effects para submenus no mobile (quando o dispositivo é touchscreen) */
@media (hover: none) and (pointer: coarse) {

  .menu-item:hover .submenu,
  .menu-item .submenu:hover {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
  }
}

/* --- MEDIA QUERIES --- */

/* Para telas até 1024px (Laptops menores, Tablets Paisagem) */
@media (max-width: 1024px) {
  
  .container-header {
    max-width: 100%;
    align-items: flex-start center;
    justify-content: start;
    margin-left: 40px;
    gap: 6%;
  }

  header nav ul {
    font-size: 0.75rem;
    gap: 20px;
  }

  nav ul li {
    white-space: nowrap;
  }

  .logo {
    width: 200px;
  }


  nav hr {
    height: 30px;
  }

  .section-curso {
    padding: 30px 40px;
    gap: 40px;
  }

  .section-curso img {
    max-width: 50%;
  }

  .section-curso .texto-curso h2 {
    font-size: 2rem;
  }

  .section-curso .texto-curso p {
    font-size: 1rem;
  }

  .section-chamada {
    padding: 40px;
    gap: 40px;
  }

  .frase-modernizada h2 {
    font-size: 2.4rem;
  }

  .frase-modernizada p {
    font-size: 1.1rem;
  }

  .imagem-emerson img {
    width: 320px;
  }

  .section-video {
    padding: 60px 40px;
  }

  .video-container.aguardando-video {
    height: 400px;
  }

  .texto-em-breve {
    font-size: 2rem;
  }
}


/* Para telas até 992px (Tablets Retrato, Mobile Landscape grande) */
@media (max-width: 992px) {
  .container-header {
    margin-left: 20px;
    margin-right: 20px;
    justify-content: space-between;
  }

  /* Oculta a navegação padrão e mostra o hambúrguer */
  .nav-area {
    display: none;
    /* Esconde o menu de navegação padrão em mobile */
  }

  .hamburger-menu {
    display: block;
    /* Mostra o hambúrguer */
  }

  .logo {
    width: 180px;
    /* Ajuste o tamanho do logo */
  }

  /* --- SEÇÃO DO CURSO (IMAGEM + TEXTO) --- */
  .section-curso {
    flex-direction: column;
    /* Empilha imagem e texto */
    text-align: center;
    /* Centraliza o texto */
    padding: 5px 20px;
    gap: 30px;
  }

  .section-curso img {
    max-width: 55vw;
    /* Ajusta a largura da imagem */
    margin: 0 auto;
    /* Centraliza a imagem */
  }

  .section-curso .texto-curso {
    height: auto;
    /* Altura automática */
    padding-bottom: 0;
    /* Remove padding inferior */
  }

  .section-curso .texto-curso h2 {
    font-size: 2rem;
  }

  .section-curso .texto-curso p {
    font-size: 1rem;
  }

  /* --- SEÇÃO CHAMADA (FRASE + FOTO EMERSON) --- */
  .section-chamada {
    flex-direction: column-reverse;
    /* Empilha e inverte a ordem */
    padding: 5px 20px;
    gap: 30px;
  }

  .frase-modernizada {
    text-align: center;
    border-left: none;
    border-top: 4px solid var(--cor-primaria);
    padding: 20px;
  }

  .frase-modernizada h2 {
    font-size: 2rem;
  }

  .frase-modernizada p {
    font-size: 1rem;
  }

  .imagem-emerson{
    height: 430px;
  }

  .imagem-emerson img {
    width: 280px;
    /* Ajusta o tamanho da imagem */
    margin: 0 auto;
    /* Centraliza a imagem */
  }

  /* --- SEÇÃO VÍDEO --- */
  .section-video {
    padding: 40px 20px;
  }

  .video-container.aguardando-video {
    height: 300px;
  }

  .texto-em-breve {
    font-size: 1.5rem;
  }

  .botao-hotmart {
    font-size: 1.2rem;
    padding: 10px 20px;
  }

  /* Rodapé */
  footer.rodape {
    padding: 20px 10px;
  }

  footer.rodape p {
    font-size: 0.9rem;
  }

  footer.rodape .redes a {
    font-size: 1.2rem;
    margin: 0 5px;
  }

  .whatsapp {
    width: 50px;
    height: 50px;
    font-size: 25px;
    bottom: 15px;
    right: 15px;
  }

  .btn-topo {
    width: 50px;
    height: 50px;
    font-size: 25px;
    bottom: 80px;
    right: 15px;
  }
}

/* Para telas até 768px */
@media (max-width: 768px) {

  .section-curso .texto-curso h2 {
    font-size: 1.8rem;
  }

  .section-curso .texto-curso p {
    font-size: 0.95rem;
  }

  .frase-modernizada h2 {
    font-size: 1.8rem;
  }

  .frase-modernizada p {
    font-size: 0.9rem;
  }

  .imagem-emerson img {
    width: 250px;
  }

  .video-container.aguardando-video {
    height: 250px;
  }

  .texto-em-breve {
    font-size: 1.3rem;
  }
}


/* Para telas até 480px (Celulares pequenos a médios) */
@media (max-width: 480px) {

  .section-curso {
    padding: 5px 15px;
  }

  .section-curso img{
    max-width: 250px;
  } 

  .section-curso .texto-curso h2 {
    font-size: 1.5rem;
  }

  .section-curso .texto-curso p {
    font-size: 0.85rem;
  }

  .section-chamada {
    padding: 10px 15px;
  }

  .frase-modernizada h2 {
    font-size: 1.5rem;
  }

  .frase-modernizada p {
    font-size: 0.8rem;
  }

  .imagem-emerson{
    height: 345px;
  }

  .imagem-emerson img {
    width: 200px;
  }

  .section-video {
    padding: 30px 15px;
  }

  .video-container.aguardando-video {
    height: 200px;
  }

  .texto-em-breve {
    font-size: 1.1rem;
  }

  .botao-hotmart {
    font-size: 1rem;
    padding: 8px 18px;
  }

  footer.rodape p {
    font-size: 0.75rem;
  }

  footer.rodape .redes a {
    font-size: 1rem;
    margin: 0 4px;
  }
}