/* =====================================================================
   GlowFela — Folha de estilos principal
   Paleta: Prateado · Pérola · Pó (Powder) · Lótus · Terracota
   Sem frameworks. Sem CDN. Sem fontes externas.
   ===================================================================== */

:root {
  /* ---- Paleta de cor ---- */
  --gf-prata:        #b9bcc4;   /* Prateado */
  --gf-prata-claro:  #d7dade;
  --gf-prata-escuro: #8d9099;

  --gf-perola:       #f6f2ec;   /* Pérola */
  --gf-perola-quente:#fbf8f3;
  --gf-perola-fria:  #eef1f3;

  --gf-po:           #ead7d8;   /* Pó / Powder rosado */
  --gf-po-claro:     #f5e9ea;
  --gf-po-fundo:     #faf1f1;

  --gf-lotus:        #d99fb0;   /* Lótus */
  --gf-lotus-escuro: #bd7c8f;
  --gf-lotus-suave:  #f0d6dd;

  --gf-terracota:    #c8765a;   /* Terracota */
  --gf-terracota-q:  #b5634a;
  --gf-terracota-s:  #e9b8a6;

  /* ---- Tons neutros / texto ---- */
  --gf-tinta:        #3a3338;
  --gf-tinta-suave:  #6d646a;
  --gf-tinta-clara:  #978f94;
  --gf-branco:       #ffffff;
  --gf-linha:        #e6ddd9;

  /* ---- Tipografia (apenas pilhas de sistema) ---- */
  --gf-fonte-titulo: "Iowan Old Style", "Palatino Linotype", "Book Antiqua",
                     Palatino, "Times New Roman", Georgia, serif;
  --gf-fonte-corpo:  -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue",
                     "Liberation Sans", Arial, sans-serif;

  /* ---- Espaçamento e formas ---- */
  --gf-raio:         18px;
  --gf-raio-peq:     10px;
  --gf-raio-grande:  32px;
  --gf-sombra:       0 18px 48px -24px rgba(58, 51, 56, 0.45);
  --gf-sombra-suave: 0 10px 30px -18px rgba(58, 51, 56, 0.35);
  --gf-transicao:    320ms cubic-bezier(0.22, 0.61, 0.36, 1);
  --gf-largura:      1180px;
}

/* ---------------------------------------------------------------------
   Reposição base
   --------------------------------------------------------------------- */
*,
*::before,
*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--gf-fonte-corpo);
  color: var(--gf-tinta);
  background:
    radial-gradient(120% 80% at 85% -10%, var(--gf-po-fundo) 0%, transparent 55%),
    radial-gradient(110% 70% at 0% 0%, var(--gf-perola-fria) 0%, transparent 50%),
    var(--gf-perola);
  line-height: 1.65;
  font-size: 17px;
  overflow-x: hidden;
}

img { max-width: 100%; display: block; height: auto; }

a { color: var(--gf-terracota-q); text-decoration: none; transition: color var(--gf-transicao); }
a:hover { color: var(--gf-lotus-escuro); }

h1, h2, h3, h4 {
  font-family: var(--gf-fonte-titulo);
  font-weight: 600;
  line-height: 1.18;
  color: var(--gf-tinta);
  letter-spacing: -0.01em;
  margin: 0 0 0.5em;
}

p { margin: 0 0 1.1em; }

.gf-env {
  width: 100%;
  max-width: var(--gf-largura);
  margin-inline: auto;
  padding-inline: clamp(20px, 5vw, 48px);
}

.gf-pre-titulo {
  display: inline-block;
  font-family: var(--gf-fonte-corpo);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gf-terracota-q);
  margin-bottom: 14px;
  padding: 6px 14px;
  border-radius: 100px;
  background: var(--gf-po-claro);
  border: 1px solid var(--gf-po);
}

.gf-seccao { padding: clamp(64px, 9vw, 120px) 0; position: relative; }

