/* ============================================================
   Seivee · single-product.css  (tarefa 4.11/4.14)
   CSS da PÁGINA DE PRODUTO — modo Caminho.
   Migrado de produto-template-unificado.html (fonte de design).
   NÃO inclui: :root, fontes, nav, breadcrumb, rodapé, carrinho
   (já no tema), a barra-demo de modo, nem os modos Acessório/Composto.
   Depende das variáveis de marca (--vinho, --rosado, --f-poetico, etc.)
   já definidas no :root do tema.
   ============================================================ */

/* ---------- HERO · GALERIA · INFO · ACORDEÃO · PREÇO · SELOS ---------- */
.produto-single .hero {
  display:grid; grid-template-columns:1.1fr 0.9fr;
  height:auto; min-height:auto;
  align-items:stretch;
  overflow:visible;
}

/* ── Galeria ── */
.galeria {
  position:relative; overflow:hidden;
  background:var(--offwhite);
  display:flex; flex-direction:row;
  align-items:center; justify-content:center; gap:16px;
  align-self:stretch;
  padding:0;
}
.gal-principal {
  flex:initial;
  height:70vh;
  padding:24px;
  position:relative;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
}
.gal-bg-grad {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 70% 80% at 42% 36%, rgba(255,253,230,0.55) 0%, transparent 60%),
    var(--offwhite);
}
.gal-produto {
  position:relative; z-index:2;
  width:auto; height:auto;
  max-width:100%; max-height:100%;
  object-fit:contain;
  animation:floatP 10s ease-in-out infinite;
  filter:drop-shadow(0 20px 48px rgba(96,49,56,0.12));
  transition:opacity .25s ease;
}
.gal-produto.trocando { opacity:0; }
.gal-flor-fallback {
  position:relative; z-index:2;
  width:42%; opacity:0.45;
}
@keyframes floatP {
  0%,100% { transform:translateY(0); }
  50%      { transform:translateY(-12px); }
}
/* Miniatura de thumbnails */
.gal-thumbs {
  order:-1;
  display:flex; flex-direction:column;
  align-self:center;
  gap:8px; padding:0;
  background:rgba(250,250,248,0.55);
  backdrop-filter:blur(6px);
}
.gal-thumb {
  width:64px; height:64px; flex-shrink:0;
  border:1.5px solid transparent;
  overflow:hidden; cursor:pointer;
  transition:border-color .25s;
  display:flex; align-items:center; justify-content:center;
}
.gal-thumb.ativo { border-color:var(--vinho); }
.gal-thumb-bg {
  width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  transition:transform .4s ease;
}
/* Vence .woocommerce img { height:auto } via specificity */
.gal-thumb .gal-thumb-bg img { width:100%; height:100%; object-fit:cover; display:block; }
.gal-thumb:hover .gal-thumb-bg { transform:scale(1.08); }
/* Seta de navegação (mobile) — display gerenciado pelo media query ≤1023px */
.gal-seta {
  display:none;
  position:absolute; right:12px; top:50%;
  transform:translateY(-50%);
  z-index:4;
  width:40px; height:40px;
  padding:0; border:none; cursor:pointer;
  background:rgba(250,250,248,0.78);
  backdrop-filter:blur(4px);
  color:var(--vinho);
  font-family:var(--f-corpo); font-size:26px; line-height:1;
  border-radius:50%;
  box-shadow:0 4px 12px rgba(74,3,1,0.10);
  transition:background .25s, transform .25s;
}
.gal-seta:hover { background:rgba(250,250,248,0.95); }
.gal-seta:active { transform:translateY(-50%) scale(0.94); }
/* ── Info de compra ── */
.info {
  padding:80px 60px 64px;
  display:flex; flex-direction:column; justify-content:flex-start;
  background:var(--offwhite);
  border-left:1px solid rgba(196,155,162,0.1);
}

.p-caminho-ctx {
  display:flex; align-items:center; gap:10px; margin-bottom:16px;
}
.p-caminho-lbl {
  font-family:var(--f-corpo); font-weight:400;
  font-size:var(--fs-micro); letter-spacing:0.32em; text-transform:uppercase; color:var(--muted);
}
.p-caminho-sep { color:var(--rosa-claro); }
.p-caminho-nome {
  font-family:var(--f-corpo); font-weight:400;
  font-size:var(--fs-micro); letter-spacing:0.32em; text-transform:uppercase; color:var(--rosado);
  transition:color .3s;
}
.p-caminho-nome:hover { color:var(--vinho); }

.p-linha-badge {
  display:inline-block;
  align-self:flex-start;
  font-family:var(--f-corpo); font-weight:400;
  font-size:8px; letter-spacing:0.28em; text-transform:uppercase;
  color:var(--rosado); border:1px solid rgba(196,155,162,0.3);
  padding:4px 12px; margin-bottom:18px;
}

.p-nome {
  font-family:var(--f-titulo); font-weight:400;
  font-size:clamp(28px, 3vw, 44px); color:var(--vinho);
  line-height:1.08; margin-bottom:10px; letter-spacing:0.02em;
}
.p-frase {
  font-family:var(--f-poetico);
  font-size:19px; color:var(--rosado); opacity:0.85;
  margin-bottom:28px; line-height:1.45;
}

.p-divisor { width:36px; height:1px; background:var(--rosa-claro); margin-bottom:22px; }

