:root{
  --bg:#0a0a0e;         /* fundo geral escuro */
  --ink:#12131a;        /* blocos alternados */
  --txt:#e8e8ee;
  --muted:#b8b8c4;

  --grad: linear-gradient(90deg, #444, #777); /* degradê cinza escuro → claro */
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;height:100%}
body{
  font-family: Montserrat, system-ui, -apple-system, sans-serif;
  background: var(--bg);
  color: var(--txt);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

a{
    color:inherit;
    text-decoration:none;
}
    
img{
    max-width:100%;
    height:auto;
    display:block;
}

.container{
    max-width:1200px;
    margin:0 auto;
    padding:56px 20px;
}

.container-services{
    display: grid;
    max-width:400px;
    margin:0 auto;
    padding:56px 20px;
}

.block{
    padding:5px 0;}
.block--dark{background:var(--bg)}
.block--ink{background:var(--ink)}

h1,h2,h3{margin:0 0 12px;
        line-height:1.2;
        text-align: center;
}
h1{font-size:44px;font-weight:800;letter-spacing:.2px; text-align: center;}
h2{
  font-size:28px;
  font-weight:800;
  border-left:6px solid transparent;
  padding-left:12px;
  text-align: center;
}

/* aplica o degradê somente em h2 normais */
h2:not(.titulo-diferenciais){
  background-image: var(--grad);
  background-clip: text;
  -webkit-background-clip: text;
  color: #ffffff; /* se preferir o texto com degradê visível, troque para 'transparent' */
}
h3{font-size:18px;font-weight:700}

p{color:var(--txt);opacity:.95}
.muted{color:var(--muted)}

.hero p{font-size:18px;opacity:.9;margin:0 0 24px}

/* Botões */
.btn{
  display:inline-block;padding:12px 22px;border-radius:999px;
  font-weight:800;letter-spacing:.3px
}
.btn--grad{
  background:linear-gradient(90deg, #0d3c61, #1a5a99);
  color:#fff;
  box-shadow:0 12px 28px rgba(0,0,0,.28);
  transition: transform .4s ease, filter .2s ease;
}
.btn--grad:hover{
  transform: scale(1.02);
  filter: brightness(1.05);
}
.btn--outline{background:transparent;border:2px solid #777;color:var(--txt)}

.btn--grad-blue {
  background: linear-gradient(90deg, #0d3c61, #1a5a99);
  color: #fff;
  box-shadow: 0 12px 28px rgba(0,0,0,.28);
  transition: transform .2s ease, filter .2s ease;
}
.btn--grad-blue:hover {
  transform: scale(1.08);
  filter: brightness(1.05);
}


/* Bullets & grids */
.bullets{padding-left:18px}
.bullets li{list-style:disc;margin:8px 0}

.grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:14px;
}

/* Cards diferenciais */
.cards{
  display:grid;
  list-style:none;
  padding-left:0;
  gap:18px;
  margin-top:18px;
}
.cards li{
  padding:20px;
  background: rgba(255,255,255,.02);
  border:1px solid rgba(255,255,255,.06);
  border-radius:16px;
  box-shadow:0 10px 30px rgba(0,0,0,.25);
  color:#f0f0f0;
  text-align:center;
}
/* desktop: força 3 colunas (3x2) */
@media (min-width:1024px){
  .cards{ grid-template-columns: repeat(3, 1fr); }
}

/* Pricing (grade dos pacotes) */
.pricing{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); /* mobile/tablet responsivo */
  gap:20px;
  margin-top:18px;
}
/* desktop: 3 colunas; 4º card centralizado na linha de baixo → fica 3 em cima e 2 embaixo */
@media (min-width:1024px){
  .pricing{ grid-template-columns: repeat(3, 1fr); }
  .pricing > :nth-child(4){ grid-column: 1; }
}

/* Ajusta blocos escuros consecutivos para parecer uma seção única */
.block.block--dark + .block.block--dark {
  margin-top: -80px;   /* sobrepõe um pouco a margem entre as seções */
  padding-top: -10px;   /* diminui o espaço no topo da segunda */
}


/* Subtítulo que separa as linhas da grade de preços */
.pricing-subtitle{
  grid-column: 1 / -1;        /* ocupa a largura inteira da grade */
  text-align: center;
  margin: 28px 0 12px;
}


.price-card{
  background: rgba(255,255,255,.02);
  border:1px solid rgba(255,255,255,.06);
  border-radius:18px;
  padding:18px;
  position:relative;
  overflow:hidden;
}
.price-card::after{
  content:"";
  position:absolute;inset:auto -40px -40px auto;
  width:160px;height:160px;border-radius:50%;
  background: radial-gradient(closest-side, rgba(255,255,255,.08), transparent 70%);
  transform:rotate(25deg);
}
.price-card h3{
  font-size:20px;margin-bottom:8px;
  background-image:var(--grad);
  -webkit-background-clip:text;
  background-clip:text;
  color: #f0f0f0;
}
.price-card .time{color:var(--muted);margin:0 0 4px}
.price-card .value{font-size:24px;font-weight:800;margin:0 0 4px}
.price-card .wknd{font-size:14px;color:var(--muted);margin:0 0 12px}
.price-card .features{padding-left:18px;margin:0 0 16px}
.price-card .features li{list-style:disc;margin:6px 0}
.price-card .btn{width:100%;text-align:center}

/* Intro (vídeo splash) */
.intro{
  position:fixed;inset:0;background:#000;
  display:flex;align-items:center;justify-content:center;z-index:9999;
}
.intro__video{
  width:min(820px,90vw);height:auto;object-fit:contain;display:block;margin:0 auto;
}
.page.is-hidden{opacity:0;visibility:hidden}
.page.is-visible{opacity:1;visibility:visible;transition:opacity .6s ease}

/* Vídeo do topo */
.hero-copy {
  padding: 1px 1px;
  text-align: center;
}

.hero-video {
  display: block;
  width: 100%;
  height: auto;
  margin: 0 auto 24px;
  max-width: 1200px;
  object-fit: contain;
  padding: 0 5px;
  border-radius: 12px;
}

/* Títulos do topo */
.hero-copy h1 {
  font-size: 40px;
  font-weight: 800;
  margin: 20px 0 12px;
  padding-top: 20px;
}
.hero-copy h2 {
  font-size: 20px;
  font-weight: 400;
  margin: 0 0 24px;
  color: var(--muted);
}

/* Responsividade */
@media (max-width: 1024px) {
  .hero-video {
    max-height: 50vh;       /* ocupa metade da tela em tablets */
    object-fit: cover;      /* cobre sem distorcer (pode cortar um pouco) */
  }
}

@media (max-width: 768px) {
  .hero-video {
    max-height: 32vh;       /* limita bem no celular */
    margin: 0 auto 14px;
    padding: 0;             /* remove padding lateral */
    object-fit: cover;      /* cobre mantendo proporção */
  }
  .hero-copy h1 {
    font-size: clamp(22px, 6vw, 28px);
    margin: 12px 0 6px;
    padding-top: 8px;
  }
  .hero-copy h2 {
    font-size: clamp(14px, 4vw, 18px);
    margin: 0 0 14px;
  }
  .btn {
    padding: 10px 18px;
    font-size: 14px;
  }
}


/* Footer */
.footer{display:flex;
justify-content:center;
padding:28px 20px;
opacity:.75}

/* Título específico sem degradê */
.titulo-diferenciais{
  background:none !important;
  -webkit-background-clip:unset !important;
  background-clip:unset !important;
  color:#ffffff !important;
  padding-bottom: 25px;
}

/* ---- Serviços Adicionais (caixas, lado a lado no desktop, empilhadas no mobile) ---- */
.addon-list {
  list-style: none;
  padding: 0;
  margin: 18px auto 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); /* várias colunas adaptáveis */
  gap: 20px;
  max-width: 820px;   /* largura confortável */
}

.addon-card {
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 16px;
  padding: 18px 20px;
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
  text-align: center;
}

.addon-card h3 { 
  margin: 0 0 6px; 
  font-size: 18px; 
  font-weight: 800; 
}
.addon-card p { 
  margin: 0 0 6px; 
  color: var(--muted); 
}
.addon-card strong { 
  display: inline-block; 
  margin-top: 2px; 
  font-size: 18px; 
}


/* Condições: segue o mesmo visual das caixas */
.terms-list{
  list-style: none;
  padding: 0;
  margin: 14px auto 0;
  display: grid;
  gap: 12px;
  max-width: 820px;
}
.terms-list li{
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 12px;
  padding: 12px 16px;
}

/* ---- CTA “Vamos gravar?”: força tudo centralizado ---- */
.cta .container{ text-align: center; }
.cta p{ margin: 0 0 18px; }


/* ---- Serviços Adicionais (ícones) ---- */
.addon-list{
  list-style: none;
  padding: 0;
  /* centraliza a lista e iguala a largura às outras seções */
  max-width: 960px;           /* ↑ pode ajustar para 900/980 se quiser */
  margin: 18px auto 0;

  display: grid;
  grid-template-columns: repeat(2, minmax(280px, 1fr)); /* 2 colunas fixas no desktop */
  gap: 20px 24px;

  justify-content: center;    /* centraliza o conjunto das colunas */
  align-items: start;
}

/* responsivo: em telas menores, empilha */
@media (max-width: 700px){
  .addon-list{
    grid-template-columns: 1fr;
    max-width: 520px;         /* mantém centrado e com respiro no mobile */
  }
}


.addon-card{
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 16px;
  padding: 18px 20px;
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
  text-align: center;
}

.addon-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:56px;height:56px;
  border-radius:14px;
  background: rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  box-shadow: 0 8px 22px rgba(0,0,0,.25) inset;
  margin-bottom:10px;
}

.addon-icon svg{
  width:28px;height:28px;
  fill: none;
  stroke: #cfd2da;     /* cinza claro */
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* realce no hover do card */
.addon-card:hover .addon-icon{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.12);
}
.addon-card:hover .addon-icon svg{
  stroke: #ffffff;
}

/* Condições comerciais em “caixinhas” */
.terms-list{
  list-style: none;
  padding: 0;
  margin: 14px auto 0;
  display: grid;
  gap: 12px;
  max-width: 820px;
}
.terms-list li{
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 12px;
  padding: 12px 16px;
}

/* CTA centralizado (garantia) */
.cta .container{ text-align:center; }
.cta p{ margin:0 0 18px; }

.center-text {
  text-align: center;
}

/* Galeria Estrutura & Equipamentos */
.estrutura-galeria {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-top: 24px;
}

.estrutura-galeria img {
  width: 100%;
  height: auto;
  border-radius: 10px;
  object-fit: cover;
  box-shadow: 0 8px 20px rgba(0,0,0,0.35);
}

/* Responsividade: no celular (até 768px) as imagens ficam 1 por linha */
@media (max-width: 768px) {
  .estrutura-galeria {
    grid-template-columns: 1fr;
  }
}

/* ===== Carrossel Estrutura ===== */
.estrutura-carousel{
  position: relative;
  margin-top: 1px;
  user-select: none;
}

.estrutura-carousel .viewport {
  overflow: hidden;
  border-radius: 12px;
  box-shadow: 0 10px 28px rgba(0,0,0,.35);
  max-width: 1500px;    /* define o limite */
  margin: 0 auto;       /* centraliza */
}

.estrutura-carousel .track{
  display: flex;
  transition: transform .5s ease;
  will-change: transform;
  /* sem justify-content aqui! */
}

.estrutura-carousel .slide{
  flex: 0 0 auto;       /* largura natural do conteúdo */
  margin: 0 8px;        /* espaçamento entre fotos */
}

.estrutura-carousel img{
  display: block;
  width: 400px;
  height: auto;
  border-radius: 10px;
}

/* Setas */
.estrutura-carousel .nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(0,0,0,.45);
  color: #fff;
  border: 0;
  width: 40px; height: 40px;
  border-radius: 999px;
  display: grid; place-items: center;
  cursor: pointer;
  transition: filter .2s ease, background .2s ease;
}
.estrutura-carousel .nav:hover{ filter: brightness(1.15); }
.estrutura-carousel .prev{ left: 10px; }
.estrutura-carousel .next{ right: 10px; }