.gf-titulo-seccao {
  font-size: clamp(1.9rem, 4.2vw, 3rem);
  max-width: 22ch;
}

.gf-intro-seccao {
  color: var(--gf-tinta-suave);
  max-width: 60ch;
  font-size: 1.06rem;
}

/* ---------------------------------------------------------------------
   Botões
   --------------------------------------------------------------------- */
.gf-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--gf-fonte-corpo);
  font-weight: 600;
  font-size: 1rem;
  padding: 15px 30px;
  border-radius: 100px;
  border: none;
  cursor: pointer;
  transition: transform var(--gf-transicao), box-shadow var(--gf-transicao),
              background var(--gf-transicao);
  text-align: center;
}

.gf-btn--principal {
  background: linear-gradient(135deg, var(--gf-terracota) 0%, var(--gf-lotus-escuro) 100%);
  color: var(--gf-branco);
  box-shadow: 0 14px 30px -14px var(--gf-terracota-q);
}
.gf-btn--principal:hover {
  transform: translateY(-3px);
  box-shadow: 0 20px 38px -14px var(--gf-terracota-q);
  color: var(--gf-branco);
}

.gf-btn--contorno {
  background: var(--gf-branco);
  color: var(--gf-tinta);
  border: 1.5px solid var(--gf-linha);
}
.gf-btn--contorno:hover {
  border-color: var(--gf-lotus);
  color: var(--gf-lotus-escuro);
  transform: translateY(-3px);
}

.gf-btn--bloco { width: 100%; justify-content: center; }

/* ---------------------------------------------------------------------
   Cabeçalho / Navegação
   --------------------------------------------------------------------- */
.gf-topo {
  position: sticky;
  top: 0;
  z-index: 60;
  backdrop-filter: blur(14px);
  background: rgba(246, 242, 236, 0.82);
  border-bottom: 1px solid rgba(230, 221, 217, 0.7);
}

.gf-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  height: 76px;
}

.gf-marca {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  font-family: var(--gf-fonte-titulo);
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--gf-tinta);
  letter-spacing: -0.01em;
}
.gf-marca:hover { color: var(--gf-tinta); }

.gf-marca__simbolo {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: conic-gradient(from 140deg, var(--gf-lotus), var(--gf-terracota-s),
              var(--gf-prata-claro), var(--gf-lotus));
  display: grid;
  place-items: center;
  box-shadow: inset 0 0 0 3px rgba(255, 255, 255, 0.55);
  position: relative;
}
.gf-marca__simbolo::after {
  content: "";
  width: 13px;
  height: 13px;
  border-radius: 50%;
  background: var(--gf-branco);
}