.p-desc {
  font-family:var(--f-corpo); font-weight:300;
  font-size:var(--fs-corpo); line-height:1.65; color:var(--muted);
  margin-bottom:24px;
}
.p-desc em {
  font-style:italic; color:var(--vinho); font-family:var(--f-display); font-size:14.5px;
}

/* Acordeão */
.acord { border-top:1px solid rgba(196,155,162,0.2); margin-bottom:28px; }
.ai { border-bottom:1px solid rgba(196,155,162,0.2); }
.at {
  width:100%; padding:14px 0;
  display:flex; align-items:center; justify-content:space-between;
  background:none; border:none;
  font-family:var(--f-corpo); font-weight:400;
  font-size:var(--fs-eyebrow); letter-spacing:0.22em; text-transform:uppercase;
  color:var(--text); transition:color .3s;
}
.at:hover { color:var(--vinho); }
.aa { font-size:var(--fs-lead); color:var(--rosado); transition:transform .3s; line-height:1; }
.aa.open { transform:rotate(45deg); }
.ab {
  max-height:0; overflow:hidden;
  transition:max-height .5s ease, padding .3s;
  font-family:var(--f-corpo); font-weight:300;
  font-size:var(--fs-corpo-sm); color:var(--muted); line-height:1.9;
}
.ab.open { max-height:600px; padding-bottom:18px; }
.ingr-lista {
  display:flex; flex-wrap:wrap; gap:6px; padding-top:2px;
}
.acord-lista { list-style:none; display:flex; flex-direction:column; gap:8px; }
.ingr-item {
  font-family:var(--f-corpo); font-weight:300;
  font-size:11.5px; letter-spacing:0.06em; color:var(--text);
  background:rgba(196,155,162,0.08); padding:4px 12px;
}

/* Link âncora composição */
.ver-composicao {
  display:inline-flex; align-items:center; align-self:flex-start; gap:6px;
  font-family:var(--f-corpo); font-weight:400;
  font-size:var(--fs-eyebrow); letter-spacing:0.22em; text-transform:uppercase;
  color:var(--rosado); margin-bottom:24px;
  transition:color .3s, gap .3s;
}
.ver-composicao:hover { color:var(--vinho); gap:10px; }

/* Preço e CTA */
.preco-wrap { margin-top:4px; transition:transform .35s ease; }
.preco-wrap.pw-hide { transform:translateY(120%); }
.pw-nome { display:none; }
.preco-row {
  display:flex; align-items:baseline; gap:12px; margin-bottom:18px;
}
.preco {
  font-family:var(--f-titulo); font-weight:400;
  font-size:32px; color:var(--vinho); letter-spacing:0.01em;
}
.preco-lbl {
  font-family:var(--f-corpo); font-weight:300;
  font-size:var(--fs-eyebrow); letter-spacing:0.12em; color:var(--muted);
}
.btn-adicionar {
  display:flex; width:100%; align-items:center; justify-content:center; gap:14px;
  padding:17px 24px;
  font-family:var(--f-corpo); font-weight:400;
  font-size:10.5px; letter-spacing:0.3em; text-transform:uppercase;
  background:var(--vinho); color:var(--offwhite);
  border:none; transition:background .35s, letter-spacing .35s;
  margin-bottom:12px;
}
.btn-adicionar:hover { background:var(--rosado); }
.btn-adicionar-seta { font-size:var(--fs-corpo-sm); transition:transform .3s; }
.btn-adicionar:hover .btn-adicionar-seta { transform:translateX(4px); }
/* ---------- Botão "Guardar na lista de desejos" (TI Wishlist via shortcode) ----------
   Re-skin do <a.tinvwl_add_to_wishlist_button>: full-width, outline rosado, vira
   vinho no hover. O ícone (.tinvwl-icon-heart:before) vinha da webfont do plugin
   (\e909/\e908); substituímos por SVG via mask-image (mesma técnica de account.css),
   assim a cor herda de currentColor e o toggle salvo/não-salvo é só trocar a
   mask-image — sem JS, sem dependência da webfont externa carregar. */
.tinv-wraper.tinvwl-shortcode-add-to-cart { display:block; margin-bottom:20px; }
.tinv-wraper.tinvwl-shortcode-add-to-cart .tinvwl_add_to_wishlist_button {
  display:flex; width:100%; align-items:center; justify-content:center; gap:10px;
  padding:13px;
  font-family:var(--f-corpo); font-weight:400;
  font-size:var(--fs-eyebrow); letter-spacing:0.22em; text-transform:uppercase;
  text-decoration:none;
  background:transparent; color:var(--muted);
  border:1px solid rgba(196,155,162,0.25); transition:all .3s;
}
.tinv-wraper.tinvwl-shortcode-add-to-cart .tinvwl_add_to_wishlist_button:hover {
  border-color:var(--vinho); color:var(--vinho);
}

/* Anula o glyph da webfont do TI (\e909) e injeta o coração outline em SVG.
   font-family no !important do plugin é necessário sobrescrever via content:""." */
