/* ================================================================
   FLUZÃO GÁS — RESPONSIVIDADE MOBILE
   Solução completa para todos os breakpoints
   Problema principal: mascote ofuscado pelos cards flutuantes no mobile
   ================================================================ */

/* ================================================================
   BREAKPOINT PRINCIPAL: até 980px (tablet e mobile)
   ================================================================ */
@media (max-width: 980px) {

  /* ---- HEADER ---- */
  nav.main,
  .header-cta .btn { display: none; }
  .menu-toggle { display: flex; }

  /* ---- HERO GRID ---- */
  .hero-grid {
    grid-template-columns: 1fr;
    gap: 0;
  }

  /* Arte do hero PRIMEIRO no mobile */
  .hero-art {
    order: -1;
    min-height: auto;
    margin-bottom: 0;
  }

  /* ================================================================
     CORREÇÃO PRINCIPAL: mascote e floaties no mobile
     
     Problema: os .floaty saiam para fora da área visível e cobriam
     o mascote porque usavam posicionamento absoluto sem respeitar
     os limites do container.
     
     Solução: contenedor com altura definida, mascote centralizado,
     floaties reposicionados para não sobrepor o rosto/corpo principal.
  ================================================================ */

  .hero-art {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: flex-end;
    /* Altura generosa o suficiente para o mascote respirar */
    min-height: 380px;
    /* Padding lateral para dar espaço aos floaties */
    padding: 16px 20px 0;
    /* Overflow hidden para evitar que floaties vazem */
    overflow: visible;
  }

  /* Mascote: menor no mobile para dar espaço aos floaties */
  .mascot {
    height: 340px;
    max-height: 55vw;
    width: auto;
    position: relative;
    z-index: 2;
    /* Afastar ligeiramente para a direita para dar espaço ao floaty da esquerda */
    margin-left: 10%;
    filter: drop-shadow(0 20px 20px rgba(80,15,35,.28));
  }

  /* Blobs: reduzir no mobile */
  .blob.c {
    width: 220px;
    height: 220px;
    left: 0;
    top: 10%;
  }

  .blob.g {
    width: 200px;
    height: 200px;
    right: 0;
    bottom: 5%;
  }

  .glow {
    width: 300px;
    height: 300px;
    bottom: 20px;
  }

  /* ----------------------------------------------------------------
     FLOATIES: reposicionamento mobile
     
     No desktop ficam sobrepostos ao mascote de forma artística.
     No mobile precisamos reorganizá-los para NÃO cobrir o rosto
     e o corpo principal do mascote.
     
     Layout mobile dos floaties:
     - f1 (tempo): canto superior ESQUERDO, fora do mascote
     - f2 (estrelas): canto inferior DIREITO, abaixo da cintura
     - f3 (segurança): canto inferior ESQUERDO, abaixo da cintura
  ---------------------------------------------------------------- */

  .floaty {
    /* Tamanho menor no mobile */
    padding: 9px 12px;
    border-radius: 14px;
    gap: 9px;
    /* Parar animação bob no mobile para não causar overflow */
    animation: bob 4.5s ease-in-out infinite;
  }

  .floaty svg {
    width: 24px;
    height: 24px;
  }

  .floaty b {
    font-size: .88rem;
  }

  .floaty span {
    font-size: .7rem;
  }

  /* Floaty 1: "Em até 40 min" — esquerda, abaixo do rosto */
  .floaty.f1 {
    top: auto;
    bottom: 38%;     /* Abaixo do rosto do mascote */
    left: 0;
    right: auto;
    animation-delay: 0s;
  }

  /* Floaty 2: "4,9 / 5" — canto inferior direito */
  .floaty.f2 {
    bottom: 16%;
    right: 0;
    left: auto;
    top: auto;
    animation-delay: .6s;
  }

  /* Floaty 3: "Botijão lacrado" — inferior esquerdo */
  .floaty.f3 {
    bottom: 2%;
    left: 0;
    top: auto;
    animation-delay: .3s;
  }

  /* ---- HERO COPY: fica abaixo da arte ---- */
  .hero-copy {
    padding: 16px 0 0;
  }

  .hero h1 {
    font-size: clamp(2rem, 7vw, 3rem);
    margin: 12px 0 0;
  }

  .hero p.lead {
    font-size: 1.05rem;
    margin: 16px 0 22px;
  }

  .hero-cta {
    gap: 10px;
  }

  .trust {
    gap: 18px;
    flex-wrap: wrap;
  }

  /* ---- PRODUTOS: 1 coluna ---- */
  .cards {
    grid-template-columns: 1fr;
    max-width: 460px;
    margin: 0 auto;
  }

  /* ---- INSTITUCIONAL: 1 coluna ---- */
  .about-grid {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  /* ---- JOBS ---- */
  .jobs-inner {
    padding: 40px 26px;
    border-radius: 24px;
  }

  .jobs-top {
    grid-template-columns: 1fr;
    gap: 20px;
    margin-bottom: 28px;
  }

  .jobs-top h2 {
    font-size: clamp(1.7rem, 6vw, 2.4rem);
  }

  .role-grid {
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-bottom: 24px;
  }

  /* ---- FORMULÁRIO NO HERO ---- */
  .leads-form {
    padding: 22px 20px;
  }

  /* ---- FOOTER ---- */
  .foot-grid {
    grid-template-columns: 1fr 1fr;
    gap: 30px;
  }

  .foot-brand {
    grid-column: 1 / -1;
  }
}


/* ================================================================
   BREAKPOINT PEQUENO: até 560px (smartphones compactos)
   ================================================================ */
@media (max-width: 560px) {

  /* ---- WRAP ---- */
  .wrap { padding: 0 16px; }

  /* ---- HERO ART: ajuste fino para telas pequenas ---- */
  .hero-art {
    min-height: 320px;
    padding: 12px 16px 0;
  }

  .mascot {
    height: 280px;
    max-height: 58vw;
    margin-left: 8%;
  }

  /* Floaties ainda menores */
  .floaty {
    padding: 8px 10px;
    gap: 8px;
    border-radius: 12px;
    max-width: 45%;   /* Impede que floaties sejam largos demais */
  }

  .floaty svg {
    width: 20px;
    height: 20px;
    flex: none;
  }

  .floaty b {
    font-size: .80rem;
    line-height: 1.1;
  }

  .floaty span {
    font-size: .65rem;
  }

  /* Reposicionamento específico para telas bem pequenas */
  .floaty.f1 { top: auto; bottom: 34%; left: 0; }
  .floaty.f2 { bottom: 14%; right: 0; }
  .floaty.f3 { bottom: 1%; left: 0; }

  /* ---- HERO COPY ---- */
  .hero h1 {
    font-size: clamp(1.8rem, 8vw, 2.4rem);
  }

  .hero h1 .hl {
    white-space: normal;  /* Permite quebrar linha no highlight */
  }

  .hero p.lead {
    font-size: 1rem;
  }

  /* ---- TRUST BADGES ---- */
  .trust { gap: 14px; }

  /* ---- STATS: 1 coluna ---- */
  .stats { grid-template-columns: 1fr; }

  /* ---- JOBS ---- */
  .role-grid { grid-template-columns: 1fr; }

  /* ---- FORMULÁRIO ---- */
  .leads-form { padding: 18px 16px; }
  .two { grid-template-columns: 1fr; }

  /* ---- FOOTER ---- */
  .foot-grid { grid-template-columns: 1fr; }
  .foot-bottom {
    flex-direction: column;
    text-align: center;
    gap: 8px;
  }
}


/* ================================================================
   BREAKPOINT EXTRA PEQUENO: até 380px (iPhone SE, Galaxy A)
   ================================================================ */
@media (max-width: 380px) {

  .hero-art {
    min-height: 280px;
  }

  .mascot {
    height: 240px;
    max-height: 60vw;
    margin-left: 5%;
  }

  .floaty {
    padding: 7px 9px;
    max-width: 48%;
  }

  .floaty b { font-size: .76rem; }
  .floaty span { font-size: .62rem; }

  /* Floaty 1 abaixo do rosto mesmo em telas menores */
  .floaty.f1 { top: auto; bottom: 30%; }

  .hero h1 {
    font-size: clamp(1.6rem, 9vw, 2rem);
  }

  .jobs-inner { padding: 32px 18px; }

  .leads-form { padding: 32px 20px; }
  .leads-aside { padding: 32px 22px; }

  .leads-aside h2 { font-size: 1.6rem; }
}


/* ================================================================
   ACESSIBILIDADE: respeitar preferência de movimento reduzido
   ================================================================ */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation: none !important;
    transition: none !important;
  }

  .reveal,
  .hero-copy > *,
  .hero-art {
    opacity: 1 !important;
    transform: none !important;
  }
}