/* ==========================================================
   GRANATO JOIAS — COMPONENTS
   Footer + Componentes reutilizáveis de ecommerce
   ========================================================== */

/* ----------------------------------------------------------
   FOOTER TOKENS (locais — não expor no :root global)
---------------------------------------------------------- */
:root {
  --footer-bg:       #4A0E16;
  --footer-bg-mid:   #3D0B12;
  --footer-bg-deep:  #2D0A0E;
  --footer-gold:     #D8BD67;
  --footer-cream:    #EEDEC4;
  --footer-muted:    rgba(238,222,196,0.45);
  --footer-border:   rgba(238,222,196,0.12);
  --footer-border-s: rgba(238,222,196,0.07);
}

/* ==========================================================
   FOOTER
   ========================================================== */

.site-footer {
  background: var(--footer-bg);
  margin-top: var(--sp-20);
  color: var(--footer-cream);
}

/* Quando a última seção antes do footer é escura (vinho),
   elimina o gap de margin-top para que não apareça espaço
   branco entre os dois fundos escuros. O padding interno
   do footer já garante o respiro adequado.
   NÃO afeta a home, cujo último bloco é .section--trust-bar (creme). */
.section--dark + .site-footer {
  margin-top: 0;
}

/* ----------------------------------------------------------
   TOPO: Brand + Colunas
---------------------------------------------------------- */
.footer__top {
  padding-block: var(--sp-20) var(--sp-16);
  border-bottom: 1px solid var(--footer-border);
}

/* Brand — logo centralizada mobile */
.footer__brand {
  text-align: center;
  margin-bottom: var(--sp-10);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-4);
}

.footer__logo-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  opacity: 0.88;
  transition: opacity var(--dur-base) ease;
}
.footer__logo-link:hover { opacity: 1; }

.footer__logo-img {
  height: 44px;
  width: auto;
  max-width: 200px;
  object-fit: contain;
  filter: brightness(0) invert(1) sepia(1) saturate(0.3) brightness(1.1);
}
.footer__logo-text {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: var(--fw-light);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--footer-cream);
}

.footer__tagline {
  font-size: var(--text-sm);
  color: var(--footer-muted);
  letter-spacing: 0.04em;
  line-height: var(--lh-loose);
}

/* Social */
.footer__social {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-3);
}
.footer__social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px; height: 44px;
  border: 1px solid var(--footer-border);
  border-radius: var(--radius-sm);
  color: var(--footer-muted);
  transition:
    color        var(--dur-base) ease,
    border-color var(--dur-base) ease,
    background   var(--dur-base) ease;
}
.footer__social-link:hover {
  color: var(--footer-gold);
  border-color: var(--footer-gold);
  background: rgba(216,189,103,0.08);
}
.footer__social-link svg { width: 20px; height: 20px; }

/* Desktop: brand alinha à esquerda */
@media (min-width: 1024px) {
  .footer__brand {
    text-align: left;
    align-items: flex-start;
    margin-bottom: 0;
  }
  .footer__social    { justify-content: flex-start; }
  .footer__logo-link { opacity: 0.85; }
}

/* Grid de colunas */
.footer__cols {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-8);
}
@media (min-width: 640px) {
  .footer__cols { grid-template-columns: repeat(2, 1fr); gap: var(--sp-10) var(--sp-8); }
}
@media (min-width: 1024px) {
  .footer__top > .container {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1.1fr;
    gap: var(--sp-12);
    align-items: start;
  }
  .footer__brand { margin-bottom: 0; }
  .footer__cols  { display: contents; }
}

/* ----------------------------------------------------------
   TÍTULOS DE COLUNA
---------------------------------------------------------- */
.footer__col-title {
  font-family: var(--font-body);
  font-size: var(--text-2xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--footer-gold);
  margin-bottom: var(--sp-6);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--footer-border);
}

