/* ------------------------------------------------------------
   22.18.0 — Esconde Woo padrão nas PDPs Ecossistema
   ------------------------------------------------------------
   Galão = ID 117, Frigobar = ID 115.
   Anula padding 60px 0 da seção 12 e esconde gallery/summary
   padrão do WooCommerce — temos hero próprio via shortcode.
   ------------------------------------------------------------ */
#product-117.product,
#product-115.product,
.woocommerce div#product-117.product,
.woocommerce div#product-115.product {
  padding: 0 !important;
}

#product-117 .woocommerce-product-gallery,
#product-117 .summary,
#product-117 .woocommerce-tabs,
#product-117 .related,
#product-117 .upsells,
#product-115 .woocommerce-product-gallery,
#product-115 .summary,
#product-115 .woocommerce-tabs,
#product-115 .related,
#product-115 .upsells {
  display: none !important;
}

/* Sticky precisa de overflow:visible em ancestrais Elementor */
#product-117 .elementor,
#product-117 .elementor-element,
#product-117 .e-con,
#product-117 .e-parent,
#product-115 .elementor,
#product-115 .elementor-element,
#product-115 .e-con,
#product-115 .e-parent {
  overflow: visible !important;
}


/* ------------------------------------------------------------
   22.18.1 — Override do hero: visual neutro (sem tons da marca)
   ------------------------------------------------------------
   As regras 22.2/22.3 dão fundo rosa pro #product-41 e verde pro
   #product-56. Pra Ecossistema queremos visual neutro — só o
   bg-deep + glow sutil branco.
   ------------------------------------------------------------ */
#product-117 .fp-bg,
#product-115 .fp-bg {
  background:
    radial-gradient(ellipse 70% 80% at 30% 40%, rgba(255, 255, 255, 0.04) 0%, transparent 65%),
    radial-gradient(ellipse 50% 60% at 75% 75%, rgba(255, 31, 143, 0.06) 0%, transparent 70%),
    linear-gradient(180deg, rgba(20, 5, 15, 0.40) 0%, rgba(10, 5, 10, 0.85) 70%, var(--feltoni-bg-deep) 100%);
}

#product-117 .fp-visual,
#product-115 .fp-visual {
  background:
    radial-gradient(circle at 50% 40%, rgba(255, 255, 255, 0.06), transparent 60%),
    linear-gradient(180deg, #1a1a20 0%, #0a0a0d 100%);
  border-color: var(--feltoni-border-strong);
}

#product-117 .fp-thumb--active,
#product-115 .fp-thumb--active {
  border-color: var(--feltoni-pink);
  box-shadow: 0 0 16px rgba(255, 31, 143, 0.30);
}

#product-117 .fp-thumb:hover,
#product-115 .fp-thumb:hover {
  border-color: var(--feltoni-pink);
}


/* ------------------------------------------------------------
   22.18.2 — Lista de specs inline (abaixo da descrição)
   ------------------------------------------------------------
   Output do helper feltoni_render_atributos_pdp:
   <ul class="fp-acc-specs">
     <li><span>Nome</span><strong>Valor</strong></li>
   </ul>
   Grid 2 colunas, separadores sutis. Versão compacta dos
   atributos pra leitura rápida no hero.
   ------------------------------------------------------------ */
.fp-acc-specs {
  list-style: none;
  padding: 20px 0;
  margin: 0 0 28px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px 24px;
  border-top: 1px solid var(--feltoni-border);
  border-bottom: 1px solid var(--feltoni-border);
}

.fp-acc-specs li {
  display: flex;
  flex-direction: column;
  gap: 4px;
  color: inherit;
}

.fp-acc-specs li span {
  font-family: 'Archivo', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--feltoni-text-mute);
}

.fp-acc-specs li strong {
  font-family: 'Archivo', sans-serif;
  font-weight: 700;
  font-size: 14px;
  color: var(--feltoni-text);
}


/* ------------------------------------------------------------
   22.18.3 — BUY BOX (preço + qty + add-to-cart + payment)
   ------------------------------------------------------------
   Output do helper feltoni_render_buy_box_pdp:
   <div class="fp-acc-buy">
     <div class="fp-acc-price-block">
       <div class="fp-acc-stock">Em estoque</div>
       <div class="fp-acc-price">
         <span class="fp-acc-price-old">R$ X</span>
         <span class="fp-acc-price-now">R$ Y</span>
         <span class="fp-acc-price-unit">/ unidade</span>
       </div>
     </div>
     <form class="fp-acc-buy-form">
       <div class="fp-acc-qty">...</div>
       <button class="fp-acc-buy-btn">Adicionar</button>
     </form>
     <div class="fp-acc-payment-row">...</div>
   </div>

   Estilo SOLTO (sem caixa de fundo) — segue v11.
   ------------------------------------------------------------ */
.fp-acc-buy {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* Bloco de preço (estoque em cima, valor abaixo) */
.fp-acc-price-block {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.fp-acc-stock {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: max-content;
  padding: 6px 14px;
  background: rgba(37, 229, 98, 0.12);
  border: 1px solid rgba(37, 229, 98, 0.30);
  border-radius: 999px;
  font-family: 'Archivo', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--feltoni-green);
}

.fp-acc-stock--out {
  background: rgba(255, 77, 77, 0.10);
  border-color: rgba(255, 77, 77, 0.30);
  color: #ff8a8a;
}

.fp-acc-stock-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--feltoni-green);
  box-shadow: 0 0 8px var(--feltoni-green);
  flex-shrink: 0;
}

.fp-acc-stock--out .fp-acc-stock-dot {
  background: #ff8a8a;
  box-shadow: 0 0 8px #ff8a8a;
}

/* Preço: riscado sozinho em cima, preço grande + "/ unidade" na linha de baixo */
.fp-acc-price {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  column-gap: 8px;
  row-gap: 2px;
}

/* Riscado ocupa a linha inteira -> empurra preço+unidade pra linha de baixo */
.fp-acc-price-old {
  flex: 0 0 100%;
}

.fp-acc-price-old {
  font-family: 'Archivo', sans-serif;
  font-size: 18px;
  font-weight: 500;
  color: var(--feltoni-text-mute);
  text-decoration: line-through;
  text-decoration-thickness: 1.5px;
  text-decoration-color: rgba(110, 110, 118, 0.6);
}