.tinv-wraper.tinvwl-shortcode-add-to-cart .tinvwl_add_to_wishlist_button.tinvwl-icon-heart:before {
  content:""; display:inline-block;
  width:18px; height:18px;
  background-color:currentColor;
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none'><path d='M12 21s-7-4.5-9.5-9.5C1 7 4 3 8 3c2 0 3.4 1 4 2 .6-1 2-2 4-2 4 0 7 4 5.5 8.5C19 16.5 12 21 12 21z' stroke='black' stroke-width='1.6' stroke-linejoin='round'/></svg>") no-repeat center / contain;
          mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none'><path d='M12 21s-7-4.5-9.5-9.5C1 7 4 3 8 3c2 0 3.4 1 4 2 .6-1 2-2 4-2 4 0 7 4 5.5 8.5C19 16.5 12 21 12 21z' stroke='black' stroke-width='1.6' stroke-linejoin='round'/></svg>") no-repeat center / contain;
  vertical-align:middle; margin-right:0;
}
/* Estado "já está na lista" — coração filled */
.tinv-wraper.tinvwl-shortcode-add-to-cart .tinvwl_add_to_wishlist_button.tinvwl-icon-heart.tinvwl-product-in-list:before {
  -webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 21s-7-4.5-9.5-9.5C1 7 4 3 8 3c2 0 3.4 1 4 2 .6-1 2-2 4-2 4 0 7 4 5.5 8.5C19 16.5 12 21 12 21z' fill='black'/></svg>");
          mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 21s-7-4.5-9.5-9.5C1 7 4 3 8 3c2 0 3.4 1 4 2 .6-1 2-2 4-2 4 0 7 4 5.5 8.5C19 16.5 12 21 12 21z' fill='black'/></svg>");
}
/* Tooltip nativa do TI fica escondida — temos label próprio no botão */
.tinv-wraper.tinvwl-shortcode-add-to-cart .tinvwl-tooltip { display:none; }

/* Sticky bar de compra — desktop fixed quando o hero sai da viewport */
@media (min-width:600px) {
  .preco-wrap.pw-fixed {
    position:fixed; left:0; right:0; bottom:0; z-index:100;
    display:flex; flex-direction:row; align-items:center; gap:28px;
    padding:14px var(--sp-card-sm);
    background:var(--offwhite);
    border-top:1px solid rgba(196,155,162,0.2);
    box-shadow:0 -4px 20px rgba(96,49,56,0.06);
    margin:0;
    animation:pwSlideUp .35s ease;
  }
  .preco-wrap.pw-fixed .pw-nome {
    display:block; flex:1;
    font-family:var(--f-titulo); font-size:var(--fs-corpo); letter-spacing:0.1em;
    text-transform:uppercase; color:var(--vinho);
    white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  }
  .preco-wrap.pw-fixed .preco-row { margin-bottom:0; flex:0 0 auto; }
  .preco-wrap.pw-fixed .preco { font-size:var(--fs-h-md); }
  .preco-wrap.pw-fixed .preco-lbl { display:none; }
  .preco-wrap.pw-fixed .btn-adicionar { width:auto; padding:14px 36px; margin-bottom:0; }
  .preco-wrap.pw-fixed .tinv-wraper.tinvwl-shortcode-add-to-cart { display:none; }
  .preco-wrap.pw-leaving { animation:pwSlideDown .3s ease forwards; }
}
@keyframes pwSlideUp   { from { transform:translateY(100%); } to { transform:translateY(0); } }
@keyframes pwSlideDown { to   { transform:translateY(110%); } }

/* Selos de confiança */
.selos {
  display:flex; gap:16px; margin-top:20px;
  padding-top:20px; border-top:1px solid rgba(196,155,162,0.12);
  flex-wrap:wrap;
}
.selo {
  display:flex; align-items:center; gap:6px;
  font-family:var(--f-corpo); font-weight:300;
  font-size:var(--fs-eyebrow); letter-spacing:0.1em; color:var(--muted);
}
.selo-icone { font-size:var(--fs-corpo); opacity:0.6; }

.sec-eyebrow {
  font-family:var(--f-corpo); font-weight:400;
  font-size:var(--fs-eyebrow); letter-spacing:0.42em; text-transform:uppercase;
  color:var(--rosado); margin-bottom:12px;
  display:flex; align-items:center; gap:14px;
}
.sec-eyebrow::before { content:''; display:block; width:28px; height:1px; background:var(--rosado); opacity:0.5; }
.sec-tit {
  font-family:var(--f-titulo); font-weight:400;
  font-size:clamp(20px,2.6vw,32px); color:var(--vinho);
  margin-bottom:52px; letter-spacing:0.03em;
}

/* ══════════════════════════════════════════
   SABEDORIA DOS INGREDIENTES — split layout
══════════════════════════════════════════ */
.sabedoria {
  display:grid; grid-template-columns:1.1fr 0.9fr;
  border-top:1px solid rgba(196,155,162,0.1);
  min-height:70vh;
}