/* ----------------------------------------------------------
   NAV LINKS
---------------------------------------------------------- */
.footer__nav {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.footer__nav-link {
  font-family: var(--font-display);
  font-size: var(--text-md);
  font-weight: var(--fw-light);
  color: var(--footer-muted);
  padding: var(--sp-3) 0;
  border-bottom: 1px solid var(--footer-border-s);
  transition:
    color     var(--t-fast),
    transform var(--dur-base) var(--ease-luxury);
  letter-spacing: -0.01em;
  display: block;
}
.footer__nav-link:last-child { border-bottom: none; }
.footer__nav-link:hover {
  color: var(--footer-cream);
  transform: translateX(var(--sp-2));
}

/* ----------------------------------------------------------
   CONTATO
---------------------------------------------------------- */
.footer__contact {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
}
.footer__contact-item {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  font-size: var(--text-sm);
  color: var(--footer-muted);
  text-decoration: none;
  line-height: var(--lh-snug);
  transition: color var(--t-fast);
}
a.footer__contact-item:hover { color: var(--footer-cream); }
.footer__contact-icon {
  width: 15px; height: 15px;
  flex-shrink: 0;
  margin-top: 2px;
  opacity: 0.6;
}

/* ----------------------------------------------------------
   FAIXA DE SEGURANÇA
---------------------------------------------------------- */
.footer__trust {
  background: var(--footer-bg-mid);
  border-block: 1px solid var(--footer-border);
  padding-block: var(--sp-5);
}
.footer__trust-items {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0;
}
.footer__trust-item {
  display: flex;
  align-items: center;
  font-size: 10px;
  font-weight: var(--fw-medium);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--footer-muted);
  white-space: nowrap;
  padding-inline: var(--sp-3);
}
.footer__trust-item + .footer__trust-item::before {
  content: "|";
  margin-right: var(--sp-3);
  opacity: 0.2;
  font-weight: var(--fw-light);
  color: var(--footer-cream);
}
.footer__trust-icon { display: none; }

/* Mobile: mostra 3 itens */
.footer__trust-item:nth-child(n+4) { display: none; }

@media (min-width: 640px) {
  .footer__trust-item:nth-child(n+4) { display: flex; }
  .footer__trust-item { font-size: var(--text-2xs); padding-inline: var(--sp-4); }
}

/* ----------------------------------------------------------
   FAIXA DE SELOS + DADOS LEGAIS
---------------------------------------------------------- */
.footer__seals-bar {
  background: var(--footer-bg-deep);
  padding-block: var(--sp-5);
  border-bottom: 1px solid var(--footer-border-s);
}
.footer__seals-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-4);
  text-align: center;
}
@media (min-width: 768px) {
  .footer__seals-inner {
    flex-direction: row;
    justify-content: space-between;
    text-align: left;
  }
}
.footer__seals {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  flex-wrap: wrap;
  justify-content: center;
}
.footer__seal-img {
  height: 32px;
  width: auto;
  opacity: 0.55;
  filter: grayscale(30%) brightness(1.4);
  transition:
    opacity var(--dur-base) ease,
    filter  var(--dur-base) ease;
}
.footer__seal-img:hover {
  opacity: 0.85;
  filter: grayscale(0%) brightness(1.2);
}
.footer__legal-data {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--text-xs);
  color: rgba(238,222,196,0.30);
  letter-spacing: 0.02em;
  justify-content: center;
}
@media (min-width: 768px) {
  .footer__legal-data { justify-content: flex-end; }
}
.footer__legal-sep {
  opacity: 0.35;
  color: var(--footer-muted);
}

/* ----------------------------------------------------------
   LINHA FINAL
---------------------------------------------------------- */
.footer__bottom {
  background: var(--footer-bg-deep);
  padding-block: var(--sp-4);
}
.footer__bottom-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-2);
  text-align: center;
}
@media (min-width: 768px) {
  .footer__bottom-inner {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    text-align: left;
  }
}
.footer__bottom-text {
  font-size: var(--text-xs);
  color: rgba(238,222,196,0.28);
  letter-spacing: 0.02em;
  order: 1;
}
.footer__bottom-links {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  flex-wrap: wrap;
  justify-content: center;
  order: 2;
}
@media (min-width: 768px) {
  .footer__bottom-links { justify-content: flex-end; }
}
.footer__bottom-link {
  font-size: var(--text-xs);
  color: rgba(238,222,196,0.35);
  letter-spacing: 0.03em;
  transition: color var(--t-fast);
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-color: transparent;
}
.footer__bottom-link:hover {
  color: var(--footer-gold);
  text-decoration-color: var(--footer-gold);
}
.footer__bottom-last {
  font-size: var(--text-xs);
  color: rgba(238,222,196,0.28);
  letter-spacing: 0.02em;
  margin-top: 0;
  padding-top: 0;
  border-top: none;
  text-align: center;
}

/* ==========================================================
   ECOMMERCE COMPONENTS — reutilizáveis em todas as páginas
   ========================================================== */