.gf-menu {
  display: flex;
  align-items: center;
  gap: 30px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.gf-menu a {
  color: var(--gf-tinta-suave);
  font-weight: 500;
  font-size: 0.96rem;
  position: relative;
}
.gf-menu a::after {
  content: "";
  position: absolute;
  left: 0; bottom: -6px;
  width: 0; height: 2px;
  background: var(--gf-terracota);
  border-radius: 2px;
  transition: width var(--gf-transicao);
}
.gf-menu a:hover { color: var(--gf-tinta); }
.gf-menu a:hover::after { width: 100%; }

.gf-nav__acao { display: flex; align-items: center; gap: 14px; }

.gf-hamburguer {
  display: none;
  width: 46px; height: 46px;
  border: 1px solid var(--gf-linha);
  border-radius: 12px;
  background: var(--gf-branco);
  cursor: pointer;
  position: relative;
}
.gf-hamburguer span,
.gf-hamburguer span::before,
.gf-hamburguer span::after {
  content: "";
  position: absolute;
  left: 50%;
  width: 20px; height: 2px;
  background: var(--gf-tinta);
  border-radius: 2px;
  transform: translateX(-50%);
  transition: transform var(--gf-transicao), opacity var(--gf-transicao);
}
.gf-hamburguer span { top: 50%; transform: translate(-50%, -50%); }
.gf-hamburguer span::before { top: -7px; }
.gf-hamburguer span::after  { top: 7px; }
.gf-hamburguer.estah-aberto span { background: transparent; }
.gf-hamburguer.estah-aberto span::before { transform: translateX(-50%) rotate(45deg); top: 0; }
.gf-hamburguer.estah-aberto span::after  { transform: translateX(-50%) rotate(-45deg); top: 0; }

/* ---------------------------------------------------------------------
   Hero
   --------------------------------------------------------------------- */
.gf-hero {
  position: relative;
  padding: clamp(60px, 8vw, 110px) 0 clamp(70px, 9vw, 120px);
  overflow: hidden;
}
.gf-hero__grelha {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  align-items: center;
  gap: clamp(36px, 6vw, 72px);
}
.gf-hero__titulo {
  font-size: clamp(2.4rem, 6vw, 4.1rem);
  margin-bottom: 22px;
}
.gf-hero__titulo .destaque {
  background: linear-gradient(120deg, var(--gf-terracota), var(--gf-lotus-escuro));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.gf-hero__texto {
  font-size: 1.15rem;
  color: var(--gf-tinta-suave);
  max-width: 52ch;
  margin-bottom: 30px;
}
.gf-hero__botoes { display: flex; flex-wrap: wrap; gap: 14px; }

.gf-hero__provas {
  display: flex;
  flex-wrap: wrap;
  gap: 26px;
  margin-top: 38px;
}
.gf-hero__prova { display: flex; flex-direction: column; }
.gf-hero__prova strong {
  font-family: var(--gf-fonte-titulo);
  font-size: 1.7rem;
  color: var(--gf-terracota-q);
}
.gf-hero__prova span { font-size: 0.86rem; color: var(--gf-tinta-clara); }

.gf-hero__media { position: relative; }
.gf-hero__moldura {
  border-radius: var(--gf-raio-grande);
  overflow: hidden;
  box-shadow: var(--gf-sombra);
  position: relative;
  isolation: isolate;
}
.gf-hero__moldura img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
}
.gf-hero__moldura::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(160deg, transparent 55%, rgba(189, 124, 143, 0.28));
  z-index: 1;
}
.gf-hero__selo {
  position: absolute;
  left: -22px;
  bottom: 36px;
  background: var(--gf-branco);
  padding: 16px 20px;
  border-radius: var(--gf-raio);
  box-shadow: var(--gf-sombra-suave);
  display: flex;
  align-items: center;
  gap: 12px;
  z-index: 2;
}
.gf-hero__selo .ponto {
  width: 42px; height: 42px;
  border-radius: 50%;
  background: var(--gf-lotus-suave);
  display: grid; place-items: center;
  color: var(--gf-lotus-escuro);
  font-family: var(--gf-fonte-titulo);
  font-size: 1.2rem;
}
.gf-hero__selo small { color: var(--gf-tinta-clara); display: block; font-size: 0.74rem; }
.gf-hero__selo strong { font-size: 0.95rem; }

.gf-borrao {
  position: absolute;
  border-radius: 50%;
  filter: blur(60px);
  opacity: 0.55;
  z-index: -1;
}
.gf-borrao--1 { width: 360px; height: 360px; background: var(--gf-lotus-suave); top: -60px; right: -80px; }
.gf-borrao--2 { width: 300px; height: 300px; background: var(--gf-terracota-s); bottom: -90px; left: -60px; }

/* ---------------------------------------------------------------------
   Estilo de vida — três pilares
   --------------------------------------------------------------------- */