.fp-acc-price-old .woocommerce-Price-amount {
  color: inherit;
}

.fp-acc-price-now {
  font-family: 'Anton', sans-serif;
  font-size: clamp(38px, 4.5vw, 52px);
  font-weight: 400;
  line-height: 1;
  letter-spacing: -0.01em;
}

/* Cinza no preco grande, incluindo o "R$" (span proprio) */
.fp-acc-price-now,
.fp-acc-price-now * {
  color: #c8c8cc !important;
}

.fp-acc-price-unit {
  align-self: baseline;
  font-family: 'Archivo', sans-serif;
  font-size: 13px;
  font-weight: 500;
  color: var(--feltoni-text-mute);
}

/* Form de compra: stepper em cima (largura cheia), botao embaixo — igual Pre/Pos */
.fp-acc-buy-form {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin: 0;
}

.fp-acc-qty {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.fp-acc-qty-label {
  font-family: 'Archivo', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--feltoni-text-mute);
}

.fp-acc-qty-controls {
  display: flex;
  align-items: center;
  background: var(--feltoni-bg-card);
  border: 1px solid var(--feltoni-border);
  border-radius: 10px;
  overflow: hidden;
  height: 52px;
  width: 100%;
}

.fp-acc-qty-btn {
  flex-shrink: 0;
  width: 40px;
  height: 100%;
  background: transparent;
  border: none;
  color: var(--feltoni-text-dim);
  font-family: 'Archivo', sans-serif;
  font-size: 18px;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.2s var(--feltoni-ease), color 0.2s var(--feltoni-ease);
}

.fp-acc-qty-btn:hover {
  background: rgba(255, 255, 255, 0.04);
  color: var(--feltoni-text);
}

.fp-acc-qty-controls input[type="number"] {
  flex: 1;
  height: 100% !important;
  text-align: center !important;
  background: transparent !important;
  border: none !important;
  color: var(--feltoni-text) !important;
  font-family: 'Archivo', sans-serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  padding: 0 !important;
  -moz-appearance: textfield !important;
  box-shadow: none !important;
}

.fp-acc-qty-controls input[type="number"]::-webkit-outer-spin-button,
.fp-acc-qty-controls input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none !important;
  margin: 0;
}

.fp-acc-qty-controls input[type="number"]:focus {
  outline: none !important;
  box-shadow: none !important;
}

/* Botão "Adicionar ao carrinho" — texto preto sobre rosa */
.fp-acc-buy-btn {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 52px !important;
  padding: 0 24px !important;
  background: #ff1f8f !important;
  background-color: #ff1f8f !important;
  background-image: none !important;
  color: #050507 !important;
  border: none !important;
  border-radius: 10px !important;
  font-family: 'Archivo', sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: background-color 0.3s var(--feltoni-ease),
              transform 0.3s var(--feltoni-ease),
              box-shadow 0.3s var(--feltoni-ease) !important;
  box-shadow: 0 8px 24px rgba(255, 31, 143, 0.35) !important;
  white-space: nowrap;
}

.fp-acc-buy-btn,
.fp-acc-buy-btn span {
  color: #050507 !important;
}

.fp-acc-buy-btn:hover,
.fp-acc-buy-btn:focus-visible {
  background: #ff3ea0 !important;
  background-color: #ff3ea0 !important;
  color: #050507 !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 14px 32px rgba(255, 31, 143, 0.50) !important;
}

/* Estado "Indisponível no momento" (sem estoque) */
.fp-acc-unavailable {
  padding: 18px 20px;
  background: rgba(255, 77, 77, 0.06);
  border: 1px solid rgba(255, 77, 77, 0.25);
  border-radius: 10px;
  color: #ffa8a8;
  font-family: 'Archivo', sans-serif;
  font-size: 14px;
  font-weight: 600;
  text-align: center;
}

/* Payment row (PIX / CARTÃO / BOLETO) */
.fp-acc-payment-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-top: 18px;
  margin-top: 4px;
  border-top: 1px solid var(--feltoni-border);
  font-family: 'Archivo', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--feltoni-text-mute);
}

.fp-acc-payment-icons {
  display: flex;
  gap: 6px;
}

.fp-acc-payment-icon {
  padding: 4px 10px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--feltoni-border);
  border-radius: 4px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--feltoni-text-dim);
}


/* ------------------------------------------------------------
   22.18.4 — SEÇÃO "SOBRE O PRODUTO" (about)
   ------------------------------------------------------------
   Output: <section class="fp-acc-about">
   Renderiza descrição longa do produto WP.
   Layout: heading à esquerda + texto à direita (2 colunas).
   ------------------------------------------------------------ */
.fp-acc-about {
  padding: 80px 32px;
  background: var(--feltoni-bg-deep);
  position: relative;
}

