/* GapStoreAll — visual moderno e feminino */

/* =========================
   Variáveis / Paleta
   ========================= */
:root {
  --color-bg: #fff6fb;          /* rosa sólido do site */
  --color-primary: #ff5aa5;
  --color-accent: #ff8fc8;
  --color-text: #2a2432;
  --color-muted: #7a6b80;
  --color-card: #ffffffcc;
  --color-border: #f6cfe2;

  --radius-lg: 18px;
  --radius-md: 14px;

  --shadow-sm: 0 6px 16px rgba(255, 90, 165, .12);
  --shadow-md: 0 18px 40px rgba(42,36,50,.12);

  --transition: .25s ease;

  --font-title: "Poppins", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --font-body: "Inter", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  /* para bordas/halo discretos */
  --holo-iris-1: #ff4da6;
  --holo-iris-2: #8a7bff;
  --holo-iris-3: #58e6ff;
  --holo-iris-4: #ffd166;

  /* superfície rosa suave para cartões (derivada da paleta) */
  --color-surface-pink: color-mix(in oklab, var(--color-primary) 10%, #fff);
}

/* ===== Base ===== */
* { box-sizing: border-box; }
html, body { height: 100%; }

/* FUNDO SÓLIDO — aplicado globalmente */
html,
body {
  margin: 0;
  font-family: var(--font-body);
  line-height: 1.6;
  color: var(--color-text);
  background: var(--color-bg) !important; /* força rosa sólido */
  font-size: 18px; /* aumento global de fonte */
}

/* Reforço do fundo sólido em wrappers comuns do WP */
.site,
.site-content,
.content-area,
#content,
main,
.site-main,
.wp-site-blocks,
.front-page,
.home,
.page,
.page-template-default {
  background: var(--color-bg) !important;
}

/* ===== Acessibilidade ===== */
.visually-hidden {
  position: absolute !important;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  white-space: nowrap;
}

/* Compatível com o padrão WP (.screen-reader-text) */
.screen-reader-text {
  position: absolute;
  left: -10000px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}
.screen-reader-text:focus {
  position: static;
  width: auto;
  height: auto;
  margin: 0.5rem;
  padding: 0.6rem 0.8rem;
  background: #fff;
  border-radius: 10px;
  box-shadow: var(--shadow-sm);
  z-index: 999;
}

/* Skip link visível ao foco */
.skip-link {
  position: absolute;
  left: -9999px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}
.skip-link:focus {
  position: fixed;
  left: 1rem;
  top: 1rem;
  width: auto;
  height: auto;
  padding: .6rem .8rem;
  background: #fff;
  border-radius: 10px;
  box-shadow: var(--shadow-sm);
  z-index: 999;
}

.container { width: min(1120px, 92%); margin-inline: auto; }

/* Permite “transpassar a tela” com segurança apenas do conteúdo */
.container,
.header-inner,
.footer-inner,
.produtos,
.legais {
  position: relative;
  overflow: visible;
}

/* ===== Header / Footer — fundo sólido rosa ===== */
.header-inner,
.footer-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .85rem 0;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--color-bg);          /* sólido */
  border-bottom: 1px solid var(--color-border);
  transition: box-shadow var(--transition), background var(--transition);
}
.site-header.is-scrolled { box-shadow: 0 10px 28px rgba(42, 36, 50, .07); }

.site-footer {
  background: var(--color-bg);          /* sólido */
  border-top: 1px solid var(--color-border);
  color: var(--color-muted);
  padding: 1.2rem 0;
  font-size: 1rem;
}

/* Marca (logo ou texto) */
.brand {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  text-decoration: none;
}
.brand img {
  display: block;
  height: auto;
  max-height: 48px;
  width: auto;
}
.brand__text {
  font-family: var(--font-title);
  font-weight: 700;
  font-size: 1.2rem;
  color: var(--color-text);
}