/* ----------------------------------------------------------
   CATEGORY CARD
   Usado: home, catálogo, laterais de coleção
---------------------------------------------------------- */
.category-card {
  display: block;
  position: relative;
  text-decoration: none;
  border-radius: var(--card-radius);
  overflow: hidden;
  background: var(--c-surface);
  box-shadow: var(--shadow-xs);
  transition:
    box-shadow 520ms var(--ease-luxury),
    transform  520ms var(--ease-luxury);
}
.category-card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-4px);
}
.category-card:focus-visible {
  outline: 2px solid var(--c-gold);
  outline-offset: 2px;
  border-radius: var(--card-radius);
}

.category-card__img-wrap {
  aspect-ratio: var(--product-img-ratio);
  overflow: hidden;
  background: var(--c-gray-100);
  position: relative;
}
.category-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 700ms var(--ease-luxury);
}
.category-card:hover .category-card__img { transform: scale(1.06); }
.category-card__img-placeholder {
  width: 100%;
  height: 100%;
  background: linear-gradient(145deg, var(--c-cream-dark) 0%, var(--c-gray-100) 100%);
}

.category-card__body {
  padding: var(--card-py) var(--card-px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-2);
}
.category-card__name {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: var(--fw-regular);
  color: var(--c-dark);
  letter-spacing: -0.015em;
  line-height: 1.2;
  transition: color var(--t-base);
}
.category-card__cta {
  font-size: var(--text-2xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide);
  color: var(--c-gold-dark);
  text-transform: uppercase;
  white-space: nowrap;
  flex-shrink: 0;
  display: inline-block;
  opacity: 0.58;
  transition:
    transform var(--t-base),
    opacity   var(--t-base),
    color     var(--t-base);
}

/* ----------------------------------------------------------
   PRODUCT CARD
   Usado: catálogo, relacionados, home destaques
---------------------------------------------------------- */
.product-card {
  display: block;
  text-decoration: none;
  /* Elevação sutil no hover — leve lift, não agressivo */
  transition:
    transform  520ms var(--ease-luxury),
    box-shadow 520ms var(--ease-luxury);
}
.product-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}
.product-card:focus-visible {
  outline: 2px solid var(--c-gold);
  outline-offset: 3px;
  border-radius: var(--card-radius);
}

.product-card__img-wrap {
  aspect-ratio: var(--product-img-ratio);
  overflow: hidden;
  background: var(--c-gray-100);
  border-radius: var(--card-radius);
  margin-bottom: var(--sp-4);
  position: relative;
}
.product-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 700ms var(--ease-luxury);
}
.product-card:hover .product-card__img { transform: scale(1.05); }

/* Placeholder premium — gradiente discreto */
.product-card__img-placeholder {
  width: 100%;
  height: 100%;
  background: linear-gradient(
    145deg,
    var(--c-cream-dark)   0%,
    var(--c-gray-100)    55%,
    var(--c-cream-dark)  100%
  );
}