.fp-acc-about-wrap {
  max-width: var(--feltoni-maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 60px;
  align-items: start;
}

.fp-acc-about-head {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.fp-acc-about-eyebrow {
  display: inline-block;
  width: max-content;
  font-family: 'Archivo', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--feltoni-pink);
}

.fp-acc-about-title {
  font-family: 'Anton', sans-serif !important;
  font-weight: 400 !important;
  font-size: clamp(36px, 4.5vw, 56px) !important;
  line-height: 0.95 !important;
  text-transform: uppercase;
  letter-spacing: -0.01em !important;
  margin: 0 !important;
  color: var(--feltoni-text) !important;
}

.fp-acc-about-body {
  font-family: 'Archivo', sans-serif;
  font-size: 16px;
  line-height: 1.7;
  color: var(--feltoni-text-dim);
}

.fp-acc-about-body p {
  margin: 0 0 14px;
  color: inherit;
}

.fp-acc-about-body p:last-child {
  margin-bottom: 0;
}

.fp-acc-about-body strong {
  color: var(--feltoni-text);
  font-weight: 600;
}


/* ------------------------------------------------------------
   22.18.5 — SEÇÃO "ESPECIFICAÇÕES TÉCNICAS" (specs grid)
   ------------------------------------------------------------
   Output: <section class="fp-acc-specs-section">
   Grid 3 colunas de cards, cada card = label + valor.
   Escala automaticamente com qualquer quantidade de atributos.
   ------------------------------------------------------------ */
.fp-acc-specs-section {
  padding: 0 32px 100px;
  background: var(--feltoni-bg-deep);
  position: relative;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

.fp-acc-specs-wrap {
  max-width: 1000px;
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}

.fp-acc-specs-head {
  text-align: center;
  max-width: 640px;
  margin: 0 auto 48px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  align-items: center;
}

.fp-acc-specs-eyebrow {
  font-family: 'Archivo', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--feltoni-pink);
}

.fp-acc-specs-title {
  font-family: 'Anton', sans-serif !important;
  font-weight: 400 !important;
  font-size: clamp(36px, 4.5vw, 56px) !important;
  line-height: 0.95 !important;
  text-transform: uppercase;
  letter-spacing: -0.01em !important;
  margin: 0 !important;
  color: var(--feltoni-text) !important;
}

.fp-acc-specs-sub {
  font-family: 'Archivo', sans-serif;
  font-size: 15px;
  color: var(--feltoni-text-dim);
  margin: 0;
  line-height: 1.6;
}

/* Tabela de specs — formato v11: label esquerda, valor direita,
   linhas separadoras sutis, dentro de um card único com fundo bg-card */
.fp-acc-specs-table-wrap {
  background: var(--feltoni-bg-card);
  border: 1px solid var(--feltoni-border);
  border-radius: 16px;
  padding: 8px 32px;
}

.fp-acc-specs-table {
  width: 100%;
  border-collapse: collapse;
}

.fp-acc-specs-table tr {
  border-bottom: 1px solid var(--feltoni-border);
}

.fp-acc-specs-table tr:last-child {
  border-bottom: none;
}

.fp-acc-specs-table th,
.fp-acc-specs-table td {
  text-align: left;
  padding: 18px 24px;
  font-size: 14px;
  background: transparent;
}

.fp-acc-specs-table th {
  font-family: 'Archivo', sans-serif;
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--feltoni-text-mute);
  width: 40%;
}

.fp-acc-specs-table td {
  color: var(--feltoni-text);
  font-weight: 500;
}


/* ------------------------------------------------------------
   22.18.6 — CROSS-SELL (fh-rotina, reutilizado de outras telas)
   ------------------------------------------------------------
   Output: <section class="fh-rotina fh-rotina--cross-ecossistema">
   Helper renderiza Pré + Pós + outros Ecossistema (exceto atual).
   Grid responsivo de cards de produto.
   ------------------------------------------------------------ */
.fh-rotina {
  padding: 80px 32px 100px;
  background: var(--feltoni-bg-deep);
  position: relative;
}

.fh-rotina__head {
  max-width: var(--feltoni-maxw);
  margin: 0 auto 48px;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 14px;
  align-items: center;
}

.fh-rotina__eyebrow {
  font-family: 'Archivo', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--feltoni-pink);
}

.fh-rotina__title {
  font-family: 'Anton', sans-serif !important;
  font-weight: 400 !important;
  font-size: clamp(36px, 5vw, 60px) !important;
  line-height: 0.95 !important;
  text-transform: uppercase;
  letter-spacing: -0.01em !important;
  margin: 0 !important;
  color: var(--feltoni-text) !important;
}

.fh-rotina__lede {
  font-family: 'Archivo', sans-serif;
  font-size: 15px;
  color: var(--feltoni-text-dim);
  margin: 0;
  max-width: 540px;
  line-height: 1.6;
}

.fh-rotina__grid {
  max-width: var(--feltoni-maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
}

.fh-rotina__card {
  display: flex;
  flex-direction: column;
  background: var(--feltoni-bg-card);
  border: 1px solid var(--feltoni-border);
  border-radius: 16px;
  overflow: hidden;
  text-decoration: none !important;
  color: inherit !important;
  transition: border-color 0.4s var(--feltoni-ease),
              transform 0.4s var(--feltoni-ease),
              box-shadow 0.4s var(--feltoni-ease);
}

.fh-rotina__card:hover {
  border-color: var(--feltoni-pink);
  transform: translateY(-4px);
  box-shadow: 0 20px 40px rgba(255, 31, 143, 0.12);
}

.fh-rotina__visual {
  height: 220px;
  background:
    radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.04), transparent 70%),
    var(--feltoni-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  overflow: hidden;
}

.fh-rotina__img {
  max-height: 180px;
  width: auto;
  object-fit: contain;
  filter: drop-shadow(0 12px 28px rgba(0, 0, 0, 0.5));
  transition: transform 0.5s var(--feltoni-ease);
}

.fh-rotina__card:hover .fh-rotina__img {
  transform: scale(1.05);
}

.fh-rotina__body {
  padding: 20px 22px 22px;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.fh-rotina__tag {
  font-family: 'Archivo', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--feltoni-pink);
}

.fh-rotina__name {
  font-family: 'Anton', sans-serif !important;
  font-weight: 400 !important;
  font-size: 22px !important;
  line-height: 1.1 !important;
  text-transform: uppercase;
  letter-spacing: -0.01em !important;
  margin: 0 !important;
  color: var(--feltoni-text) !important;
}