.gf-pilares {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 26px;
  margin-top: 48px;
}
.gf-pilar {
  background: var(--gf-branco);
  border: 1px solid var(--gf-linha);
  border-radius: var(--gf-raio);
  padding: 34px 30px;
  transition: transform var(--gf-transicao), box-shadow var(--gf-transicao);
  position: relative;
  overflow: hidden;
}
.gf-pilar::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 4px;
  background: linear-gradient(90deg, var(--gf-lotus), var(--gf-terracota));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--gf-transicao);
}
.gf-pilar:hover { transform: translateY(-6px); box-shadow: var(--gf-sombra-suave); }
.gf-pilar:hover::before { transform: scaleX(1); }
.gf-pilar__icone {
  width: 56px; height: 56px;
  border-radius: 16px;
  display: grid; place-items: center;
  margin-bottom: 20px;
  background: var(--gf-po-claro);
}
.gf-pilar__icone svg { width: 28px; height: 28px; }
.gf-pilar h3 { font-size: 1.3rem; margin-bottom: 10px; }
.gf-pilar p { color: var(--gf-tinta-suave); margin: 0; font-size: 0.98rem; }

/* ---------------------------------------------------------------------
   Produto
   --------------------------------------------------------------------- */
.gf-produto { background: linear-gradient(180deg, transparent, var(--gf-po-fundo) 40%, transparent); }
.gf-produto__grelha {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: clamp(36px, 6vw, 70px);
  align-items: center;
}
.gf-produto__visual {
  position: relative;
  border-radius: var(--gf-raio-grande);
  background:
    radial-gradient(70% 70% at 50% 40%, var(--gf-perola-quente), var(--gf-po-claro));
  padding: 44px;
  display: grid;
  place-items: center;
  box-shadow: var(--gf-sombra-suave);
}
.gf-produto__visual img {
  max-height: 420px;
  width: auto;
  filter: drop-shadow(0 24px 30px rgba(58, 51, 56, 0.25));
  animation: gf-flutua 6s ease-in-out infinite;
}
.gf-produto__lista { list-style: none; margin: 22px 0 0; padding: 0; }
.gf-produto__lista li {
  display: flex;
  gap: 14px;
  padding: 14px 0;
  border-bottom: 1px dashed var(--gf-linha);
}
.gf-produto__lista li:last-child { border-bottom: none; }
.gf-produto__lista .marca {
  flex: none;
  width: 26px; height: 26px;
  border-radius: 50%;
  background: var(--gf-lotus-suave);
  color: var(--gf-lotus-escuro);
  display: grid; place-items: center;
  font-weight: 700;
  font-size: 0.85rem;
}
.gf-produto__lista strong { display: block; }
.gf-produto__lista span { color: var(--gf-tinta-suave); font-size: 0.94rem; }

.gf-ingredientes {
  margin-top: 26px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.gf-tag {
  background: var(--gf-branco);
  border: 1px solid var(--gf-linha);
  padding: 8px 16px;
  border-radius: 100px;
  font-size: 0.86rem;
  color: var(--gf-tinta-suave);
}

.gf-aviso-conforme {
  margin-top: 26px;
  background: var(--gf-perola-fria);
  border-left: 4px solid var(--gf-prata);
  border-radius: var(--gf-raio-peq);
  padding: 16px 20px;
  font-size: 0.9rem;
  color: var(--gf-tinta-suave);
}

/* ---------------------------------------------------------------------
   Benefícios
   --------------------------------------------------------------------- */
.gf-beneficios__grelha {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 24px;
  margin-top: 48px;
}
.gf-cartao-beneficio {
  background: var(--gf-branco);
  border-radius: var(--gf-raio);
  padding: 30px 28px;
  border: 1px solid var(--gf-linha);
  transition: transform var(--gf-transicao), box-shadow var(--gf-transicao);
}
.gf-cartao-beneficio:hover { transform: translateY(-5px); box-shadow: var(--gf-sombra-suave); }
.gf-cartao-beneficio__num {
  font-family: var(--gf-fonte-titulo);
  font-size: 2.2rem;
  color: var(--gf-terracota-s);
  line-height: 1;
}
.gf-cartao-beneficio h3 { font-size: 1.2rem; margin: 14px 0 8px; }
.gf-cartao-beneficio p { color: var(--gf-tinta-suave); margin: 0; font-size: 0.96rem; }

/* ---------------------------------------------------------------------
   Hábitos de bem-estar
   --------------------------------------------------------------------- */
.gf-habitos__grelha {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: clamp(36px, 6vw, 64px);
  align-items: center;
}
.gf-habitos__media {
  border-radius: var(--gf-raio-grande);
  overflow: hidden;
  box-shadow: var(--gf-sombra);
  position: relative;
}
.gf-habitos__media img { width: 100%; aspect-ratio: 5 / 4; object-fit: cover; }
.gf-habitos__lista { list-style: none; margin: 24px 0 0; padding: 0; }
.gf-habitos__lista li {
  display: flex;
  gap: 16px;
  margin-bottom: 22px;
}
.gf-habitos__lista .passo {
  flex: none;
  width: 40px; height: 40px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--gf-lotus), var(--gf-terracota-s));
  color: var(--gf-branco);
  display: grid; place-items: center;
  font-family: var(--gf-fonte-titulo);
  font-weight: 600;
}
.gf-habitos__lista h3 { font-size: 1.12rem; margin: 0 0 4px; }
.gf-habitos__lista p { margin: 0; color: var(--gf-tinta-suave); font-size: 0.95rem; }

