/*
Theme Name: Lume Lar — Flatsome Child
Description: Child theme da Casa da Fé baseado em Flatsome.
Author: Casa da Fé
Template: flatsome
Version: 1.5.0
*/

/* ============ HERO HOME (full-width banner) ============ */
.cdf-hero {
  position: relative;
  width: 100vw !important;
  max-width: 100vw !important;
  left: 50% !important;
  right: 50% !important;
  margin-left: -50vw !important;
  margin-right: -50vw !important;
}
.cdf-hero .banner-bg .overlay {
  background: linear-gradient(90deg, rgba(15,30,55,0.85) 0%, rgba(15,30,55,0.55) 50%, rgba(15,30,55,0.25) 100%) !important;
}
@media (max-width: 768px) {
  .cdf-hero .banner-bg .overlay {
    background: linear-gradient(180deg, rgba(15,30,55,0.45) 0%, rgba(15,30,55,0.85) 100%) !important;
  }
}

/* ============ TIPOGRAFIA ============ */
.banner h1, .banner h2, .banner h3,
.text-inner h1, .text-inner h2, .text-inner h3 {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 600;
}

/* ============ BOTOES CTA GOLD ============ */
.button.primary {
  background: #C9A961 !important;
  color: #1E3A5F !important;
  border-color: #C9A961 !important;
  font-weight: 700;
  letter-spacing: 1.5px;
}
.button.primary:hover {
  background: #1E3A5F !important;
  color: #C9A961 !important;
  border-color: #1E3A5F !important;
}

/* ============ PDP — Rating block ============ */
.cdf-rating-block {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 0 0 14px;
  margin: 0 0 8px;
}
.cdf-rating-block__col { flex: 1; }
.cdf-rating-block__divider {
  width: 1px;
  background: #d8d8d8;
  align-self: stretch;
}
.cdf-rating-block__label {
  font-size: 13px;
  color: #2c2c2c;
  font-weight: 400;
}
.cdf-rating-block__stars {
  color: #E8B939;
  font-size: 18px;
  letter-spacing: 1px;
  margin-top: 2px;
}
.cdf-rating-block__number {
  font-size: 22px;
  font-weight: 700;
  color: #1a1a1a;
  margin-top: 2px;
}

/* ============ PDP — Badge ALTA DEMANDA ============ */
.cdf-badge-demand {
  display: inline-block;
  background: #FCE4DC;
  color: #C8462E;
  padding: 5px 12px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  border-radius: 4px;
  margin: 0 0 14px;
}

/* ============ PDP — Title ============ */
.product-page-title,
.product_title {
  font-family: 'New York','Iowan Old Style','Apple Garamond',Baskerville,'Times New Roman',Times,serif !important;
  font-weight: 600 !important;
  font-size: clamp(24px, 4vw, 34px) !important;
  line-height: 1.18 !important;
  color: #101010 !important;
  margin: 0 0 12px !important;
}

/* ============ PDP — Eyebrow descritivo ============ */
.cdf-eyebrow {
  font-size: 14px;
  color: #555;
  line-height: 1.5;
  margin: 0 0 14px;
}

/* ============ PDP — Badge ECONOMIZE ============ */
.cdf-badge-economize {
  display: inline-block;
  background: #C9A961;
  color: #fff;
  padding: 5px 12px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1px;
  border-radius: 3px;
  margin: 0 0 12px;
}

/* ============ PDP — Price ============ */
.product-page-pricing,
.product .price {
  font-size: 26px !important;
  font-weight: 800 !important;
  color: #1a1a1a !important;
  margin: 0 !important;
}
.product-page-pricing del,
.product .price del {
  font-size: 16px !important;
  color: #888 !important;
  font-weight: 400 !important;
  margin-left: 8px;
}

/* ============ PDP — Badge PIX ============ */
.cdf-badge-pix {
  display: inline-block;
  background: #D4F5E1;
  color: #1F7A3D;
  padding: 5px 12px;
  font-size: 12px;
  font-weight: 700;
  border-radius: 3px;
  margin: 8px 0 16px;
}

/* ============ PDP — Quote box ============ */
.cdf-quote-box {
  background: transparent;
  border: 1px solid #e6e6e6;
  border-radius: 6px;
  padding: 14px 16px;
  margin: 0 0 24px;
}
.cdf-quote-box em {
  font-family: 'New York', Georgia, serif;
  font-size: 15px;
  line-height: 1.5;
  color: #2a2a2a;
  font-style: italic;
}

/* ============ PDP — Variant Cards "Escolha sua Experiência" ============ */
.product-form__input.product-form-pa_experiencia,
.variations {
  position: relative;
}
.variations::before {
  content: "Escolha sua Experiência";
  display: block;
  text-align: center;
  font-family: 'New York', Georgia, serif;
  font-size: 18px;
  font-weight: 600;
  color: #1a1a1a;
  margin: 24px 0 14px;
  position: relative;
}
.variations::after {
  content: "";
  display: block;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, #ccc 30%, #ccc 70%, transparent 100%);
  margin: -10px 0 18px;
}

/* WooCommerce variations table (override default ugly select) */
.variations { border-collapse: separate; }
.variations tr { display: block; }
.variations th { display: none; }
.variations td.value {
  display: block;
  padding: 0;
}

/* Custom radio cards (replaces select) — generated via JS or via theme template */
.cdf-variant-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin: 0 0 14px;
}
.cdf-variant-card {
  border: 2px solid #e0e0e0;
  border-radius: 6px;
  padding: 12px;
  cursor: pointer;
  text-align: center;
  position: relative;
  transition: border-color 0.2s, box-shadow 0.2s;
  background: #fff;
}
.cdf-variant-card.is-selected {
  border-color: #C9A961;
  box-shadow: 0 0 0 1px #C9A961;
}
.cdf-variant-card.is-bestseller {
  padding-top: 32px;
}
.cdf-variant-card.is-bestseller::before {
  content: "MAIS VENDIDO";
  position: absolute;
  top: 0; left: 0; right: 0;
  background: #C9A961;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.2px;
  padding: 6px 0;
  border-radius: 4px 4px 0 0;
}
.cdf-variant-card__img {
  width: 100%;
  aspect-ratio: 1/1;
  object-fit: cover;
  border-radius: 4px;
  margin-bottom: 10px;
}
.cdf-variant-card__title {
  font-family: 'New York', Georgia, serif;
  font-size: 15px;
  font-weight: 700;
  color: #1a1a1a;
  margin: 0 0 6px;
  line-height: 1.2;
}
.cdf-variant-card__caption {
  font-size: 11px;
  color: #666;
  line-height: 1.35;
  margin: 0 0 10px;
  min-height: 28px;
}
.cdf-variant-card__price {
  font-size: 16px;
  font-weight: 800;
  color: #1a1a1a;
}
.cdf-variant-card__compare {
  font-size: 12px;
  color: #999;
  text-decoration: line-through;
}
.cdf-variant-card__benefit {
  display: inline-block;
  background: #D4F5E1;
  color: #1F7A3D;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.5px;
  padding: 3px 8px;
  border-radius: 2px;
  margin-top: 8px;
}

/* ============ PDP — Stock alert ============ */
.cdf-stock-alert {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: #2a2a2a;
  margin: 14px 0 4px;
}
.cdf-stock-alert__dot {
  width: 8px;
  height: 8px;
  background: #FF7A1A;
  border-radius: 50%;
  display: inline-block;
}
.cdf-stock-alert__note {
  font-size: 11px;
  color: #888;
  font-style: italic;
  margin: 0 0 14px;
}

/* ============ PDP — CTA preto fullwidth ============ */
.single_add_to_cart_button {
  background: #1a1a1a !important;
  color: #fff !important;
  border: 0 !important;
  padding: 16px 24px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  letter-spacing: 1.5px !important;
  border-radius: 4px !important;
  width: 100% !important;
  display: block !important;
  text-transform: uppercase !important;
}
.single_add_to_cart_button:hover {
  background: #C9A961 !important;
  color: #1a1a1a !important;
}

/* ============ PDP — After CTA (delivery + warranty) ============ */
.cdf-delivery-info {
  font-size: 13px;
  color: #2a2a2a;
  margin: 16px 0 8px;
}
.cdf-warranty-link {
  font-size: 13px;
  color: #1a1a1a;
  text-decoration: underline;
  display: inline-block;
  margin-bottom: 16px;
}

/* ============ PDP layout — wider summary on desktop ============ */
@media (min-width: 850px) {
  .product-info { padding-left: 24px; }
}

/* ============ Mobile fine-tune ============ */
@media (max-width: 767px) {
  .cdf-rating-block { gap: 12px; }
  .cdf-rating-block__number { font-size: 18px; }
  .cdf-variant-card { padding: 10px; }
  .cdf-variant-card__title { font-size: 13px; }
  .product-page-title { font-size: 22px !important; }
  .banner h1 { font-size: clamp(28px, 8vw, 36px) !important; }
}

/* ============ Hide default WC Oferta! badge (substituido por ALTA DEMANDA) ============ */
.product .onsale,
.woocommerce span.onsale {
  display: none !important;
}

/* ============ Breadcrumb compact ============ */
.product-page .woocommerce-breadcrumb,
.product-page .breadcrumbs {
  font-size: 12px;
  color: #888;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 8px;
}

/* ============ Variation form — hide default select, show our custom cards ============ */
.variations_form .variations select { display: none !important; }
.variations_form .reset_variations { display: none !important; }
.variations_form table.variations { display: none !important; }

/* ============ Single Product layout fine-tune ============ */
.product-page .product-info {
  padding-left: 0;
}
@media (min-width: 850px) {
  .product-page .product-info { padding-left: 24px; }
}

/* ============ Hide WooCommerce default variation chrome ============ */
.variations_form .single_variation_wrap .price { display: none !important; }
.variations_form .reset_variations { display: none !important; }
.variations { display: none !important; }
.variations_form .single_variation_wrap { padding: 0 !important; margin: 0 !important; }
.variations_form .single_variation { display: none !important; }

/* ============ ECONOMIZE + 5% PIX em linhas separadas ============ */
.cdf-badge-economize {
  display: block !important;
  margin: 0 0 10px;
  width: fit-content;
}
.cdf-badge-pix {
  display: block !important;
  margin: 8px 0 16px;
  width: fit-content;
}

/* ============ Price único (não range) ============ */
.cdf-price-current {
  font-size: 28px;
  font-weight: 800;
  color: #1a1a1a;
}
.cdf-price-regular {
  font-size: 16px;
  color: #888;
  font-weight: 400;
  margin-left: 8px;
}

/* ============ Title editorial Casa da Fé ============ */
.product .product_title {
  font-family: 'New York','Iowan Old Style','Apple Garamond',Baskerville,'Times New Roman',Times,serif !important;
  font-weight: 600 !important;
  font-size: clamp(22px, 4.5vw, 32px) !important;
  line-height: 1.2 !important;
  color: #1a1a1a !important;
  margin: 8px 0 12px !important;
  letter-spacing: -0.2px;
}

/* ============ Eyebrow position abaixo do title ============ */
.cdf-eyebrow {
  font-size: 14px;
  color: #555;
  line-height: 1.5;
  margin: 0 0 16px;
}

/* ============ Variants section "Escolha sua Experiência" — title com linhas decorativas ============ */
.cdf-variants-section { margin: 24px 0 14px; }
.cdf-variants-title-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin: 0 0 14px;
}
.cdf-variants-title-line {
  flex: 0 0 28px;
  height: 1px;
  background: #1a1a1a;
}
.cdf-variants-title {
  font-family: 'New York', Georgia, serif;
  font-size: 18px;
  font-weight: 600;
  color: #1a1a1a;
  white-space: nowrap;
}

/* ============ Mobile fine-tune ============ */
@media (max-width: 767px) {
  .cdf-rating-block { gap: 12px; padding: 0 0 10px; }
  .cdf-rating-block__number { font-size: 18px; }
  .cdf-variant-card { padding: 10px; }
  .cdf-variant-card__title { font-size: 13px; }
  .product .product_title { font-size: 22px !important; }
  .cdf-price-current { font-size: 24px; }
}

/* ============ FIX VISUAIS PDP — round 2 ============ */

/* Nuke ALL default WC sale badges (Oferta!, onsale, etc) */
.product .onsale,
.woocommerce span.onsale,
.woocommerce-page span.onsale,
.product .badge-container,
.product-badge,
.bagde-container,
ul.product-badges,
.image-tools .image-badge,
.flatsome-onsale,
.flatsome-product-badge,
span.bagde-text {
  display: none !important;
}

/* Hide breadcrumb on single product (cleaner like Artes da Fé) */
.single-product .woocommerce-breadcrumb,
.single-product .shop-page-title,
.single-product nav.breadcrumb,
.product-page .breadcrumb,
.product-page .woocommerce-breadcrumb,
body.single-product nav.breadcrumb,
.cdf-breadcrumb {
  display: none !important;
}