.sab-foto {
  position:relative; overflow:hidden;
  background:var(--cam, #E5CFD2);
  display:flex; align-items:center; justify-content:center;
}
/* Vence .woocommerce img { height:auto } via specificity */
.sab-foto img.sab-foto-img {
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover;
}
.sab-flor-fallback {
  width:48%; opacity:0.4;
  animation:floatP 12s ease-in-out infinite;
}

.sab-texto {
  padding:var(--sp-secao-md) 64px;
  background:var(--offwhite);
  display:flex; flex-direction:column; justify-content:center;
}
.sab-item {
  margin-bottom:36px; padding-bottom:36px;
  border-bottom:1px solid rgba(196,155,162,0.15);
}
.sab-item:last-child { border-bottom:none; margin-bottom:0; padding-bottom:0; }
.sab-ingrediente {
  font-family:var(--f-titulo); font-weight:400;
  font-size:15.5px; color:var(--vinho); margin-bottom:2px; letter-spacing:0.02em;
}
.sab-cientifico {
  font-family:var(--f-corpo); font-weight:300;
  font-size:var(--fs-eyebrow); font-style:italic; color:var(--rosado); margin-bottom:10px;
}
.sab-desc {
  font-family:var(--f-corpo); font-weight:300;
  font-size:var(--fs-corpo-sm); color:var(--muted); line-height:1.9;
}
.sab-tipo {
  display:inline-block;
  font-size:8.5px; letter-spacing:0.22em; text-transform:uppercase;
  color:var(--vinho); margin-bottom:8px;
}
.sab-sec-tit { margin-bottom:var(--sp-card-sm); }

/* ══════════════════════════════════════════
   RESPIRO — artesanal, silêncio generoso
══════════════════════════════════════════ */
.respiro {
  background:var(--offwhite);
  padding:190px 64px;
  text-align:center;
  border-top:1px solid rgba(196,155,162,0.1);
}
.respiro-in { max-width:620px; margin:0 auto; }
.respiro-eyebrow {
  font-family:var(--f-corpo); font-weight:400;
  font-size:var(--fs-eyebrow); letter-spacing:0.42em; text-transform:uppercase;
  color:var(--rosado); margin-bottom:54px;
}
.respiro-sep { margin:0 14px; opacity:0.5; }
.respiro-titulo {
  font-family:var(--f-titulo); font-weight:400;
  font-size:clamp(22px,2.6vw,32px); color:var(--vinho);
  line-height:1.7; margin-bottom:54px; letter-spacing:0.03em;
}
.respiro-texto {
  font-family:var(--f-corpo); font-weight:300;
  font-size:var(--fs-corpo); line-height:2.3; color:var(--muted);
}

/* ══════════════════════════════════════════
   FINAL DO CAMINHO — atmosfera + intenção
══════════════════════════════════════════ */
.caminho-final {
  display:grid; grid-template-columns:1.1fr 0.9fr;
  border-top:1px solid rgba(196,155,162,0.1);
  min-height:80vh;
}
.cf-visual {
  position:relative; overflow:hidden;
  background:var(--cam, #E5CFD2);
  display:flex; align-items:flex-end; justify-content:flex-start;
  padding:64px;
}
/* Vence .woocommerce img { height:auto } via specificity */
.cf-visual img.cf-foto {
  position:absolute; inset:0; z-index:0;
  width:100%; height:100%; object-fit:cover;
}
.caminho-final.c-bruma .cf-foto { object-position:center 70%; }
.cf-veu {
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(to bottom,
    rgba(40,30,28,0.55) 0%,
    rgba(40,30,28,0.18) 22%,
    rgba(40,30,28,0.04) 42%,
    rgba(40,30,28,0.50) 72%,
    rgba(40,30,28,0.84) 100%);
}
.cf-frase {
  position:relative; z-index:2;
  font-family:var(--f-poetico); font-style:italic;
  font-size:26px;
  color:rgba(255,253,230,0.85); line-height:1.4; text-align:left;
}
.cf-texto {
  padding:var(--sp-secao-lg) 64px; background:var(--offwhite);
  display:flex; flex-direction:column; justify-content:center;
}
.cf-eyebrow {
  font-family:var(--f-corpo); font-weight:400;
  font-size:var(--fs-eyebrow); letter-spacing:0.42em; text-transform:uppercase;
  color:var(--rosado); margin-bottom:30px;
  display:flex; align-items:center; gap:14px;
}
.cf-eyebrow::before { content:''; display:block; width:28px; height:1px; background:var(--rosado); opacity:0.5; }
.cf-declaracao {
  font-family:var(--f-titulo); font-weight:400;
  font-size:clamp(22px,2.4vw,30px); color:var(--vinho);
  line-height:1.65; margin-bottom:34px; max-width:22ch; letter-spacing:0.03em;
}
.cf-estado {
  font-family:var(--f-corpo);
  font-size:11px; letter-spacing:0.3em; text-transform:uppercase;
  color:var(--vinho); margin-bottom:28px;
}
.cf-intencao {
  font-family:var(--f-corpo); font-weight:300;
  font-size:var(--fs-corpo); line-height:2.05; color:var(--muted);
  max-width:48ch; margin-bottom:44px;
}
.cf-intencao p { margin-bottom:1em; }
.cf-intencao p:last-child { margin-bottom:0; }
.cf-btn {
  display:inline-block; text-decoration:none; width:fit-content;
  border:1px solid var(--vinho); color:var(--vinho);
  font-family:var(--f-corpo);
  font-size:10.5px; letter-spacing:0.26em; text-transform:uppercase;
  padding:15px 36px; transition:all .3s;
}
.cf-btn:hover { background:var(--vinho); color:#FFFDE6; }

/* ══════════════════════════════════════════
   NOTA CERÂMICA — faixa verde-claro
══════════════════════════════════════════ */
.nota-ceramica {
  background:var(--verde-claro);
  padding:60px 64px; text-align:center;
}
.nota-ceramica-txt {
  font-family:var(--f-poetico);
  font-size:var(--fs-h-md); color:var(--oliva);
  line-height:1.85; max-width:620px; margin:0 auto 14px;
}
.nota-ceramica-ass {
  font-family:var(--f-corpo); font-weight:400;
  font-size:var(--fs-micro); letter-spacing:0.3em; text-transform:uppercase;
  color:var(--oliva); opacity:0.5;
}

/* ══════════════════════════════════════════
   OUTRAS CRIAÇÕES DO CAMINHO
══════════════════════════════════════════ */

/* ---------- ANIMAÇÃO DE ENTRADA (.reveal) ---------- */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(22px); }
  to   { opacity:1; transform:translateY(0); }
}
.reveal { opacity:0; }
.reveal.visible { animation:fadeUp .8s ease forwards; }

/* ---------- TROCA DE MODO (somente .modo-band; barra-demo excluída) ---------- */
.modo-band { display:none; }
.modo-band.active { display:block; }

/* ============================================================
   RESPONSIVO ≤1023px (subconjunto de produto)
   ============================================================ */
@media (max-width:1023px) {
  .produto-single .hero { grid-template-columns:1fr; }
  .galeria { padding-top:72px; flex-direction:column; gap:0; align-self:auto; justify-content:initial; }
  .gal-principal { flex:initial; max-height:none; height:clamp(360px, 50vh, 520px); padding:20px; }
  .gal-flor-fallback { width:min(36%, 240px); }
  .gal-thumbs { order:initial; flex-direction:row; align-self:initial; padding:12px 16px; }
  .gal-thumb { width:52px; height:52px; }
  .gal-seta { display:flex; align-items:center; justify-content:center; }
  .info { padding:72px var(--sp-card-sm) 52px; border-left:none; }
  .sabedoria { grid-template-columns:1fr; }
  .sab-foto { order:1; min-height:52vw; }
  .sab-texto { order:2; padding:64px var(--sp-card-sm); }
  .nota-ceramica { padding:var(--sp-card-md) var(--sp-card-sm); }
  .respiro { padding:130px var(--sp-card-sm); }
  .caminho-final { grid-template-columns:1fr; }
  .cf-visual { min-height:56vw; order:1; padding:var(--sp-card-sm); }
  .caminho-final.c-bruma .cf-foto { object-position:center 62%; }
  .cf-texto { order:2; padding:64px var(--sp-card-sm); }
}

/* ============================================================
   RESPONSIVO ≤599px (subconjunto de produto)
   ============================================================ */
@media (max-width:599px) {
  .galeria { padding-top:64px; }
  .gal-principal { height:clamp(320px, 60vh, 440px); padding:16px; }
  .gal-flor-fallback { width:min(40%, 200px); }
  .gal-thumbs { gap:6px; padding:10px 14px; }
  .gal-thumb { width:44px; height:44px; }
  .info { padding:64px 20px 44px; }
  .p-nome { font-size:clamp(26px,7vw,36px); }
  .p-frase { font-size:17px; }
  .preco { font-size:26px; }
  .sabedoria { grid-template-columns:1fr; }
  .sab-foto { min-height:72vw; }
  .sab-texto { padding:52px 20px; }
  .nota-ceramica { padding:44px 20px; }
  .nota-ceramica-txt { font-size:var(--fs-h-sm); }
  .respiro { padding:100px 20px; }
  .respiro-titulo br { display:none; }
  .cf-texto { padding:52px 20px; }
  .cf-frase { font-size:20px; }

  /* Sticky bar de compra mobile (preço em cima, Adicionar + favoritar lado a lado embaixo)
     Grid 2 colunas pra fazer Adicionar (1fr) + ícone Favoritar (auto, 50px) na 2ª linha,
     enquanto a preco-row ocupa a 1ª linha inteira. Mantém altura da sticky em ~96px. */
  .preco-wrap {
    position:fixed;
    left:0; right:0; bottom:0;
    background:var(--offwhite);
    border-top:1px solid rgba(196,155,162,0.2);
    padding:12px 20px calc(16px + env(safe-area-inset-bottom));
    margin:0;
    z-index:100;
    display:grid;
    grid-template-columns:1fr auto;
    grid-template-areas:
      "preco preco"
      "adicionar favoritar";
    gap:10px;
    box-shadow:0 -4px 20px rgba(96,49,56,0.06);
  }
  .preco-wrap .preco-row { grid-area:preco; margin-bottom:0; justify-content:space-between; }
  .preco-wrap .preco { font-size:var(--fs-h-md); }
  .preco-wrap .btn-adicionar { grid-area:adicionar; padding:14px; margin-bottom:0; }

  /* Favoritar vira ícone-só 50x50, mesma altura visual do Adicionar; preserva
     aria-label do plugin pra acessibilidade (label "Add to Wishlist" continua no <a>). */
  .preco-wrap .tinv-wraper.tinvwl-shortcode-add-to-cart {
    grid-area:favoritar;
    margin-bottom:0;
  }
  .preco-wrap .tinv-wraper.tinvwl-shortcode-add-to-cart .tinvwl_add_to_wishlist-text { display:none; }
  .preco-wrap .tinv-wraper.tinvwl-shortcode-add-to-cart .tinv-wishlist-clear { display:none; }
  .preco-wrap .tinv-wraper.tinvwl-shortcode-add-to-cart .tinvwl_add_to_wishlist_button {
    width:50px; padding:14px; gap:0;
  }

  /* Espaço inferior pro conteúdo não ficar coberto pelo bar fixo */
  .produto-single { padding-bottom:calc(128px + env(safe-area-inset-bottom)); }
}


/* ============================================================
   MODO COMPOSTO  — "O que está dentro" + "A curadoria"
   Classes emitidas pelo band-composto em single-product.php.
   Cor por caminho vem inline via style="--cam:#XXX;" no .item-card
   (lido do meta _seivee_cam_cor do CPT caminho). Sem hardcode.
   ============================================================ */

/* ── SEÇÃO 1: "O que está dentro" ── */
.composto-itens {
  background:var(--offwhite);
  padding:var(--sp-secao-lg) 64px;
  border-top:1px solid rgba(196,155,162,0.1);
}
.ci-in { max-width:1100px; margin:0 auto; }

.ci-titulo {
  font-family:var(--f-titulo); font-weight:400;
  font-size:clamp(20px,2.6vw,32px); color:var(--vinho);
  margin-bottom:52px; letter-spacing:0.03em;
}

/* Grid adaptativo: 1–4 colunas conforme largura disponível */
.itens-grid {
  display:grid; grid-template-columns:repeat(auto-fit, minmax(200px,1fr));
  gap:24px;
}

.item-card {
  background:var(--offwhite);
  outline:1px solid rgba(196,155,162,0.12); outline-offset:0;
  transition:background .35s;
  position:relative; overflow:hidden;
  display:flex; flex-direction:column;
}

.item-card:hover { background:rgba(196,155,162,0.04); }

/* Foto: quadrado de cor (fundo vem inline). Se houver <img>, ela cobre. */
.item-foto {
  width:100%; aspect-ratio:1/1;
  position:relative; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
}
/* Vence .woocommerce img { height:auto } via specificity */
.item-card img.item-foto-img {
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover;
  opacity:1; transition:opacity .35s, transform .35s;
}
.item-card:hover .item-foto-img { opacity:1; transform:scale(1.04); }

.item-info { padding:22px 22px 24px; }

.item-caminho {
  font-family:var(--f-corpo); font-weight:400;
  font-size:var(--fs-micro); letter-spacing:0.28em; text-transform:uppercase;
  color:var(--rosado); margin:0 0 6px;
}
.item-nome {
  font-family:var(--f-titulo); font-weight:400;
  font-size:14px; color:var(--vinho); letter-spacing:0.02em;
  margin:0 0 8px;
}
.item-frase {
  font-family:var(--f-poetico);
  font-size:var(--fs-corpo); color:var(--rosado); opacity:0.85;
  line-height:1.55; margin:0 0 10px;
}
.item-desc {
  font-family:var(--f-corpo); font-weight:300;
  font-size:var(--fs-corpo-sm); color:var(--muted); line-height:1.75;
  margin:0;
}
.item-ver {
  display:inline-flex; align-items:center; gap:4px; margin-top:14px;
  font-family:var(--f-corpo); font-weight:400;
  font-size:var(--fs-micro); letter-spacing:0.18em; text-transform:uppercase;
  color:var(--rosado); opacity:0; transition:opacity .3s;
  text-decoration:none;
}
.item-card:hover .item-ver { opacity:1; }

/* ── SEÇÃO 2: "A curadoria" ── */
.experiencia {
  background:var(--offwhite);
  padding:var(--sp-secao-lg) 64px;
  border-top:1px solid rgba(196,155,162,0.1);
}
.experiencia-in {
  max-width:880px; margin:0 auto; text-align:center;
}
.exp-frase {
  font-family:var(--f-display); font-weight:400;
  font-size:clamp(22px,2.8vw,36px); color:var(--vinho);
  line-height:1.55; margin:0 0 36px; letter-spacing:0.02em;
}
.exp-divisor {
  width:48px; height:1px; background:var(--rosa-claro);
  margin:0 auto 36px;
}
.exp-texto {
  font-family:var(--f-corpo); font-weight:300;
  font-size:var(--fs-corpo); line-height:2; color:var(--muted);
  max-width:640px; margin:0 auto;
}
.exp-texto p { margin:0 0 14px; }
.exp-texto p:last-child { margin-bottom:0; }

/* ── Responsivo ── */
@media (max-width:1023px) {
  .composto-itens { padding:72px var(--sp-card-sm); }
  .itens-grid { grid-template-columns:repeat(2,1fr); }
  .experiencia { padding:72px var(--sp-card-sm); }
}

@media (max-width:599px) {
  .composto-itens { padding:var(--sp-card-lg) 20px; }
  .itens-grid { grid-template-columns:1fr; }
  .experiencia { padding:var(--sp-card-lg) 20px; }
  .exp-frase { font-size:clamp(18px,5vw,26px); }
  .ci-titulo { font-size:clamp(18px,5vw,24px); margin-bottom:32px; }
  .item-info { padding:16px 14px 18px; }
  .item-frase { font-size:var(--fs-corpo); }
  .item-desc { font-size:var(--fs-corpo-sm); }
}


/* ============================================================
   MODO COMPOSTO  — "A curadoria" expandida (5 classes novas)
   Vivem dentro de .experiencia.experiencia-in (já centralizada).
   Continuação do padrão das exp-* existentes.
   ============================================================ */

/* Texto introdutório auto-montado ("Esta caixa reúne X caminhos...") */
.exp-intro {
  font-family:var(--f-corpo); font-weight:300;
  font-size:var(--fs-corpo); line-height:1.65;
  color:var(--text);
  max-width:640px; margin:0 auto var(--sp-card-sm);
}

/* Lista de caminhos (sem bullets, formato editorial) */
.exp-caminhos {
  list-style:none; padding:0;
  max-width:640px; margin:0 auto 44px;
}

.exp-caminho {
  font-family:var(--f-corpo); font-weight:300;
  font-size:var(--fs-corpo); line-height:1.7;
  color:var(--text);
  margin:0 0 14px;
}
.exp-caminho:last-child { margin-bottom:0; }

/* Nome do caminho destacado (Florescer, Bruma…) — sem peso bruto, só com tipografia + cor */
.exp-caminho-nome {
  font-family:var(--f-titulo); font-weight:400;
  color:var(--vinho); letter-spacing:0.02em;
  margin-right:4px;
}

/* Frase de fecho ("Encante-se com a arte da perfumaria botânica.") */
.exp-poetico {
  font-family:var(--f-poetico);
  font-size:clamp(18px,2.2vw,24px);
  color:var(--rosado); opacity:0.85;
  line-height:1.6; letter-spacing:0.01em;
  margin:var(--sp-card-md) auto 0; max-width:640px;
}

/* ── Responsivo (alinhado ao bloco @media de .experiencia existente) ── */
@media (max-width:1023px) {
  .exp-intro    { font-size:var(--fs-corpo); margin-bottom:36px; }
  .exp-caminhos { margin-bottom:var(--sp-card-sm); }
  .exp-poetico  { margin-top:var(--sp-card-sm); }
}

@media (max-width:599px) {
  .exp-intro       { font-size:var(--fs-corpo); margin-bottom:28px; }
  .exp-caminhos    { margin-bottom:32px; }
  .exp-caminho     { font-size:var(--fs-corpo); }
  .exp-caminho-nome{ display:block; margin-bottom:2px; }
  .exp-poetico     { font-size:clamp(16px,5vw,20px); margin-top:32px; }
}


/* ============================================================
   MODO COMPOSTO  — "Recomendações de uso" (3 passos)
   Classes emitidas pela seção .como-usar do band-composto.
   Padrão coerente com .composto-itens e .experiencia.
   ============================================================ */

.como-usar {
  background:var(--offwhite);
  padding:var(--sp-secao-lg) 64px;
  border-top:1px solid rgba(196,155,162,0.1);
}
.como-usar-in { max-width:1100px; margin:0 auto; }

/* Grid adaptativo (3 ou eventualmente outro número de passos) */
.passos-grid {
  display:grid; grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:var(--sp-card-md); margin-top:52px;
}

.rp {
  position:relative; padding-top:16px;
}
/* Tracinho rosa-claro acima de cada passo (detalhe visual de ancoragem) */
.rp::before {
  content:''; position:absolute; top:0; left:0;
  width:28px; height:1px;
  background:var(--rosa-claro);
}

.rp-num {
  font-family:var(--f-display); font-weight:400;
  font-size:40px; line-height:1;
  color:var(--rosa-claro); opacity:0.7;
  letter-spacing:-0.02em;
  margin:0 0 16px;
}

.rp-tit {
  font-family:var(--f-titulo); font-weight:400;
  font-size:var(--fs-corpo); letter-spacing:0.02em;
  color:var(--vinho);
  margin:0 0 10px;
}

.rp-desc {
  font-family:var(--f-corpo); font-weight:300;
  font-size:var(--fs-corpo-sm); line-height:1.9;
  color:var(--muted);
  margin:0;
}

/* ── Responsivo ── */
@media (max-width:1023px) {
  .como-usar   { padding:72px var(--sp-card-sm); }
  .passos-grid { gap:32px; margin-top:var(--sp-card-sm); }
  .rp-num      { font-size:34px; }
}

@media (max-width:599px) {
  .como-usar   { padding:var(--sp-card-lg) 20px; }
  .passos-grid { grid-template-columns:1fr; gap:36px; margin-top:32px; }
  .rp-num      { font-size:30px; margin-bottom:12px; }
  .rp-tit      { font-size:13.5px; }
  .rp-desc     { font-size:var(--fs-corpo-sm); }
}


/* ============================================================
   MODO ACESSÓRIO  — "Como funciona" (3 passos)
   ============================================================ */

.como-funciona {
  background:var(--offwhite);
  padding:var(--sp-secao-lg) 64px;
  border-top:1px solid rgba(196,155,162,0.1);
}
.como-funciona-in { max-width:1100px; margin:0 auto; }
.como-funciona .sec-tit { margin-bottom:16px; }
.como-funciona .sec-sub {
  font-family:var(--f-corpo); font-weight:300;
  font-size:var(--fs-corpo); line-height:1.9; color:var(--muted);
  max-width:580px; margin:0 auto 32px;
  text-align:center;
}

/* Layout horizontal: passo · passo · passo */
.passos-flow {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--sp-card-sm); align-items:start;
  margin-top:52px;
}