/* ---------------------------------------------------------------------
   Testemunhos / experiência do cliente
   --------------------------------------------------------------------- */
.gf-experiencia { background: linear-gradient(180deg, transparent, var(--gf-perola-fria) 50%, transparent); }
.gf-experiencia__topo {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: center;
  margin-bottom: 48px;
}
.gf-experiencia__foto {
  border-radius: var(--gf-raio-grande);
  overflow: hidden;
  box-shadow: var(--gf-sombra);
}
.gf-experiencia__foto img { width: 100%; aspect-ratio: 16 / 10; object-fit: cover; }

.gf-depoimentos {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.gf-depoimento {
  background: var(--gf-branco);
  border-radius: var(--gf-raio);
  padding: 30px 28px;
  border: 1px solid var(--gf-linha);
  display: flex;
  flex-direction: column;
}
.gf-depoimento__estrelas { color: var(--gf-terracota); letter-spacing: 3px; margin-bottom: 12px; }
.gf-depoimento__texto { color: var(--gf-tinta); font-style: italic; flex: 1; }
.gf-depoimento__autor { display: flex; align-items: center; gap: 12px; margin-top: 18px; }
.gf-depoimento__inicial {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--gf-po-claro);
  color: var(--gf-lotus-escuro);
  display: grid; place-items: center;
  font-family: var(--gf-fonte-titulo);
  font-weight: 600;
}
.gf-depoimento__autor strong { display: block; font-size: 0.96rem; }
.gf-depoimento__autor span { color: var(--gf-tinta-clara); font-size: 0.82rem; }
.gf-experiencia__nota {
  margin-top: 28px;
  text-align: center;
  font-size: 0.88rem;
  color: var(--gf-tinta-clara);
}

/* ---------------------------------------------------------------------
   FAQ
   --------------------------------------------------------------------- */
.gf-faq__lista { max-width: 820px; margin: 44px auto 0; }
.gf-faq__item {
  background: var(--gf-branco);
  border: 1px solid var(--gf-linha);
  border-radius: var(--gf-raio);
  margin-bottom: 14px;
  overflow: hidden;
  transition: box-shadow var(--gf-transicao);
}
.gf-faq__item.estah-aberto { box-shadow: var(--gf-sombra-suave); }
.gf-faq__pergunta {
  width: 100%;
  text-align: left;
  background: none;
  border: none;
  cursor: pointer;
  padding: 22px 26px;
  font-family: var(--gf-fonte-corpo);
  font-size: 1.04rem;
  font-weight: 600;
  color: var(--gf-tinta);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}