/* Hide "Início / Kits e Presentes" breadcrumb */
.product-info > .woocommerce-breadcrumb,
.product-info nav.breadcrumb,
.product-summary nav.breadcrumb {
  display: none !important;
}

/* Reduzir altura da imagem principal (galeria cleaner como Artes da Fé) */
.product-gallery-slider .flickity-viewport,
.woocommerce-product-gallery .flex-viewport {
  max-height: 480px !important;
}
.woocommerce-product-gallery .woocommerce-product-gallery__image img {
  max-height: 480px;
  width: auto;
  margin: 0 auto;
  object-fit: contain;
}

/* ============ ROUND 3 — Tighten + hide WC chrome ============ */

/* CTA preto (não gold) — forçar override */
.product .single_add_to_cart_button,
.woocommerce .single_add_to_cart_button,
button.single_add_to_cart_button {
  background: #1a1a1a !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: 4px !important;
  font-weight: 700 !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  padding: 16px 24px !important;
  width: 100% !important;
}
.product .single_add_to_cart_button:hover {
  background: #C9A961 !important;
  color: #1a1a1a !important;
}

/* Esconder quantity selector */
.product .quantity,
.product div.quantity,
.product .qty,
.product form.cart .quantity {
  display: none !important;
}

/* Esconder product_meta (SKU + Categorias + Tags) */
.product .product_meta,
.product_meta,
.product .product_meta * {
  display: none !important;
}

/* Esconder social share icons */
.product .ux_share,
.product .product-share,
.product .share-block,
.product-info .ux_share,
.product-info .social-icons,
.product-info .share-block {
  display: none !important;
}

/* Compactar espaçamentos verticais */
.cdf-rating-block { margin: 0 0 10px !important; padding: 0 0 10px !important; }
.cdf-badge-demand { margin: 0 0 10px !important; }
.product .product_title { margin: 0 0 8px !important; }
.cdf-eyebrow { margin: 0 0 12px !important; }
.cdf-badge-economize { margin: 0 0 6px !important; }
.product .price,
.cdf-price-current { margin: 4px 0 6px !important; }
.cdf-badge-pix { margin: 6px 0 12px !important; }
.cdf-quote-box { margin: 0 0 18px !important; padding: 12px 14px !important; }
.cdf-variants-section { margin: 0 0 14px !important; }
.cdf-variants-title-wrap { margin: 0 0 12px !important; }
.cdf-variant-cards { margin: 0 0 12px !important; }
.cdf-stock-alert { margin: 12px 0 4px !important; }
.cdf-stock-alert__note { margin: 0 0 12px !important; }
.cdf-delivery-info { margin: 12px 0 6px !important; }
.cdf-warranty-link { margin: 0 0 14px !important; display: inline-block; }

/* Compactar form.cart */
.product form.cart {
  margin: 0 !important;
  padding: 0 !important;
}
.product form.cart .single_variation_wrap {
  margin: 0 !important;
  padding: 0 !important;
}

/* Single variation price hidden (usa o do topo) */
.single_variation_wrap .price { display: none !important; }

/* Tabs/accordion compacto */
.product-tabs-section {
  margin-top: 14px !important;
}

/* ============ FASE 4 — DESCRIÇÃO RICA (Sales page abaixo) ============ */

/* Hero tagline cinematográfica (centro) */
.cdf-pdp-hero-title {
  font-family: 'New York','Iowan Old Style','Apple Garamond',Baskerville,'Times New Roman',Times,serif !important;
  font-weight: 600 !important;
  font-size: clamp(28px, 4.5vw, 44px) !important;
  line-height: 1.2 !important;
  color: #1a1a1a !important;
  margin: 0 auto !important;
  max-width: 760px;
}
.cdf-pdp-hero-eyebrow {
  font-size: 11px !important;
  letter-spacing: 4px !important;
  font-weight: 600 !important;
  color: #888 !important;
  text-transform: uppercase !important;
  margin: 0 !important;
  line-height: 1.5;
}

/* Image + Text section */
.cdf-pdp-image-frame {
  margin: 0 !important;
  padding: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.cdf-pdp-image-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  min-height: 360px;
}
.cdf-pdp-section-title {
  font-family: 'New York','Iowan Old Style',Baskerville,'Times New Roman',Times,serif !important;
  font-weight: 600 !important;
  font-size: clamp(24px, 3.4vw, 34px) !important;
  line-height: 1.2 !important;
  color: #1a1a1a !important;
  margin: 0 0 14px !important;
}
.cdf-pdp-section-text {
  font-size: 16px !important;
  line-height: 1.65 !important;
  color: #444 !important;
  margin: 0 !important;
}

/* 3 Pilares com vídeo GIF loop */
.cdf-pdp-pillar {
  background: #fcfaf6;
  border-radius: 4px;
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
}
.cdf-pdp-pillar__media {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  display: block;
  background: #f4ecd8;
}
.cdf-pdp-pillar__title {
  font-family: 'New York', Baskerville, Times, serif !important;
  font-weight: 600 !important;
  font-size: 22px !important;
  color: #1a1a1a !important;
  margin: 24px 24px 12px !important;
  line-height: 1.25 !important;
}
.cdf-pdp-pillar__text {
  font-size: 15px !important;
  line-height: 1.55 !important;
  color: #555 !important;
  margin: 0 24px 24px !important;
}

/* Quote final cinematográfico */
.cdf-pdp-quote-final {
  font-family: 'New York', Baskerville, Times, serif !important;
  font-style: italic !important;
  font-weight: 500 !important;
  font-size: clamp(22px, 3.4vw, 32px) !important;
  line-height: 1.3 !important;
  color: #1a1a1a !important;
  margin: 0 auto !important;
  max-width: 720px;
}
.cdf-pdp-quote-paragraph {
  font-size: 16px !important;
  line-height: 1.7 !important;
  color: #444 !important;
  margin: 0 auto 14px !important;
  max-width: 680px;
}
.cdf-pdp-quote-cta {
  font-size: 16px !important;
  color: #1a1a1a !important;
  margin: 0 auto !important;
  max-width: 680px;
}

/* FAQ Accordion */
.cdf-pdp-faq-title {
  font-family: 'New York','Iowan Old Style',Baskerville,Times,serif !important;
  font-weight: 600 !important;
  font-size: clamp(26px, 3.8vw, 36px) !important;
  text-align: center !important;
  color: #1a1a1a !important;
  margin: 0 !important;
}

/* Accordion items styling override (Flatsome default) */
.accordion .accordion-item {
  border-bottom: 1px solid #e8e8e8;
  margin: 0;
}
.accordion .accordion-title {
  padding: 18px 0 !important;
  font-size: 16px !important;
  font-weight: 500 !important;
  color: #1a1a1a !important;
}
.accordion .accordion-inner {
  padding: 0 0 18px !important;
  font-size: 15px !important;
  line-height: 1.65 !important;
  color: #555 !important;
}

/* Mobile fine-tune */
@media (max-width: 767px) {
  .cdf-pdp-pillar { margin-bottom: 20px; }
  .cdf-pdp-pillar__title { font-size: 19px !important; margin: 20px 20px 10px !important; }
  .cdf-pdp-pillar__text { margin: 0 20px 20px !important; }
  .cdf-pdp-image-frame img { min-height: 280px; }
}

/* ============ FINAL TIGHTEN — remover espaço em branco abaixo do CTA + setinha "próximo" + arrumar layout ============ */

/* Remover Garantia de 90 Dias se ainda existir */
.cdf-warranty-link { display: none !important; }

/* Tirar espaço grande entre CTA e descrição/tabs */
.product form.cart {
  margin-bottom: 8px !important;
}
.product .cdf-delivery-info {
  margin: 10px 0 4px !important;
  font-size: 13px;
}
.product .product-page-section {
  margin-top: 0 !important;
  padding-top: 0 !important;
}
.product-tabs-section { margin-top: 6px !important; padding-top: 0 !important; }

/* Remover setinha "next product" / "previous product" navigation */
.product-page .next-prev-thumbs,
.product-page .next-prev-product,
.product-pagination,
.product-page .product-thumbnails-wrapper .nav-arrows,
.product-page-icons .icon-angle-right,
.product-page .next-product,
.product-page .prev-product,
nav.product-pagination,
.product-info .product-pagination,
.absolute.next.button,
.absolute.prev.button {
  display: none !important;
}

/* Variant cards: tamanho/spacing better */
.cdf-variant-cards {
  gap: 12px !important;
}
.cdf-variant-card {
  padding: 14px 12px !important;
}
.cdf-variant-card__caption {
  min-height: auto !important;
  font-size: 12px !important;
  line-height: 1.4 !important;
}

/* Variant card image bigger */
.cdf-variant-card__img {
  aspect-ratio: 1/1;
  width: 100%;
  margin-bottom: 12px;
  border-radius: 4px;
}

/* Page padding mais generoso */
.product-page,
body.single-product .product {
  padding: 16px 0 32px !important;
}