.fh-rotina__desc {
  font-family: 'Archivo', sans-serif;
  font-size: 13px;
  line-height: 1.5;
  color: var(--feltoni-text-dim);
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.fh-rotina__desc p {
  margin: 0;
  color: inherit;
}

.fh-rotina__footer {
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px solid var(--feltoni-border);
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.fh-rotina__pricing {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 8px;
}

.fh-rotina__price-old {
  font-family: 'Archivo', sans-serif;
  font-size: 13px;
  color: var(--feltoni-text-mute);
  text-decoration: line-through;
}

.fh-rotina__price-old .woocommerce-Price-amount {
  color: inherit;
}

.fh-rotina__price-now {
  font-family: 'Anton', sans-serif;
  font-size: 22px;
  font-weight: 400;
  line-height: 1;
  color: var(--feltoni-pink);
}

.fh-rotina__price-now .woocommerce-Price-amount {
  color: inherit;
}

.fh-rotina__price-unit {
  font-family: 'Archivo', sans-serif;
  font-size: 11px;
  font-weight: 500;
  color: var(--feltoni-text-mute);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.fh-rotina__cta {
  font-family: 'Archivo', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--feltoni-text-dim);
  transition: color 0.3s var(--feltoni-ease);
}

.fh-rotina__card:hover .fh-rotina__cta {
  color: var(--feltoni-pink);
}


/* ------------------------------------------------------------
   22.18.7 — RESPONSIVO (ajustado pra mobile real ~375-430px)
   ------------------------------------------------------------ */
@media (max-width: 900px) {
  .fp-acc-about-wrap {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .fp-acc-specs {
    grid-template-columns: 1fr;
    gap: 10px;
  }
}

@media (max-width: 768px) {
  /* Hero stack: galeria em cima, info embaixo */
  #product-117 .fp-grid,
  #product-115 .fp-grid {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }

  /* Galeria sem sticky no mobile (vai junto do scroll) */
  #product-117 .fp-gallery,
  #product-115 .fp-gallery {
    position: static !important;
    width: 100%;
    max-width: 100%;
  }

  /* Garante que imagem principal não estoura */
  #product-117 .fp-visual,
  #product-115 .fp-visual {
    max-width: 100%;
    width: 100%;
  }

  /* Padding lateral menor no hero */
  #product-117 .fp-section,
  #product-115 .fp-section {
    padding: 24px 20px 60px !important;
  }

  /* Título do hero quebra linha sem cortar */
  #product-117 .fp-title,
  #product-115 .fp-title {
    font-size: clamp(36px, 9vw, 56px) !important;
    overflow-wrap: break-word;
    word-break: normal;
    hyphens: auto;
  }

  /* Tabela de specs com padding menor */
  .fp-acc-specs-table-wrap {
    padding: 4px 20px;
  }

  .fp-acc-specs-table th,
  .fp-acc-specs-table td {
    padding: 14px 16px;
    font-size: 13px;
  }

  .fp-acc-specs-table th {
    width: 45%;
  }

  /* Lista inline de specs do hero em 1 coluna */
  .fp-acc-specs {
    grid-template-columns: 1fr;
    gap: 10px;
  }
}

@media (max-width: 600px) {
  /* Padding lateral mínimo nas seções pra usar a viewport inteira */
  .fp-acc-about,
  .fh-rotina {
    padding: 50px 20px 60px;
  }

  .fp-acc-specs-section {
    padding: 0 20px 50px;
  }

  /* Buy box: tudo vertical, qty cheio e botão cheio */
  .fp-acc-buy-form {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .fp-acc-qty-controls {
    width: 100%;
  }

  .fp-acc-buy-btn {
    width: 100%;
    height: 56px !important;
  }

  /* Payment row empilha */
  .fp-acc-payment-row {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }

  /* Preço menor pra não estourar */
  .fp-acc-price-now {
    font-size: 38px !important;
  }

  /* Cross-sell: cards em 1 coluna ocupando largura inteira */
  .fh-rotina__grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  /* Headings menores no mobile */
  .fp-acc-about-title,
  .fp-acc-specs-title,
  .fh-rotina__title {
    font-size: clamp(32px, 8vw, 44px) !important;
  }

  /* Garante alinhamento centralizado da head de specs */
  .fp-acc-specs-head {
    align-items: center;
    text-align: center;
  }
}
/* 22.18.8 — Containers Elementor da PDP Ecossistema respeitam a largura
   do .product (corrige overflow no mobile: Elementor vazava p/ 1393px
   dentro de um .product de ~338px). Escopo por classe -> cobre Galao,
   Frigobar E kits (IDs proprios). */
.single-product div.product .elementor,
.single-product div.product .e-con,
.single-product div.product .e-con-inner,
.single-product div.product .elementor-widget-shortcode,
.single-product div.product .elementor-widget-container {
  max-width: 100% !important;
  min-width: 0 !important;
}

#product-117 .elementor-widget-shortcode,
#product-115 .elementor-widget-shortcode,
#product-117 .elementor-widget-shortcode .elementor-widget-container,
#product-115 .elementor-widget-shortcode .elementor-widget-container {
  display: block !important;
  width: 100% !important;
}

/* Garante que a tabela de specs aplica mesmo dentro de containers Elementor */
#product-117 .fp-acc-specs-table-wrap,
#product-115 .fp-acc-specs-table-wrap {
  background: var(--feltoni-bg-card) !important;
  border: 1px solid var(--feltoni-border) !important;
  border-radius: 16px !important;
  padding: 8px 32px !important;
}

#product-117 .fp-acc-specs-table,
#product-115 .fp-acc-specs-table {
  width: 100% !important;
  border-collapse: collapse !important;
}

/* ============================================================
   22.18.9 - Hero buy box: economia + parcelamento + SKU
   ============================================================ */
.fp-acc-sku {
  display: inline-block;
  width: max-content;
  margin: 0 0 18px;
  padding: 4px 12px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--feltoni-border);
  border-radius: 999px;
  font-family: 'Archivo', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--feltoni-text-mute);
}
.fp-acc-economia {
  display: inline-block;
  width: max-content;
  max-width: 100%;
  margin-top: 8px;
  padding: 6px 12px;
  background: #ff1f8f;
  font-family: 'Archivo', sans-serif;
  font-size: 12px;
  font-weight: 600;
  line-height: 1.3;
  border-radius: 10px;
}
/* TUDO branco no chip, inclusive o "R$" (span proprio pego pelo span{dim}) */
.fp-acc-economia,
.fp-acc-economia * {
  color: #fff !important;
}
.fp-acc-inst {
  font-family: 'Archivo', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--feltoni-green);
}

/* ============================================================
   22.18.10 - Cross-sell rico (espelha 22.25/26/27)
   ============================================================
   Escopo: .fh-rotina--cross-ecossistema (classe que o shortcode
   [feltoni_pdp_ecossistema section="crosssell"] sempre emite).
   Cobre Galao, Frigobar E os kits/combos, que usam o MESMO
   template mas tem IDs proprios -> por isso nao da pra escopar
   por #product-XX aqui.
   ============================================================ */

/* track flex + cards lado a lado */
.fh-rotina--cross-ecossistema .fh-rotina__track {
  display: flex !important;
  gap: 24px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding: 16px 4px;
  margin: -16px 0;
}
.fh-rotina--cross-ecossistema .fh-rotina__track::-webkit-scrollbar { display: none; }
.fh-rotina--cross-ecossistema .fh-rotina__track .fh-rotina__card {
  flex: 0 0 calc((100% - 48px) / 3) !important;
  scroll-snap-align: start;
  min-width: 0;
}