/* Bolinhas */
.estrutura-carousel .dots{
  display: flex; gap: 8px;
  justify-content: center;
  margin-top: 10px;
}
.estrutura-carousel .dots button{
  width: 8px; height: 8px; border-radius: 999px;
  background: rgba(255,255,255,.35);
  border: 0; cursor: pointer;
  transition: transform .2s ease, background .2s ease;
}
.estrutura-carousel .dots button.active{
  background: #fff;
  transform: scale(1.25);
}

/* ===== Modal de Serviços ===== */
.service-modal{
  position: fixed; inset: 0;
  display: none;
  z-index: 9999;
}
.service-modal.is-open{ display: block; }

.service-modal__overlay{
  position: absolute; inset: 0;
  background: rgba(0,0,0,.65);
  backdrop-filter: blur(2px);
}

.service-modal__dialog{
  position: relative;
  width: min(920px, 92vw);
  max-height: 90vh;                 /* nunca passa da tela */
  margin: 0 auto;                   /* centraliza horizontal */
  top: 50%; transform: translateY(-50%); /* centraliza vertical */
  background: #111217;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  box-shadow: 0 20px 60px rgba(0,0,0,.45);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}


.service-modal__img{
  display: block;
  width: 100%;
  height: 180px;
  object-fit: cover;
}

.service-modal__content{
  padding: 18px 20px 22px;
}

.service-modal__title{
  margin: 0 0 8px;
  font-size: 22px;
  font-weight: 800;
}

.service-modal__body{
  color: var(--muted);
  line-height: 1.6;
  font-size: 15px;
}

.service-modal__close{
  position: absolute; top: 8px; right: 8px;
  width: 36px; height: 36px;
  border-radius: 999px;
  border: 0;
  background: rgba(255,255,255,.08);
  color: #fff;
  font-size: 22px;
  cursor: pointer;
  transition: filter .2s ease;
}
.service-modal__close:hover{ filter: brightness(1.15); }

/* link de serviço (opcional, só estiliza o hover) */
.service-link {
  text-decoration: none;
  border-bottom: 1px dotted rgba(255,255,255,.35);
  display: inline-block;                  /* necessário para o transform funcionar */
  transition: transform 0.2s ease, 
              filter 0.2s ease;           /* anima suavemente */
}

.service-link:hover {
  filter: brightness(1.1);
  transform: scale(1.08);                 /* aumenta ~8% no hover */
}



/* utilitário: h1 escondido para SEO */
.visually-hidden{
  position:absolute!important;clip:rect(1px,1px,1px,1px);
  padding:0!important;border:0!important;height:1px!important;width:1px!important;overflow:hidden;
}

/* === Serviços (grid responsivo) === */

/* Remove bullets e padding padrão */
#servicos .bullets {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr); /* desktop: 4 colunas */
  gap: 20px 40px;                        /* espaço entre linhas/colunas */
  justify-items: start;                  /* alinhado à esquerda */
}

