/* ============================================================
   STEFANO DE PAULA - CSS v7
   Paleta: #0a0a0a (preto), #ffffff (branco), #f5f0e8 (creme)
           rgb(158,138,115) (bege/tan botões), rgb(201,168,76) (dourado labels)
   Fontes: Noto Serif Display (headings), Poppins (corpo/botões)
   ============================================================ */

/* --------------------------------------------------------
   FIX CRÍTICO: Seção do vídeo full-width
   -------------------------------------------------------- */
.elementor-element-d971319 {
  min-height: 56.25vw !important;
  height: auto !important;
  overflow: hidden !important;
  display: block !important;
}

.elementor-element-d971319,
.elementor-element-d971319 > .e-con-inner {
  max-width: 100% !important;
  width: 100% !important;
  --content-width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
}

.elementor-element-d971319 .elementor-widget-video,
.elementor-element-d971319 .elementor-widget-video .elementor-widget-container,
.elementor-element-d971319 .elementor-video-container {
  width: 100% !important;
  height: 100% !important;
  min-height: 56.25vw !important;
  padding: 0 !important;
  margin: 0 !important;
}

.elementor-element-d971319 .elementor-video-container iframe,
.elementor-element-d971319 .elementor-video-container video {
  width: 100% !important;
  height: 100% !important;
  min-height: 56.25vw !important;
  display: block !important;
  object-fit: cover !important;
}

/* Garantir que o texto da seção seguinte NÃO sobreponha o vídeo */
.elementor-element-207537a3 {
  position: relative !important;
  z-index: 1 !important;
  margin-top: 0 !important;
}

/* --------------------------------------------------------
   FIX: Cor do texto da seção intro (quase invisível)
   -------------------------------------------------------- */
.elementor-element-207537a3 .elementor-heading-title,
.elementor-element-207537a3 .elementor-widget-heading .elementor-heading-title {
  color: #0a0a0a !important;
}

/* --------------------------------------------------------
   FIX: Tipografia serifada nos parágrafos de texto corrido
   Noto Serif Display para manter identidade elegante
   -------------------------------------------------------- */
.elementor-widget-text-editor p,
.elementor-widget-text-editor div,
.elementor-text-editor p,
.elementor-text-editor div {
  font-family: 'Noto Serif Display', 'Georgia', serif !important;
  font-size: 17px !important;
  line-height: 1.85 !important;
  font-weight: 400 !important;
  letter-spacing: 0.01em !important;
  color: inherit !important;
}

/* Parágrafos em seções claras (creme/branco) */
.elementor-element-207537a3 .elementor-widget-text-editor p,
.elementor-element-7a9c7c5 .elementor-widget-text-editor p {
  font-family: 'Noto Serif Display', 'Georgia', serif !important;
  font-size: 17px !important;
  line-height: 1.85 !important;
  color: #2a2a2a !important;
}

/* --------------------------------------------------------
   FIX: Padding lateral nos containers de texto
   Textos não podem começar na borda 0px
   -------------------------------------------------------- */
.elementor-element-207537a3 > .e-con-inner,
.elementor-element-7a9c7c5 > .e-con-inner {
  padding-left: max(40px, 5vw) !important;
  padding-right: max(40px, 5vw) !important;
}

/* Padding geral para seções de texto corrido */
.e-con-inner {
  padding-left: max(24px, 4vw) !important;
  padding-right: max(24px, 4vw) !important;
}