/* Mobile: padding lateral generoso (Artes da Fé tem mais "ar") */
@media (max-width: 767px) {
  body.single-product .product-info {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
  .cdf-rating-block {
    padding: 0 0 12px !important;
  }
  .cdf-variant-cards {
    gap: 10px !important;
  }
  .cdf-variant-card { padding: 12px 10px !important; }
  .cdf-variant-card__title { font-size: 14px !important; margin: 0 0 4px !important; }
  .cdf-variant-card__caption { font-size: 11px !important; margin: 0 0 8px !important; }
  .cdf-variant-card__price { font-size: 15px !important; }
  .cdf-variant-card__compare { font-size: 11px !important; }
}

/* Quote final maior + bold (já em h2 cdf-pdp-quote-final-h2) */
.cdf-pdp-quote-final-h2 {
  font-family: 'New York','Iowan Old Style',Baskerville,Times,serif !important;
  font-style: italic !important;
  font-weight: 700 !important;
  font-size: clamp(26px, 4.2vw, 40px) !important;
  line-height: 1.25 !important;
  color: #1a1a1a !important;
  margin: 0 auto !important;
  max-width: 760px;
}

/* Carrossel de pillars no slider */
.cdf-pdp-pillar {
  background: #fcfaf6;
  border-radius: 6px;
  overflow: hidden;
  height: auto;
  margin: 0 !important;
}
.flickity-button.previous,
.flickity-button.next {
  background: rgba(255,255,255,0.85) !important;
  color: #1a1a1a !important;
}
.flickity-page-dots .dot.is-selected {
  background: #C9A961 !important;
}

/* Tabs Descrição + Especificações */
.product-tabs-wrapper {
  border-top: 1px solid #e8e8e8;
  margin-top: 14px;
}
.tab-panels { padding: 16px 0 !important; }
.cdf-specs-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.cdf-specs-list li {
  padding: 10px 0;
  border-bottom: 1px solid #eee;
  font-size: 14px;
  line-height: 1.55;
  color: #333;
}

/* ============ Esconder TODAS as setinhas Flickity (thumbnails next/prev) ============ */
.product-page .flickity-button,
.product-page .flickity-prev-next-button,
.product-thumbnails-wrapper .flickity-button,
.product-gallery-slider .flickity-button.next,
.product-gallery-slider .flickity-button.previous,
.product-thumbnails .flickity-button,
button.flickity-button.next,
button.flickity-button.previous,
button.flickity-button {
  display: none !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Mas DEIXAR setas no carrossel de pillars na descrição */
.cdf-pdp-pillar-slider .flickity-button,
.ux_slider .flickity-button {
  display: block !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}
.cdf-pdp-section + .cdf-pdp-pillar .flickity-button { display: block !important; }

/* Esconder qualquer "next product" / "prev product" arrow do tema */
.product-pagination,
.product-page-prev-next,
.next-prev-product,
.next-product-link,
.prev-product-link,
.absolute.next.right,
.absolute.prev.left,
.product-thumbnails-wrapper button[class*="next"],
.product-info > button,
nav.next-prev-thumbs {
  display: none !important;
}

/* Tabs Descrição + Especificações — clean look */
.woocommerce-tabs .nav,
.product-tabs.nav-uppercase,
ul.tabs.product-tabs {
  border-bottom: 1px solid #e8e8e8 !important;
  margin: 24px 0 16px !important;
  padding: 0 !important;
  display: flex !important;
  gap: 24px !important;
  list-style: none !important;
}
.woocommerce-tabs .nav li,
.product-tabs li {
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
}
.woocommerce-tabs .nav li a,
.product-tabs li a {
  padding: 12px 0 14px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  letter-spacing: 1px !important;
  color: #888 !important;
  text-transform: uppercase !important;
  border-bottom: 2px solid transparent !important;
  display: block !important;
}
.woocommerce-tabs .nav li.active a,
.product-tabs li.active a {
  color: #1a1a1a !important;
  border-bottom-color: #C9A961 !important;
}
.tab-panels .panel,
.tab-panels .tab-panel,
.woocommerce-tabs .panel {
  padding: 18px 0 !important;
  background: transparent !important;
}

/* Especificações list styling */
.cdf-specs-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.cdf-specs-list li {
  padding: 12px 0 !important;
  border-bottom: 1px solid #efefef !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
  color: #333 !important;
}
.cdf-specs-list li:last-child {
  border-bottom: 0 !important;
}

/* Remove qualquer espaço esquisito entre tabs e conteúdo */
#tab-description,
#tab-cdf_specs {
  padding: 16px 0 !important;
  margin: 0 !important;
}

/* ============ Hide next-prev-thumbs (Flatsome product navigation) ============ */
.next-prev-thumbs,
ul.next-prev-thumbs,
.next-prev-thumbs.is-small,
.next-prev-thumbs.show-for-medium,
.prod-dropdown.has-dropdown,
li.prod-dropdown {
  display: none !important;
}

/* ============ FINAL SPACING — Match Artes da Fé exact ============ */

/* Reset spacing — neutralize generic padding */
.product .cart, .product form.cart {
  margin: 0 !important;
  padding: 0 !important;
}

/* Estoque baixo — compact, gold dot */
.cdf-stock-alert {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px !important;
  color: #1a1a1a !important;
  margin: 14px 0 4px !important;
}
.cdf-stock-alert__dot {
  width: 10px !important;
  height: 10px !important;
  background: #FF8C42 !important;
  border-radius: 50% !important;
  display: inline-block !important;
  flex-shrink: 0;
}
.cdf-stock-alert__note {
  font-size: 12px !important;
  color: #999 !important;
  font-style: italic !important;
  margin: 0 0 16px !important;
}

/* CTA preto compact (já preto) */
.product .single_add_to_cart_button {
  margin: 0 !important;
  padding: 16px 24px !important;
}

/* Receba Entre — directly below CTA, no extra space */
.cdf-delivery-info {
  font-size: 14px !important;
  color: #1a1a1a !important;
  margin: 14px 0 4px !important;
  padding: 0 !important;
}

/* Garantia 90 Dias — link sublinhado simples (no extra block space) */
.cdf-warranty-link-v2 {
  display: block !important;
  font-size: 14px !important;
  color: #1a1a1a !important;
  text-decoration: underline !important;
  margin: 0 0 14px !important;
  padding: 0 !important;
  font-weight: 400 !important;
}

/* Hide old warranty link */
.cdf-warranty-link { display: none !important; }

/* Tabs Descrição/Especificações — start right below Garantia */
.product-page .tabs-section,
.product-page .product-tabs-section,
.woocommerce-tabs {
  margin: 0 !important;
  padding: 14px 0 0 !important;
  border-top: 1px solid #ececec !important;
}

/* Tabs nav */
.woocommerce-tabs ul.tabs.product-tabs,
ul.tabs.product-tabs {
  display: flex !important;
  gap: 24px !important;
  border: 0 !important;
  border-bottom: 1px solid #ececec !important;
  margin: 0 0 0 !important;
  padding: 0 !important;
  list-style: none !important;
  background: transparent !important;
}
.product-tabs li.tab,
.tabs.product-tabs li {
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}
.product-tabs li.tab a,
.tabs.product-tabs li a {
  padding: 14px 0 !important;
  font-size: 16px !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  color: #1a1a1a !important;
  text-transform: none !important;
  border-bottom: none !important;
  display: block !important;
  background: transparent !important;
  font-family: 'New York','Iowan Old Style',Baskerville,Times,serif !important;
}
.product-tabs li.tab.active a,
.tabs.product-tabs li.active a {
  color: #1a1a1a !important;
  font-weight: 600 !important;
  border-bottom: none !important;
}

/* Tab panel content padding */
.tab-panels .panel,
#tab-description, #tab-cdf_specs,
.woocommerce-Tabs-panel {
  padding: 18px 0 0 !important;
  margin: 0 !important;
}

/* Hide accordion arrows do Flatsome se aparecerem */
.tabs-section .icon-angle-down { display: none !important; }

/* Mobile spacing fine-tune (match Artes da Fé) */
@media (max-width: 767px) {
  .cdf-rating-block { margin: 0 0 8px !important; padding: 0 !important; }
  .cdf-badge-demand { margin: 0 0 8px !important; }
  .product .product_title { margin: 0 0 6px !important; font-size: 22px !important; }
  .cdf-eyebrow { margin: 0 0 12px !important; }
  .cdf-badge-economize { margin: 0 0 6px !important; }
  .product .price { margin: 4px 0 4px !important; }
  .cdf-badge-pix { margin: 4px 0 14px !important; }
  .cdf-quote-box { margin: 0 0 18px !important; padding: 14px !important; }
  .cdf-variants-section { margin: 0 0 14px !important; }
  .cdf-stock-alert { margin: 12px 0 2px !important; }
  .cdf-stock-alert__note { margin: 0 0 14px !important; }
  .cdf-delivery-info { margin: 12px 0 2px !important; }
  .cdf-warranty-link-v2 { margin: 0 0 14px !important; }
  .product-tabs.tabs li.tab a { font-size: 16px !important; padding: 14px 0 !important; }
}

/* ============ Hide ANY remaining next-prev navigation ============ */
ul.next-prev-thumbs,
.next-prev-thumbs,
.prod-dropdown,
li.prod-dropdown {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  overflow: hidden !important;
}

/* ============ TIGHT — Remove ALL extra spacing between elements ============ */

/* Hide next-prev-thumbs definitivamente (not even taking dom space) */
ul.next-prev-thumbs,
.next-prev-thumbs,
li.prod-dropdown {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  font-size: 0 !important;
  line-height: 0 !important;
  position: absolute !important;
  left: -9999px !important;
}

/* Variant cards section bottom — tight to stock alert */
.cdf-variants-section { margin: 0 0 8px !important; }

/* Stock alert — tight margins */
.cdf-stock-alert { margin: 8px 0 0 !important; }
.cdf-stock-alert__note { margin: 0 0 10px !important; }

/* CTA — no margin */
.product .single_add_to_cart_button { margin: 0 !important; }

/* Form cart wrapper — no margin */
.product form.cart,
.product .cart,
.single_variation_wrap,
.woocommerce-variation-add-to-cart {
  margin: 0 !important;
  padding: 0 !important;
}

/* Receba Entre + Warranty — tight */
.cdf-delivery-info { margin: 10px 0 2px !important; }
.cdf-warranty-link-v2 { margin: 0 0 10px !important; }

/* Tabs — NO border-top, NO padding extra */
.product-page .product-tabs-section,
.tabs-section,
.woocommerce-tabs,
.product-page-section.tabs-section,
.product-tabs-section {
  margin: 0 !important;
  padding: 8px 0 0 !important;
  border-top: 1px solid #ececec !important;
}

/* Tabs nav row */
ul.tabs.product-tabs,
.tabs.product-tabs,
.woocommerce-tabs ul.tabs {
  margin: 0 !important;
  padding: 0 !important;
  border-bottom: 1px solid #ececec !important;
}
.product-tabs li.tab a,
.tabs.product-tabs li a {
  padding: 12px 0 !important;
}

/* Tabs panels — no extra padding */
.tab-panels { padding: 0 !important; margin: 0 !important; }
.tab-panels .panel,
.tab-panels .tab-panel,
#tab-description, #tab-cdf_specs,
.woocommerce-Tabs-panel {
  padding: 12px 0 !important;
  margin: 0 !important;
}

/* Tabs end → description rich content (no extra gap) */
.product-page .product-footer,
.product-footer-wrapper,
.product-footer {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* Description first section padding tighter */
.product-page > .product-footer .section:first-child,
.product-info ~ .product-footer section:first-child {
  padding-top: 24px !important;
}

/* Sections within description — reduce padding */
.product-footer section.section,
.product-info ~ .product-footer .section {
  padding: 30px 0 !important;
}

/* Mobile super tight */
@media (max-width: 767px) {
  .cdf-variants-section { margin: 0 0 6px !important; }
  .cdf-stock-alert { margin: 8px 0 0 !important; font-size: 13px !important; }
  .cdf-stock-alert__note { margin: 0 0 8px !important; font-size: 11px !important; }
  .cdf-delivery-info { margin: 8px 0 0 !important; font-size: 13px !important; }
  .cdf-warranty-link-v2 { margin: 0 0 10px !important; font-size: 13px !important; }

  .product-tabs-section,
  .product-page .product-tabs-section { padding: 6px 0 0 !important; }

  .product-tabs li.tab a,
  .tabs.product-tabs li a { padding: 10px 0 !important; font-size: 15px !important; }

  .tab-panels .panel { padding: 10px 0 !important; }

  .product-footer section.section { padding: 22px 0 !important; }
}

/* Remove tab arrow accordion icons no Flatsome */
.tabs.product-tabs li a::after,
.tabs.product-tabs li a::before { display: none !important; }

/* ============ CASA DA FÉ — PDP CUSTOM GRID (universal layout) ============ */

.cdf-pdp { padding: 0; }
.cdf-pdp__wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 16px 16px 32px;
}
.cdf-pdp__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
@media (min-width: 850px) {
  .cdf-pdp__grid {
    grid-template-columns: 1.1fr 1fr;
    gap: 48px;
    align-items: start;
  }
  .cdf-pdp__gallery { position: sticky; top: 24px; }
}
.cdf-pdp__summary { padding: 0; }
.cdf-pdp__description { margin-top: 32px; padding: 0; }

/* Reset — kill all default WC summary spacing */
.cdf-pdp__summary > * { margin: 0 !important; padding: 0 !important; }

/* Now apply EXACT spacing per element (Artes da Fé matching) */
.cdf-pdp__summary .cdf-rating-block { margin-bottom: 12px !important; padding-bottom: 12px !important; border-bottom: 1px solid transparent !important; }
.cdf-pdp__summary .cdf-badge-demand { margin-bottom: 10px !important; }
.cdf-pdp__summary .product_title { margin-bottom: 8px !important; }
.cdf-pdp__summary .cdf-eyebrow { margin-bottom: 14px !important; }
.cdf-pdp__summary .cdf-badge-economize { margin-bottom: 6px !important; }
.cdf-pdp__summary .price { margin-bottom: 6px !important; }
.cdf-pdp__summary .cdf-badge-pix { margin-bottom: 16px !important; }
.cdf-pdp__summary .cdf-quote-box { margin-bottom: 20px !important; padding: 14px 16px !important; }

/* Variants */
.cdf-pdp__summary .cdf-variants-section { margin-bottom: 12px !important; }
.cdf-pdp__summary .cdf-variants-title-wrap { margin-bottom: 12px !important; }
.cdf-pdp__summary .cdf-variant-cards { margin: 0 !important; }

/* Form cart wrapper */
.cdf-pdp__summary form.cart,
.cdf-pdp__summary .cart {
  margin: 0 !important;
  padding: 0 !important;
}
.cdf-pdp__summary .single_variation_wrap,
.cdf-pdp__summary .woocommerce-variation-add-to-cart,
.cdf-pdp__summary .woocommerce-variation {
  margin: 0 !important;
  padding: 0 !important;
}
.cdf-pdp__summary .single_variation { display: none !important; }

/* Stock alert */
.cdf-pdp__summary .cdf-stock-alert { margin: 8px 0 0 !important; }
.cdf-pdp__summary .cdf-stock-alert__note { margin: 0 0 12px !important; }

/* CTA */
.cdf-pdp__summary .single_add_to_cart_button {
  margin: 0 !important;
  padding: 18px 24px !important;
  width: 100% !important;
}

/* After CTA */
.cdf-pdp__summary .cdf-delivery-info { margin: 12px 0 0 !important; }
.cdf-pdp__summary .cdf-warranty-link-v2 { margin: 4px 0 14px !important; display: block !important; }

/* Tabs section */
.cdf-pdp__description .product-tabs-section,
.cdf-pdp__description .tabs-section,
.cdf-pdp__description .woocommerce-tabs {
  margin: 0 !important;
  padding: 0 !important;
  border-top: 1px solid #ececec !important;
}
.cdf-pdp__description ul.tabs.product-tabs,
.cdf-pdp__description .tabs.product-tabs {
  margin: 0 !important;
  padding: 0 !important;
  border-bottom: 1px solid #ececec !important;
}

/* Quantity selector hidden */
.cdf-pdp__summary .quantity { display: none !important; }

/* Hide ALL extra WC chrome */
.cdf-pdp__summary .product_meta,
.cdf-pdp__summary .product-share,
.cdf-pdp__summary .ux_share,
.cdf-pdp__summary .share-block,
.cdf-pdp__summary .next-prev-thumbs,
.cdf-pdp__summary ul.next-prev-thumbs,
.cdf-pdp__summary .prod-dropdown,
.cdf-pdp__summary .woocommerce-breadcrumb,
.cdf-pdp__summary .breadcrumbs,
.cdf-pdp__summary .is-divider {
  display: none !important;
}

/* Mobile spacing tighter */
@media (max-width: 767px) {
  .cdf-pdp__wrap { padding: 12px 16px 24px; }
  .cdf-pdp__grid { gap: 16px; }
  .cdf-pdp__description { margin-top: 20px; }

  .cdf-pdp__summary .cdf-rating-block { margin-bottom: 10px !important; padding-bottom: 10px !important; }
  .cdf-pdp__summary .cdf-badge-demand { margin-bottom: 8px !important; }
  .cdf-pdp__summary .product_title { margin-bottom: 6px !important; font-size: 22px !important; }
  .cdf-pdp__summary .cdf-eyebrow { margin-bottom: 10px !important; font-size: 13px !important; }
  .cdf-pdp__summary .cdf-badge-economize { margin-bottom: 4px !important; }
  .cdf-pdp__summary .price { margin-bottom: 4px !important; }
  .cdf-pdp__summary .cdf-badge-pix { margin-bottom: 12px !important; }
  .cdf-pdp__summary .cdf-quote-box { margin-bottom: 14px !important; padding: 12px 14px !important; }
  .cdf-pdp__summary .cdf-variants-section { margin-bottom: 10px !important; }
  .cdf-pdp__summary .cdf-stock-alert { margin: 6px 0 0 !important; font-size: 13px !important; }
  .cdf-pdp__summary .cdf-stock-alert__note { margin: 0 0 10px !important; font-size: 11px !important; }
  .cdf-pdp__summary .single_add_to_cart_button { padding: 16px 20px !important; }
  .cdf-pdp__summary .cdf-delivery-info { margin: 10px 0 0 !important; font-size: 13px !important; }
  .cdf-pdp__summary .cdf-warranty-link-v2 { margin: 2px 0 10px !important; font-size: 13px !important; }
}

/* ============ Description fullwidth (edge-to-edge) ============ */
.cdf-pdp { padding: 0; max-width: none; }
.cdf-pdp__top { padding: 0; }
.cdf-pdp__top-wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 16px 16px 24px;
}