/* Cada item da lista */
#servicos .bullets li {
  display: flex;
  justify-content: flex-start;
}

/* Link com ícone */
#servicos .service-link {
  position: relative;
  display: inline-flex;
  align-items: center;
  padding-left: 30px; /* espaço pro ícone */
  text-decoration: none;
  border-bottom: 1px dotted rgba(255,255,255,.35);
  transition: transform .2s ease, filter .2s ease;
  font-size: 18px;
}

#servicos .service-link:hover {
  filter: brightness(1.1);
  transform: scale(1.08);
}

/* Ícones (PNG) antes do texto */
#servicos .service-link::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 22px;
  height: 22px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

/* Ícones por serviço */
#servicos .service-link[data-service="podcast"]::before {
  background-image: url("/estudio/assets/icons/podcast.png");
}
#servicos .service-link[data-service="transmissoes-ao-vivo"]::before {
  background-image: url("/estudio/assets/icons/live-streaming.png");
}
#servicos .service-link[data-service="videoaulas"]::before {
  background-image: url("/estudio/assets/icons/online-learning.png");
}
#servicos .service-link[data-service="talkshows"]::before {
  background-image: url("/estudio/assets/icons/podcaster.png");
}
#servicos .service-link[data-service="producoes-digitais"]::before {
  background-image: url("/estudio/assets/icons/podcaster (1).png");
}
#servicos .service-link[data-service="reels-tiktok"]::before {
  background-image: url("/estudio/assets/icons/reels.png");
}
#servicos .service-link[data-service="infoprodutos"]::before {
  background-image: url("/estudio/assets/icons/product-design.png");
}
#servicos .service-link[data-service="treinamentos-cursos"]::before {
  background-image: url("/estudio/assets/icons/online-learning (1).png");
}

