/* ===============================================
   COMPORTAMENTO DE ROLAGEM SUAVE E CENTRALIZAÇÃO
   (Carrossel de Produtos Exclusivos)
   =============================================== */
#carouselProdutos {
  scroll-snap-type: x mandatory;
}

#carouselProdutos > div {
  scroll-snap-align: center;
}

/* ===============================================
   EFEITO DE ZOOM SUAVE (Ken Burns Effect)
   (Carrossel Principal)
   =============================================== */
@keyframes zoomIn {
  from {
    transform: scale(1);
  }
  to {
    transform: scale(1.08);
  }
}

.zoom-active {
  animation: zoomIn 6s ease-in-out forwards;
}

/* ===============================================
   ANIMAÇÃO DO MENU MOBILE
   =============================================== */
@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.animate-slide-down {
  animation: slideDown 0.3s ease forwards;
}

/* ===============================================
   FOOTER
   =============================================== */
footer .payment-card {
  width: 4rem; /* igual a w-16 */
  height: 3rem; /* igual a h-12 */
  background: #fff;
  border: 1px solid rgba(255, 255, 255, 0.95); /* borda mínima */
  border-radius: 0.375rem; /* igual ao rounded-md */
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08); /* sombra suave */
  transition: transform 0.2s ease;
}
footer .payment-card:hover {
  transform: scale(1.05);
}
footer .payment-card img {
  max-width: 70%;
  max-height: 90%;
  object-fit: contain;
}

/* ============================
   ÍCONES SOCIAIS — ANIMAÇÕES
   ============================ */

/* Transições gerais */
footer a img {
  transition: transform 0.25s ease, filter 0.25s ease;
}

/* Efeito hover (desktop) */
footer a:hover img {
  transform: scale(1.15) translateY(-2px);
  filter: drop-shadow(0 0 6px rgba(255, 255, 255, 0.4));
}

/* Brilho por rede */
footer a[aria-label='Instagram']:hover img {
  filter: drop-shadow(0 0 6px rgba(255, 0, 128, 0.6));
}

footer a[aria-label='Facebook']:hover img {
  filter: drop-shadow(0 0 6px rgba(59, 89, 152, 0.6));
}

footer a[aria-label='WhatsApp']:hover img {
  filter: drop-shadow(0 0 6px rgba(37, 211, 102, 0.6));
}

/* Efeito mobile (animação contínua) */
@media (hover: none) and (pointer: coarse) {
  footer a img {
    animation: pulse-icons 2.8s ease-in-out infinite alternate;
  }
}

@keyframes pulse-icons {
  0% {
    transform: scale(1);
    filter: brightness(1);
  }
  100% {
    transform: scale(1.08);
    filter: brightness(1.15);
  }
}

/* ===============================================
   ZOOM INTERATIVO — PRODUTOS EXCLUSIVOS
   (Desktop: clique / Mobile: segurar)
   =============================================== */

/* Fundo escurecido quando o zoom está ativo */
.zoom-fundo {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.65);
  backdrop-filter: blur(3px);
  z-index: 40;
  opacity: 0;
  animation: fadeIn 0.3s ease forwards;
}

/* Animação de fade suave do fundo */
@keyframes fadeIn {
  to {
    opacity: 1;
  }
}

/* Produto ampliado */
#carouselProdutos > div.zoom-ativo {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(1.1);
  z-index: 50;
  width: auto;
  max-width: 95vw;
  background: #fff;
  border-radius: 1rem;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.35);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  cursor: zoom-out;
}

/* Imagem dentro do zoom — ocupa a maior parte da tela */
#carouselProdutos > div.zoom-ativo img {
  border-radius: 1rem 1rem 0 0;
  height: auto;
  max-height: 85vh;
  object-fit: contain;
}

/* Legenda do produto ampliado */
#carouselProdutos > div.zoom-ativo h3 {
  font-size: 1rem;
}

/* ===============================================
   AJUSTE DE TAMANHO — ZOOM INTERATIVO (MOBILE)
   =============================================== */
@media (max-width: 768px) {
  #carouselProdutos > div.zoom-ativo {
    width: 85vw;
    transform: translate(-50%, -50%) scale(1.02);
    border-radius: 2rem; /* bordas mais suaves e modernas */
  }

  #carouselProdutos > div.zoom-ativo img {
    max-height: 68vh;
    border-radius: 2rem;
    transition: transform 0.3s ease-in-out;
  }

  /* botão de fechar */
  .zoom-close {
    top: 12px;
    right: 12px;
    width: 34px;
    height: 34px;
    font-size: 1.25rem;
  }
}