.gf-faq__sinal {
  flex: none;
  width: 30px; height: 30px;
  border-radius: 50%;
  background: var(--gf-po-claro);
  color: var(--gf-lotus-escuro);
  display: grid; place-items: center;
  font-size: 1.3rem;
  line-height: 1;
  transition: transform var(--gf-transicao), background var(--gf-transicao);
}
.gf-faq__item.estah-aberto .gf-faq__sinal {
  transform: rotate(45deg);
  background: var(--gf-terracota);
  color: var(--gf-branco);
}
.gf-faq__resposta {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--gf-transicao);
}
.gf-faq__resposta-interior { padding: 0 26px 24px; color: var(--gf-tinta-suave); }

/* ---------------------------------------------------------------------
   Formulário de encomenda
   --------------------------------------------------------------------- */
.gf-encomenda { background: linear-gradient(160deg, var(--gf-po-fundo), var(--gf-perola)); }
.gf-encomenda__grelha {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(36px, 6vw, 64px);
  align-items: center;
}
.gf-encomenda__lista { list-style: none; padding: 0; margin: 24px 0 0; }
.gf-encomenda__lista li {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  margin-bottom: 14px;
  color: var(--gf-tinta-suave);
}
.gf-encomenda__lista .check {
  flex: none;
  width: 24px; height: 24px;
  border-radius: 50%;
  background: var(--gf-lotus-suave);
  color: var(--gf-lotus-escuro);
  display: grid; place-items: center;
  font-size: 0.8rem; font-weight: 700;
}

.gf-form {
  background: var(--gf-branco);
  border-radius: var(--gf-raio-grande);
  padding: clamp(28px, 4vw, 42px);
  box-shadow: var(--gf-sombra);
  border: 1px solid var(--gf-linha);
}
.gf-form__campo { margin-bottom: 20px; }
.gf-form__campo label {
  display: block;
  font-size: 0.9rem;
  font-weight: 600;
  margin-bottom: 8px;
  color: var(--gf-tinta);
}
.gf-form__campo input[type="text"],
.gf-form__campo input[type="tel"] {
  width: 100%;
  padding: 14px 16px;
  border: 1.5px solid var(--gf-linha);
  border-radius: var(--gf-raio-peq);
  font-family: var(--gf-fonte-corpo);
  font-size: 1rem;
  color: var(--gf-tinta);
  background: var(--gf-perola-quente);
  transition: border-color var(--gf-transicao), box-shadow var(--gf-transicao);
}
.gf-form__campo input:focus {
  outline: none;
  border-color: var(--gf-lotus);
  box-shadow: 0 0 0 4px var(--gf-lotus-suave);
  background: var(--gf-branco);
}
.gf-form__erro {
  display: none;
  color: var(--gf-terracota-q);
  font-size: 0.82rem;
  margin-top: 6px;
}
.gf-form__campo.tem-erro input { border-color: var(--gf-terracota); background: var(--gf-po-fundo); }
.gf-form__campo.tem-erro .gf-form__erro { display: block; }

.gf-consent {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  margin-bottom: 16px;
  font-size: 0.88rem;
  color: var(--gf-tinta-suave);
}
.gf-consent input[type="checkbox"] {
  flex: none;
  width: 20px; height: 20px;
  margin-top: 2px;
  accent-color: var(--gf-terracota);
  cursor: pointer;
}
.gf-consent.tem-erro { color: var(--gf-terracota-q); }

.gf-form__rodape {
  margin-top: 10px;
  font-size: 0.78rem;
  color: var(--gf-tinta-clara);
  text-align: center;
}

/* ---------------------------------------------------------------------
   Rodapé
   --------------------------------------------------------------------- */