.passo {
  padding:var(--sp-card-sm) 32px 36px;
  position:relative;
}
/* Faixa colorida no topo do passo (revela no hover) */
.passo::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, var(--rosa-claro), var(--rosado));
  opacity:0; transition:opacity .35s;
}
.passo:hover::before { opacity:1; }

.passo-num {
  font-family:var(--f-display); font-weight:400;
  font-size:40px; line-height:1;
  color:var(--rosa-claro); opacity:0.7;
  letter-spacing:-0.02em;
  margin:0 0 20px;
}

.passo-produto {
  display:flex; align-items:center; gap:10px;
  margin:0 0 16px;
}
.passo-produto-tag {
  font-family:var(--f-corpo); font-weight:400;
  font-size:8px; letter-spacing:0.28em; text-transform:uppercase;
  color:var(--rosado);
  border:1px solid rgba(196,155,162,0.3);
  padding:4px 10px;
}

.passo-tit {
  font-family:var(--f-titulo); font-weight:400;
  font-size:var(--fs-lead); letter-spacing:0.02em;
  color:var(--vinho);
  margin:0 0 10px;
}

.passo-desc {
  font-family:var(--f-corpo); font-weight:300;
  font-size:var(--fs-corpo-sm); line-height:1.9;
  color:var(--muted);
  margin:0;
}