/* ===============================================
   BOTÃO DE FECHAR — ZOOM INTERATIVO
   =============================================== */
.zoom-close {
  position: absolute;
  top: 10px;
  right: 10px;
  background: rgba(0, 0, 0, 0.55);
  color: #fff;
  font-size: 1.5rem;
  border: none;
  border-radius: 50%;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 60;
  transition: all 0.25s ease;
}

.zoom-close:hover {
  background: rgba(220, 38, 38, 0.9); /* vermelho La Rose */
  transform: scale(1.1);
}

/* ===============================================
   DESCRIÇÃO DENTRO DO ZOOM — PRODUTOS EXCLUSIVOS
   =============================================== */
.zoom-descricao {
  position: absolute;
  bottom: 12px;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(255, 255, 255, 0.92);
  color: #14532d;
  font-size: 0.9rem;
  font-weight: 600;
  padding: 8px 14px;
  border-radius: 12px;
  text-align: center;
  width: 80%;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  animation: fadeInZoomDesc 0.4s ease;
}

@keyframes fadeInZoomDesc {
  from {
    opacity: 0;
    transform: translateX(-50%) translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
  }
}

@media (max-width: 768px) {
  .zoom-descricao {
    font-size: 0.8rem;
    width: 85%;
    padding: 6px 12px;
    bottom: 10px;
    border-radius: 10px;
  }
}
/* ===============================================
   TEXTO DE ORIENTAÇÃO — PRODUTOS EXCLUSIVOS
   ("Toque ou clique sobre o produto...")
   =============================================== */
.orientacao-produtos {
  text-align: center;
  font-size: 1rem; /* mais legível */
  color: #14532d; /* verde elegante La Rose */
  font-weight: 500;
  letter-spacing: 0.3px;
  margin-bottom: 2.5rem;
  animation: fadeInText 0.8s ease-in-out forwards;
}

/* Destaques sutis nas palavras importantes */
.orientacao-produtos span {
  color: #dc2626; /* vermelho La Rose */
  font-weight: 600;
  position: relative;
  display: inline-block;
}

/* Efeito de brilho suave correndo */
.orientacao-produtos span::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.65), transparent);
  animation: brilho 3s infinite;
}

/* Brilho em loop */
@keyframes brilho {
  0% {
    left: -100%;
  }
  50% {
    left: 100%;
  }
  100% {
    left: 100%;
  }
}

/* Fade-in suave do texto */
@keyframes fadeInText {
  from {
    opacity: 0;
    transform: translateY(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Ajuste para telas menores */
@media (max-width: 768px) {
  .orientacao-produtos {
    font-size: 0.95rem;
    padding: 0 1rem;
  }
}
/* ===============================================
   BOTÃO "VOLTAR AO TOPO" — CENTRALIZADO
   =============================================== */
#scrollTop {
  position: fixed;
  bottom: 3rem;
  left: 50%;
  transform: translateX(-50%);
  background: #dc2626;
  color: #fff;
  border: none;
  border-radius: 9999px;
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.25);
  z-index: 60;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease, transform 0.3s ease, background-color 0.3s ease;
}

#scrollTop:not(.hidden) {
  opacity: 1;
  pointer-events: all;
  animation: floatUpDown 2.5s ease-in-out infinite;
}

#scrollTop:hover {
  transform: translateX(-50%) scale(1.1);
  background: #b91c1c;
}

@keyframes floatUpDown {
  0%,
  100% {
    transform: translateX(-50%) translateY(0);
  }
  50% {
    transform: translateX(-50%) translateY(-6px);
  }
}

@media (max-width: 768px) {
  #scrollTop {
    bottom: 2rem;
    width: 48px;
    height: 48px;
  }
}

/* ===========================
   paleta & tokens (comentários em minúsculas)
   =========================== */
