
    :root {
      --brand: #0a4df0;        /* primária */
      --brand-2: #0b7dda;      /* destaque */
      --azulperifa: #1d4484;     /* azul perifa */    
      --ink: #0b1324;          /* texto */
      --muted: #6b7280;        /* texto secundário */
      --bg: #f7f8fb;           /* fundo */
      --card: #ffffff;         /* cartões */
      --accent: #16a34a;       /* sucesso/cta secundário */
      --radius-xl: 18px;
      --radius-2xl: 26px;
      --shadow: 0 10px 30px rgba(2, 6, 23, .08);
    }

    * { box-sizing: border-box; }
    html, body { margin:0; padding:0; }
    body {
      font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, 'Helvetica Neue', Arial, sans-serif;
      color: var(--ink);
      background: var(--bg);
      line-height: 1.55;
    }

    header {
      position: sticky; top: 0; z-index: 60;
      backdrop-filter: saturate(1.2) blur(8px);
      
      border-bottom: 1px solid rgba(2,6,23,.06);
      background:var(--azulperifa);
    }
    .nav {
      max-width: 1200px; margin: 0 auto; padding: 14px 20px;
      display: flex; align-items: center; gap: 18px;
      
    }
    .brand { display:flex; align-items:center; gap:12px; font-weight: 800; letter-spacing:.2px; }
    .brand .logo {
      width: 42px; height: 42px; border-radius: 50%;
      background: radial-gradient(120% 120% at 30% 20%, var(--brand) 0%, var(--brand-2) 55%, #112270 100%);
      box-shadow: 0 8px 20px rgba(10,77,240,.35);
    }
    .nav a { text-decoration: none; color: var(--card); font-weight: 600; opacity: .85; }
    .nav a:hover { opacity: 1; }
    .nav .links { margin-left:auto; display:flex; gap:18px; align-items:center; }
    .cta { background: var(--brand); color: #fff; padding: 10px 16px; border-radius: 999px; box-shadow: 0 10px 20px rgba(10,77,240,.25); }
    .cta:hover { background: var(--brand-2); }

    /* Hero */
    .hero {
      max-width: 1200px; margin: 0 auto; padding: 56px 20px 32px;
      display: grid; grid-template-columns: 1.2fr 1fr; gap: 32px; align-items: center;
    }
    .badge { display:inline-flex; align-items:center; gap:8px; background:#eaf1ff; color: #1849ff; padding:6px 10px; border-radius: 999px; font-weight:700; font-size: 12px; letter-spacing:.3px; }
    .hero h1 { font-size: clamp(32px, 5vw, 54px); margin: 10px 0 14px; line-height:1.1; }
    .hero p { font-size: 18px; color: var(--muted); margin: 0 0 24px; }
    .hero .actions { display:flex; gap: 12px; flex-wrap: wrap; }
    .btn { display:inline-flex; align-items:center; gap:10px; padding: 14px 18px; border-radius: 12px; font-weight: 700; text-decoration: none; box-shadow: var(--shadow); border:1px solid rgba(2,6,23,.06); }
    .btn.primary { background: var(--brand); color:#fff; border-color: transparent; }
    .btn.primary:hover { background: var(--brand-2); }
    .btn.secondary { background: #fff; }

    .poster { position: relative; border-radius: var(--radius-2xl); overflow: hidden; box-shadow: var(--shadow); aspect-ratio: 4/3; background: #fff; }
    .poster img { width:100%; height:100%; object-fit: cover; display:block; }

    /* Sections */
    section { padding: 56px 20px; }
    .container { max-width: 1200px; margin: 0 auto; }
    .section-title { font-size: clamp(24px, 3.6vw, 36px); margin: 0 0 14px; }
    section-title-programacao { font-size: clamp(24px, 3.6vw, 36px); margin: 0 0 14px; color: #ffffff; }
    .section-sub { color: var(--muted); margin: 0 0 28px; }

    /* Features / Atividades */
    .features { display:grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
    .card { background: var(--card); border-radius: var(--radius-xl); padding: 20px; box-shadow: var(--shadow); border:1px solid rgba(2,6,23,.06); }
    .card h3 { margin: 6px 0 8px; font-size: 18px; }
    .card p { margin: 0; color: var(--muted); font-size: 14px; }

    /* Programação */
    .schedule { display: grid; grid-template-columns: 1fr 1fr; /* duas colunas (manhã/tarde) */ gap: 16px;}
    #programacao {background: var(--azulperifa); border-radius: 40px; }
    /* Cada "slot" (horário) */
    .slot {  background: var(--card);  border-radius: var(--radius-xl);  padding: 16px;  border: 1px solid rgba(2, 6, 23, 0.06);  box-shadow: var(--shadow);  display: flex; margin-bottom: 10px; gap: 16px;  align-items: center;}

    /* Horário destacado */
    .hour {  font-weight: 800;  min-width: 78px;  padding: 10px 12px;  border-radius: 10px;  background: #eef2ff;  color: #1d4ed8;  text-align: center;}

.logo-strip {
  max-width: 1440px;
  width: 100%;
  height: 110px;
  background: #fff;
  display: flex;
  justify-content: space-around;
  align-items: center;
  margin: 0 auto;
  opacity: 1;
  border-radius: 8px; /* opcional, para bordas mais suaves */
}

.logo-strip img {
  height: 60px;          /* ajustável conforme proporção das logos */
  max-width: 220px;      /* evita logos muito largas */
  object-fit: contain;
  filter: none;          /* mantém as cores originais */
}
.logo-strip-container{
  background: #fff;
}
    
    /* Sobre*/
    .texto-video-container { display: flex; align-items: center;  justify-content: space-between;  gap: 30px;  flex-wrap: wrap; /* Permite empilhar em telas pequenas */}
    .texto {  flex: 1 1 50%;}
    .video2 {  flex: 1 1 45%;  max-width: 560px;}
.video2 .video-wrapper {  position: relative;  width: 100%;  aspect-ratio: 16 / 9;  overflow: hidden;  border-radius: 12px;}

.video2 .video-wrapper iframe {  position: absolute;  top: 0;  left: 0;  width: 100%;  height: 100%;  border: 0;}
    
    /* Vídeos */
    .video {  border-radius: 12px;  overflow: hidden; flex: 1 1 45%;  max-width: 560px;  height: 300px; /* ou a altura que você quiser */}
    .video-wrapper { position: relative;  width: 100%;  aspect-ratio: 16 / 9; /* Mantém formato de vídeo */  overflow: hidden;  border-radius: 12px;}
    .video-wrapper iframe {  position: absolute;  top: 0;  left: 0;  width: 100%;  height: 100%;  border: 0;}
    


    /* Galeria */
    .gallery-grid { display:grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
    .gallery-grid img { width:100%; height: 180px; object-fit: cover; border-radius: 12px; cursor: pointer; }

    /* Lightbox */
    .lightbox { position: fixed; inset: 0; background: rgba(2,6,23,.85); display: none; align-items: center; justify-content: center; z-index: 70; }
    .lightbox.open { display: flex; }
    .lightbox img { max-width: 92vw; max-height: 86vh; border-radius: 16px; }
    .lightbox .close { position: absolute; top: 16px; right: 16px; background: #fff; border: none; padding: 10px 14px; border-radius: 999px; font-weight: 800; cursor:pointer; }

    /* Revista (PDF) */
    
.magazine {
  max-height: 400px;       /* altura máxima */
  overflow: hidden;         /* esconde conteúdo que ultrapassar o limite */
  border-radius: 12px;      /* opcional, para manter cantos arredondados */
  display: flex;            /* centraliza conteúdo se precisar */
  justify-content: center;
  align-items: center;
}
.container.magazine {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 20px;
  align-items: center;     /* vertical */
  justify-content: center; /* horizontal */
  width: 100%;
}
.container.magazine img {
  align-items: center;
}
    /*.magazine .cover { border-radius: var(--radius-2xl); overflow:hidden; box-shadow: var(--shadow); aspect-ratio: 4/5; background: #e5e7eb; display:flex; align-items:center; justify-content:center; font-weight:800; color:#111827; }*/
    .download { display:inline-flex; align-items:center; gap:12px; background: var(--accent); color: #fff; padding: 14px 18px; border-radius: 12px; text-decoration: none; font-weight: 800; box-shadow: 0 10px 20px rgba(22,163,74,.25); }
    .download:hover { filter: brightness(1.05); }
    /* Revista (capa) */
        /*.magazine .cover { border-radius: var(--radius-2xl); overflow:hidden; box-shadow: var(--shadow); aspect-ratio: 4/5; background: #e5e7eb; display:flex; align-items:center; justify-content:center; font-weight:800; color:#111827; }*/
    .capa_revista {
      width: 100%;              /* largura pequena */
      aspect-ratio: 4/5;        /* mantém proporção */
      border-radius: var(--radius-2xl);
      overflow: hidden;
      box-shadow: var(--shadow);
      display: flex;
      align-items: center;
      justify-content: center;
      background: #e5e7eb;
    }
    .capa_revista {
  width: 60%;           /* Reduz a largura para 60% do espaço disponível */
  max-width: 320px;     /* Largura máxima (ajuste conforme necessário) */
  aspect-ratio: 4/5;
  border-radius: var(--radius-2xl);
  overflow: hidden;
  box-shadow: var(--shadow);
  display: flex;
  align-items: center;
  justify-content: center;
  background: #e5e7eb;
}
    
    .capa_revista img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }
    /* Local/Mapa */
    .map { border: 0; width: 100%; height: 360px; border-radius: var(--radius-2xl); box-shadow: var(--shadow); }

footer {
  background: #0b1020;
  color: #cbd5e1;
  padding: 24px 16px;
  margin-top: 32px;
}
.footer-container {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
}
.footer-brand,
.footer-prod,
.footer-info {
  display: flex;
  align-items: center;
  gap: 14px;
}
.footer-brand > div {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.footer-logo51 {
  height: 32px;
}
.footer-logo {
  height: 52px;
}
.subtitle {
  font-size: 14px;
  opacity: 0.85;
}
.legal {
  font-size: 13px;
  opacity: 0.8;
  margin-top: 4px;
}
/* Responsivo */
@media (max-width: 768px) {
  .footer-container {
    flex-direction: column;
    align-items: flex-start;
    gap: 18px;
  }
  .footer-brand,
  .footer-prod,
  .footer-info {
    justify-content: flex-start;
  }
}


/* Responsivo */
@media (max-width: 980px) {
  .foot {
    flex-direction: column;
    gap: 14px;
  }
}

/* Responsivo */
@media (max-width: 980px) {
  .foot {
    flex-direction: column;
    gap: 14px;
  }
}
    @media (max-width: 560px) {
      .features { grid-template-columns: 1fr; }
      .gallery-grid { grid-template-columns: 1fr; }
    
    
    }
/* ===== MENU RESPONSIVO ===== */
/* ========== MENU MOBILE ========== */

/* Esconde o menu por padrão */
.nav .links {
  display: none;
}

/* Exibe e estiliza ao abrir menu hambúrguer (classe .open adicionada via JS) */
.nav .links.open {
  display: flex;
  flex-direction: column;
  width: 90%;            
  gap: 8px;
  margin: 0 auto;        
}


/* Regras específicas para telas menores */
@media (max-width: 768px) {
  .nav {
    flex-direction: column;
    align-items: center;
    gap: 10px;
  }

  .videos-wrapper {
    display: block !important; /* garante que apareça em telas pequenas */
  }

  .nav .links {
    margin-left: 0;
    flex-direction: column;
    width: 100%;
    gap: 8px;
  }

  .nav .links a:hover,
  .nav .links a:focus {
    background: linear-gradient(90deg, var(--brand-2), var(--brand));
    transform: scale(1.025);
    color: #fff;
  }

  .schedule {
    grid-template-columns: 1fr; /* apenas uma coluna */
  }

  .texto-video-container {
    flex-direction: column; /* empilha texto e vídeo */
    text-align: justify;
  }

    .video2 {
    width: 100%;
    max-width: 100%;
    min-height: 200px; /* Garante altura mínima visível */
    height: auto;
  }
  .video2 .video-wrapper {
    width: 100%;
    aspect-ratio: 16/9;
    min-height: 200px; /* Garante espaço para o vídeo */
    height: auto;
    display: block;
  }

  .video {
    width: 100% !important;
    max-width: 430px !important;
    min-width: 220px !important;
    margin: 10% auto auto 2% !important;
    height: auto !important;
    aspect-ratio: 16 / 9;
  }
    .video iframe {
    width: 100% !important;
    height: 100% !important;
    border: 0;
    display: block;
  }
   .logo-strip-container {
    display: none;
  }
    .hero {
    display: flex;
    flex-direction: column;
    gap: 24px;
    padding: 36px 20px 24px;
  }
  .hero > div,
  .poster {
    width: 100%;
    max-width: 100%;
  }
  .poster {
    height: 200px;
    max-width: 100%;
    margin: 0 auto;
  }

}


/* Fallback para desktop: mantém os links em linha se não estiver em modo hambúrguer */
@media (min-width: 769px) {
  .nav .links {
    display: flex !important;
    flex-direction: row;
    width: auto;
    gap: 18px;
  }

  /*.nav .links a {
    padding: 8px 16px;
    font-size: 16px;
    border-radius: 8px;
    box-shadow: none;
    background: var(--brand);
    color: #fff;
    margin: 0;
    transition: background 0.2s;
  }
  .nav .links a:hover,
  .nav .links a:focus {
    background: var(--brand-2);
    color: #fff;
  }*/
}
#faq {
    padding: 60px 20px;
    background: #f7f8fb;
  }
  .faq {
    max-width: 800px;
    margin: 0 auto;
  }
  .faq-item {
    border-bottom: 1px solid #ddd;
  }
  .faq-question {
    width: 100%;
    text-align: left;
    background: none;
    border: none;
    padding: 15px;
    font-size: 16px;
    font-weight: bold;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .faq-question::after {
    content: "+";
    font-size: 20px;
  }
  .faq-item.active .faq-question::after {
    content: "-";
  }
  .faq-answer {
    display: none;
    padding: 0 15px 15px;
    font-size: 15px;
    color: #444;
  }
  .faq-item.active .faq-answer {
    display: block;
  }
/*  .magazine .cover {
  aspect-ratio: 4/5;
  max-width: 70%  
}*/

  .poster {
    position: relative;
    width: 100%;
    max-width: 600px; /* ajuste conforme necessário */
    height: 350px;
    overflow: hidden;
    border-radius: 12px;
  }

.carousel img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 0.5s ease-in-out;
}
.carousel img.active {
  opacity: 1;
}
.carousel img[src$=".svg"] {
  object-fit: contain;
  background: #fff; /* para svg transparente */
  padding: 20px;    /* ajuste para dar margem interna */
  box-sizing: border-box;
}


@media (max-width: 600px) {
  .poster {
    margin-left: auto;
    margin-right: auto;
  }
}

.pvideos {
  display: flex;
  justify-content: center;   /* Centraliza horizontalmente */
  align-items: center;       /* Centraliza verticalmente */
  min-height: 60vh;          /* Altura mínima maior para seção */
  width: 100%;
  padding: 40px 0;
}

.pvideos > * {
  max-width: 900px;    /* Ajusta largura máxima do conteúdo interno */
  width: 100%;
}