/* ===== Redes sociais no header ===== */
.header-social {
  display: flex;
  align-items: center;
  gap: .75rem;
}
.header-social .social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 38px;
  width: 38px;
  border-radius: 50%;
  color: var(--color-primary);
  background: #fff;
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition), box-shadow var(--transition), color var(--transition), background var(--transition);
}
.header-social .social-link:hover {
  color: #fff;
  background: linear-gradient(92deg, var(--color-primary), var(--color-accent));
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
.header-social .social-link:focus-visible { outline: 2px solid #ffb6d8; outline-offset: 2px; }
.header-social .social-link svg { width: 20px; height: 20px; display: block; }

/* (legado) */
.social a { color: var(--color-accent); opacity: .9; transition: opacity var(--transition), transform var(--transition); }
.social a:hover { opacity: 1; transform: translateY(-2px); }

/* ===== Hero ===== */
.hero { min-height: 56px; }

/* === HERO CONTENT (Front-page destaque) === */
.hero-content{
  text-align:center;
  max-width:720px;
  margin: 3rem auto 1.5rem;
  padding: 2rem 1rem 0;
}
.hero-content h1{
  font-family:var(--font-title);
  font-weight:700;
  font-size: clamp(1.9rem, 1.2rem + 1.6vw, 2.4rem);
  line-height:1.3;
  color:var(--color-text);
  margin:0 0 .5rem 0;
  letter-spacing:.2px;
}
.hero-content p{
  font-size: clamp(1rem, .95rem + .2vw, 1.1rem);
  color:var(--color-muted);
  margin:0;
}

/* ===== Produtos (mais distância entre cards) ===== */
.produtos {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: clamp(18px, 3.2vw, 34px);   /* ↑ gap para afastar os cards */
  padding: 1.8rem 0 2.2rem;
}
.produtos > .produto-card { grid-column: span 4; }
@media (max-width: 1024px) { .produtos > .produto-card { grid-column: span 6; } }
@media (max-width: 640px) {
  .produtos { gap: clamp(14px, 4vw, 22px); }
  .produtos > .produto-card { grid-column: span 12; }
}

/* Card futurista feminino (com halo discreto) */
.produto-card {
  position: relative;
  display: block;
  border-radius: var(--radius-lg);
  padding: .8rem;
  text-decoration: none;
  transform-style: preserve-3d;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition), filter var(--transition);
  will-change: transform;
  isolation: isolate;

  /* base rosa suave + glass */
  background:
    linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,.08)),
    var(--color-surface-pink);
  border: 1px solid rgba(255, 185, 225, .55);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);

  /* leve transpassar sem colar no vizinho */
  margin-inline: clamp(-8px, -1vw, -16px);
  box-shadow: var(--shadow-sm);
}
.produto-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg,
    color-mix(in oklab, var(--color-accent) 70%, white),
    color-mix(in oklab, var(--color-primary) 55%, white)
  );
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
}
/* HALO AJUSTADO — menor e sem “mancha” de seção */
.produto-card::after {
  content: "";
  position: absolute;
  inset: -6%;
  border-radius: inherit;
  background:
    radial-gradient(60% 60% at 50% 40%, color-mix(in oklab, var(--color-primary) 35%, transparent), transparent 65%),
    conic-gradient(from 0deg,
      color-mix(in oklab, var(--holo-iris-1) 55%, transparent),
      color-mix(in oklab, var(--holo-iris-2) 55%, transparent),
      color-mix(in oklab, var(--holo-iris-3) 55%, transparent),
      color-mix(in oklab, var(--holo-iris-4) 55%, transparent),
      color-mix(in oklab, var(--holo-iris-1) 55%, transparent)
    );
  filter: blur(10px) saturate(120%);
  opacity: .28;
  z-index: -1;
  pointer-events: none;
}
.produto-card:hover { transform: translateY(-6px) scale(1.01); box-shadow: var(--shadow-md); }

.produto-foto {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: calc(var(--radius-lg) - 6px);
  background-size: cover;
  background-position: center;
  overflow: hidden;
  transform: translateZ(20px);
}
.produto-nome {
  margin: .75rem .3rem .2rem;
  font-family: var(--font-title);
  font-weight: 600;
  font-size: clamp(1rem, 1vw + .75rem, 1.2rem);
  color: var(--color-text);
  letter-spacing: .2px;

  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  word-break: break-word;
  hyphens: auto;
}

/* ===== Cartas legais (Política, Termos, etc.) ===== */
.legais {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: clamp(18px, 3vw, 32px);      /* ↑ espaço entre as cartas */
  padding: .9rem 0 3rem;
}
.legais .legal-card { grid-column: span 6; }
@media (max-width: 800px) { .legais .legal-card { grid-column: span 12; } }

.legal-card {
  position: relative;
  border-radius: var(--radius-lg);
  padding: 1rem 1.1rem;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition), filter var(--transition);

  /* base rosa suave + glass */
  background:
    linear-gradient(180deg, rgba(255,255,255,.14), rgba(255,255,255,.06)),
    var(--color-surface-pink);
  border: 1px solid rgba(255, 185, 225, .45);
  backdrop-filter: blur(12px) saturate(130%);
  -webkit-backdrop-filter: blur(12px) saturate(130%);
  box-shadow: var(--shadow-sm);

  /* leve transpassar, mas sem encostar */
  margin-inline: clamp(-6px, -0.8vw, -12px);
}
.legal-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.legal-card::before {
  content: "";
  position: absolute;
  inset: -4%;
  border-radius: inherit;
  background: conic-gradient(from 140deg at 10% 10%,
    color-mix(in oklab, var(--color-accent) 45%, white),
    color-mix(in oklab, var(--color-primary) 40%, white),
    color-mix(in oklab, var(--color-accent) 50%, white)
  );
  filter: blur(8px);
  opacity: .22;
  z-index: -1;
}