:root{
  --brand-50:#f6fbf7;
  --brand-100:#eaf7ef;
  --brand-200:#d6efdf;
  --brand-300:#bce2cc;
  --brand-400:#8ed4ad;
  --brand-500:#57b986;
  --brand-600:#2f9466;
  --brand-700:#1f7a52;
  --brand-800:#0b3b22;
  --brand-900:#052e16;
  --accent:#dc2626;
  --neutral-0:#ffffff;
  --neutral-50:#f9fafb;
  --neutral-100:#f3f4f6;
  --neutral-200:#e5e7eb;
  --neutral-700:#374151;
  --neutral-800:#1f2937;
  --neutral-900:#111827;
  --fs-xs: clamp(.78rem,.76rem + .1vw,.82rem);
  --fs-sm: clamp(.9rem,.88rem + .1vw,.95rem);
  --fs-md: clamp(1rem,.98rem + .2vw,1.06rem);
  --fs-lg: clamp(1.125rem,1.05rem + .45vw,1.35rem);
  --fs-xl: clamp(1.35rem,1.2rem + .7vw,1.7rem);
  --fs-2xl: clamp(1.7rem,1.45rem + 1.2vw,2.2rem);
  --lh: 1.55;
  --sp-1:.25rem; --sp-2:.5rem; --sp-3:.75rem; --sp-4:1rem; --sp-5:1.25rem;
  --sp-6:1.5rem; --sp-8:2rem; --sp-10:2.5rem; --sp-12:3rem;
  --radius:14px; --radius-lg:20px;
  --shadow-sm: 0 2px 10px rgba(0,0,0,.06);
  --shadow-md: 0 8px 24px rgba(0,0,0,.10);
  --shadow-lg: 0 18px 40px rgba(0,0,0,.14);
  --ease: cubic-bezier(.2,.8,.2,1);
  --t-fast:.18s var(--ease);
  --t-base:.28s var(--ease);
}

/* ===========================
   base global (comentário em minúsculas)
   =========================== */
html{ scroll-behavior:smooth; }
body, body.bg-gray-50{
  background: var(--brand-50) !important;
  color: var(--neutral-800);
  font-size: var(--fs-md);
  line-height: var(--lh);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* containers e seções (comentário em minúsculas) */
.util-container{ max-width:1280px; margin:0 auto; padding-inline: var(--sp-6); }
.util-section{ padding: var(--sp-12) 0; }
.util-section--alt{ padding: var(--sp-12) 0; background: linear-gradient(180deg,var(--brand-50),#fff); }

/* títulos (comentário em minúsculas) */
.ui-h1{ font-size: var(--fs-2xl); font-weight:800; letter-spacing:-.02em; }
.ui-h2{ font-size: var(--fs-xl); font-weight:700; letter-spacing:-.01em; }
.ui-lead{ font-size: var(--fs-lg); color: var(--neutral-700); }

/* navbar premium (comentário em minúsculas) */
header{
  background: rgba(11,59,34,.97);
  color:#fff;
  border-bottom:1px solid rgba(255,255,255,.28);
  transition: background-color var(--t-base), color var(--t-base), border-color var(--t-base), box-shadow var(--t-base);
}
@supports ((backdrop-filter: blur(6px)) or (-webkit-backdrop-filter: blur(6px))){
  header{ -webkit-backdrop-filter:saturate(120%) blur(6px); backdrop-filter:saturate(120%) blur(6px); }
}
header.shadow-lg, header.is-scrolled{
  background: var(--neutral-0) !important;
  color: var(--brand-800) !important;
  border-bottom-color: rgba(0,0,0,.06) !important;
  box-shadow: var(--shadow-md) !important;
}
header a{
  color: currentColor; text-decoration:none; opacity:.95;
  font-weight:500; font-size: var(--fs-sm);
  transition: opacity var(--t-fast), color var(--t-fast), transform var(--t-fast);
  position: relative;
}
header a:hover{ opacity:1; transform: translateY(-1px); }
header .nav-link::after{
  content:""; position:absolute; left:0; bottom:-6px; height:2px; width:0;
  background: currentColor; transition: width var(--t-fast);
}
header .nav-link:hover::after{ width:100%; }

/* botão delivery premium (comentário em minúsculas) */
.cta-delivery{
  display:inline-flex; align-items:center; justify-content:center; gap:.5ch;
  padding:.65rem 1rem; border-radius:999px; font-weight:800;
  background: var(--accent); color:#fff; border:2px solid transparent;
  box-shadow: var(--shadow-sm);
  transition: background-color var(--t-fast), color var(--t-fast), border-color var(--t-fast), box-shadow var(--t-fast), transform var(--t-fast);
}
.cta-delivery:active{ transform: translateY(1px); }
header.shadow-lg .cta-delivery, header.is-scrolled .cta-delivery{
  background:#fff; color: var(--accent); border-color: var(--accent);
}
header.shadow-lg .cta-delivery:hover, header.is-scrolled .cta-delivery:hover{
  background: var(--accent); color:#fff;
}

/* hero overlay para legibilidade (comentário em minúsculas) */
.hero-overlay{
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.15) 40%, rgba(0,0,0,0) 65%),
              linear-gradient(0deg, rgba(0,0,0,.25), rgba(0,0,0,0));
  pointer-events:none;
}
.hero-title{ color:#fff; text-shadow: 0 2px 8px rgba(0,0,0,.35); }

/* cards premium (comentário em minúsculas) */
.ui-card{
  position:relative;
  background: rgba(255,255,255,.9);
  border:1px solid var(--neutral-100);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  transition: transform var(--t-fast), box-shadow var(--t-fast), border-color var(--t-fast), background-color var(--t-fast);
}
.ui-card:hover{ transform: translateY(-2px); box-shadow: var(--shadow-md); }
.ui-card__media{ position:relative; overflow:hidden; border-top-left-radius: var(--radius); border-top-right-radius: var(--radius); }
.ui-card__media img{ display:block; width:100%; height:auto; transform: scale(1.001); transition: transform .6s var(--ease); }
.ui-card:hover .ui-card__media img{ transform: scale(1.045); }
.ui-card__body{ padding: var(--sp-5); }

/* badge (comentário em minúsculas) */
.ui-badge{
  display:inline-flex; align-items:center; gap:.4ch;
  background: var(--brand-100); color: var(--brand-800);
  border:1px solid var(--brand-200);
  padding:.3rem .6rem; border-radius:999px; font-size: var(--fs-xs); font-weight:700;
}

/* botões secundários (comentário em minúsculas) */
.ui-btn{ display:inline-flex; align-items:center; justify-content:center; gap:.5ch;
  padding:.65rem 1rem; border-radius:999px; font-weight:800; border:2px solid transparent;
  transition: transform var(--t-fast), box-shadow var(--t-fast), background-color var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}
.ui-btn:active{ transform: translateY(1px); }
.ui-btn--ghost{ background:transparent; color:var(--brand-800); }
.ui-btn--outline{ background:transparent; color:var(--brand-800); border-color:var(--brand-800); }
.ui-btn--success{ background:var(--brand-700); color:#fff; }

/* skeleton loader (comentário em minúsculas) */
.skeleton{ position:relative; overflow:hidden; background: var(--neutral-100); }
.skeleton::after{
  content:""; position:absolute; inset:0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.5), transparent);
  transform: translateX(-100%); animation: shine 1.2s infinite;
}
@keyframes shine{ to{ transform: translateX(100%); } }

/* reveal on scroll (comentário em minúsculas) */
.reveal{ opacity:0; transform: translateY(12px); transition: opacity .6s var(--ease), transform .6s var(--ease); }
.reveal.is-in{ opacity:1; transform: translateY(0); }

/* footer premium (comentário em minúsculas) */
.site-footer{ background: linear-gradient(180deg, var(--brand-800), var(--brand-900)); color:#fff; }

/* foco visível (comentário em minúsculas) */
a:focus-visible, button:focus-visible{ outline:3px solid #34d399; outline-offset:2px; }

/* motion-safe (comentário em minúsculas) */
@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; scroll-behavior:auto !important; }
}

/* hover dos botões do carrossel (comentário em minúsculas) */
#prev:hover, #next:hover{ background-color: rgba(11,59,34,.85) !important; }

/* ===========================
   correções mobile do menu (comentários em minúsculas)
   =========================== */
/* coloca o menu mobile logo abaixo do header e cobre a largura toda */
#mobile-menu{
  position: absolute;
  left: 0; right: 0; top: 100%;
  background: var(--brand-800);
  color: #fff;
  z-index: 40;
  /* garante que o conteúdo por trás não vaze nas bordas */
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  box-shadow: var(--shadow-md);
}