.gf-rodape {
  background: var(--gf-tinta);
  color: var(--gf-perola-fria);
  padding: clamp(56px, 8vw, 88px) 0 32px;
}
.gf-rodape a { color: var(--gf-prata-claro); }
.gf-rodape a:hover { color: var(--gf-branco); }
.gf-rodape__grelha {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1.2fr;
  gap: 40px;
  margin-bottom: 48px;
}
.gf-rodape__marca {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  font-family: var(--gf-fonte-titulo);
  font-size: 1.4rem;
  color: var(--gf-branco);
  margin-bottom: 16px;
}
.gf-rodape__sobre { color: var(--gf-prata); font-size: 0.94rem; max-width: 38ch; }
.gf-rodape h4 {
  color: var(--gf-branco);
  font-family: var(--gf-fonte-corpo);
  font-size: 0.82rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  margin-bottom: 18px;
}
.gf-rodape ul { list-style: none; padding: 0; margin: 0; }
.gf-rodape li { margin-bottom: 11px; font-size: 0.94rem; }
.gf-rodape__contacto { color: var(--gf-prata); font-size: 0.94rem; font-style: normal; }
.gf-rodape__contacto strong { color: var(--gf-perola-fria); display: block; margin-bottom: 4px; font-weight: 600; }
.gf-rodape__legal {
  border-top: 1px solid rgba(185, 188, 196, 0.2);
  padding-top: 26px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 16px;
  font-size: 0.84rem;
  color: var(--gf-prata);
}
.gf-rodape__legal-links { display: flex; flex-wrap: wrap; gap: 18px; }

/* ---------------------------------------------------------------------
   Banner de cookies
   --------------------------------------------------------------------- */
.gf-cookies {
  position: fixed;
  left: 50%;
  bottom: 24px;
  transform: translateX(-50%) translateY(150%);
  width: min(680px, calc(100% - 32px));
  background: var(--gf-branco);
  border: 1px solid var(--gf-linha);
  border-radius: var(--gf-raio);
  box-shadow: 0 24px 60px -22px rgba(58, 51, 56, 0.5);
  padding: 24px 26px;
  z-index: 90;
  transition: transform 480ms cubic-bezier(0.22, 0.61, 0.36, 1);
}
.gf-cookies.estah-visivel { transform: translateX(-50%) translateY(0); }
.gf-cookies h3 { font-size: 1.15rem; margin-bottom: 8px; }
.gf-cookies p { font-size: 0.9rem; color: var(--gf-tinta-suave); margin-bottom: 18px; }
.gf-cookies__acoes { display: flex; flex-wrap: wrap; gap: 12px; }
.gf-cookies__acoes .gf-btn { padding: 12px 24px; font-size: 0.92rem; }

/* ---------------------------------------------------------------------
   Páginas legais e de sucesso
   --------------------------------------------------------------------- */
.gf-pagina-legal { padding: clamp(48px, 7vw, 90px) 0; }
.gf-pagina-legal__cabecalho { max-width: 760px; margin-bottom: 40px; }
.gf-pagina-legal__cabecalho h1 { font-size: clamp(2rem, 5vw, 3rem); }
.gf-pagina-legal__cabecalho p { color: var(--gf-tinta-suave); }
.gf-doc {
  background: var(--gf-branco);
  border: 1px solid var(--gf-linha);
  border-radius: var(--gf-raio-grande);
  padding: clamp(28px, 5vw, 56px);
  box-shadow: var(--gf-sombra-suave);
  max-width: 900px;
}
.gf-doc h2 {
  font-size: 1.4rem;
  margin-top: 36px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--gf-po-claro);
}
.gf-doc h2:first-of-type { margin-top: 0; }
.gf-doc h3 { font-size: 1.1rem; margin-top: 24px; }
.gf-doc p, .gf-doc li { color: var(--gf-tinta-suave); }
.gf-doc ul { padding-left: 22px; }
.gf-doc li { margin-bottom: 8px; }
.gf-doc__meta {
  display: inline-block;
  background: var(--gf-perola-fria);
  padding: 6px 14px;
  border-radius: 100px;
  font-size: 0.82rem;
  color: var(--gf-tinta-clara);
  margin-bottom: 24px;
}