/* Badge — discreto, legível, não chamativo */
.product-card__badge {
  position: absolute;
  top: var(--sp-3);
  left: var(--sp-3);
  font-size: 9px;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.10em;
  text-transform: uppercase;
  padding: 4px var(--sp-3);
  background: rgba(45, 10, 14, 0.72);
  color: var(--c-cream);
  border-radius: 0;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.product-card__badge--new  {
  background: rgba(184,153,62,0.82);
  color: var(--c-dark);
}
.product-card__badge--sale {
  background: var(--c-error);
  color: var(--c-white);
}

.product-card__name {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: var(--fw-light);
  color: var(--c-dark);
  line-height: 1.25;
  letter-spacing: -0.018em;
  margin-bottom: var(--sp-2);
  transition: color var(--t-fast);
}

.product-card__price-block {
  display: flex;
  align-items: baseline;
  gap: var(--sp-2);
  flex-wrap: wrap;
  margin-top: var(--sp-1);
}
.product-card__price {
  font-size: var(--text-md);
  font-weight: var(--fw-semibold);
  color: var(--c-burgundy);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}
.product-card__price--original {
  font-size: var(--text-sm);
  font-weight: var(--fw-regular);
  color: var(--c-text-light);
  text-decoration: line-through;
}

/* ----------------------------------------------------------
   TRUST PILL
   Usado: home, product page, checkout topo
---------------------------------------------------------- */
.trust-pill {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
}
.trust-pill__icon {
  width: 26px;
  height: 26px;
  flex-shrink: 0;
  color: var(--c-gold-dark);
  stroke-width: 1.5;
  opacity: 0.85;
  margin-top: 2px;
}
.trust-pill__text {
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
}
.trust-pill__text strong {
  font-size: var(--text-base);
  font-weight: var(--fw-semibold);
  color: var(--c-dark);
  letter-spacing: -0.01em;
  line-height: 1.3;
}
.trust-pill__text span {
  font-size: var(--text-sm);
  color: var(--c-text-muted);
  line-height: 1.4;
  opacity: 0.72;
}

/* ----------------------------------------------------------
   PRICE BLOCK
   Usado: PDP, carrinho, checkout
---------------------------------------------------------- */
.price-block {
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
}
.price-block__main {
  font-size: var(--text-2xl);
  font-weight: var(--fw-semibold);
  color: var(--c-burgundy);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.price-block__original {
  font-size: var(--text-sm);
  color: var(--c-text-light);
  text-decoration: line-through;
}
.price-block__installment {
  font-size: var(--text-sm);
  color: var(--c-text-muted);
  margin-top: var(--sp-1);
}

/* ----------------------------------------------------------
   SECTION CTA
   Botão de encerramento de seção — centralizado
---------------------------------------------------------- */
.section-cta {
  text-align: center;
  margin-top: var(--sp-10);
}

/* ==========================================================
   GRANATO — ADIÇÕES PREMIUM: COMPONENTES
   Regras novas (sem equivalente nos blocos acima)
   ========================================================== */

/* Category card: overlay gradient emerge no hover */
.category-card__img-wrap::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(28, 10, 8, 0.38) 0%,
    rgba(28, 10, 8, 0.08) 42%,
    transparent           66%
  );
  opacity: 0;
  transition: opacity 520ms var(--ease-luxury);
  pointer-events: none;
  z-index: 1;
}
.category-card:hover .category-card__img-wrap::after { opacity: 1; }

/* Hover states dos elementos internos */
.category-card:hover .category-card__name { color: var(--c-burgundy); }
.category-card:hover .category-card__cta {
  transform: translateX(4px);
  opacity: 1;
  color: var(--c-burgundy);
}

/* Editorial: profundidade na imagem */
.editorial-block__img-placeholder,
.editorial-block__img {
  box-shadow: var(--shadow-lg);
}

/* Product card: hover color — elevação agora no bloco principal acima */
.product-card:hover .product-card__name { color: var(--c-burgundy); }


/* ==========================================================
   GRANATO — PÁGINAS INSTITUCIONAIS
   .hero--institutional  Herói leve para páginas internas
   .content              Prosa editorial estruturada
   ========================================================== */

/* ----------------------------------------------------------
   HERO INSTITUCIONAL
   Fundo creme suave. Header sólido (sem $is_hero).
   Proporcional e elegante — menos impacto que a home hero.
---------------------------------------------------------- */
.hero--institutional {
  padding-block: var(--sp-20) var(--sp-16);
  background:
    radial-gradient(ellipse at 70% 30%, rgba(216,189,103,0.09) 0%, transparent 55%),
    var(--c-cream-light);
  border-bottom: 1px solid var(--c-border-subtle);
  text-align: center;
}
@media (min-width: 1024px) {
  .hero--institutional {
    padding-block: var(--sp-24) var(--sp-20);
  }
}

.hero--institutional__eyebrow {
  font-size: var(--text-2xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--c-gold-dark);
  margin-bottom: var(--sp-4);
}

.hero--institutional__title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-3xl), 5vw, var(--text-5xl));
  font-weight: var(--fw-light);
  letter-spacing: -0.03em;
  line-height: 1.1;
  color: var(--c-dark);
  margin-bottom: var(--sp-5);
}

.hero--institutional__desc {
  font-size: var(--text-md);
  color: var(--c-text-muted);
  max-width: 480px;
  margin-inline: auto;
  line-height: 1.75;
}

/* ----------------------------------------------------------
   CONTEÚDO EDITORIAL — prosa estruturada
   Usado com .container.container--narrow para leitura
---------------------------------------------------------- */
.content {
  padding-block: var(--sp-16);
}
.content + .content {
  padding-top: 0;
}