/* links do menu mobile sempre brancos para alto contraste */
#mobile-menu .nav-link{ color:#fff; opacity:.95; }
#mobile-menu .nav-link:hover{ opacity:1; }

/* botão delivery dentro do menu mobile em versão clara */
#mobile-menu .cta-delivery{
  background:#fff; color: var(--accent); border-color: var(--accent);
  width: 100%;
}

/* quando o menu está aberto, forçamos o header a ficar verde para coerência */
header.menu-open{
  background: rgba(11,59,34,.97) !important;
  color:#fff !important;
  border-bottom-color: rgba(255,255,255,.28) !important;
  box-shadow: none !important;
}

/* ícone do botão (hamburger) herda a cor do header; aqui garantimos contraste */
#menu-btn{ color: currentColor; }
#menu-btn svg{ stroke: currentColor; }


/* reforço de especificidade para estado aberto no mobile (comentários em minúsculas) */
header.menu-open,
header.menu-open.shadow-lg,
header.menu-open.is-scrolled{
  background: rgba(11,59,34,.97) !important;
  color:#fff !important;
  border-bottom-color: rgba(255,255,255,.28) !important;
  box-shadow: none !important;
}
/* links e ícone do toggle sempre brancos com menu aberto */
header.menu-open a{ color:#fff !important; }
header.menu-open #menu-btn{ color:#fff !important; }
header.menu-open #menu-btn svg{ stroke:#fff !important; }


