/* =====================================================
   Focofy – Overrides (Desktop + Mobile)
   Arquivo FINAL para substituição completa
   ===================================================== */


/* =====================================================
   1) CONTAINERS E MARGENS LATERAIS
   ===================================================== */
.focofy-section .focofy-features__header,
.focofy-section .focofy-features__grid,
.focofy-section .focofy-testimonials__header,
.focofy-section .focofy-testimonials__grid,
.focofy-section .focofy-faq__header,
.focofy-section .focofy-faq__grid,
.focofy-section .focofy-pricing__inner,
.focofy-section .focofy-blog-feed__inner,
.focofy-section .focofy-cta__inner,
.focofy-section .focofy-content-image__inner {
  max-width: var(--focofy-container, 1200px);
  margin-inline: auto;
  padding-inline: var(--focofy-gutter, 24px);
}


/* =====================================================
   2) ESPAÇAMENTO ENTRE SEÇÕES (DESKTOP)
   ===================================================== */
@media (min-width: 981px) {
  :root { --sec-y: 64px; }

  .focofy-section {
    padding-block: var(--sec-y);
  }
}


/* =====================================================
   3) HERO – AJUSTES FINOS
   ===================================================== */
@media (min-width: 981px) {
  .focofy-hero__grid {
    min-height: calc(100vh - 92px);
    align-items: center;
  }
}

@media (max-width: 980px) {
  .focofy-hero__grid { padding-top: 18px; }
  .focofy-hero__content { margin-top: 10px; }
}


/* =====================================================
   4) BOTÕES / CTA
   ===================================================== */
.btn{
  padding: 14px 22px;
  border-radius: 999px;
  font-weight: 600;
  border: 1px solid rgba(255,255,255,.22);
  transition: all .2s ease;
}

.btn--primary{
  background: var(--btn-primary-bg);
  color: var(--color-text-inverse);
}

.btn--accent{
  background: var(--btn-secondary-bg);
  color: var(--color-text-inverse);
  box-shadow: 0 6px 22px rgba(0,0,0,.28);
}

.btn--accent:hover{
  box-shadow: 0 10px 28px rgba(0,0,0,.36);
}

.btn--neutral{
  background: var(--color-text-muted);
  color: var(--color-text);
}


/* =====================================================
   5) FEATURES GRID
   ===================================================== */
.focofy-features__grid{
  gap: 18px;
}

@media (max-width: 980px){
  .focofy-features__grid{
    grid-template-columns: 1fr;
    gap: 14px;
  }
}


/* =====================================================
   6) HEADER – DESKTOP
   ===================================================== */
.site-header .header-grid{
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--s-5);
}

.site-header .nav-panel{
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--s-5);
}

.site-header .main-nav{
  display: flex;
  justify-content: center;
}

.site-header .primary-menu{
  display: flex;
  gap: var(--s-4);
  flex-wrap: wrap;
  justify-content: center;
}

.site-header .header-cta{
  display: flex;
  justify-content: flex-end;
}

.site-header .header-cta .btn{
  white-space: nowrap;
}

.site-header .nav-toggle{
  display: none;
}


/* =====================================================
   7) MENU MOBILE – FINAL / PREMIUM
   ===================================================== */
@media (max-width: 980px){

  body.nav-open{
    overflow: hidden;
  }

  /* header sempre acima */
  .site-header{
    position: relative;
    z-index: 1000;
  }

  .site-header .site-brand,
  .site-header .nav-toggle{
    position: relative;
    z-index: 1002;
  }

  /* toggle visível */
  .site-header .nav-toggle{
    display: inline-flex;
    justify-self: end;
  }

  /* overlay real */
  .site-header .nav-panel{
    position: fixed;
    inset: 0;
    z-index: 1000;

    display: none;
    place-items: center;

    background: var(--color-surface-dark); /* FUNDO SÓLIDO */
  }

  body.nav-open .site-header .nav-panel{
    display: grid;
  }

  /* painel central */
  .site-header .nav-panel nav{
    width: min(420px, calc(100% - 36px));
  }

  .site-header .primary-menu{
    display: grid;
    gap: 12px;
    padding: 18px;
    border-radius: 16px;

    background: color-mix(in srgb, white 6%, transparent);
    border: 1px solid rgba(255,255,255,.12);
  }

  .site-header .primary-menu a{
    display: block;
    padding: 14px;
    text-align: center;
    border-radius: 14px;

    background: color-mix(in srgb, white 6%, transparent);
    border: 1px solid rgba(255,255,255,.10);
    color: var(--color-text-inverse);
    text-decoration: none;
    font-weight: 600;
  }

  /* CTA separado */
  .site-header .header-cta{
    margin-top: 14px;
    width: min(420px, calc(100% - 36px));
  }

  .site-header .header-cta .btn{
    width: 100%;
  }
}


/* =====================================================
   8) TOGGLE → X
   ===================================================== */
.site-header .nav-toggle__icon{
  position: relative;
  width: 22px;
  height: 2px;
  background: color-mix(in srgb, white 90%, transparent);
  border-radius: 2px;
}

.site-header .nav-toggle__icon::before,
.site-header .nav-toggle__icon::after{
  content:'';
  position: absolute;
  left: 0;
  width: 22px;
  height: 2px;
  background: color-mix(in srgb, white 90%, transparent);
  border-radius: 2px;
  transition: transform .2s ease, top .2s ease;
}

.site-header .nav-toggle__icon::before{ top: -7px; }
.site-header .nav-toggle__icon::after{ top: 7px; }

body.nav-open .site-header .nav-toggle__icon{
  background: transparent;
}

body.nav-open .site-header .nav-toggle__icon::before{
  top: 0;
  transform: rotate(45deg);
}

body.nav-open .site-header .nav-toggle__icon::after{
  top: 0;
  transform: rotate(-45deg);
}
@media (max-width: 980px){
  .site-header .header-cta{
    display: none !important;
  }
}
@media (max-width: 980px){
  /* garante centralização perfeita do painel */
  .site-header .nav-panel{
    justify-items: center !important;
  }

  .site-header .nav-panel nav{
    margin-inline: auto !important;
  }

  .site-header .primary-menu{
    width: 100% !important;
    margin: 0 auto !important;
  }
}