.content h2 {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: var(--fw-light);
  letter-spacing: -0.025em;
  line-height: 1.2;
  color: var(--c-dark);
  margin-bottom: var(--sp-5);
  padding-top: var(--sp-6);
  border-top: 1px solid var(--c-border-subtle);
}
.content h2:first-child {
  padding-top: 0;
  border-top: none;
}

.content p {
  font-size: var(--text-base);
  line-height: 1.9;
  color: var(--c-text-muted);
  margin-bottom: var(--sp-5);
}
.content p strong {
  color: var(--c-dark);
  font-weight: var(--fw-medium);
}

.content ul,
.content ol {
  padding-left: var(--sp-5);
  margin-bottom: var(--sp-5);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.content ul li {
  list-style: none;
  position: relative;
  padding-left: var(--sp-5);
  font-size: var(--text-base);
  line-height: 1.75;
  color: var(--c-text-muted);
}
.content ul li::before {
  content: '◆';
  position: absolute;
  left: 0;
  top: 0.45em;
  font-size: 5px;
  color: var(--c-gold);
  line-height: 1;
}
.content ol {
  list-style: decimal;
  padding-left: var(--sp-6);
}
.content ol li {
  font-size: var(--text-base);
  line-height: 1.75;
  color: var(--c-text-muted);
  padding-left: var(--sp-2);
}
.content ol li::marker {
  color: var(--c-gold-dark);
  font-weight: var(--fw-semibold);
  font-size: var(--text-sm);
}

/* Nota / destaque leve — citação interna */
.content__note {
  border-left: 2px solid var(--c-gold);
  padding: var(--sp-4) var(--sp-6);
  background: var(--c-cream-light);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  margin-block: var(--sp-6);
}
.content__note p {
  margin-bottom: 0;
  font-size: var(--text-sm);
  color: var(--c-text-muted);
  line-height: 1.7;
}

/* ----------------------------------------------------------
   SEÇÃO FINAL DE CONFIANÇA — igual à home
   Reutiliza .section--dark + .trust-row existentes
   Aqui apenas o CTA específico de páginas institucionais
---------------------------------------------------------- */
.institutional-cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-4);
  justify-content: center;
  margin-top: var(--sp-8);
}


/* ==========================================================
   GRANATO — HOME COMPONENTS
   cat-cover-card, testimonial-card, instagram-grid,
   product-card home extras
   ========================================================== */

/* ----------------------------------------------------------
   CAT COVER CARD — imagem full, texto sobreposto no inferior
---------------------------------------------------------- */
.cat-cover-card {
  position: relative;
  display: block;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  text-decoration: none;
  background: var(--c-gray-100);
}

/* Skeleton state antes da API responder */
.cat-cover-card--skeleton {
  pointer-events: none;
}

.cat-cover-card__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 720ms var(--ease-luxury);
}
.cat-cover-card:hover .cat-cover-card__img {
  transform: scale(1.06);
}

/* Placeholder para categorias sem cover_url */
.cat-cover-card__placeholder {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    145deg,
    var(--c-burgundy-dark) 0%,
    #3D1015              50%,
    var(--c-burgundy)    100%
  );
}

/* Overlay: gradiente de baixo ancora o nome da categoria */
.cat-cover-card__overlay {
  position: absolute;
  inset: 0;
  /* Dois layers: base escura + vinheta lateral para profundidade */
  background:
    linear-gradient(
      to top,
      rgba(10, 3, 2, 0.80) 0%,
      rgba(10, 3, 2, 0.28) 35%,
      rgba(10, 3, 2, 0.05) 58%,
      transparent           75%
    ),
    linear-gradient(
      to right,
      rgba(10, 3, 2, 0.18) 0%,
      transparent           50%
    );
  transition: opacity 560ms var(--ease-luxury);
}
.cat-cover-card:hover .cat-cover-card__overlay {
  opacity: 0.92;
}

.cat-cover-card__content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--sp-6) var(--sp-5) var(--sp-5);
  z-index: 2;
  transition: transform 480ms var(--ease-luxury);
}
@media (min-width: 768px) {
  .cat-cover-card__content { padding: var(--sp-7) var(--sp-6) var(--sp-6); }
}
/* Conteúdo sobe levemente no hover */
.cat-cover-card:hover .cat-cover-card__content {
  transform: translateY(-4px);
}