/* ============================================================
   MODO ACESSÓRIO  — "Detalhes" vitrine (imagem + texto + specs + frase)
   ============================================================ */

.detalhes {
  background:var(--offwhite);
  padding:var(--sp-secao-lg) 64px;
  border-top:1px solid rgba(196,155,162,0.1);
}
.detalhes-in {
  max-width:1100px; margin:0 auto;
  display:grid; grid-template-columns:1fr 1fr; gap:var(--sp-secao-md); align-items:center;
}

/* Coluna esquerda: visual */
.det-visual {
  aspect-ratio:4/5;
  background:var(--verde-claro);
  position:relative; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
}
.det-visual-grad {
  position:absolute; inset:0;
  z-index:2;
  background:radial-gradient(ellipse 65% 70% at 48% 40%,
                             rgba(255,253,230,0.45) 0%, transparent 65%);
}
/* Foto da Cerâmica — compound selector pra vencer .woocommerce img{height:auto} */
.det-visual img.det-foto {
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover; object-position:center;
  z-index:1;
}

/* Coluna direita: texto */
.det-texto { }

.det-corpo {
  font-family:var(--f-corpo); font-weight:300;
  font-size:var(--fs-corpo); line-height:1.85;
  color:var(--text);
  margin:0 0 8px;
}
.det-corpo p { margin:0 0 14px; }
.det-corpo p:last-child { margin-bottom:0; }