/* Description = 100vw edge-to-edge */
.cdf-pdp__description {
  width: 100% !important;
  max-width: 100vw !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Sections within description get their own internal max-width on text-only blocks */
.cdf-pdp__description section.section,
.cdf-pdp__description .section {
  width: 100% !important;
  max-width: 100% !important;
  padding-left: 16px;
  padding-right: 16px;
}

/* Image+text row: full edge-to-edge bg */
.cdf-pdp__description section[style*="padding:0"],
.cdf-pdp__description section.row-padding-0,
.cdf-pdp__description .row.row-collapse {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Image+text col with image: no padding */
.cdf-pdp__description .col[style*="padding:0px"],
.cdf-pdp__description .img.col {
  padding: 0 !important;
}

/* Pillar slider edge-to-edge */
.cdf-pdp__description .ux_slider-wrapper,
.cdf-pdp__description .ux_slider {
  margin: 0 !important;
  padding: 0 !important;
}

/* On mobile, description sections compress padding */
@media (max-width: 767px) {
  .cdf-pdp__top-wrap { padding: 12px 16px 20px; }
  .cdf-pdp__description section.section { padding: 24px 0 !important; }
  .cdf-pdp__description .section .col { padding-left: 16px; padding-right: 16px; }
  .cdf-pdp__description .row.row-collapse .col { padding: 0 !important; }
}

/* Image hero on mobile fullwidth */
.cdf-pdp__description .cdf-pdp-image-frame img {
  width: 100% !important;
  display: block;
}

/* ============ NUKE ORANGE CIRCLE BADGE — todas as variantes do Flatsome ============ */
.product-page .badge-container,
.product-page .badge-container.absolute,
.product-page .badge-container.is-larger,
.product-page .callout.badge,
.product-page .callout.badge-circle,
.product-page .badge-inner,
.product-page .badge-inner.on-sale,
.product-page .badge-inner.secondary,
.product-page .product-image-radius .callout,
.cdf-pdp__gallery .badge-container,
.cdf-pdp__gallery .callout,
.cdf-pdp__gallery .badge-inner,
.woocommerce-product-gallery .callout,
.woocommerce-product-gallery .badge-container,
.product-images .badge-container,
.product-images .callout,
.product-images .badge-inner,
/* Hide also in product-small cards (related products at bottom) */
.cdf-pdp__description .product-small .badge-container,
.cdf-pdp__description .product-small .callout,
.cdf-pdp__description .product-small .badge-inner,
/* Catch-all for any "Oferta!" floating badge */
.product .onsale,
span.onsale,
.image-tools .image-badge,
.flatsome-onsale,
ul.product-badges {
  display: none !important;
  visibility: hidden !important;
}

/* But KEEP MY custom badges (cdf-badge-*) visible */
.cdf-badge-demand,
.cdf-badge-economize,
.cdf-badge-pix,
.cdf-variant-card__benefit {
  display: inline-block !important;
  visibility: visible !important;
}

/* ============ FAQ Accordion — match Artes da Fé style ============ */

/* Container do accordion */
.cdf-pdp__sales-page .accordion,
.cdf-pdp-faq-title + .accordion,
.accordion {
  border-top: 1px solid #e8e8e8;
  margin: 24px 0 0 !important;
}

/* Cada accordion item = linha com border bottom */
.accordion .accordion-item {
  border: 0 !important;
  border-bottom: 1px solid #e8e8e8 !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
}

/* Title (clickable) */
.accordion .accordion-title {
  position: relative !important;
  padding: 18px 40px 18px 0 !important;
  margin: 0 !important;
  font-size: 16px !important;
  font-weight: 500 !important;
  color: #1a1a1a !important;
  background: transparent !important;
  border: 0 !important;
  cursor: pointer !important;
  font-family: 'New York', Baskerville, Times, serif !important;
  line-height: 1.4 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  display: block !important;
}

/* Hover */
.accordion .accordion-title:hover {
  color: #C9A961 !important;
}

/* Chevron ▽ no canto direito */
.accordion .accordion-title::after {
  content: "" !important;
  position: absolute !important;
  right: 8px !important;
  top: 50% !important;
  width: 10px !important;
  height: 10px !important;
  border-right: 2px solid #1a1a1a !important;
  border-bottom: 2px solid #1a1a1a !important;
  transform: translateY(-75%) rotate(45deg) !important;
  transition: transform 0.3s !important;
}

/* Chevron rotaciona quando expandido */
.accordion .accordion-item.active .accordion-title::after,
.accordion .accordion-title[aria-expanded="true"]::after {
  transform: translateY(-25%) rotate(-135deg) !important;
}

/* Hide default toggle icon (icon-angle-down do Flatsome) */
.accordion .accordion-title .toggle,
.accordion .accordion-title i,
.accordion .accordion-title .icon {
  display: none !important;
}

/* Inner content (expanded) */
.accordion .accordion-inner {
  padding: 0 0 20px !important;
  margin: 0 !important;
  font-size: 15px !important;
  line-height: 1.7 !important;
  color: #444 !important;
}

/* Mobile fine-tune */
@media (max-width: 767px) {
  .accordion .accordion-title { padding: 16px 36px 16px 0 !important; font-size: 15px !important; }
  .accordion .accordion-inner { font-size: 14px !important; padding: 0 0 18px !important; }
  .accordion .accordion-title::after { right: 4px !important; width: 8px !important; height: 8px !important; }
}

/* ============ Sales page rich content wrapper ============ */
.cdf-pdp__sales-page {
  width: 100% !important;
  max-width: 100vw !important;
  margin: 0 !important;
  padding: 0 !important;
}

.cdf-pdp__sales-page section.section {
  width: 100% !important;
  max-width: 100% !important;
}

/* ============ Specs table format (label/value 2 col) ============ */
.cdf-specs-table {
  width: 100% !important;
  border-collapse: collapse !important;
  margin: 0 !important;
}
.cdf-specs-table tr {
  border-bottom: 1px solid #efefef !important;
}
.cdf-specs-table tr:last-child {
  border-bottom: 0 !important;
}
.cdf-specs-table__label {
  padding: 14px 16px 14px 0 !important;
  font-weight: 600 !important;
  color: #1a1a1a !important;
  width: 40% !important;
  vertical-align: top !important;
  font-size: 14px !important;
}
.cdf-specs-table__value {
  padding: 14px 0 !important;
  color: #555 !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
  vertical-align: top !important;
}

/* ============ TABS — Collapsed by default (toggle on click) ============ */

/* Container: position relative for chevron */
.product-tabs-section .woocommerce-tabs,
.woocommerce-tabs {
  display: block !important;
}

/* Tab nav becomes accordion-like buttons (mobile-first) */
ul.tabs.product-tabs,
.tabs.product-tabs {
  display: block !important;
  border: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.product-tabs li.tab,
.tabs.product-tabs li {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  border-bottom: 1px solid #e8e8e8 !important;
}

.product-tabs li.tab a,
.tabs.product-tabs li a {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  padding: 16px 40px 16px 0 !important;
  margin: 0 !important;
  font-size: 16px !important;
  font-weight: 500 !important;
  color: #1a1a1a !important;
  background: transparent !important;
  border: 0 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  text-align: left !important;
  font-family: 'New York', Baskerville, Times, serif !important;
}

/* Chevron icon */
.product-tabs li.tab a::after,
.tabs.product-tabs li a::after {
  content: "" !important;
  position: absolute !important;
  right: 8px !important;
  top: 50% !important;
  width: 10px !important;
  height: 10px !important;
  border-right: 2px solid #1a1a1a !important;
  border-bottom: 2px solid #1a1a1a !important;
  transform: translateY(-75%) rotate(45deg) !important;
  transition: transform 0.3s !important;
}

/* Active state — chevron rotated */
.product-tabs li.tab.active a::after,
.tabs.product-tabs li.active a::after {
  transform: translateY(-25%) rotate(-135deg) !important;
}

/* Hide ALL tab panels by default */
.tab-panels .panel,
.tab-panels .tab-panel,
.woocommerce-Tabs-panel {
  display: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Show only active panel */
.tab-panels .panel.active,
.tab-panels .tab-panel.active,
.woocommerce-Tabs-panel.active {
  display: block !important;
  padding: 16px 0 !important;
  margin: 0 !important;
}

/* JS-less fallback: use :target and details/summary trick - not needed since Flatsome JS handles */

/* Description wrap inside panel */
.tab-panels .panel h3 {
  font-family: 'New York', Baskerville, Times, serif !important;
  font-size: 18px !important;
  font-weight: 600 !important;
  margin: 12px 0 8px !important;
  color: #1a1a1a !important;
}
.tab-panels .panel p {
  font-size: 15px !important;
  line-height: 1.65 !important;
  color: #444 !important;
  margin: 0 0 12px !important;
}

/* Related products — push to bottom + style */
.cdf-pdp .related,
.cdf-pdp .related.products,
.cdf-pdp__sales-page ~ .related,
.cdf-pdp__sales-page ~ .upsells {
  margin-top: 60px !important;
  padding: 40px 16px !important;
  border-top: 1px solid #e8e8e8;
}

.cdf-pdp .related h2,
.cdf-pdp .upsells h2 {
  font-family: 'New York', Baskerville, Times, serif !important;
  font-weight: 600 !important;
  text-align: center !important;
  font-size: 24px !important;
  margin-bottom: 20px !important;
}

/* Mobile fine-tune */
@media (max-width: 767px) {
  .product-tabs li.tab a { padding: 14px 36px 14px 0 !important; font-size: 15px !important; }
  .product-tabs li.tab a::after { right: 4px !important; width: 8px !important; height: 8px !important; }
}

/* ============ FORCE — All tabs panels closed on load ============ */

/* Hide ALL panels by default — including .active class set by WC */
.product-tabs-section .tab-panels .panel,
.tab-panels .panel,
.tab-panels .tab-panel,
.woocommerce-tabs .panel,
.woocommerce-Tabs-panel {
  display: none !important;
}

/* Active class AS-IS doesn't show — only .active.is-open shows */
.tab-panels .panel.is-open,
.tab-panels .tab-panel.is-open,
.woocommerce-Tabs-panel.is-open {
  display: block !important;
  padding: 16px 0 !important;
}

/* Tab nav button — no active state by default */
.product-tabs li.tab,
.tabs.product-tabs li {
  /* override Flatsome active state */
}
.product-tabs li.tab a::after,
.tabs.product-tabs li a::after {
  /* default chevron pointing down */
  transform: translateY(-75%) rotate(45deg) !important;
}
.product-tabs li.tab.is-open a::after,
.tabs.product-tabs li.is-open a::after {
  transform: translateY(-25%) rotate(-135deg) !important;
}

/* ============ SCROLL REVEAL ANIMATION (igual Artes da Fé) ============ */
.cdf-pdp__sales-page section,
.cdf-pdp__sales-page .section,
.cdf-pdp__sales-page .row {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.7s ease-out, transform 0.7s ease-out;
}

.cdf-pdp__sales-page section.cdf-revealed,
.cdf-pdp__sales-page .section.cdf-revealed,
.cdf-pdp__sales-page .row.cdf-revealed {
  opacity: 1 !important;
  transform: translateY(0) !important;
}

/* Reduce motion fallback */
@media (prefers-reduced-motion: reduce) {
  .cdf-pdp__sales-page section,
  .cdf-pdp__sales-page .section,
  .cdf-pdp__sales-page .row {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* ============ FIX padding lateral — texto sangrando pra fora ============ */
.cdf-pdp__top-wrap .product-tabs-section,
.cdf-pdp__top-wrap .woocommerce-tabs,
.cdf-pdp__top-wrap .product-info {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.product-tabs li.tab,
.tabs.product-tabs li,
.tab-panels .panel,
#tab-description, #tab-cdf_specs {
  padding-left: 16px !important;
  padding-right: 16px !important;
}

.product-tabs li.tab a,
.tabs.product-tabs li a {
  padding-left: 0 !important;
  padding-right: 36px !important;
}

@media (max-width: 767px) {
  .product-tabs li.tab,
  .tabs.product-tabs li,
  .tab-panels .panel { padding-left: 16px !important; padding-right: 16px !important; }
}

/* Specs table inside tab — also has lateral padding */
#tab-cdf_specs .cdf-specs-table { width: 100% !important; }

/* ============ FIX click handler — padding no <li>, mas <a> 100% clicável ============ */

/* Padding no LI (cria espaço lateral) */
.product-tabs li.tab,
.tabs.product-tabs li {
  padding: 0 16px !important;  /* lateral apenas no LI */
  margin: 0 !important;
  display: block !important;
  position: relative !important;
}

/* O <a> fica 100% clicável dentro do LI */
.product-tabs li.tab a,
.tabs.product-tabs li a {
  display: block !important;
  width: 100% !important;
  padding: 16px 36px 16px 0 !important;  /* só padding pro chevron, não lateral */
  margin: 0 !important;
  position: relative !important;
  cursor: pointer !important;
  pointer-events: auto !important;
  z-index: 2 !important;
}

/* Tab panel também tem padding lateral */
.tab-panels .panel,
#tab-description, #tab-cdf_specs {
  padding: 16px !important;
}

/* Mas remove padding-left do INNER content */
.tab-panels .panel > *:first-child {
  margin-top: 0 !important;
}

/* Nothing should block click */
.product-tabs li.tab *,
.tabs.product-tabs li * {
  pointer-events: auto !important;
}

/* ============ FIX SELECTOR — Flatsome usa class="description_tab", "cdf_specs_tab" ============ */

/* Tab nav LI — todos no Flatsome têm class "*_tab" */
.product-tabs li[class*="_tab"],
ul.tabs.product-tabs li[class*="_tab"],
ul.tabs li[role="presentation"] {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 16px !important;
  border-bottom: 1px solid #e8e8e8 !important;
  position: relative !important;
}

/* Tab link */
.product-tabs li[class*="_tab"] > a,
ul.tabs.product-tabs li[class*="_tab"] > a,
li[role="presentation"] > a {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  padding: 16px 36px 16px 0 !important;
  font-family: 'New York', Baskerville, Times, serif !important;
  font-size: 16px !important;
  font-weight: 500 !important;
  color: #1a1a1a !important;
  text-decoration: none !important;
  background: transparent !important;
  border: 0 !important;
  cursor: pointer !important;
  pointer-events: auto !important;
  z-index: 2 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

/* Chevron ▽ */
.product-tabs li[class*="_tab"] > a::after,
li[role="presentation"] > a::after {
  content: "" !important;
  position: absolute !important;
  right: 8px !important;
  top: 50% !important;
  width: 10px !important;
  height: 10px !important;
  border-right: 2px solid #1a1a1a !important;
  border-bottom: 2px solid #1a1a1a !important;
  transform: translateY(-75%) rotate(45deg) !important;
  transition: transform 0.3s !important;
}

/* Active state — chevron rotates UP */
.product-tabs li[class*="_tab"].active > a::after,
.product-tabs li[class*="_tab"].cdf-user-clicked > a::after,
li[role="presentation"].active > a::after,
li[role="presentation"].cdf-user-clicked > a::after {
  transform: translateY(-25%) rotate(-135deg) !important;
}

/* Panels — hidden by default */
.tab-panels .panel,
.woocommerce-Tabs-panel {
  display: none !important;
  padding: 16px !important;
  margin: 0 !important;
}

/* Show panel when user clicked */
.tab-panels .panel.cdf-user-opened,
.woocommerce-Tabs-panel.cdf-user-opened {
  display: block !important;
}

/* ============ FINAL — sync com new class .cdf-open ============ */

/* Panels: SEMPRE escondidos por default, exceto .cdf-open */
.tab-panels > .panel,
.woocommerce-Tabs-panel {
  display: none !important;
}

.tab-panels > .panel.cdf-open,
.woocommerce-Tabs-panel.cdf-open {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  height: auto !important;
  overflow: visible !important;
  padding: 16px !important;
}

/* Garantir conteúdo visível */
.tab-panels .panel.cdf-open *,
.woocommerce-Tabs-panel.cdf-open * {
  visibility: visible !important;
  opacity: 1 !important;
}

/* Chevron rotation com nova class */
.product-tabs li[class*="_tab"].cdf-open > a::after,
li[role="presentation"].cdf-open > a::after {
  transform: translateY(-25%) rotate(-135deg) !important;
}

/* ============ NATIVE <details> ACCORDION — substitui tabs Flatsome ============ */

/* Esconder COMPLETAMENTE as tabs antigas do Flatsome */
.product-tabs-section,
.product-tabs,
ul.tabs,
ul.tabs.product-tabs,
.tabs.product-tabs,
.tab-panels,
.woocommerce-tabs,
.woocommerce-Tabs-panel {
  display: none !important;
}

/* Native details accordion section */
.cdf-accordion-section {
  margin: 0 !important;
  padding: 0 !important;
  border-top: 1px solid #e8e8e8;
  background: #fff;
}

/* Each <details> = uma linha */
.cdf-acc {
  margin: 0 !important;
  padding: 0 !important;
  border-bottom: 1px solid #e8e8e8;
  background: transparent;
}

/* Summary (clickable header) — sem o triangulo nativo */
.cdf-acc__summary {
  position: relative;
  display: block;
  padding: 18px 40px 18px 16px;
  margin: 0;
  font-family: 'New York', Baskerville, Times, serif;
  font-size: 16px;
  font-weight: 500;
  color: #1a1a1a;
  cursor: pointer;
  list-style: none;
  user-select: none;
}

/* Hide default arrow no Chrome/Safari/Firefox */
.cdf-acc__summary::-webkit-details-marker { display: none; }
.cdf-acc__summary::marker { display: none; content: ''; }
.cdf-acc__summary { list-style-type: none; }

/* Chevron ▽ custom no canto direito */
.cdf-acc__summary::after {
  content: '';
  position: absolute;
  right: 20px;
  top: 50%;
  width: 10px;
  height: 10px;
  border-right: 2px solid #1a1a1a;
  border-bottom: 2px solid #1a1a1a;
  transform: translateY(-75%) rotate(45deg);
  transition: transform 0.3s ease;
}

/* Quando aberto: chevron rotaciona pra cima */
.cdf-acc[open] .cdf-acc__summary::after {
  transform: translateY(-25%) rotate(-135deg);
}

/* Hover */
.cdf-acc__summary:hover {
  color: #C9A961;
}

/* Content (expanded) */
.cdf-acc__content {
  padding: 0 16px 20px;
  font-size: 15px;
  line-height: 1.65;
  color: #444;
}

.cdf-acc__content h3 {
  font-family: 'New York', Baskerville, Times, serif;
  font-size: 18px;
  font-weight: 600;
  margin: 12px 0 8px;
  color: #1a1a1a;
}

.cdf-acc__content p {
  margin: 0 0 12px;
}

/* Specs table compact */
.cdf-acc__content .cdf-specs-table {
  width: 100%;
  border-collapse: collapse;
  margin: 0;
}
.cdf-acc__content .cdf-specs-table tr {
  border-bottom: 1px solid #efefef;
}
.cdf-acc__content .cdf-specs-table tr:last-child {
  border-bottom: 0;
}
.cdf-acc__content .cdf-specs-table__label {
  padding: 12px 16px 12px 0;
  font-weight: 600;
  color: #1a1a1a;
  width: 40%;
  vertical-align: top;
  font-size: 14px;
}
.cdf-acc__content .cdf-specs-table__value {
  padding: 12px 0;
  color: #555;
  font-size: 14px;
  line-height: 1.5;
  vertical-align: top;
}

/* ============ FIX padding + borders no native details accordion ============ */

/* Wrapper section: padding lateral + max-width centralizado desktop */
.cdf-accordion-section {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 0 16px !important;
  background: #fff;
}

/* Cada <details> com border bottom + sem margin */
.cdf-acc {
  margin: 0 !important;
  padding: 0 !important;
  border-bottom: 1px solid #e8e8e8 !important;
  border-top: 0 !important;
  background: transparent !important;
  display: block !important;
}

/* Primeiro item adiciona border-top também */
.cdf-acc:first-child {
  border-top: 1px solid #e8e8e8 !important;
}

/* Summary: padding interno generoso (sem padding lateral porque o wrapper já tem) */
.cdf-acc__summary {
  position: relative !important;
  display: block !important;
  padding: 18px 40px 18px 0 !important;
  margin: 0 !important;
  font-family: 'New York', Baskerville, Times, serif !important;
  font-size: 16px !important;
  font-weight: 500 !important;
  color: #1a1a1a !important;
  cursor: pointer !important;
  user-select: none !important;
  list-style: none !important;
  background: transparent !important;
  border: 0 !important;
}

.cdf-acc__summary::-webkit-details-marker { display: none !important; }
.cdf-acc__summary::marker { content: '' !important; }

/* Chevron right side */
.cdf-acc__summary::after {
  content: '' !important;
  position: absolute !important;
  right: 4px !important;
  top: 50% !important;
  width: 10px !important;
  height: 10px !important;
  border-right: 2px solid #1a1a1a !important;
  border-bottom: 2px solid #1a1a1a !important;
  transform: translateY(-75%) rotate(45deg) !important;
  transition: transform 0.3s ease !important;
}

.cdf-acc[open] .cdf-acc__summary::after {
  transform: translateY(-25%) rotate(-135deg) !important;
}

.cdf-acc__summary:hover {
  color: #C9A961 !important;
}

/* Content padding interno */
.cdf-acc__content {
  padding: 0 0 20px !important;
  font-size: 15px !important;
  line-height: 1.65 !important;
  color: #444 !important;
}

.cdf-acc__content h3 {
  font-family: 'New York', Baskerville, Times, serif !important;
  font-size: 18px !important;
  font-weight: 600 !important;
  margin: 8px 0 8px !important;
  color: #1a1a1a !important;
}

.cdf-acc__content p {
  margin: 0 0 12px !important;
  font-size: 15px !important;
  line-height: 1.65 !important;
  color: #444 !important;
}

/* Specs table dentro do content */
.cdf-acc__content .cdf-specs-table {
  width: 100% !important;
  border-collapse: collapse !important;
  margin: 0 !important;
}
.cdf-acc__content .cdf-specs-table tr {
  border-bottom: 1px solid #efefef !important;
}
.cdf-acc__content .cdf-specs-table tr:last-child {
  border-bottom: 0 !important;
}
.cdf-acc__content .cdf-specs-table__label {
  padding: 12px 16px 12px 0 !important;
  font-weight: 600 !important;
  color: #1a1a1a !important;
  width: 40% !important;
  vertical-align: top !important;
  font-size: 14px !important;
}
.cdf-acc__content .cdf-specs-table__value {
  padding: 12px 0 !important;
  color: #555 !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
  vertical-align: top !important;
}

/* ============ Reviews block (Air Reviews-style) ============ */
.cdf-reviews {
  padding: 80px 24px;
  background: #fff;
  border-top: 1px solid #f0ece4;
}
.cdf-reviews__container {
  max-width: 1100px;
  margin: 0 auto;
}
.cdf-reviews__title {
  font-family: 'New York', 'Iowan Old Style', 'Apple Garamond', Baskerville, 'Times New Roman', Times, serif;
  font-weight: 400;
  font-size: clamp(28px, 4vw, 38px);
  color: #101010;
  text-align: center;
  margin: 0 0 40px;
  line-height: 1.2;
}
.cdf-reviews__summary {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 60px;
  align-items: center;
  padding: 36px;
  background: #fcfaf6;
  border-radius: 4px;
  margin-bottom: 48px;
}
@media (max-width: 720px) {
  .cdf-reviews__summary { grid-template-columns: 1fr; gap: 32px; padding: 28px 20px; }
}
.cdf-reviews__avg {
  text-align: center;
  border-right: 1px solid #e6e0d5;
  padding-right: 40px;
}
@media (max-width: 720px) {
  .cdf-reviews__avg { border-right: 0; border-bottom: 1px solid #e6e0d5; padding: 0 0 28px; }
}
.cdf-reviews__avg-num {
  font-family: 'New York', serif;
  font-size: 56px;
  font-weight: 500;
  color: #101010;
  line-height: 1;
  margin-bottom: 8px;
}
.cdf-reviews__avg-stars {
  font-size: 22px;
  letter-spacing: 4px;
  margin-bottom: 8px;
  display: inline-block;
}
.cdf-reviews__avg-count {
  font-size: 14px;
  color: #777;
  letter-spacing: 0.5px;
}
.cdf-reviews__star.is-full { color: #C9A961; }
.cdf-reviews__star.is-half {
  background: linear-gradient(90deg, #C9A961 50%, #d8d0c0 50%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.cdf-reviews__star.is-empty { color: #d8d0c0; }
.cdf-reviews__bars {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.cdf-reviews__bar-row {
  display: grid;
  grid-template-columns: 28px 1fr 28px;
  align-items: center;
  gap: 12px;
  font-size: 13px;
  color: #555;
}
.cdf-reviews__bar-label { font-weight: 600; color: #101010; }
.cdf-reviews__bar-track {
  height: 8px;
  background: #efe9dd;
  border-radius: 4px;
  overflow: hidden;
}
.cdf-reviews__bar-fill {
  height: 100%;
  background: #C9A961;
  border-radius: 4px;
  transition: width 0.6s ease;
}
.cdf-reviews__bar-count { text-align: right; color: #888; }

/* lista de reviews individuais */
.cdf-reviews__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.cdf-review {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 18px;
  padding: 24px 4px;
  border-bottom: 1px solid #f0ece4;
}
.cdf-review:last-child { border-bottom: 0; }
.cdf-review__avatar {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg, #1E3A5F 0%, #2a4f7d 100%);
  color: #f5f1e8;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'New York', serif;
  font-weight: 500;
  font-size: 22px;
  flex-shrink: 0;
}
.cdf-review__body { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.cdf-review__head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  font-size: 14px;
}
.cdf-review__author { font-weight: 600; color: #101010; }
.cdf-review__city { color: #888; font-size: 13px; }
.cdf-review__verified {
  font-size: 11px;
  color: #1F7A3D;
  background: #D4F5E1;
  padding: 2px 8px;
  border-radius: 3px;
  letter-spacing: 0.3px;
  font-weight: 500;
}
.cdf-review__meta {
  display: flex;
  align-items: center;
  gap: 12px;
}
.cdf-review__stars { font-size: 14px; letter-spacing: 2px; }
.cdf-review__date { font-size: 12px; color: #999; }
.cdf-review__content {
  margin: 6px 0 0;
  color: #333;
  line-height: 1.6;
  font-size: 15px;
}
@media (max-width: 720px) {
  .cdf-reviews { padding: 50px 16px; }
  .cdf-review { grid-template-columns: 44px 1fr; gap: 14px; padding: 20px 0; }
  .cdf-review__avatar { width: 44px; height: 44px; font-size: 18px; }
  .cdf-review__head { gap: 8px; font-size: 13px; }
  .cdf-review__content { font-size: 14px; }
}

/* Review pagination + photos */
.cdf-review.is-hidden { display: none !important; }
.cdf-reviews__loadmore-wrap {
  text-align: center;
  margin-top: 32px;
}
.cdf-reviews__loadmore {
  background: transparent;
  border: 1px solid #1E3A5F;
  color: #1E3A5F;
  padding: 14px 32px;
  font-family: 'New York', serif;
  font-size: 14px;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: 2px;
  transition: all 0.2s ease;
}
.cdf-reviews__loadmore:hover { background: #1E3A5F; color: #f5f1e8; }
.cdf-reviews__loadmore-count { opacity: 0.7; font-size: 12px; }

.cdf-review__photos {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}
.cdf-review__photo-link {
  display: block;
  width: 80px;
  height: 80px;
  overflow: hidden;
  border-radius: 4px;
  border: 1px solid #e6e0d5;
  flex-shrink: 0;
}
.cdf-review__photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.3s ease;
}
.cdf-review__photo-link:hover .cdf-review__photo { transform: scale(1.05); }
@media (max-width: 720px) {
  .cdf-review__photo-link { width: 64px; height: 64px; }
}

/* ============ Section dark — força cor clara em textos cdf-pdp-* ============
 * Quando uma [section] tem dark="true" no shortcode (Flatsome),
 * o tema adiciona class .dark. Forçamos texto claro nos elementos cdf-pdp-*
 */
.section.dark .cdf-pdp-hero-title,
.section.dark .cdf-pdp-section-title,
.section.dark .cdf-pdp-section-text,
.section.dark .cdf-pdp-quote-final-h2,
.section.dark .cdf-pdp-quote-final,
.section.dark .cdf-pdp-quote-paragraph,
.section.dark .cdf-pdp-quote-cta,
.section.dark .cdf-pdp-faq-title {
  color: #f5f1e8 !important;
}
.section.dark .cdf-pdp-hero-eyebrow {
  color: #C9A961 !important;
  letter-spacing: 4px !important;
}
.section.dark .cdf-pdp-quote-cta strong,
.section.dark .cdf-pdp-quote-paragraph strong {
  color: #C9A961 !important;
}
.section.dark .cdf-pdp-section-text strong {
  color: #C9A961 !important;
}

/* ============================================================
   LUME PDP — Eyebrow "Contem:" Linhares-style (caixa cinza)
   ============================================================ */
.lume-eyebrow-contem {
  background: #f3f3f3;
  border-radius: 6px;
  padding: 8px 12px;
  margin: 8px 0 14px !important;
  font-size: 14px;
  line-height: 1.45;
  color: #555555;
}
.lume-eyebrow-contem span { display: block; }

/* ============================================================
   LUME PDP — Spacing fixes Bloco 1 (elementos colados)
   ============================================================ */
body.single-product .summary .cdf-rating-block { margin-bottom: 6px !important; padding-bottom: 8px !important; }
body.single-product .summary .cdf-pdp-demand-badge,
body.single-product .summary .cdf-demand-badge { margin-top: 4px !important; margin-bottom: 6px !important; }
body.single-product .summary .product_title,
body.single-product .summary h1.product_title,
body.single-product .summary h1.entry-title { margin-bottom: 6px !important; margin-top: 4px !important; line-height: 1.2; }
body.single-product .summary .cdf-badge-economize { margin-top: 12px !important; margin-bottom: 6px !important; display: inline-block; }
body.single-product .summary .price { margin-top: 0 !important; margin-bottom: 4px !important; }
body.single-product .summary .cdf-pix-badge,
body.single-product .summary .cdf-badge-pix { margin-top: 4px !important; margin-bottom: 8px !important; display: inline-block; }
body.single-product .summary .single_variation_wrap { margin-top: 4px !important; }
body.single-product .summary form.variations_form { margin-top: 0 !important; }
body.single-product .summary .cdf-stock-alert { margin-top: 4px !important; margin-bottom: 2px !important; }
body.single-product .summary .cdf-stock-alert + p,
body.single-product .summary .cdf-stock-alert ~ .cdf-stock-disclaimer { margin-bottom: 0 !important; margin-top: 0 !important; font-size: 12px !important; }

/* Header sticky — barra fixa no topo enquanto rola */
body #wrapper > #header,
body #header.header,
.header-wrapper {
  position: sticky !important;
  top: 0 !important;
  z-index: 9990 !important;
  background: #ffffff !important;
}
/* Garantir que conteúdo abaixo não sobreponha sticky */
body.has-transparent-header #header { background: #ffffff !important; }
/* No mobile manter o header sticky também */
@media (max-width: 849px) {
  body #wrapper > #header,
  body #header.header,
  .header-wrapper {
    position: sticky !important;
    top: 0 !important;
  }
}

/* Topbar Lume Lar — fundo escuro pra texto branco ficar legível */
#top-bar.header-top,
.header-top {
  background-color: #1a1a1a !important;
  color: #FFFFFF !important;
  border: 0 !important;
}
#top-bar.header-top *,
#top-bar a,
#top-bar li,
#top-bar p,
#top-bar span,
.header-top * {
  color: #FFFFFF !important;
}
/* Manter "FRETE GRÁTIS" destacado em gold (não sobrescrever inline) */
#top-bar strong[style*="color"] {
  color: inherit !important;
}
#top-bar strong[style*="C9A961"] {
  color: #C9A961 !important;
}

/* Logo Lume Lar — aumentada 50% (era max-height: 100px → 150px) */
body .header-main #logo img,
body .header-main .header-logo img,
body .header-bottom #logo img,
body #logo img {
  max-height: 150px !important;
  width: auto !important;
  height: auto !important;
}
body .header-main { min-height: 150px; }
@media (max-width: 849px) {
  body .header-main #logo img,
  body #logo img {
    max-height: 120px !important;
  }
  body .header-main { min-height: 120px; }
}

/* Footer cleanup — remover widgets vazios Archives/Categories e organizar */
.footer-widgets.footer-1 #block-5,
.footer-widgets.footer-1 #block-6,
.footer-widgets .widget_block:has(.wp-block-archives),
.footer-widgets .widget_block:has(.wp-block-categories),
.footer-widgets .widget_archive,
.footer-widgets .widget_categories,
.footer-widgets .widget_recent_entries,
.footer-widgets .widget_recent_comments,
.footer-widgets .widget_meta { display: none !important; }
.footer-widgets.footer-1:empty,
.footer-widgets.footer-1 > .row:empty { display: none !important; padding: 0 !important; margin: 0 !important; }
/* se a row tem só os 2 blocks ocultos, esconde wrapper inteiro pra tirar gap branco */
.footer-widgets.footer-1 { padding-top: 0 !important; padding-bottom: 0 !important; border: 0 !important; }

/* Footer (Linhares-style mais clean) */
.absolute-footer { padding: 16px 0 !important; }
.absolute-footer .copyright-footer { font-size: 13px; line-height: 1.5; }

/* Specs eh-specs (Linhares-style 2-col) — duplicado do meta inline pra forçar render */
.eh-specs { width: 100%; }
.eh-specs__row {
  display: grid !important;
  grid-template-columns: minmax(140px, 1fr) minmax(160px, 1.6fr) !important;
  gap: 24px !important;
  padding: 18px 0 !important;
  align-items: start !important;
}
.eh-specs__row + .eh-specs__row { border-top: 1px solid #e6e6e6; }
.eh-specs__label { font-size: 16px !important; font-weight: 700 !important; color: #101010 !important; line-height: 1.25 !important; }
.eh-specs__value { font-size: 14px !important; font-weight: 400 !important; color: #101010 !important; line-height: 1.5 !important; }
@media (max-width: 640px) {
  .eh-specs__row {
    grid-template-columns: minmax(110px, 0.8fr) minmax(160px, 1.4fr) !important;
    gap: 18px !important;
    padding: 14px 0 !important;
  }
  .eh-specs__label { font-size: 14px !important; }
  .eh-specs__value { font-size: 13px !important; }
}

/* ============================================================
   LUME PDP — Bullets verdes (entre 5% Pix e Estoque baixo)
   ============================================================ */
.lume-bullets {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin: 10px 0 8px !important;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.lume-bullets__item {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0;
  font-size: 15px;
  line-height: 1.45;
  color: #555555;
}
.lume-bullets__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #1F7A3D;
  color: #FFFFFF;
  font-size: 12px;
  font-weight: 700;
  flex-shrink: 0;
}
.lume-bullets__text { flex: 1; }

/* ============================================================
   LUME PDP — Custom swatches (cor com imagens + tamanho pills)
   ============================================================ */
.lume-swatch-group { margin: 8px 0 !important; }
.lume-swatch-label {
  font-size: 14px;
  color: #2C2C2C;
  font-weight: 700;
  margin: 0 0 8px;
  display: block;
}
.lume-swatch-label .lume-swatch-value {
  font-weight: 400;
  color: #5A5A5A;
  margin-left: 4px;
}
.lume-swatches-cor {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 0;
}
.lume-swatches-cor .lume-swatch {
  width: 48px;
  height: 48px;
  border: 2px solid #E6DFD3;
  border-radius: 50%;
  cursor: pointer;
  overflow: hidden;
  position: relative;
  transition: border-color .2s, box-shadow .2s;
  background: #fff;
}
.lume-swatches-cor .lume-swatch.active {
  border-color: #2C2C2C;
  box-shadow: 0 0 0 2px #FFFFFF inset;
}
.lume-swatches-cor .lume-swatch img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 50%;
}
.lume-swatches-tamanho {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0;
}
.lume-swatches-tamanho .lume-tam-btn {
  padding: 8px 18px;
  border: 1.5px solid #E6DFD3;
  border-radius: 4px;
  background: #FFFFFF;
  color: #2C2C2C;
  cursor: pointer;
  font-size: 14px;
  font-weight: 500;
  transition: all .2s;
  font-family: inherit;
  text-transform: none;
  min-width: 86px;
}
.lume-swatches-tamanho .lume-tam-btn.active,
.lume-swatches-tamanho .lume-tam-btn:hover {
  border-color: #2C2C2C;
  background: #2C2C2C;
  color: #FFFFFF;
}

/* ============================================================
   LUME PDP — Addon checkbox-style (Complete sua Experiência)
   ============================================================ */
.lume-addon-section {
  margin: 8px 0 6px !important;
}
.lume-addon-section__title-bar {
  background: transparent;
  border-radius: 0;
  padding: 0;
  margin: 0 0 10px;
  font-size: 17px;
  color: #2C2C2C;
  font-weight: 700;
  text-align: left;
}
.lume-addon-section__title-bar strong { font-weight: 700; }

.lume-addon-card {
  display: flex;
  align-items: center;
  gap: 12px;
  border: 1px solid #555555;
  border-radius: 0;
  padding: 8px 10px;
  background: #FFFFFF;
  cursor: pointer;
  transition: border-color .2s;
}
.lume-addon-card:has(.lume-addon__checkbox:checked) {
  border-color: #303030;
  background: #fafafa;
}
.lume-addon__checkbox {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 0;
  height: 0;
}
.lume-addon__checkbox-visual {
  width: 22px;
  height: 22px;
  border: 2px solid #303030;
  border-radius: 4px;
  background: #FFFFFF;
  flex-shrink: 0;
  position: relative;
  transition: background .2s;
}
.lume-addon__checkbox:checked + .lume-addon__checkbox-visual {
  background: #303030;
}
.lume-addon__checkbox:checked + .lume-addon__checkbox-visual::after {
  content: '✓';
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fafafa;
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
}
.lume-addon__img {
  width: 64px;
  height: 64px;
  object-fit: cover;
  border-radius: 4px;
  flex-shrink: 0;
}
.lume-addon__content {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.lume-addon__title {
  font-size: 14px;
  color: #303030;
  font-weight: 500;
  text-decoration: none;
  line-height: 1.3;
}
.lume-addon__title:hover { text-decoration: underline; }
.lume-addon__price { font-size: 14px; color: #303030; font-weight: 700; }
.lume-addon__price-current { font-weight: 700; }
.lume-addon__price-regular { color: #999; font-weight: 400; margin-left: 6px; }

/* ============================================================
   LUME SALES BLOCK — Bloco 2 (hero + videos + quote + reviews + FAQ + trust)
   Mobile-first. Paleta neutra (creme F8F5EF + navy 1a1a1a + accent C9A961).
   ============================================================ */
.lume-sales-block {
  max-width: 720px;
  margin: 32px auto 48px;
  padding: 0 16px;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  color: #2C2C2C;
}
.lume-sales-block > * + * { margin-top: 32px; }

/* Hero */
.lume-sb__hero { text-align: center; padding: 24px 0 8px; }
.lume-sb__hero-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 600;
  font-size: 28px;
  line-height: 1.2;
  color: #1a1a1a;
  margin: 0 0 12px;
}
.lume-sb__hero-sub {
  font-size: 15px;
  line-height: 1.5;
  color: #5A5A5A;
  margin: 0 auto;
  max-width: 480px;
}

/* Video cards — carrossel horizontal scroll-snap + autoplay on intersect */
.lume-sb__videos--carousel {
  display: flex;
  flex-direction: row;
  gap: 12px;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding: 0 16px 8px;
  margin: 0 -16px;
}
.lume-sb__videos--carousel::-webkit-scrollbar { display: none; }
.lume-sb__video {
  flex: 0 0 88%;
  margin: 0;
  background: #F8F5EF;
  border-radius: 8px;
  overflow: hidden;
  scroll-snap-align: center;
  scroll-snap-stop: always;
}
.lume-sb__video-media {
  width: 100%;
  aspect-ratio: 9/16;
  display: block;
  background: #000;
  object-fit: cover;
}
.lume-sb__video-caption {
  padding: 10px 12px 12px;
  font-size: 13px;
  line-height: 1.45;
  color: #2C2C2C;
  text-align: center;
  margin: 0;
  font-weight: 500;
}
@media (min-width: 768px) {
  .lume-sb__videos--carousel { padding: 0; margin: 0; gap: 18px; }
  .lume-sb__video { flex: 0 0 calc((100% - 36px) / 3); }
}

/* Carousel dots */
.lume-sb__videos-dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin: 12px 0 0;
  padding: 0;
}
.lume-sb__videos-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  border: none;
  background: #D5CFC3;
  cursor: pointer;
  padding: 0;
  transition: background .25s, width .25s;
  appearance: none;
}
.lume-sb__videos-dot.is-active {
  background: #2C2C2C;
  width: 22px;
  border-radius: 4px;
}
@media (min-width: 768px) {
  .lume-sb__videos-dots { display: none; }
}

/* Quote section */
.lume-sb__quote {
  background: transparent;
  padding: 24px 0;
  border-top: 1px solid #E6DFD3;
  border-bottom: 1px solid #E6DFD3;
  text-align: left;
  margin: 24px 0 !important;
}
.lume-sb__quote-h2 {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 600;
  font-style: normal;
  font-size: 20px;
  line-height: 1.3;
  color: #1a1a1a;
  margin: 0 0 14px;
  text-align: center;
}
.lume-sb__quote-p {
  font-size: 14px;
  line-height: 1.6;
  color: #5A5A5A;
  margin: 0 0 10px;
}
.lume-sb__quote-p:last-child { margin-bottom: 0; }
.lume-sb__quote-p strong { color: #1a1a1a; font-weight: 600; }


/* Reviews block */
.lume-sb__reviews { padding: 24px 0; }
.lume-sb__reviews-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 600;
  font-size: 24px;
  text-align: center;
  margin: 0 0 24px;
  color: #1a1a1a;
}
.lume-sb__reviews-header {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 24px;
  align-items: center;
  background: #F8F5EF;
  padding: 20px;
  border-radius: 8px;
  margin-bottom: 24px;
}
.lume-sb__reviews-avg-col { text-align: center; }
.lume-sb__reviews-avg {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 42px;
  font-weight: 700;
  line-height: 1;
  color: #1a1a1a;
}
.lume-sb__reviews-stars { font-size: 16px; color: #C9A961; letter-spacing: 2px; margin: 4px 0; }
.lume-sb__reviews-total { font-size: 12px; color: #5A5A5A; }
.lume-sb__reviews-bars { display: flex; flex-direction: column; gap: 4px; }
.lume-sb__reviews-bar-row {
  display: grid;
  grid-template-columns: 24px 1fr 24px;
  gap: 8px;
  align-items: center;
  font-size: 12px;
}
.lume-sb__reviews-bar-label { color: #5A5A5A; }
.lume-sb__reviews-bar { height: 6px; background: #E6DFD3; border-radius: 3px; overflow: hidden; }
.lume-sb__reviews-bar-fill { height: 100%; background: #C9A961; border-radius: 3px; transition: width .3s; }
.lume-sb__reviews-bar-count { font-size: 11px; color: #5A5A5A; text-align: right; }

.lume-sb__reviews-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 16px; }
.lume-sb__rev-card {
  background: #FFFFFF;
  border: 1px solid #E6DFD3;
  border-radius: 8px;
  padding: 16px;
}
.lume-sb__rev-card.is-hidden { display: none; }
.lume-sb__rev-head { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.lume-sb__rev-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: linear-gradient(135deg, #1E3A5F 0%, #2c5586 100%);
  color: #F5F1E8;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  flex-shrink: 0;
}
.lume-sb__rev-meta { flex: 1; min-width: 0; }
.lume-sb__rev-name {
  font-weight: 600;
  font-size: 14px;
  color: #1a1a1a;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.lume-sb__rev-verified {
  font-size: 11px;
  color: #1F7A3D;
  font-weight: 500;
  background: #D4F5E1;
  padding: 2px 6px;
  border-radius: 3px;
}
.lume-sb__rev-rating { font-size: 13px; color: #C9A961; letter-spacing: 1px; margin-top: 2px; }
.lume-sb__rev-text { font-size: 14px; line-height: 1.55; color: #2C2C2C; margin: 0; }

.lume-sb__reviews-loadmore {
  display: block;
  width: 100%;
  margin: 20px 0 0;
  background: transparent;
  color: #1a1a1a;
  border: 1px solid #1a1a1a;
  padding: 12px 20px;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: 4px;
  transition: background .2s, color .2s;
}
.lume-sb__reviews-loadmore:hover { background: #1a1a1a; color: #FFFFFF; }
.lume-sb__reviews-loadmore span { font-weight: 400; opacity: .8; }

/* FAQ accordion */
.lume-sb__faq { padding: 8px 0; }
.lume-sb__faq-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 600;
  font-size: 24px;
  text-align: center;
  margin: 0 0 20px;
  color: #1a1a1a;
}
.lume-sb__faq-item {
  border-bottom: 1px solid #E6DFD3;
  padding: 14px 0;
}
.lume-sb__faq-item:first-of-type { border-top: 1px solid #E6DFD3; }
.lume-sb__faq-q {
  font-size: 15px;
  font-weight: 600;
  color: #1a1a1a;
  cursor: pointer;
  list-style: none;
  position: relative;
  padding-right: 32px;
  line-height: 1.4;
}
.lume-sb__faq-q::-webkit-details-marker { display: none; }
.lume-sb__faq-q::after {
  content: '+';
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  font-size: 22px;
  font-weight: 300;
  color: #1a1a1a;
  transition: transform .2s;
}
.lume-sb__faq-item[open] .lume-sb__faq-q::after { content: '−'; }
.lume-sb__faq-a {
  font-size: 14px;
  line-height: 1.6;
  color: #5A5A5A;
  margin-top: 10px;
}

/* Trust icon bar */
.lume-sb__trust {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  background: #F8F5EF;
  padding: 24px;
  border-radius: 8px;
}
.lume-sb__trust-item { text-align: center; }
.lume-sb__trust-icon { font-size: 28px; margin-bottom: 6px; }
.lume-sb__trust-title { font-size: 13px; font-weight: 700; color: #1a1a1a; margin-bottom: 4px; text-transform: uppercase; letter-spacing: .5px; }
.lume-sb__trust-text { font-size: 12px; color: #5A5A5A; line-height: 1.4; }
@media (min-width: 768px) {
  .lume-sb__trust { grid-template-columns: repeat(4, 1fr); }
}

/* =================================================================== */
/* === ONDA DE FIXES AUDITORIA DESIGN+UX+A11Y — 2026-05-08         === */
/* === Aplicada após auditoria das 5 PDPs Lume Lar                === */
/* =================================================================== */

/* P0.2 — Title curto mobile (era quebrando feio) */
@media (max-width: 768px) {
  .product-info h1.product_title,
  body.single-product h1.product_title { font-size: 18px !important; line-height: 1.25 !important; margin: 8px 0 !important; }
}

/* P1.7 — Stock alert urgência forte */
.cdf-stock-alert { background: #FEF3F2 !important; border-left: 3px solid #DC2626 !important; padding: 10px 14px !important; border-radius: 6px !important; color: #991B1B !important; font-weight: 500 !important; margin: 8px 0 4px !important; }
.cdf-stock-alert__fire { margin-right: 6px; }
.cdf-stock-alert__dot { display: none !important; }
.cdf-stock-alert__note { color: #991B1B !important; font-size: 12px !important; margin: 2px 0 8px !important; }
.cdf-stock-alert__note strong { color: #DC2626 !important; }

/* P1.9 — Rating block inline limpo */
.cdf-rating-block.cdf-rating-block--inline { display: flex !important; align-items: center !important; gap: 6px !important; flex-wrap: wrap !important; margin-bottom: 8px !important; padding: 0 !important; background: transparent !important; border: 0 !important; }
.cdf-rating-block.cdf-rating-block--inline .cdf-rating-block__stars { color: #F5A623 !important; font-size: 16px !important; letter-spacing: 1px !important; }
.cdf-rating-block.cdf-rating-block--inline .cdf-rating-block__rating { font-weight: 700 !important; color: #1a1a1a !important; font-size: 15px !important; }
.cdf-rating-block.cdf-rating-block--inline .cdf-rating-block__sep { color: #aaa !important; font-size: 14px !important; }
.cdf-rating-block.cdf-rating-block--inline .cdf-rating-block__count { color: #555 !important; font-size: 13px !important; }
.cdf-rating-block.cdf-rating-block--inline .cdf-rating-block__count strong { color: #1a1a1a !important; }

/* P1.11 — Hero h2 cleaner mobile */
@media (max-width: 768px) {
  .lume-sb__hero-h2 { font-size: 22px !important; line-height: 1.3 !important; max-width: 92% !important; margin-left: auto !important; margin-right: auto !important; hyphens: auto; -webkit-hyphens: auto; word-break: keep-all; }
  .lume-sb__hero-subtitle { font-size: 14px !important; line-height: 1.5 !important; }
}

/* P1.12 — Hero image weight (sombra + radius) */
.lume-sb__hero-img,
.lume-sb__hero img { box-shadow: 0 8px 24px rgba(0,0,0,0.12) !important; border-radius: 12px !important; width: 100% !important; height: auto !important; }

/* P2.1 — Spacing badges consistente */
.cdf-badge-economize { margin: 6px 0 8px !important; display: inline-flex !important; }
.cdf-badge-pix { margin: 6px 0 !important; }
.cdf-badge-demand { margin: 0 0 4px !important; }

/* P2.2 — Label cores count "(N opções)" */
.lume-swatch-count { color: #777 !important; font-size: 13px !important; font-weight: 400 !important; margin-left: 4px !important; }

/* P2.7 — Border-radius padronizado 12px */
.lume-eyebrow-contem { border-radius: 12px !important; }
.lume-addon-card { border-radius: 12px !important; }
.cdf-quote-box { border-radius: 12px !important; }

/* P2.8 — Quote contraste WCAG AA (#3a3a3a > 7:1 em #FFF) */
.lume-sb__quote-p { color: #3a3a3a !important; }

/* P3.1 — Hover/active swatches */
.lume-swatch { transition: transform 0.15s ease, border-color 0.15s ease !important; }
.lume-tam-btn { transition: transform 0.15s ease, border-color 0.15s ease, background 0.15s ease !important; }
.lume-swatch:hover, .lume-tam-btn:hover { border-color: #2C2C2C !important; transform: translateY(-1px) !important; }

/* P3.3 — Dots maiores + active mais forte */
.lume-sb__videos-dot { width: 10px !important; height: 10px !important; transition: width 0.25s ease, background 0.25s ease, border-radius 0.25s ease !important; }
.lume-sb__videos-dot.is-active { width: 24px !important; border-radius: 5px !important; }

/* P3.5 — Sticky CTA mobile (botão flutuante depois do scroll) */
@media (max-width: 768px) {
  .lume-sticky-cta {
    position: fixed !important;
    bottom: 12px !important;
    left: 12px !important;
    right: 12px !important;
    z-index: 999 !important;
    background: #FF8A1F !important;
    color: #fff !important;
    text-align: center !important;
    padding: 14px 18px !important;
    border-radius: 10px !important;
    font-weight: 700 !important;
    font-size: 16px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    box-shadow: 0 6px 20px rgba(255,138,31,0.4), 0 2px 6px rgba(0,0,0,0.15) !important;
    text-decoration: none !important;
    transform: translateY(120%) !important;
    transition: transform 0.3s ease !important;
    display: block !important;
  }
  .lume-sticky-cta.is-visible { transform: translateY(0) !important; }
}
@media (min-width: 769px) {
  .lume-sticky-cta { display: none !important; }
}

/* =================================================================== */
/* === ONDA 5 — FIXES MOBILE-CRITICAL pós-auditoria mobile         === */
/* === 90% do tráfego é mobile — ATF deve ter título+preço         === */
/* =================================================================== */

/* P0-A — Galeria mobile: limitar altura pra título/preço aparecerem no ATF */
@media (max-width: 768px) {
  .product-images,
  .woocommerce-product-gallery,
  .product-gallery,
  .product-gallery-slider { max-height: 360px !important; overflow: hidden !important; }
  .product-images .flickity-slider,
  .woocommerce-product-gallery__wrapper,
  .product-gallery-slider .flickity-slider { max-height: 360px !important; }
  .product-images img,
  .woocommerce-product-gallery__image img,
  .product-gallery img,
  .product-gallery-slider img,
  .product-image img { max-height: 360px !important; width: 100% !important; height: 360px !important; object-fit: cover !important; }
  /* Thumbs row abaixo */
  .product-thumbnails,
  .image-tools,
  .product-gallery-additional { max-height: 80px !important; margin-top: 6px !important; }
  .product-thumbnails img,
  .product-gallery-additional img { max-height: 70px !important; height: 70px !important; object-fit: cover !important; }
}

/* P1 — Logo mobile menor (libera espaço top) */
@media (max-width: 768px) {
  .header-main .logo,
  .header-main .logo a,
  .header-main .logo img { max-height: 50px !important; }
  .header-main { min-height: 60px !important; height: 60px !important; }
  .header-wrapper { min-height: 60px !important; }
}

/* P1 — "ALTA DEMANDA" badge com peso (era texto plain) */
.cdf-badge-demand {
  display: inline-block !important;
  background: #FEF3C7 !important;
  color: #92400E !important;
  padding: 3px 8px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.5px !important;
  border-radius: 4px !important;
  text-transform: uppercase !important;
}

/* P1 — Topbar "FRETE GRÁTIS" mobile mais denso */
@media (max-width: 768px) {
  #top-bar { min-height: 32px !important; line-height: 32px !important; font-size: 12px !important; padding: 0 10px !important; }
  #top-bar .nav { padding: 0 !important; }
}

/* Mobile — hero h2 sales page mais clean */
@media (max-width: 768px) {
  .lume-sb__hero { padding: 16px 0 !important; }
  .lume-sb__hero-h2 { font-size: 20px !important; padding: 0 8px !important; }
  /* Bullets compactos */
  .lume-bullets__item { font-size: 13px !important; padding: 4px 0 !important; }
}

/* P0-B — sticky CTA respeita safe-area iPhone (notch/home indicator) */
@media (max-width: 768px) {
  .lume-sticky-cta {
    bottom: max(12px, env(safe-area-inset-bottom)) !important;
    padding: 14px 18px !important;
  }
}

/* =================================================================== */
/* === ONDA 6 — FIXES HOME + LOJA + LOGO BUG SCROLL                === */
/* === Auditoria home/loja 2026-05-08                              === */
/* =================================================================== */

/* P0 — Logo flutuando no meio do scroll (bug Flatsome has-sticky-logo)
   Esconde as 2 logos extras (sticky e dark), mantém só a principal */
.header-logo-sticky,
.header-logo-dark { display: none !important; }
.header_logo.header-logo { display: block !important; }

/* P0 — Header transparente na home cobrindo banner — forçar bg sólido sempre */
.header-main, #masthead { background: #FFFFFF !important; }
.header-wrapper { background: #FFFFFF !important; }
body:not(.single-product) .header.has-transparent .header-main,
body.has-transparent-header .header-main { background: #FFFFFF !important; }
.transparent .header-main, .header.transparent { background: #FFFFFF !important; }

/* P0 — Loja: esconder breadcrumb (INÍCIO LOJA sobrepondo logo) */
.shop-page-title .breadcrumbs,
.page-title .breadcrumbs,
nav[aria-label="Breadcrumb"],
.woocommerce-breadcrumb { display: none !important; }
@media (max-width: 768px) {
  .shop-page-title { padding: 8px 0 4px !important; min-height: 0 !important; }
  .page-title-inner { padding: 0 !important; }
}

/* P1 — Loja: filtro/ordenação compacto mobile */
@media (max-width: 768px) {
  .shop-toolbar, .woocommerce-result-count, .woocommerce-ordering { font-size: 13px !important; padding: 6px 8px !important; }
  .filter-button, .show-shop-sidebar { padding: 8px 12px !important; }
}

/* P1 — Home banner H1 maior + line-height pra não cortar */
@media (max-width: 768px) {
  .banner h1, .banner .text-box h1, section.banner h1 { font-size: 28px !important; line-height: 1.15 !important; }
  .banner p, .banner .text-box p { font-size: 14px !important; line-height: 1.5 !important; }
}

/* P1 — Sticky CTA: indicar visualmente que rola pra cima (não compra direto) */
.lume-sticky-cta::before { content: "↑ "; font-size: 14px; opacity: 0.85; }

/* P2 — Reduzir altura header mobile pra não ficar gigante */
@media (max-width: 768px) {
  #masthead.header-main { padding-top: 4px !important; padding-bottom: 4px !important; }
}

/* =================================================================== */
/* === ONDA 7 — FIX PILLS TAMANHO MOBILE (4 órfão "King" bug)        === */
/* =================================================================== */

/* Pills tamanho: GRID com minmax(0, 1fr) — garante que cada coluna pode shrink abaixo do min-content */
.lume-swatches-tamanho {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 4px !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  overflow: visible !important;
}
.lume-swatches-tamanho .lume-tam-btn,
.lume-swatch-group[data-attribute="tamanho-da-cama"] .lume-tam-btn {
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  padding: 10px 2px !important;
  font-size: 12px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  text-align: center !important;
  box-sizing: border-box !important;
}
@media (min-width: 480px) {
  .lume-swatches-tamanho .lume-tam-btn { font-size: 14px !important; padding: 10px 6px !important; }
}
/* No NASA tem só 2 (1 Unidade / Par 2 Unidades) — long names — usar 2 colunas */
.lume-swatch-group[data-attribute="quantidade"] .lume-swatches-tamanho {
  grid-template-columns: repeat(2, 1fr) !important;
}
.lume-swatch-group[data-attribute="quantidade"] .lume-tam-btn {
  font-size: 13px !important;
  padding: 12px 4px !important;
}

/* =================================================================== */
/* === ONDA 8 — HEADER SEMPRE FIXO (remove sticky-jump animation)    === */
/* === Flatsome usa sticky-jump que esconde no scroll-down — bug   === */
/* =================================================================== */

/* Força header SEMPRE no topo, sem animation que esconde */
.header.has-sticky,
.header.has-sticky.sticky-jump,
.header.has-sticky.sticky-shrink,
header#header.has-sticky,
header#header.has-sticky.sticky-jump {
  position: -webkit-sticky !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 100 !important;
  transform: none !important;
  -webkit-transform: none !important;
  transition: none !important;
  -webkit-transition: none !important;
}

/* Estados internos do Flatsome sticky — todos voltam pra default */
.header.has-sticky.sticky-jump.stuck,
.header.has-sticky.sticky-jump.is-sticky,
.header.has-sticky.sticky-jump:not(.stuck),
.has-sticky-jump #header,
body.has-sticky-jump #header {
  transform: translate3d(0, 0, 0) !important;
  -webkit-transform: translate3d(0, 0, 0) !important;
  transition: none !important;
  -webkit-transition: none !important;
}

/* Header masthead inner — garante bg branco mesmo durante scroll */
#masthead.header-main,
.header-main {
  position: relative !important;
  background: #FFFFFF !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}

/* Mobile: priorizar visibilidade — sempre visible */
@media (max-width: 768px) {
  .header.has-sticky {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
  }
  /* Empurra body pra baixo do header fixed pra não cobrir conteúdo */
  body.single-product,
  body.archive,
  body.home {
    padding-top: 90px !important;
  }
  body.admin-bar.single-product,
  body.admin-bar.archive,
  body.admin-bar.home {
    padding-top: 122px !important;
  }
  /* Top bar dentro do header fixed: ainda visível */
  #top-bar { position: relative !important; }
}

/* =================================================================== */
/* === ONDA 9 — LOGO HORIZONTAL (798x166) ajuste header             === */
/* =================================================================== */

/* Logo horizontal: forçar height adequado + proporção correta */
.header_logo img,
.header-logo img,
.header-logo-sticky,
.header-logo-dark,
#logo img,
.logo img {
  max-height: 50px !important;
  height: auto !important;
  width: auto !important;
  max-width: 200px !important;
  object-fit: contain !important;
}

@media (max-width: 768px) {
  .header_logo img,
  .header-logo img,
  #logo img,
  .logo img {
    max-height: 38px !important;
    max-width: 180px !important;
  }
}

/* Garante centralização da logo no header */
#logo,
.header-logo,
.header_logo {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