.cat-cover-card__count {
  display: block;
  font-size: var(--text-2xs);
  font-weight: var(--fw-regular);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: rgba(216,189,103,0.55);
  margin-bottom: var(--sp-2);
  opacity: 0;
  transition: opacity var(--t-base);
}
.cat-cover-card:hover .cat-cover-card__count { opacity: 1; }

.cat-cover-card__name {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: var(--fw-light);
  color: var(--c-cream);
  letter-spacing: -0.025em;
  line-height: 1.12;
  transition: color 360ms var(--ease-luxury);
}
@media (min-width: 768px) {
  .cat-cover-card__name { font-size: clamp(var(--text-xl), 2.2vw, var(--text-2xl)); }
}
.cat-cover-card:hover .cat-cover-card__name {
  color: var(--c-gold-light);
}

/* ----------------------------------------------------------
   PRODUCT CARD — adições para home (freeship badge)
---------------------------------------------------------- */
.product-card__info {
  padding-top: var(--sp-4);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}

.product-card__freeship {
  font-size: var(--text-2xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--c-success);
  margin-top: var(--sp-1);
}

/* ----------------------------------------------------------
   TESTIMONIAL CARD
---------------------------------------------------------- */
.testimonial-card {
  background: var(--c-surface);
  border-top: 1px solid var(--c-border-subtle);
  padding: var(--sp-8) var(--sp-6);
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  transition: border-color var(--t-slow);
}
.testimonial-card:hover {
  border-color: var(--c-gold-dark);
}

.testimonial-card__stars {
  display: flex;
  gap: 3px;
  color: var(--c-gold);
}

.testimonial-card__quote {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: var(--fw-light);
  font-style: italic;
  color: var(--c-dark);
  line-height: 1.72;
  letter-spacing: -0.01em;
  flex: 1;
  margin: 0;
}
.testimonial-card__quote::before {
  content: '\201C';
  color: var(--c-gold);
  font-size: var(--text-3xl);
  line-height: 0;
  vertical-align: -0.42em;
  margin-right: 3px;
  opacity: 0.55;
}

.testimonial-card__author {
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--c-dark);
  letter-spacing: 0.01em;
  margin-top: var(--sp-2);
}
.testimonial-card__location {
  font-size: var(--text-xs);
  color: var(--c-text-light);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

/* ----------------------------------------------------------
   INSTAGRAM GRID ITEMS
---------------------------------------------------------- */
.instagram-grid__item {
  aspect-ratio: 1 / 1;
  overflow: hidden;
  position: relative;
  background: var(--c-gray-100);
}
.instagram-grid__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition:
    transform 700ms var(--ease-luxury),
    filter    500ms ease;
  filter: saturate(0.75) brightness(0.95);
}
.instagram-grid__item:hover .instagram-grid__img {
  transform: scale(1.08);
  filter: saturate(1) brightness(1.02);
}
.instagram-grid__placeholder {
  width: 100%;
  height: 100%;
  background: linear-gradient(
    135deg,
    var(--c-cream-dark) 0%,
    var(--c-gray-200)  50%,
    var(--c-cream-dark) 100%
  );
}


/* ==========================================================
   GRANATO — PÁGINA DE CONTATO
   contact-channel-card, contact-address-block,
   contact-socials, contact-form
   ========================================================== */

/* ----------------------------------------------------------
   CHANNEL CARDS — WhatsApp / E-mail / Horário
---------------------------------------------------------- */
.contact-channels {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
}
@media (min-width: 640px) {
  .contact-channels { grid-template-columns: repeat(3, 1fr); }
}

.contact-channel-card {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-5);
  padding: var(--sp-7) var(--sp-6);
  background: var(--c-surface);
  border: 1px solid var(--c-border-subtle);
  border-radius: var(--radius-sm);
  text-decoration: none;
  transition:
    border-color var(--t-base),
    box-shadow   var(--t-base),
    transform    var(--t-slow);
}
.contact-channel-card:not(.contact-channel-card--static):hover {
  border-color: var(--c-gold-dark);
  box-shadow: var(--shadow-sm);
  transform: translateY(-2px);
}

.contact-channel-card__icon {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-sm);
  background: var(--c-cream-light);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--c-burgundy);
  transition: background var(--t-base);
}
.contact-channel-card__icon svg { width: 20px; height: 20px; }

/* WhatsApp: ícone mais caloroso */
.contact-channel-card__icon--wpp {
  background: rgba(37,211,102,0.08);
  color: #128C7E;
}
.contact-channel-card:hover .contact-channel-card__icon--wpp {
  background: rgba(37,211,102,0.14);
}