.det-especificacoes { margin-top:var(--sp-card-sm); }

.det-spec-titulo {
  font-family:var(--f-corpo); font-weight:400;
  font-size:var(--fs-micro); letter-spacing:0.32em; text-transform:uppercase;
  color:var(--muted);
  margin:0 0 16px;
}

.det-spec-lista {
  list-style:none; padding:0; margin:0;
}

.det-spec-item {
  display:flex; justify-content:space-between; align-items:baseline; gap:24px;
  padding:12px 0;
  border-bottom:1px solid rgba(196,155,162,0.12);
  font-family:var(--f-corpo); font-weight:300;
  font-size:var(--fs-corpo-sm);
}
.det-spec-item:last-child { border-bottom:none; }

.det-spec-label { color:var(--muted); }
.det-spec-valor { color:var(--text); font-weight:400; text-align:right; }

.det-nota {
  margin:28px 0 0;
  font-family:var(--f-poetico);
  font-size:var(--fs-h-sm); line-height:1.7;
  color:var(--rosado); opacity:0.8;
}


/* ── Responsivo (Acessório) ── */
@media (max-width:1023px) {
  .como-funciona { padding:72px var(--sp-card-sm); }
  .passos-flow { grid-template-columns:1fr; gap:24px; margin-top:var(--sp-card-sm); }
  .passo { padding:32px 28px 28px; }
  .passo-num { font-size:34px; margin-bottom:16px; }

  .detalhes { padding:72px var(--sp-card-sm); }
  .detalhes-in { grid-template-columns:1fr; gap:var(--sp-card-md); }
  .det-visual { aspect-ratio:4/5; width:100%; max-width:520px; margin:0 auto; }
}

@media (max-width:599px) {
  .como-funciona { padding:var(--sp-card-lg) 20px; }
  .passos-flow { gap:18px; }
  .passo { padding:24px 20px 22px; }
  .passo-num { font-size:30px; margin-bottom:12px; }
  .passo-tit { font-size:15px; }
  .passo-desc { font-size:var(--fs-corpo-sm); }

  .detalhes { padding:var(--sp-card-lg) 20px; }
  .detalhes-in { gap:36px; }
  .det-corpo { font-size:var(--fs-corpo-sm); }
  .det-especificacoes { margin-top:32px; }
  .det-spec-item { font-size:var(--fs-corpo-sm); padding:10px 0; gap:16px; }
  .det-nota { font-size:var(--fs-lead); margin-top:24px; }
}