/* Exceto vídeo full-width */
.elementor-element-d971319 .e-con-inner {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* --------------------------------------------------------
   FIX: Heading "From Classics to Hits" cortado na borda
   -------------------------------------------------------- */
.elementor-heading-title {
  padding-left: 0 !important;
  overflow-wrap: break-word !important;
  word-wrap: break-word !important;
  hyphens: auto !important;
}

/* --------------------------------------------------------
   FIX: Logos de clientes — em linha horizontal, tamanho reduzido
   -------------------------------------------------------- */
.elementor-widget-image-gallery .elementor-gallery-item,
.elementor-widget-image-gallery .gallery-item,
.elementor-image-gallery .gallery-columns-2 .gallery-item,
.elementor-image-gallery .gallery-columns-3 .gallery-item {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.elementor-widget-image-gallery img,
.elementor-image-gallery img {
  max-height: 60px !important;
  width: auto !important;
  object-fit: contain !important;
  filter: grayscale(100%) !important;
  opacity: 0.6 !important;
  transition: opacity 0.3s ease, filter 0.3s ease !important;
}

.elementor-widget-image-gallery img:hover,
.elementor-image-gallery img:hover {
  opacity: 1 !important;
  filter: grayscale(0%) !important;
}

/* --------------------------------------------------------
   FIX: Erro do Instagram — ocultar completamente
   -------------------------------------------------------- */
.sbi_error,
.sbi-error,
.instagram-feed-error,
.esgbox-error,
.esgbox .esg-error,
[class*="instagram"] p,
.elementor-widget-instagram-feed p,
.sb-instagram p,
div[class*="sbi"] p:first-child,
.sbi_no_photos_found,
p.sbi_no_photos_found,
.elementor-widget-container p:contains("No any image"),
p:contains("No any image found"),
p:contains("Please check it again") {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  overflow: hidden !important;
}

/* Ocultar qualquer container de erro de feed social */
.elementor-widget-instagram-feed .elementor-widget-container:empty,
.elementor-widget-instagram-feed .elementor-widget-container > p {
  display: none !important;
}

/* --------------------------------------------------------
   FIX: Rodapé — ocultar links de páginas removidas
   -------------------------------------------------------- */
.footer-menu li a[href*="/about"],
.footer-menu li a[href*="/videos"],
.footer-menu li a[href*="/podcast"],
.footer-menu li a[href*="legal"],
nav.footer-menu li:has(a[href*="about"]),
nav.footer-menu li:has(a[href*="videos"]),
nav.footer-menu li:has(a[href*="podcast"]),
nav.footer-menu li:has(a[href*="legal"]) {
  display: none !important;
}

/* Rodapé do tema Lilou — links do menu antigo */
footer .nav-menu li a[href*="about"],
footer .nav-menu li a[href*="videos"],
footer .nav-menu li a[href*="legal"],
footer ul li a[href*="about"],
footer ul li a[href*="videos"],
footer ul li a[href*="legal"] {
  display: none !important;
}

/* --------------------------------------------------------
   BOTÕES — Estilo consistente
   -------------------------------------------------------- */
.elementor-button {
  outline: none !important;
  box-shadow: none !important;
  -webkit-tap-highlight-color: transparent !important;
}

.elementor-element-207537a3 .elementor-button,
.elementor-element-7a9c7c5 .elementor-button {
  border-color: rgb(158, 138, 115) !important;
  color: rgb(158, 138, 115) !important;
  background: transparent !important;
  transition: all 0.3s ease !important;
  letter-spacing: 0.12em !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: 11px !important;
  font-weight: 500 !important;
}

.elementor-element-207537a3 .elementor-button:hover,
.elementor-element-7a9c7c5 .elementor-button:hover {
  background: rgb(158, 138, 115) !important;
  color: #ffffff !important;
}

/* --------------------------------------------------------
   CARDS DE SERVIÇOS — Hover suave
   -------------------------------------------------------- */
.elementor-widget-image .elementor-image img {
  transition: transform 0.4s ease, filter 0.4s ease !important;
  will-change: transform !important;
}

.elementor-widget-image:hover .elementor-image img {
  transform: scale(1.03) !important;
  filter: brightness(1.05) !important;
}

/* --------------------------------------------------------
   TESTIMONIALS — Fundo preto correto + dots animados
   -------------------------------------------------------- */
.elementor-widget-mauve-testimonial-carousel,
.elementor-widget-mauve-testimonial-carousel .swiper,
.elementor-widget-mauve-testimonial-carousel .swiper-wrapper {
  background-color: #0a0a0a !important;
}

.swiper-pagination-bullet {
  background: rgba(201, 168, 76, 0.4) !important;
  opacity: 1 !important;
  width: 8px !important;
  height: 8px !important;
  border-radius: 4px !important;
  transition: all 0.3s ease !important;
}

.swiper-pagination-bullet-active {
  background: rgb(201, 168, 76) !important;
  width: 24px !important;
  border-radius: 4px !important;
}

/* --------------------------------------------------------
   SCROLLBAR elegante
   -------------------------------------------------------- */
::-webkit-scrollbar { width: 4px !important; }
::-webkit-scrollbar-track { background: #0a0a0a !important; }
::-webkit-scrollbar-thumb { background: rgb(158, 138, 115) !important; border-radius: 2px !important; }
::selection { background: rgb(201, 168, 76) !important; color: #0a0a0a !important; }

/* ============================================================
   MOBILE FIXES — max-width: 767px
   ============================================================ */
@media (max-width: 767px) {

  /* ---- VÍDEO: ratio 16:9 no mobile ---- */
  .elementor-element-d971319 {
    min-height: 56.25vw !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  .elementor-element-d971319 .elementor-video-container iframe,
  .elementor-element-d971319 .elementor-video-container video {
    min-height: 56.25vw !important;
    width: 100% !important;
  }

  /* ---- HEADER: esconder tagline no mobile ---- */
  .logo-image-caption,
  figcaption.logo-image-caption,
  .site-tagline, .site-description,
  .lilou-site-tagline, .lilou-header-tagline,
  .header-tagline, p.site-description,
  .site-branding p {
    display: none !important;
  }

  /* ---- FONTES: headings controlados ---- */
  .elementor-heading-title.elementor-size-xxl,
  h1.elementor-heading-title {
    font-size: clamp(32px, 10vw, 48px) !important;
    line-height: 1.1 !important;
  }

  .elementor-heading-title.elementor-size-xl,
  h2.elementor-heading-title {
    font-size: clamp(22px, 7vw, 32px) !important;
    line-height: 1.2 !important;
  }

  .elementor-heading-title.elementor-size-large,
  h3.elementor-heading-title {
    font-size: clamp(18px, 5.5vw, 26px) !important;
    line-height: 1.25 !important;
  }

  .elementor-heading-title {
    font-size: clamp(18px, 6vw, 30px) !important;
    line-height: 1.25 !important;
    word-break: normal !important;
    overflow-wrap: break-word !important;
  }

  .elementor-element-207537a3 .elementor-heading-title {
    font-size: clamp(20px, 6.5vw, 30px) !important;
    line-height: 1.3 !important;
    text-align: center !important;
  }

  /* Labels em caixa alta */
  .elementor-heading-title.elementor-size-small,
  h6.elementor-heading-title,
  h5.elementor-heading-title {
    font-size: 11px !important;
    letter-spacing: 0.15em !important;
    line-height: 1.4 !important;
  }

  /* ---- TEXTO BODY: serifado e legível no mobile ---- */
  .elementor-widget-text-editor p,
  .elementor-widget-text-editor div,
  .elementor-text-editor p,
  .elementor-text-editor div,
  p {
    font-family: 'Noto Serif Display', 'Georgia', serif !important;
    font-size: 15px !important;
    line-height: 1.75 !important;
  }

  /* ---- PADDING LATERAL: margens em todos os containers ---- */
  .e-con-inner {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  .e-con {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* Exceto vídeo full-width */
  .elementor-element-d971319 .e-con-inner {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* ---- ESPAÇAMENTOS: padding vertical coeso ---- */
  .e-con {
    padding-top: 48px !important;
    padding-bottom: 48px !important;
  }

  .e-con > .e-con-inner {
    gap: 24px !important;
  }

  .e-con:not(.elementor-element-d971319) {
    min-height: unset !important;
  }

  /* ---- YOUTUBE EMBED: responsivo ---- */
  .elementor-widget-video .elementor-video-container,
  .elementor-widget-video .elementor-wrapper {
    position: relative !important;
    width: 100% !important;
    padding-bottom: 56.25% !important;
    height: 0 !important;
    overflow: hidden !important;
  }

  .elementor-widget-video .elementor-video-container iframe,
  .elementor-widget-video .elementor-wrapper iframe {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
  }

  /* ---- MARQUEE: tamanho correto ---- */
  .mauve-marquee .elementor-heading-title,
  [class*="marquee"] .elementor-heading-title {
    font-size: clamp(24px, 7vw, 36px) !important;
  }

  /* ---- IMAGENS: sem transbordar ---- */
  .elementor-widget-image img {
    max-width: 100% !important;
    height: auto !important;
  }

  /* ---- LOGOS CLIENTES: em linha no mobile ---- */
  .elementor-widget-image-gallery .gallery,
  .elementor-image-gallery .gallery {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 16px !important;
  }

  .elementor-widget-image-gallery img,
  .elementor-image-gallery img {
    max-height: 40px !important;
    width: auto !important;
  }

  /* ---- TESTIMONIALS: fundo preto ---- */
  .elementor-widget-mauve-testimonial-carousel,
  .elementor-widget-mauve-testimonial-carousel .swiper,
  .elementor-widget-mauve-testimonial-carousel .swiper-wrapper {
    background-color: #0a0a0a !important;
  }

  .elementor-widget-mauve-testimonial-carousel .swiper-slide {
    padding: 16px !important;
  }

  /* ---- INSTAGRAM ERRO: ocultar ---- */
  .sbi_error, .sbi-error, .instagram-feed-error,
  .esgbox-error, .esgbox .esg-error,
  p:contains("No any image"),
  p:contains("Please check it again"),
  .elementor-widget-instagram-feed .elementor-widget-container > p {
    display: none !important;
    height: 0 !important;
    overflow: hidden !important;
  }

  /* ---- RODAPÉ: ocultar links removidos ---- */
  .footer-menu li a[href*="/about"],
  .footer-menu li a[href*="/videos"],
  .footer-menu li a[href*="/podcast"],
  .footer-menu li a[href*="legal"],
  nav.footer-menu li:has(a[href*="about"]),
  nav.footer-menu li:has(a[href*="videos"]),
  nav.footer-menu li:has(a[href*="podcast"]),
  nav.footer-menu li:has(a[href*="legal"]),
  footer .nav-menu li a[href*="about"],
  footer .nav-menu li a[href*="videos"],
  footer .nav-menu li a[href*="legal"],
  footer ul li a[href*="about"],
  footer ul li a[href*="videos"],
  footer ul li a[href*="legal"] {
    display: none !important;
  }

  /* ---- RODAPÉ TAGLINE: fonte controlada ---- */
  footer p, .footer-bottom p {
    font-size: 13px !important;
    line-height: 1.5 !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  /* ---- FOOTER BUZZHALO ---- */
  #stefano-buzzhalo-footer {
    font-size: 10px !important;
    padding: 8px 16px !important;
    letter-spacing: 0.08em !important;
  }

  /* ---- BOTÕES: tamanho adequado no mobile ---- */
  .elementor-button {
    font-size: 11px !important;
    padding: 12px 24px !important;
    letter-spacing: 0.12em !important;
  }

  /* ---- PROCESSO: steps legíveis ---- */
  .elementor-widget-icon-box .elementor-icon-box-title,
  .elementor-icon-box-title * {
    font-size: 15px !important;
    line-height: 1.4 !important;
  }

  .elementor-widget-icon-box .elementor-icon-box-description,
  .elementor-icon-box-description {
    font-size: 13px !important;
    line-height: 1.6 !important;
  }

}

/* ============================================================
   TABLET (768px - 1024px)
   ============================================================ */
@media (min-width: 768px) and (max-width: 1024px) {

  .elementor-heading-title {
    font-size: clamp(24px, 4vw, 42px) !important;
    line-height: 1.2 !important;
  }

  .e-con {
    padding-top: 64px !important;
    padding-bottom: 64px !important;
  }

  .e-con-inner {
    padding-left: max(32px, 4vw) !important;
    padding-right: max(32px, 4vw) !important;
  }

  .elementor-widget-text-editor p,
  .elementor-text-editor p {
    font-family: 'Noto Serif Display', 'Georgia', serif !important;
    font-size: 16px !important;
    line-height: 1.8 !important;
  }

}




/* Footer: esconder links About, Videos, Legal (widget bcc6cf3) */
.elementor-element-bcc6cf3 {
    display: none !important;
}

/* Footer: esconder coluna com Videos e Legal (widget 977b36f) */
.elementor-element-977b36f {
    display: none !important;
}

/* Testimonials: remover borda/fundo branco do card */
.elementor-widget-mauve-testimonial-carousel .swiper-slide,
.elementor-widget-mauve-testimonial-carousel .elementor-testimonial {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

/* Tipografia serifada nos parágrafos */
.elementor-widget-text-editor p,
.elementor-text-editor p {
    font-family: 'Noto Serif Display', Georgia, serif !important;
}


/* ===== CORREÇÕES CRÍTICAS v10 ===== */

/* TIPOGRAFIA: forçar serifada em TODOS os textos de parágrafo */
.elementor-widget-text-editor .elementor-widget-container,
.elementor-widget-text-editor .elementor-widget-container p,
.elementor-widget-text-editor p,
.elementor-text-editor,
.elementor-text-editor p {
    font-family: 'Noto Serif Display', Georgia, 'Times New Roman', serif !important;
    font-size: 17px !important;
    line-height: 1.8 !important;
}

/* VÍDEO MOBILE: garantir que iframe/video seja responsivo e visível */
@media (max-width: 767px) {
    .elementor-widget-video .elementor-wrapper,
    .elementor-widget-video iframe,
    .elementor-video-container,
    .elementor-video-container iframe,
    .elementor-fit-aspect-ratio,
    .elementor-fit-aspect-ratio iframe {
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
        width: 100% !important;
        height: auto !important;
        min-height: 200px !important;
        pointer-events: auto !important;
    }
    
    /* Remover qualquer overflow hidden que possa estar cortando */
    .elementor-widget-video,
    .elementor-widget-video .elementor-widget-container {
        overflow: visible !important;
    }
}


/* ===== FIX v10: VÍDEO MOBILE + TIPOGRAFIA ===== */

/* VÍDEO MOBILE: o vídeo usa position:absolute, container precisa de altura */
@media (max-width: 767px) {
    .elementor-element-d971319 {
        min-height: 56.25vw !important;
        height: 56.25vw !important;
        position: relative !important;
        overflow: hidden !important;
    }
    .elementor-element-9c0cf14 {
        position: absolute !important;
        top: 0 !important;
        left: 0 !important;
        width: 100% !important;
        height: 100% !important;
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
    }
    .elementor-element-9c0cf14 video,
    .elementor-element-9c0cf14 .elementor-video {
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
        display: block !important;
    }
}

/* TIPOGRAFIA: serifada — seletor máximo de especificidade */
body .elementor-widget-text-editor .elementor-widget-container p,
body .elementor-widget-text-editor p,
body .elementor-text-editor p {
    font-family: 'Noto Serif Display', Georgia, serif !important;
    font-size: 17px !important;
    line-height: 1.8 !important;
}
@media (max-width: 767px) {
    body .elementor-widget-text-editor .elementor-widget-container p,
    body .elementor-widget-text-editor p,
    body .elementor-text-editor p {
        font-family: 'Noto Serif Display', Georgia, serif !important;
        font-size: 15px !important;
    }
}


/* ===== FIX TIPOGRAFIA FINAL v11 ===== */

/* Headings usados como parágrafos de corpo — fonte serifada, tamanho correto */
.elementor-element-b356d67 .elementor-heading-title,
.elementor-element-8565445 .elementor-heading-title,
.elementor-element-7272196 .elementor-heading-title,
.elementor-element-1e7897b .elementor-heading-title {
    font-family: 'Noto Serif Display', Georgia, serif !important;
    font-weight: 400 !important;
    hyphens: none !important;
    -webkit-hyphens: none !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
}

/* Mobile: tamanho menor para esses parágrafos */
@media (max-width: 767px) {
    .elementor-element-b356d67 .elementor-heading-title,
    .elementor-element-8565445 .elementor-heading-title,
    .elementor-element-7272196 .elementor-heading-title,
    .elementor-element-1e7897b .elementor-heading-title {
        font-size: 17px !important;
        line-height: 1.7 !important;
        hyphens: none !important;
        -webkit-hyphens: none !important;
        word-break: normal !important;
    }
}

/* Remover hifenização global no mobile */
@media (max-width: 767px) {
    .elementor-heading-title,
    .elementor-widget-text-editor p {
        hyphens: none !important;
        -webkit-hyphens: none !important;
        word-break: normal !important;
        overflow-wrap: break-word !important;
    }
}