.gf-sucesso {
  min-height: 70vh;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 60px 0;
}
.gf-sucesso__cartao {
  background: var(--gf-branco);
  border-radius: var(--gf-raio-grande);
  padding: clamp(40px, 6vw, 70px);
  box-shadow: var(--gf-sombra);
  border: 1px solid var(--gf-linha);
  max-width: 560px;
}
.gf-sucesso__icone {
  width: 92px; height: 92px;
  border-radius: 50%;
  margin: 0 auto 26px;
  background: linear-gradient(135deg, var(--gf-lotus), var(--gf-terracota-s));
  display: grid; place-items: center;
  animation: gf-pulsa 2.4s ease-in-out infinite;
}
.gf-sucesso__icone svg { width: 44px; height: 44px; stroke: var(--gf-branco); }
.gf-sucesso h1 { font-size: clamp(1.8rem, 4vw, 2.6rem); }
.gf-sucesso p { color: var(--gf-tinta-suave); max-width: 44ch; margin-inline: auto; }
.gf-sucesso__detalhe {
  background: var(--gf-perola-fria);
  border-radius: var(--gf-raio);
  padding: 18px 22px;
  margin: 26px 0;
  font-size: 0.92rem;
  color: var(--gf-tinta-suave);
}

/* ---------------------------------------------------------------------
   Animações
   --------------------------------------------------------------------- */
@keyframes gf-flutua {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-16px); }
}
@keyframes gf-pulsa {
  0%, 100% { transform: scale(1); box-shadow: 0 0 0 0 rgba(217, 159, 176, 0.5); }
  50% { transform: scale(1.04); box-shadow: 0 0 0 18px rgba(217, 159, 176, 0); }
}
@keyframes gf-surge {
  from { opacity: 0; transform: translateY(28px); }
  to { opacity: 1; transform: translateY(0); }
}

.gf-revela {
  opacity: 0;
  transform: translateY(28px);
}
.gf-revela.estah-visivel {
  animation: gf-surge 720ms cubic-bezier(0.22, 0.61, 0.36, 1) forwards;
}

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
  .gf-revela { opacity: 1; transform: none; }
}

/* ---------------------------------------------------------------------
   Responsivo
   --------------------------------------------------------------------- */
@media (max-width: 980px) {
  .gf-hero__grelha,
  .gf-produto__grelha,
  .gf-habitos__grelha,
  .gf-experiencia__topo,
  .gf-encomenda__grelha { grid-template-columns: 1fr; }
  .gf-hero__media { order: -1; max-width: 460px; margin-inline: auto; }
  .gf-pilares { grid-template-columns: 1fr; }
  .gf-depoimentos { grid-template-columns: 1fr; }
  .gf-rodape__grelha { grid-template-columns: 1fr 1fr; }

  .gf-menu {
    position: fixed;
    inset: 76px 0 auto 0;
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    background: var(--gf-perola-quente);
    border-bottom: 1px solid var(--gf-linha);
    padding: 14px 28px 26px;
    transform: translateY(-130%);
    transition: transform var(--gf-transicao);
    box-shadow: var(--gf-sombra-suave);
  }
  .gf-menu.estah-aberto { transform: translateY(0); }
  .gf-menu li { width: 100%; border-bottom: 1px solid var(--gf-linha); }
  .gf-menu li:last-child { border-bottom: none; }
  .gf-menu a { display: block; padding: 14px 0; }
  .gf-hamburguer { display: block; }
  .gf-nav__acao .gf-btn { display: none; }
}

@media (max-width: 560px) {
  body { font-size: 16px; }
  .gf-rodape__grelha { grid-template-columns: 1fr; }
  .gf-hero__selo { left: 12px; }
  .gf-hero__provas { gap: 18px; }
  .gf-cookies { padding: 20px; }
  .gf-cookies__acoes .gf-btn { flex: 1; }
}