/* head grande + visual alto + nome maior + tag cinza */
.fh-rotina--cross-ecossistema .fh-rotina__head { max-width: 800px; margin: 0 auto 64px; }
.fh-rotina--cross-ecossistema .fh-rotina__eyebrow { margin-bottom: 20px; }
.fh-rotina--cross-ecossistema .fh-rotina__title {
  font-size: clamp(44px, 7vw, 96px) !important;
  line-height: 0.92 !important;
  margin: 0 0 24px !important;
}
.fh-rotina--cross-ecossistema .fh-rotina__lede { font-size: 17px; line-height: 1.7; max-width: 620px; }
.fh-rotina--cross-ecossistema .fh-rotina__card { border-radius: 28px; }
.fh-rotina--cross-ecossistema .fh-rotina__body { padding: 28px 28px 32px; }
.fh-rotina--cross-ecossistema .fh-rotina__name { font-size: 26px !important; }
.fh-rotina--cross-ecossistema .fh-rotina__desc { font-size: 14px; line-height: 1.65; }
.fh-rotina--cross-ecossistema .fh-rotina__tag { color: var(--feltoni-text-mute); letter-spacing: 0.22em; }

/* glow no visual + img acima do glow */
.fh-rotina--cross-ecossistema .fh-rotina__visual {
  position: relative;
  height: 320px;
  background:
    radial-gradient(ellipse 70% 60% at 30% 50%, rgba(255, 31, 143, 0.14), transparent 60%),
    radial-gradient(ellipse 70% 60% at 70% 50%, rgba(37, 229, 98, 0.12), transparent 60%),
    #0a0a0f;
}
.fh-rotina--cross-ecossistema .fh-rotina__visual::after {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 260px; height: 260px;
  border-radius: 50%;
  background: #ff1f8f;
  filter: blur(80px);
  opacity: 0.22;
  z-index: 0;
  pointer-events: none;
}
.fh-rotina--cross-ecossistema .fh-rotina__img { position: relative; z-index: 1; max-height: 240px; }

/* bloco de preco .fp-preco */
.fh-rotina--cross-ecossistema .fp-preco {
  display: flex; flex-direction: column; align-items: flex-start; gap: 2px; width: 100%;
}
.fh-rotina--cross-ecossistema .fp-preco__old {
  font-family: 'Archivo', sans-serif; font-size: 13px; font-weight: 500;
  color: var(--feltoni-text-mute);
  text-decoration: line-through; text-decoration-color: rgba(255, 31, 143, 0.6);
}
.fh-rotina--cross-ecossistema .fp-preco__now {
  font-family: 'Anton', 'Archivo', sans-serif; font-size: 28px; line-height: 1.05;
  color: var(--feltoni-text); font-weight: 400; letter-spacing: -0.01em;
  display: flex; align-items: baseline; gap: 7px;
}
.fh-rotina--cross-ecossistema .fp-preco__now .woocommerce-Price-amount { font: inherit; color: inherit; }
.fh-rotina--cross-ecossistema .fp-preco__unit {
  font-family: 'Archivo', sans-serif; font-size: 13px; font-weight: 600;
  color: var(--feltoni-text-dim); text-transform: lowercase;
}
.fh-rotina--cross-ecossistema .fp-preco__inst {
  font-family: 'Archivo', sans-serif; font-size: 13px; font-weight: 700;
  color: var(--feltoni-green); margin-top: 4px;
}
/* Linha do fardo abaixo do valor por lata (Pré/Pós no cross-sell) */
.fh-rotina--cross-ecossistema .fp-preco__fardo {
  font-family: 'Archivo', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--feltoni-text-mute);
  margin-top: 2px;
}
.fh-rotina--cross-ecossistema .fp-preco__fardo .woocommerce-Price-amount {
  font: inherit;
  color: inherit;
}

/* etiqueta de desconto + tarja esgotado */
.fh-rotina--cross-ecossistema .fh-rotina__disc {
  position: absolute; top: 18px; left: 18px; z-index: 2;
  display: inline-block; background: #ff1f8f; color: #fff;
  font-family: 'Anton', sans-serif; font-size: 15px; letter-spacing: 0.02em;
  padding: 6px 12px; border-radius: 999px; box-shadow: 0 4px 14px rgba(255, 31, 143, 0.4);
}
.fh-rotina--cross-ecossistema .fh-rotina__out {
  position: absolute; top: 18px; right: 18px; z-index: 2;
  display: inline-flex; align-items: center; gap: 7px;
  background: rgba(120, 0, 0, 0.18); border: 1px solid rgba(193, 18, 31, 0.55);
  color: #ff6b6b; font-family: 'Archivo', sans-serif; font-size: 11px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase; padding: 7px 16px; border-radius: 999px;
}
.fh-rotina--cross-ecossistema .fh-rotina__out-dot {
  width: 7px; height: 7px; border-radius: 50%; background: #ff6b6b; box-shadow: 0 0 8px #ff6b6b;
}