.legal-card h2 {
  margin: .2rem 0 .6rem;
  font-family: var(--font-title);
  font-size: clamp(1.1rem, 1vw + .9rem, 1.3rem);
  color: var(--color-primary);
}
.legal-content p { margin: .35rem 0; color: var(--color-muted); font-size: 1.05rem; }

/* ===== Reveal (JS adiciona .in-view) ===== */
.reveal {
  opacity: 0;
  transform: translateY(16px) scale(.98);
  transition: opacity .5s var(--transition), transform .5s var(--transition);
}
.reveal.in-view { opacity: 1; transform: translateY(0) scale(1); }

/* ===== Botões genéricos ===== */
a.button, .btn {
  display: inline-block;
  background: linear-gradient(92deg, var(--color-primary), var(--color-accent));
  color: #fff;
  border: 0;
  border-radius: 12px;
  padding: .8rem 1.05rem;
  box-shadow: 0 8px 20px rgba(255, 138, 197, .25);
  transition: transform var(--transition), box-shadow var(--transition);
  text-decoration: none;
  font-weight: 600;
  font-size: 1.05rem;
}
a.button:hover, .btn:hover { transform: translateY(-2px); }
a.button:focus-visible { outline: 2px solid #ffb6d8; outline-offset: 3px; }

/* ===== Ripple (elemento injetado pelo JS) ===== */
.ripple {
  position: absolute;
  border-radius: 50%;
  transform: scale(0);
  background: color-mix(in oklab, var(--color-primary) 25%, transparent);
  animation: ripple .8s ease-out forwards;
  pointer-events: none;
}
@keyframes ripple { to { transform: scale(12); opacity: 0; } }

/* ===== Acessibilidade: reduzir movimento ===== */
@media (prefers-reduced-motion: reduce) {
  .produto-card,
  .legal-card,
  .reveal {
    transition: none !important;
    transform: none !important;
  }
}

/* =========================
   RESPONSIVIDADE — Tablets e Celulares
   (sem alterar cores/funções)
   ========================= */

/* <= 1200px (laptops/tablets landscape) */
@media (max-width: 1200px) {
  .container { width: min(1120px, 94%); }
  .header-inner, .footer-inner { gap: .8rem; }
}

/* <= 992px (tablets) */
@media (max-width: 992px) {
  html, body { font-size: 17px; }

  .header-inner {
    flex-wrap: wrap;
    row-gap: .6rem;
  }

  .brand img { max-height: 46px; }
  .header-social { gap: .6rem; }
  .header-social .social-link { width: 36px; height: 36px; }
  .header-social .social-link svg { width: 18px; height: 18px; }

  .produtos { gap: clamp(16px, 2.6vw, 28px); }
  .legais { gap: clamp(16px, 2.6vw, 28px); }

  /* hero responsivo */
  .hero-content { margin: 2.6rem auto 1.2rem; }
}

/* <= 768px (tablets/celulares grandes) */
@media (max-width: 768px) {
  html, body { font-size: 16px; }
  .container { width: min(1120px, 94%); }

  .brand img { max-height: 44px; }
  .brand__text { font-size: 1.1rem; }

  .site-footer { font-size: .98rem; padding: 1rem 0; }

  .produto-nome { -webkit-line-clamp: 2; line-clamp: 2; }

  .produto-card { margin-inline: clamp(-4px, -0.6vw, -10px); }
  .legal-card   { margin-inline: clamp(-4px, -0.6vw, -10px); }

  .hero-content h1 { font-size: clamp(1.7rem, 1.1rem + 1.4vw, 2.1rem); }
}

/* <= 600px (celulares médios) */
@media (max-width: 600px) {
  html, body { font-size: 15.5px; }

  .header-inner { justify-content: center; text-align: center; }
  .brand { justify-content: center; }
  .brand img { max-height: 42px; }

  .header-social { justify-content: center; width: 100%; }
  .header-social .social-link { width: 34px; height: 34px; }
  .header-social .social-link svg { width: 17px; height: 17px; }

  .produtos { gap: clamp(14px, 4vw, 22px); }
  .legais   { gap: clamp(14px, 4vw, 22px); }

  a.button, .btn { padding: .72rem .95rem; font-size: 1rem; border-radius: 10px; }

  .hero-content { margin: 2.2rem auto 1rem; padding-top: 1.4rem; }
}

/* <= 420px (celulares pequenos) */
@media (max-width: 420px) {
  html, body { font-size: 15px; }

  .container { width: min(1120px, 94%); }
  .brand img { max-height: 40px; }

  .produto-card { padding: .7rem; }
  .legal-card   { padding: .85rem 1rem; }

  .header-social .social-link { width: 32px; height: 32px; }
  .header-social .social-link svg { width: 16px; height: 16px; }
}