.contact-channel-card__body {
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
  min-width: 0;
}

.contact-channel-card__label {
  font-size: var(--text-2xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--c-text-muted);
}

.contact-channel-card__value {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: var(--fw-light);
  color: var(--c-dark);
  letter-spacing: -0.01em;
  line-height: 1.25;
  overflow-wrap: anywhere;
}
.contact-channel-card__value--hours {
  font-size: var(--text-base);
  font-family: var(--font-body);
  line-height: 1.65;
  letter-spacing: 0;
}

.contact-channel-card__cta {
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  letter-spacing: 0.04em;
  color: var(--c-burgundy);
  margin-top: var(--sp-2);
  opacity: 0;
  transition: opacity var(--t-base);
}
.contact-channel-card:hover .contact-channel-card__cta { opacity: 1; }

/* ----------------------------------------------------------
   ADDRESS BLOCK — layout editorial
---------------------------------------------------------- */
.contact-address-block {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-10);
}
@media (min-width: 768px) {
  .contact-address-block {
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-16);
    align-items: start;
  }
}

.contact-address-block__title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: var(--fw-light);
  letter-spacing: -0.025em;
  color: var(--c-dark);
  margin-block: var(--sp-3) var(--sp-5);
}

.contact-address-block__addr {
  font-size: var(--text-base);
  line-height: 1.9;
  color: var(--c-text-muted);
}

.contact-address-detail {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  font-size: var(--text-sm);
  color: var(--c-text-muted);
  line-height: 1.65;
  padding: var(--sp-4) 0;
  border-bottom: 1px solid var(--c-border-subtle);
}
.contact-address-detail:last-child { border-bottom: none; }
.contact-address-detail svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  margin-top: 2px;
  color: var(--c-gold-dark);
  opacity: 0.8;
}

/* ----------------------------------------------------------
   SOCIAL LINKS
---------------------------------------------------------- */
.contact-socials {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-4);
  justify-content: center;
  margin-top: var(--sp-8);
}

.contact-social-link {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-6);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-sm);
  text-decoration: none;
  color: var(--c-text);
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  letter-spacing: 0.03em;
  transition:
    border-color var(--t-base),
    color        var(--t-base),
    background   var(--t-base);
}
.contact-social-link svg { width: 18px; height: 18px; flex-shrink: 0; }
.contact-social-link:hover {
  border-color: var(--c-burgundy);
  color: var(--c-burgundy);
  background: rgba(74,14,22,0.03);
}

/* ----------------------------------------------------------
   CONTACT FORM
---------------------------------------------------------- */
.contact-form {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
}

.contact-form__row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5);
}
@media (min-width: 640px) {
  .contact-form__row { grid-template-columns: 1fr 1fr; }
}

.contact-form__field {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}

.contact-form__label {
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--c-text-muted);
}

.contact-form__input {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--c-dark);
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: 0;
  padding: var(--sp-4) var(--sp-5);
  line-height: 1.5;
  transition:
    border-color var(--t-base),
    box-shadow   var(--t-base);
  -webkit-appearance: none;
  appearance: none;
}
.contact-form__input::placeholder { color: var(--c-text-light); }
.contact-form__input:focus {
  outline: none;
  border-color: var(--c-burgundy);
  box-shadow: 0 0 0 3px rgba(74,14,22,0.06);
}

.contact-form__select {
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%237A6350' stroke-width='1.5' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--sp-4) center;
  padding-right: var(--sp-10);
}

.contact-form__textarea {
  resize: vertical;
  min-height: 140px;
}

.contact-form__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-top: var(--sp-2);
}

.contact-form__wpp-btn {
  flex: 1;
  min-width: 200px;
}
.contact-form__submit-btn {
  flex-shrink: 0;
}

.contact-form__feedback {
  font-size: var(--text-sm);
  color: var(--c-text-muted);
  min-height: 1.4em;
  padding: var(--sp-2) 0;
  line-height: 1.6;
}
.contact-form__feedback--success { color: var(--c-success); }
.contact-form__feedback--error   { color: var(--c-error);   }


/* -- Categoria no card de produto (catálogo) */
.product-card__category {
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--c-text-light);
  margin-bottom: var(--sp-1);
  cursor: pointer;
  transition: color var(--t-fast);
}
.product-card__category:hover { color: var(--c-burgundy); }