/* setas circulares */
.fh-rotina--cross-ecossistema .fh-rotina__arrow {
  position: absolute; top: 38%; transform: translateY(-50%); z-index: 5;
  width: 44px; height: 44px; border-radius: 50%;
  background: rgba(14,14,18,0.85); border: 1px solid #2a2a33;
  color: var(--feltoni-text); font-size: 20px; line-height: 1; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.4);
  transition: background .25s var(--feltoni-ease), border-color .25s var(--feltoni-ease), opacity .25s var(--feltoni-ease);
}
.fh-rotina--cross-ecossistema .fh-rotina__arrow:hover { background: #ff1f8f; border-color: #ff1f8f; color: #fff; }
.fh-rotina--cross-ecossistema .fh-rotina__arrow--prev { left: -10px; }
.fh-rotina--cross-ecossistema .fh-rotina__arrow--next { right: -10px; }
.fh-rotina--cross-ecossistema .fh-rotina__arrow.is-disabled { opacity: 0; pointer-events: none; }

/* dots */
.fh-rotina--cross-ecossistema .fh-rotina__dots {
  display: none; justify-content: center; align-items: center; gap: 8px; margin-top: 28px;
}
.fh-rotina--cross-ecossistema .fh-rotina__carousel.has-scroll .fh-rotina__dots { display: flex; }
.fh-rotina--cross-ecossistema .fh-rotina__dot {
  width: 8px; height: 8px; border-radius: 50%; background: #2a2a33; flex: 0 0 auto;
  transition: background .25s var(--feltoni-ease), width .25s var(--feltoni-ease);
}
.fh-rotina--cross-ecossistema .fh-rotina__dot.is-active { background: #ff1f8f; width: 22px; border-radius: 999px; }

/* relative pras setas */
.fh-rotina--cross-ecossistema .fh-rotina__carousel,
.fh-rotina--cross-ecossistema .fh-rotina__row { position: relative; }

/* mobile */
@media (max-width: 700px) {
  .fh-rotina--cross-ecossistema .fh-rotina__track .fh-rotina__card { flex: 0 0 85% !important; }
  .fh-rotina--cross-ecossistema .fh-rotina__head { margin-bottom: 48px; }
  .fh-rotina--cross-ecossistema .fh-rotina__visual { height: 280px; }
  .fh-rotina--cross-ecossistema .fh-rotina__img { max-height: 220px; }
  .fh-rotina--cross-ecossistema .fh-rotina__arrow { display: none; }
}

/* ============================================================
   22.18.11 - Etiqueta de estoque (chip ao lado do SKU)
   ============================================================ */
.fp-acc-meta-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin: 0 0 18px;
}
.fp-acc-meta-row .fp-acc-sku { margin: 0; }

.fp-stock-chip-row { margin: -4px 0 18px; }

.fp-stock-chip {
  display: inline-block;
  width: max-content;
  padding: 4px 12px;
  background: rgba(255, 31, 143, 0.08);
  border: 1px solid rgba(255, 31, 143, 0.30);
  border-radius: 999px;
  font-family: 'Archivo', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #ff1f8f;
}

/* ===== ASSINATURA — PDP de plano (.fp-assina-*) ===== */
.fp-assina { background: var(--feltoni-bg-deep); color: var(--feltoni-text); font-family: 'Archivo', sans-serif; }
.fp-assina * { box-sizing: border-box; }
.fp-assina-hero { position: relative; padding: 80px 32px; background: radial-gradient(ellipse 80% 70% at 50% 0%, rgba(255,31,143,0.18), transparent 60%), var(--feltoni-bg-deep); }
.fp-assina-hero__inner { max-width: 760px; margin: 0 auto; text-align: center; }
.fp-assina-bc { font-size: 12px; letter-spacing: .08em; text-transform: uppercase; color: var(--feltoni-text-mute); margin-bottom: 16px; }
.fp-assina-bc a { color: var(--feltoni-text-mute); }
.fp-assina-badge { display:inline-block; background: var(--feltoni-pink); color:#fff; font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; padding:5px 12px; border-radius:999px; margin-bottom:16px; }
.fp-assina-eyebrow { display:block; font-size:12px; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color: var(--feltoni-pink); margin-bottom:14px; }
.fp-assina-title { font-family:'Anton',sans-serif !important; font-weight:400 !important; font-size: clamp(40px,7vw,80px) !important; line-height:.95 !important; text-transform:uppercase; margin:0 0 16px !important; color: var(--feltoni-text) !important; }
.fp-assina-lede { font-size:17px; line-height:1.7; color: var(--feltoni-text-dim); max-width:560px; margin:0 auto 24px; }
.fp-assina-compo { display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin-bottom:24px; }
.fp-assina-qtd, .fp-assina-mix { padding:6px 14px; border:1px solid var(--feltoni-border-strong); border-radius:999px; font-size:13px; font-weight:600; color: var(--feltoni-text); }
.fp-assina-price { font-family:'Anton',sans-serif; font-size:48px; line-height:1; color: var(--feltoni-text); }
.fp-assina-price .woocommerce-Price-amount { font: inherit; color: inherit; }
.fp-assina-period { display:block; font-family:'Archivo'; font-size:13px; font-weight:600; color: var(--feltoni-text-dim); margin-top:6px; }
.fp-assina-actions { display:flex; gap:14px; justify-content:center; align-items:center; flex-wrap:wrap; margin:24px 0 12px; }
.fp-assina-btn { display:inline-flex; align-items:center; justify-content:center; height:54px; padding:0 34px; background:#ff1f8f; color:#fff !important; border-radius:999px; font-size:15px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; text-decoration:none !important; transition:all .3s var(--feltoni-ease); box-shadow:0 8px 24px rgba(255,31,143,.4); }
.fp-assina-btn:hover { background: var(--feltoni-pink-glow); transform: translateY(-2px); }
.fp-assina-btn--off { background: rgba(255,255,255,.08); color: var(--feltoni-text-mute) !important; box-shadow:none; cursor:default; }
.fp-assina-ghost { font-size:14px; font-weight:700; color: var(--feltoni-text-dim) !important; text-transform:uppercase; letter-spacing:.04em; text-decoration:none !important; }
.fp-assina-pay { font-size:11px; letter-spacing:.06em; text-transform:uppercase; color: var(--feltoni-text-mute); margin-top:8px; }
.fp-assina-sec { max-width: var(--feltoni-maxw); margin:0 auto; padding: 60px 32px; }
.fp-assina-head { text-align:center; margin-bottom:40px; }
.fp-assina-h2 { font-family:'Anton',sans-serif !important; font-weight:400 !important; font-size: clamp(30px,4vw,48px) !important; text-transform:uppercase; line-height:1 !important; margin:8px 0 0 !important; color: var(--feltoni-text) !important; }
.fp-assina-grid, .fp-assina-steps, .fp-assina-cross { display:grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap:16px; }
.fp-assina-card, .fp-assina-steps li { background: var(--feltoni-bg-card); border:1px solid var(--feltoni-border); border-radius: var(--feltoni-radius); padding:24px; }
.fp-assina-card h3, .fp-assina-steps h3 { font-family:'Anton',sans-serif !important; font-weight:400 !important; font-size:21px !important; text-transform:uppercase; margin:0 0 8px !important; color: var(--feltoni-text) !important; }
.fp-assina-card p, .fp-assina-steps p { font-size:14px; line-height:1.6; color: var(--feltoni-text-dim); margin:0; }
.fp-assina-card--gift { border-color: rgba(255,31,143,.4); }
.fp-assina-steps { list-style:none; padding:0; margin:0; }
.fp-assina-steps h3 { margin-top:8px !important; }
.fp-assina-num { font-family:'Anton',sans-serif; font-size:32px; color: var(--feltoni-pink); }
.fp-assina-faq { max-width:760px; margin:0 auto; display:flex; flex-direction:column; gap:10px; }
.fp-assina-faq details { background: var(--feltoni-bg-card); border:1px solid var(--feltoni-border); border-radius: var(--feltoni-radius); padding:16px 20px; }
.fp-assina-faq summary { cursor:pointer; font-weight:700; font-size:15px; color: var(--feltoni-text); }
.fp-assina-faq p { font-size:14px; line-height:1.6; color: var(--feltoni-text-dim); margin:10px 0 0; }
.fp-assina-cross { max-width:760px; margin:0 auto; }
.fp-assina-cross__card { position:relative; background: var(--feltoni-bg-card); border:1px solid var(--feltoni-border); border-radius: var(--feltoni-radius-lg); padding:28px 24px; text-decoration:none !important; color:inherit !important; transition:all .3s var(--feltoni-ease); }
.fp-assina-cross__card:hover, .fp-assina-cross__card.is-featured { border-color: var(--feltoni-pink); }
.fp-assina-cross__card:hover { transform: translateY(-4px); }
.fp-assina-cross__tag { display:inline-block; background: var(--feltoni-pink); color:#fff; font-size:10px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; padding:4px 10px; border-radius:999px; margin-bottom:12px; }
.fp-assina-cross__card h3 { font-family:'Anton',sans-serif !important; font-weight:400 !important; font-size:24px !important; text-transform:uppercase; margin:0 0 8px !important; color: var(--feltoni-text) !important; }
.fp-assina-cross__price { font-family:'Anton',sans-serif; font-size:28px; color: var(--feltoni-pink); margin:0 0 8px; }
.fp-assina-cross__price small { font-family:'Archivo'; font-size:12px; color: var(--feltoni-text-mute); }
.fp-assina-cross__desc { font-size:13px; color: var(--feltoni-text-dim); margin:0 0 14px; }
.fp-assina-cross__cta { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color: var(--feltoni-text-dim); }
@media (max-width:768px){ .fp-assina-hero, .fp-assina-sec { padding:48px 20px; } }

/* ASSINATURA — corrige o left-align (via :has, sem depender do slug) */
.single-product div.product:has(.fp-assina) {
  display: block !important;
  padding: 0 !important;
}
.single-product div.product:has(.fp-assina) > .elementor,
.single-product div.product:has(.fp-assina) .e-con,
.single-product div.product:has(.fp-assina) .e-con-inner,
.single-product div.product:has(.fp-assina) .elementor-widget-html,
.single-product div.product:has(.fp-assina) .elementor-widget-container {
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
}

/* ============================================================
 * HERO ASSINATURA — 2 COLUNAS (info esquerda + latas direita)
 * As classes batem 1:1 com o PHP. Carrega DEPOIS das regras base.
 * ============================================================ */

/* Override do inner: era 760px centralizado, agora grid 2-col */
.fp-assina-hero__inner{
  max-width:1140px;
  margin:0 auto;
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(0,0.95fr);
  gap:48px;
  align-items:center;
  text-align:left;
}
/* 1 lata: estreita a coluna de midia para nao "boiar" */
.fp-assina-hero__inner.is-single{
  grid-template-columns:minmax(0,1.2fr) minmax(0,0.8fr);
}

/* ---- INFO (esquerda) ---- */
.fp-assina-hero__info{ min-width:0; }
.fp-assina-title{ overflow-wrap:anywhere; }
.fp-assina-hero .fp-assina-hero__info .fp-assina-bc,
.fp-assina-hero .fp-assina-hero__info .fp-assina-compo,
.fp-assina-hero .fp-assina-hero__info .fp-assina-actions{ justify-content:flex-start; }
.fp-assina-hero__info .fp-assina-badge{ display:inline-block; }

/* ---- MIDIA (direita): palco com brilho e latas ---- */
.fp-assina-hero__media{
  position:relative;
  min-width:0;
  min-height:380px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-end;
  isolation:isolate;
  overflow:hidden;
}
.fp-assina-hero__media--single{ min-height:340px; }

/* brilho rosa -> verde atras das latas */
.fp-assina-glow{
  position:absolute;
  z-index:0;
  inset:auto 0 14% 0;
  top:4%;
  pointer-events:none;
  background:
    radial-gradient(closest-side, rgba(255,31,143,0.42), transparent 72%) -14% 18% / 62% 78% no-repeat,
    radial-gradient(closest-side, rgba(37,229,98,0.32), transparent 72%) 116% 30% / 60% 74% no-repeat,
    radial-gradient(ellipse 70% 60% at 50% 42%, rgba(255,31,143,0.16), transparent 70%);
  filter:blur(8px);
}
.fp-assina-hero__media--single .fp-assina-glow{
  background:radial-gradient(closest-side, rgba(255,31,143,0.40), transparent 70%) 50% 34% / 78% 80% no-repeat;
}

/* linha das latas — pedestal ancorado via ::after */
.fp-assina-cans{
  position:relative;
  z-index:2;
  display:flex;
  justify-content:center;
  align-items:flex-end;
  gap:0;
  width:100%;
  padding-bottom:18px;
}
.fp-assina-cans::after{
  content:'';
  position:absolute;
  z-index:-1;
  left:50%;
  bottom:6px;
  transform:translateX(-50%);
  width:78%;
  height:48px;
  pointer-events:none;
  background:
    radial-gradient(ellipse 60% 100% at 50% 0%, rgba(255,255,255,0.10), transparent 70%),
    radial-gradient(ellipse 70% 100% at 50% 0%, rgba(0,0,0,0.55), transparent 72%);
  border-radius:50%;
  filter:blur(2px);
}

/* cada lata */
.fp-assina-can{
  position:relative;
  margin:0;
  width:min(48%, 230px);
  display:flex;
  justify-content:center;
  transition:transform .35s ease;
  will-change:transform;
}
.fp-assina-hero__media--single .fp-assina-can{ width:min(64%, 290px); }

/* disco de brilho colorido atras de cada lata */
.fp-assina-can::before{
  content:'';
  position:absolute;
  left:50%;
  top:46%;
  width:108%;
  aspect-ratio:1 / 1;
  transform:translate(-50%,-50%);
  border-radius:50%;
  z-index:0;
  filter:blur(8px);
  opacity:0.9;
  pointer-events:none;
}
.fp-assina-can.is-pre::before{ background:radial-gradient(circle at 50% 45%, rgba(255,31,143,0.42), transparent 62%); }
.fp-assina-can.is-pos::before{ background:radial-gradient(circle at 50% 45%, rgba(37,229,98,0.40), transparent 62%); }
.fp-assina-can.is-neutral::before{ background:radial-gradient(circle at 50% 45%, rgba(255,255,255,0.18), transparent 62%); }

/* sobreposicao + inclinacao oposta no duo */
.fp-assina-hero__media--duo .fp-assina-can:nth-child(1){ transform:rotate(-7deg) translateY(6px); z-index:2; margin-right:-7%; }
.fp-assina-hero__media--duo .fp-assina-can:nth-child(2){ transform:rotate(7deg);  z-index:1; margin-left:-7%; }
.fp-assina-hero__media--duo .fp-assina-can:hover{ transform:rotate(0deg) translateY(-6px); z-index:5; }
.fp-assina-hero__media--single .fp-assina-can:hover{ transform:translateY(-6px); }

.fp-assina-can__img{
  position:relative;
  z-index:1;
  display:block;
  height:clamp(240px,32vw,440px);
  width:auto;
  max-width:100%;
  object-fit:contain;
  filter:drop-shadow(0 26px 30px rgba(0,0,0,0.55));
}
.fp-assina-can.is-pre .fp-assina-can__img{ filter:drop-shadow(0 22px 26px rgba(255,31,143,0.40)) drop-shadow(0 30px 34px rgba(0,0,0,0.55)); }
.fp-assina-can.is-pos .fp-assina-can__img{ filter:drop-shadow(0 22px 26px rgba(37,229,98,0.36)) drop-shadow(0 30px 34px rgba(0,0,0,0.55)); }

/* pilulas de confianca */
.fp-assina-trust{
  position:relative;
  z-index:3;
  list-style:none;
  margin:8px 0 0;
  padding:0;
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px 12px;
}
.fp-assina-trust__item{
  display:inline-flex;
  align-items:center;
  gap:7px;
  font-family:'Archivo',sans-serif;
  font-size:13px;
  line-height:1;
  color:var(--feltoni-text-dim);
  background:var(--feltoni-bg-card);
  border:1px solid var(--feltoni-border);
  border-radius:999px;
  padding:9px 14px;
  white-space:nowrap;
}
.fp-assina-trust__ico{ font-size:13px; line-height:1; }

/* ===== RESPONSIVO: empilha em 1 coluna abaixo de 900px ===== */
@media (max-width:900px){
  .fp-assina-hero{ padding:56px 24px; }
  .fp-assina-hero__inner,
  .fp-assina-hero__inner.is-single{
    grid-template-columns:1fr;
    gap:32px;
    max-width:560px;
    text-align:center;
  }
  .fp-assina-hero .fp-assina-hero__info .fp-assina-bc,
  .fp-assina-hero .fp-assina-hero__info .fp-assina-compo,
  .fp-assina-hero .fp-assina-hero__info .fp-assina-actions{ justify-content:center; }
  .fp-assina-hero__media{ order:2; min-height:320px; }
  .fp-assina-hero__media--duo .fp-assina-can{ width:min(46%, 200px); }
  .fp-assina-hero__media--single .fp-assina-can{ width:min(58%, 230px); }
  .fp-assina-can__img{ height:clamp(220px,40vw,340px); }
}
@media (max-width:480px){
  .fp-assina-hero__media{ min-height:280px; }
  .fp-assina-hero__media--duo .fp-assina-can{ width:min(48%, 165px); }
  .fp-assina-hero__media--duo .fp-assina-can:nth-child(1){ transform:rotate(-4deg) translateY(4px); }
  .fp-assina-hero__media--duo .fp-assina-can:nth-child(2){ transform:rotate(4deg); }
  .fp-assina-can__img{ height:clamp(180px,52vw,260px); }
  .fp-assina-trust__item{ font-size:12px; padding:8px 12px; }
}

/* respeita reduce-motion */
@media (prefers-reduced-motion:reduce){
  .fp-assina-can{ transition:none; }
  .fp-assina-can:hover{ transform:none; }
  .fp-assina-hero__media--duo .fp-assina-can:nth-child(1):hover{ transform:rotate(-7deg) translateY(6px); }
  .fp-assina-hero__media--duo .fp-assina-can:nth-child(2):hover{ transform:rotate(7deg); }
}

/* ===== ASSINATURA — tira o vazio preto acima do hero =====
   Zera o topo dos wrappers (escopo :has(.fp-assina), so nos planos).
   O respiro abaixo do header fica controlado pelo padding do hero. */
body:has(.fp-assina) main.jet-theme-core-location,
body:has(.fp-assina) .jet-theme-core-location__inner,
body:has(.fp-assina) .jet-theme-core-document__inner,
body:has(.fp-assina) #jet-theme-core-document,
.single-product div.product:has(.fp-assina) > .elementor,
.single-product div.product:has(.fp-assina) > .elementor > .elementor-section:first-child,
.single-product div.product:has(.fp-assina) > .elementor > .e-con:first-child {
  padding-top: 0 !important;
  margin-top: 0 !important;
}
/* respiro controlado no lugar do vazio gigante */
.fp-assina-hero { padding-top: 56px; }
@media (max-width:900px){ .fp-assina-hero { padding-top: 40px; } }

/* ASSINATURA — tira o vazio preto acima do hero */
body:has(.fp-assina) { padding-top: 0 !important; }
.fp-assina-hero { padding-top: 28px; }
@media (max-width:900px){ .fp-assina-hero { padding-top: 20px; } }