/* === Responsividade === */

/* Tablet e Celular: 2 colunas */
@media (max-width: 1024px) {
  #servicos .bullets {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px 24px;
  }

  #servicos .service-link {
    font-size: 16px;
    padding-left: 28px;
  }

  #servicos .service-link::before {
    width: 20px;
    height: 20px;
  }
}
/* =========================================================
   NOVA SEÇÃO - PODCASTS & LIVES
========================================================= */
#podcasts-lives {
  background: #000;
}

.podcasts-lives__intro {
  max-width: 920px;
  margin: 0 auto 24px;
  font-size: 18px;
  line-height: 1.7;
  color: var(--txt);
}

.pricing--podcasts {
  margin-top: 24px;
}

.podcasts-lives__image-wrap {
  margin-top: 28px;
  margin-bottom: 28px;
  text-align: center;
  justify-content: center;
}

.podcasts-lives__image {
  width: 50%;
  max-width: 900px; /* tamanho da imagem */
  display: block;
  margin: 0 auto;   /* isso centraliza */
  border-radius: 18px;
  box-shadow: 0 20px 50px rgba(0,0,0,.35);
}

.podcasts-lives__notice {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 22px;
  padding: 18px 20px;
  border-radius: 10px;
  background: #062b57;
  color: #fff;
}

.podcasts-lives__notice p {
  margin: 0;
  font-size: 15px;
  line-height: 1.55;
  color: #fff;
}

.podcasts-lives__notice-icon {
  flex: 0 0 28px;
  width: 28px;
  height: 28px;
  border: 2px solid #8fd1ff;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 15px;
  color: #8fd1ff;
}

@media (max-width: 768px) {
  .podcasts-lives__intro {
    font-size: 16px;
    margin-bottom: 18px;
  }

  .podcasts-lives__notice {
    align-items: flex-start;
    padding: 16px;
  }

  .podcasts-lives__notice-icon {
    margin-top: 2px;
  }
}