@font-face {
  font-family: "Blessy Sections Gazpacho";
  src: url("./assets/gazpacho-bold.woff2") format("woff2");
  font-style: normal;
  font-weight: 700;
  font-display: swap;
}

@font-face {
  font-family: "Blessy Sections Bricolage";
  src: url("./assets/bricolage-grotesque.woff2") format("woff2");
  font-style: normal;
  font-weight: 300 800;
  font-display: swap;
}

:is(.launch-extra-sections, .site-footer, .ing-modal) {
  /* Modelo da referência (/pages/comprar): coluna ÚNICA que PREENCHE a largura
     (sem trava), com ~22px de gutter, refluindo até o breakpoint desktop (768px).
     --content-max só é usado como teto temporário ACIMA de 768 (placeholder do desktop). */
  --content-max: 720px;
  --gutter: 22px;

  /* Desktop (>= 768px): conteúdo centralizado numa coluna ampla (frame Figma 1450). */
  --desktop-max: 1300px;
  --desktop-gutter: 24px;

  --green: #3e6858;
  --deep-green: #20522e;
  --cream: #fff4e3;
  --soft-lime: #c3f4ac;
  --lime-panel: #cdec89;
  --stat-yellow: #ffdf54;
  --mint-card: #f1ffec;
  --mint-section: #f3ffee;
  --mint-strong: #d8fec8;
  --soft-lavender: #f2dcff;
  --testimonial-green: #dcffd1;
  --table-line: #243c1b;

  --system-font: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --body-font: "Blessy Sections Bricolage", "Inter", system-ui, sans-serif;
  --display-font: "Blessy Sections Gazpacho", Georgia, serif;
}

:where(.launch-extra-sections, .site-footer, .ing-modal),
:where(.launch-extra-sections, .site-footer, .ing-modal) *,
:where(.launch-extra-sections, .site-footer, .ing-modal) *::before,
:where(.launch-extra-sections, .site-footer, .ing-modal) *::after {
  box-sizing: border-box;
}

:where(.launch-extra-sections, .site-footer, .ing-modal) {
  color: var(--deep-green);
  font-family: var(--body-font);
}

html,
body {
  background: #1d6b4d;
}

.launch-maracuja,
.launch-extra-sections {
  background: #ffffff;
}

:where(.launch-extra-sections, .site-footer, .ing-modal) :where(img) {
  display: block;
  max-width: 100%;
}

:where(.launch-extra-sections, .site-footer, .ing-modal) :where(figure) {
  margin: 0;
}

:where(.launch-extra-sections, .site-footer, .ing-modal) :where(button, a) {
  font: inherit;
}

:where(.launch-extra-sections, .site-footer, .ing-modal) :where(button) {
  border: 0;
  cursor: pointer;
}

/* ===========================================================================
   ESTRUTURA RESPONSIVA (mobile-first, sem transform/scale)
   - Cada filho direto de .pdp é uma faixa full-bleed (fundo até a borda).
   - O conteúdo vive numa coluna fluida, centralizada, limitada a --content-max.
   - O conteúdo REFLUI: texto reposiciona, grids se ajustam. Nada escala como imagem.
   =========================================================================== */
.pdp {
  width: 100%;
  margin: 0 auto;
}

.pdp > * {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  padding: 48px var(--gutter);
}

.pdp > * > * {
  /* Conteúdo PREENCHE a largura da coluna (como na referência). Sem trava aqui:
     o teto só entra acima de 768px (placeholder do desktop, no @media lá embaixo). */
  width: 100%;
}

.greensclub-section,
.creators-row,
.comparison-section,
.comparison-image,
.video-stories-section {
  background: #ffffff;
}

/* Base compartilhada dos CTAs. O box-model (tamanho/margem) fica em cada seção. */
.primary-cta,
.deficiency-cta,
.ingredients-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 96px;
  background: var(--deep-green);
  color: #ffffff;
  transition: transform 180ms ease, box-shadow 180ms ease, filter 180ms ease;
}

.primary-cta:hover,
.deficiency-cta:hover,
.ingredients-button:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 26px rgb(32 82 46 / 18%);
}

.primary-cta:active,
.deficiency-cta:active,
.ingredients-button:active {
  transform: translateY(0);
  filter: brightness(0.96);
}

/* ===========================================================================
   SEÇÕES — preenchido pela conversão absolute -> fluxo
   =========================================================================== */
/* === Beneficios (intro + 4 cards + blob) === */

/* Secao vira coluna em fluxo: intro, linha de cards, blob, linha de cards.
   A largura/centralizacao da coluna ja vem da regra global .pdp > *. */
.benefits-section {
  display: grid;
  /* 2 colunas fluidas: as duas linhas de cards refluem lado a lado;
     intro e blob ocupam a largura inteira via grid-column. */
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 32px 16px; /* ritmo vertical do canvas original (~34px) + calha entre cards */
  align-items: start;
  /* respiro vertical um pouco maior no topo e na base */
  padding-block: 64px;
  color: var(--green);
  font-family: var(--system-font);
}

/* Intro centralizada, largura total */
.benefits-intro {
  grid-column: 1 / -1;
  text-align: center;
}
.benefits-intro h1 {
  margin: 0;
  font-family: var(--display-font);
  font-size: 28px;
  line-height: 1.03;
}
.benefits-intro p {
  /* preenche a largura (como no Figma original e no modelo da referência) */
  margin: 18px 0 0;
  font-size: 17px;
  font-weight: 400;
  line-height: 1.22;
}

/* Cards: antes posicionados por left/top, agora celulas do grid 2col */
.benefit-card {
  text-align: center;
}
.benefit-icon {
  margin: 0 auto;
}
.icon-bloat { width: 57px; height: 57px; }
.icon-energy { width: 50px; height: 62px; }
.icon-visible-health { width: 63px; height: 63px; }
.icon-body-mind { width: 70px; height: 73px; }

.benefit-card h2 {
  margin: 6px 0 0;
  font-family: var(--display-font);
  font-size: 21px;
  line-height: 1;
}
.benefit-card p {
  margin: 10px 0 0;
  font-size: 17px;
  line-height: 1.1;
}
.benefit-card-top p { padding: 0 2px; }
.benefit-card-bottom p { margin-top: 12px; }

/* Blob: caixa fluida com proporcao do original (327x335) e crop por object-position.
   X: img 418 vs caixa 327 => sobra 91px; translate -46 => 46/91 ≈ 50%.
   Y: img 628 vs caixa 335 => sobra 293px; translate -15 => 15/293 ≈ 5%. */
.benefit-blob {
  grid-column: 1 / -1;
  width: 100%;
  margin: 0 auto;
  /* A imagem (mask-renata.webp) já vem com a máscara orgânica + transparência.
     Nada de clip aqui — o alpha da própria imagem define o formato. */
}
.benefit-blob img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

/* === Deficiencia (foto + painel lime + cta + 2 stats) === */

/* Coluna: foto encostada no painel. Sem position absoluto: tudo flui. */
.deficiency-section {
  /* topo um tiquinho maior; base um pouco maior */
  padding-top: 56px;
  padding-bottom: 64px;
  color: var(--green);
  font-family: var(--system-font);
}

/* Foto com cantos arredondados so em cima. Caixa fluida 359x276 -> aspect-ratio. */
.deficiency-photo {
  margin: 0;
  width: 100%;
  aspect-ratio: 359 / 276;
  overflow: hidden;
  border-radius: 30px 30px 0 0;
}

/* Crop ja era centralizado no original (cover, sem translate) -> object-position padrao. */
.deficiency-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Painel encostado na foto (eram flush/sobrepostos). Cantos arredondados embaixo. */
.deficiency-panel {
  width: 100%;
  padding: 24px 20px;
  border-radius: 0 0 20px 20px;
  background: var(--lime-panel);
  text-align: center;
}

.deficiency-panel h2 {
  margin: 0;
  font-family: var(--display-font);
  font-size: 26px;
  line-height: 1.05;
}

/* Paragrafo estreito centralizado (era 250px num painel de 360). */
.deficiency-panel > p {
  max-width: 250px;
  margin: 15px auto 0;
  font-size: 17px;
  line-height: 1.2;
}

/* CTA largura cheia da coluna do painel. Box-model apenas (visual e global). */
.deficiency-cta {
  width: 100%;
  margin-top: 20px;
  gap: 11px;
  min-height: 70px;
  padding: 0 25px;
  font-family: var(--display-font);
  font-size: 17px;
  line-height: 1;
}

.deficiency-cta span {
  white-space: nowrap;
}

.deficiency-cta img {
  width: 24px;
  height: 24px;
}

/* Dois cards empilhados, alinhados a esquerda. */
.deficiency-stats {
  display: grid;
  gap: 12px;
  width: 100%;
  margin-top: 22px;
}

/* Cada card: icone-numero + texto. Colunas fluidas (minmax(0,1fr) nao estoura 320px). */
.deficiency-stat {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  width: 100%;
  margin: 0;
  padding: 17px 19px;
  border: 1px solid var(--green);
  border-radius: 20px;
  background: var(--stat-yellow);
  text-align: left;
}

.deficiency-stat strong {
  font-family: var(--display-font);
  font-size: 31px;
  line-height: 1;
}

.deficiency-stat p {
  margin: 0;
  font-size: 16px;
  line-height: 1.12;
}

/* === Testada (copy + grade 2x2 de stats) === */

/* Bloco da secao: fluxo vertical. A coluna ja e centralizada/limitada (440) pela regra global.
   Removido position:absolute/left/top/width/height fixos do canvas. */
.tested-section {
  /* mais espaço no topo, acima da headline */
  padding-top: 80px;
  color: var(--green);
  font-family: var(--system-font);
  text-align: center;
}

/* Copy (h2 + p): sem absoluto. O paragrafo segue no fluxo logo abaixo do titulo. */
.tested-copy h2 {
  margin: 0;
  font-family: var(--display-font);
  font-size: 30px;
  line-height: 1.1;
}

/* p estava em top:88px dentro do copy (~22px abaixo do titulo de 2 linhas) -> margin-top 22px */
.tested-copy p {
  margin: 22px 0 0;
  font-size: 18px;
  line-height: 1.364;
}

/* Grade: 2 colunas fluidas (minmax(0,1fr) p/ nao estourar em 320px), gap 13.
   Linhas auto pelo conteudo. Gap copy->grid (canvas: 253-233 = 20px) vira margin-top. */
.tested-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 13px;
  margin-top: 20px;
}

/* Card: largura fluida (1fr), altura pelo conteudo. min-height preserva o porte do canvas
   (linha alta = 312px) mas permite refluxo se o texto crescer. */
.tested-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-height: 312px;
  padding: 20px 10px;
  border-radius: 30px;
  background: var(--mint-card);
}

/* Cards de baixo eram mais curtos (267px) */
.tested-card-short {
  min-height: 267px;
}

/* Imagens de stat e o box do icone mantem 120x120 fixos (tamanho do glifo, nao escala). */
.tested-card > img,
.tested-icon {
  display: block;
  flex: 0 0 auto;
  width: 120px;
  height: 120px;
  margin: 0 0 20px;
}

.tested-card > img {
  object-fit: contain;
}

/* Crop LOCAL do icone (sobreposicao real): box recorta a img maior posicionada dentro. Preservado. */
.tested-icon {
  position: relative;
  overflow: hidden;
}

.tested-icon img {
  position: absolute;
  top: 0;
  height: 120px;
  max-width: none;
}

.tested-icon-65 img {
  left: 9px;
  width: 111px;
}

.tested-icon-56 img {
  left: 12px;
  width: 108px;
}

/* Texto do card */
.tested-card p {
  margin: 0;
  color: var(--green);
  font-size: 16px;
  line-height: 1.364;
}

/* === Ritual (foto + tag + lista de 4 + cta) === */

/* Faixa da seção: já é flex-column centralizada via .pdp > *.
   Só mantém cor/fonte e o respiro entre foto e conteúdo (era top 351 -> 371 = 20px). */
.ritual-section {
  gap: 20px;
  color: var(--deep-green);
  font-family: var(--system-font);
}

/* Foto com crop: caixa 360x351 (aspect ~1.026) vira fluida.
   img original 403x706 translate(-43px,-80px):
   - X: sobra 403-360=43, deslocada -43 = 100% do excesso -> mostra a borda direita (100%).
   - Y: sobra 706-351=355, deslocada -80 = 80/355 ~= 22% -> object-position-y 22%. */
.ritual-photo {
  position: relative;
  width: 100%;
  margin: 0;
  aspect-ratio: 360 / 351;
  overflow: hidden;
  border-radius: 40px;
}

/* Carrossel: trilho horizontal com snap; cada slide ocupa a caixa inteira. */
.ritual-carousel-track {
  display: flex;
  width: 100%;
  height: 100%;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  cursor: grab;
  user-select: none;
}
.ritual-carousel-track::-webkit-scrollbar {
  display: none;
}
.ritual-carousel-track.is-dragging {
  cursor: grabbing;
}
.ritual-carousel-track figure {
  flex: 0 0 100%;
  width: 100%;
  height: 100%;
  margin: 0;
  scroll-snap-align: start;
}

.ritual-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 25%;
  pointer-events: none;
}

/* Bolinhas (paginação) do carrossel — ocultas: o carrossel passa sozinho. */
.ritual-dots {
  display: none;
}
.ritual-dot {
  width: 8px;
  height: 8px;
  padding: 0;
  border-radius: 50%;
  background: rgb(255 255 255 / 55%);
  box-shadow: 0 1px 3px rgb(0 0 0 / 25%);
  transition: background 160ms ease, transform 160ms ease;
}
.ritual-dot.is-active {
  background: #ffffff;
  transform: scale(1.3);
}

/* Conteúdo: coluna alinhada à esquerda (no original tudo começava em left:0). */
.ritual-content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

/* Pílula inline: não estica na coluna flex (align-self garante mesmo com stretch herdado). */
.tag {
  display: inline-flex;
  align-self: flex-start;
  align-items: center;
  justify-content: center;
  width: 169px;
  max-width: 100%;
  height: 44px;
  margin: 0;
  border-radius: 111px;
  background: var(--soft-lime);
  color: #000;
  font-size: 18px;
  font-weight: 400;
  line-height: 1;
}

/* Título: era top 73 com tag terminando em 44 -> respiro de 29px. */
.ritual-content h2 {
  margin: 29px 0 0;
  font-family: var(--display-font);
  font-size: 31px;
  line-height: 1.12;
}

/* Lista: era top 176; h2 (~2 linhas) terminava ~142 -> respiro ~34px. */
.ritual-list {
  display: grid;
  gap: 25px;
  width: 100%;
  margin: 34px 0 0;
  padding: 0;
  list-style: none;
}

/* Cada item: ícone (42px) + texto fluido. minmax(0,1fr) impede estouro em 320px. */
.ritual-list li {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 9px;
  min-height: 46px;
  align-items: center;
}

/* Ícone: círculo fixo; position:relative mantido p/ empilhar base+top localmente. */
.ritual-icon {
  position: relative;
  display: grid;
  width: 42px;
  height: 42px;
  place-items: center;
  border: 1px solid var(--deep-green);
  border-radius: 50%;
  background: var(--soft-lavender);
}

.ritual-icon img {
  width: 25px;
  height: 25px;
}

/* Sobreposição real e local: base preenche o círculo, top fica por cima. */
.ritual-icon .icon-base {
  position: absolute;
  inset: -1px;
  width: 42px;
  height: 42px;
}

.ritual-icon .icon-top {
  position: relative;
  z-index: 1;
  width: 21px;
  height: 21px;
}

.ritual-list p {
  /* Tópico em 2 níveis: título (display, maior, bold) + subtítulo (menor, leve). */
  display: flex;
  flex-direction: column;
  gap: 3px;
  margin: 0;
}
.ritual-list p strong {
  font-family: var(--display-font);
  font-size: 19px;
  font-weight: 700;
  line-height: 1.05;
  color: var(--deep-green);
}
.ritual-list p span {
  font-size: 15px;
  font-weight: 400;
  line-height: 1.3;
  color: var(--green);
}

/* CTA largura cheia: era 338px dentro de 360 (margem ~11px cada lado);
   na coluna fluida usa 100%. Era top 471; lista terminava ~435 -> respiro ~36px. */
.primary-cta {
  width: 100%;
  margin: 36px 0 0;
  gap: 10px;
  padding: 21px 32px;
  font-family: var(--display-font);
  font-size: 20px;
  line-height: 1;
}

.primary-cta img {
  width: 24px;
  height: 24px;
}

/* === Ingredientes inteligentes (mint) + card antioxidantes === */

/* Fundo full-bleed mint; o padding/centralizacao vem da regra global .pdp > * */
.smart-ingredients-section {
  /* respiro extra na base (abaixo do carrossel/controles) */
  padding-bottom: 72px;
  background: var(--mint-section);
  color: var(--green);
  font-family: var(--system-font);
  text-align: center;
}

/* Wrapper antes absoluto (360px) -> fluxo, ocupa a coluna (limitada a 440 no global) */
.smart-ingredients-inner {
  display: flex;
  flex-direction: column;
  width: 100%;
}

/* Bloco de copy: h2 + p centralizados */
.smart-ingredients-copy {
  width: 100%;
}

.smart-ingredients-copy h2 {
  margin: 0;
  font-family: var(--display-font);
  font-size: 25px;
  line-height: 1.29;
}

/* gap original entre h2 e p era margin:10px 0 0 */
.smart-ingredients-copy p {
  margin: 10px 0 0;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.48;
}

/* Card: era absoluto em top:246 dentro do inner -> margin-top traduz o respiro */
.antioxidants-card {
  width: 100%;
  margin-top: 28px;
  overflow: hidden;
  border-radius: 10px;
  text-align: left;
}

/* Foto: caixa 360x265 -> proporcao fluida, img cobre */
.antioxidants-card figure {
  width: 100%;
  margin: 0;
  aspect-ratio: 360 / 265;
  overflow: hidden;
}

.antioxidants-card figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Bloco mint embaixo. Altura fixa (189) vira fluida; padding-bottom (era 0) ganha
   ~35px pra preservar o respiro inferior que a altura fixa garantia */
.antioxidants-card > div {
  width: 100%;
  padding: 35px 29px 35px 37px;
  border-radius: 0 0 10px 10px;
  background: var(--mint-strong);
}

.antioxidants-card h3 {
  margin: 0;
  font-family: var(--display-font);
  font-size: 20px;
  line-height: 1.29;
}

/* divisor: width 294 (dentro do padding) -> 100% acompanha a largura util */
.antioxidants-card h3::after {
  display: block;
  width: 100%;
  height: 1px;
  margin: 9px 0 10px;
  background: var(--green);
  content: "";
}

/* paragrafo: width 294 -> 100% (a largura ja vem limitada pelo padding do div) */
.antioxidants-card p {
  width: 100%;
  margin: 0;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.48;
}

/* === Scoop (cream) copy + tabela nutricional + foto === */

/* Fundo full-bleed cream; o padding/centralizacao da coluna vem da regra global .pdp > * */
.scoop-section {
  background: var(--cream);
  color: var(--green);
}

/* Copy centralizado. Largura cheia (coluna ja limitada a 440 no global).
   No canvas era left:31 top:46 width:338 — o ritmo vira gap entre os blocos abaixo. */
.scoop-copy {
  text-align: center;
}

.scoop-copy h2 {
  margin: 0;
  font-family: var(--display-font);
  font-size: 31px;
  line-height: 1.15;
}

/* p tinha margin-top 18 no original */
.scoop-copy p {
  margin: 18px 0 0;
  font-size: 16px;
  line-height: 1.2;
}

/* Botao largura cheia (era 338px fixo); altura via min-height pra nao cortar texto que quebre.
   Base visual (cor/fundo/hover) vem do global; aqui so o box-model. */
.ingredients-button {
  width: 100%;
  min-height: 69px;
  margin-top: 19px;
  padding: 14px 28px;
  font-size: 16px;
}

/* Tabela: largura cheia ate ~376; espacamento do bloco acima vira margin-top (era top 327 vs copy em 46). */
.nutrition-table {
  width: 100%;
  max-width: 376px;
  margin: 32px auto 0;
  border: 1px solid var(--table-line);
  border-radius: 15px;
  overflow: hidden;
  color: #3c3c3c;
  font-size: 15px;
  line-height: 1.1;
}

/* Linha: 2 colunas (rotulo | valor) com espaco entre elas.
   minmax(0,1fr) impede estouro em 320px; sem white-space:nowrap o valor pode quebrar.
   Altura vira min-height + padding vertical pra acomodar texto em 2 linhas. */
.nutrition-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, auto);
  column-gap: 12px;
  align-items: center;
  min-height: 40px;
  padding: 8px 10px;
  border-bottom: 1px solid #191919;
}

/* Valor (2a coluna) alinhado a direita, podendo quebrar palavra longa sem estourar */
.nutrition-row > :last-child {
  text-align: right;
  overflow-wrap: anywhere;
}

.nutrition-head {
  color: var(--green);
  font-size: 16px;
  font-weight: 800;
}

.nutrition-row:last-child {
  border-bottom: 0;
}

/* Foto: caixa 306x392 (aspect 306/392 ~0.781), cantos 26.
   Sem translate no original => crop centralizado padrao (object-position 50% 50%).
   Espacamento do bloco acima vira margin-top (era top 768 vs tabela em 327). */
.scoop-photo {
  width: 100%;
  max-width: 306px;
  aspect-ratio: 306 / 392;
  margin: 32px auto 0;
  overflow: hidden;
  border-radius: 26px;
}

.scoop-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 50%;
}

/* === Creators (2 cards lado a lado: Luna | Natalia) === */

/* Wrapper: o global .pdp > * aplica flex coluna; aqui viramos LINHA com os 2 cards */
.creators-row {
  flex-direction: row;
  justify-content: center;
  align-items: flex-start;
  gap: 13px;
}

/* Card: era absoluto 169x286; agora flui e encolhe junto (nada de px fixo) */
.creator-card {
  position: relative;
  flex: 1 1 0;
  min-width: 0; /* permite encolher abaixo de 320px sem estourar */
  max-width: 200px;
  height: auto;
}

/* Foto: caixa fluida com a proporcao original 169x254; radius so no topo */
.creator-photo {
  position: relative;
  width: 100%;
  aspect-ratio: 169 / 254;
  height: auto;
  margin: 0;
  overflow: hidden;
  border-radius: 8px 8px 0 0;
}

/* img sempre cobre a caixa; o enquadramento vem do object-position calculado */
.creator-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Luna: caixa 169x254, img 182x300 translate(-10,-31).
   X: sobra 13px, deslocada 10 => 10/13 = 77% | Y: sobra 46px, deslocada 31 => 31/46 = 67% */
.luna-photo img {
  object-position: 77% 67%;
}

/* Natalia: caixa 169x254, img 228x280 translate(-29,0).
   X: sobra 59px, deslocada 29 => 29/59 = 49% | Y: sobra 26px, deslocada 0 => 0% */
.natalia-photo img {
  object-position: 49% 0%;
}

/* Handle: continua absoluto SOBRE a foto, ancorado no canto do card relativo */
.creator-handle {
  position: absolute;
  right: 6px;
  top: 8px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  height: 19px;
  padding: 0 6px;
  border-radius: 11px;
  background: var(--soft-lavender);
  color: #2b513e;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
}

.natalia-handle {
  right: 8px;
}

/* Footer: era absoluto sob a foto; agora flui (static) com radius embaixo */
.creator-footer {
  position: static;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 7px 13px;
  border-radius: 0 0 8px 8px;
  background: var(--testimonial-green);
  color: var(--green);
}

.creator-footer strong {
  font-family: var(--display-font);
  font-size: 12px;
  line-height: 1.05;
}

.creator-footer span {
  font-size: 11px;
  line-height: 1;
}

/* === Comparacao (titulo + paragrafo + imagem da tabela) === */

/* Faixa do bloco de texto. Centralizacao/coluna 440 vem da regra global .pdp > *.
   So definimos cor e alinhamento; nao recriamos largura nem centralizacao. */
.comparison-section {
  color: var(--green);
  text-align: center;
}

/* Titulo: preserva fonte/tamanho/line-height originais do canvas. */
.comparison-section h2 {
  margin: 0;
  font-family: var(--display-font);
  font-size: 31px;
  line-height: 1.15;
}

/* Paragrafo: mesmo ritmo do original (7px acima). */
.comparison-section p {
  margin: 7px 0 0;
  font-size: 18px;
  line-height: 1.4;
}

/* A figura e filho direto de .pdp, entao herda padding 48px no topo pela regra
   global. No canvas o gap titulo->imagem era ~26px (6400 - 6374), bem menor que
   os 48+48 que sobrariam entre as duas faixas. Zeramos o padding-top e usamos
   margin-top:26px para colar a imagem perto do titulo, preservando o ritmo. */
.comparison-image {
  padding-top: 0;
  /* calha lateral menor pra imagem ocupar mais largura no mobile */
  padding-inline: 8px;
  margin-top: 18px;
}

/* Caixa da tabela: ocupa mais largura no mobile e usa <picture> para trocar a arte no desktop. */
.comparison-image img {
  display: block;
  width: 100%;
  max-width: 440px;
  height: auto;
  margin-inline: auto;
  aspect-ratio: 318 / 270;
  /* E grafico/tabela informativa: nao cortar. contain preserva tudo legivel. */
  object-fit: contain;
}

.comparison-image picture {
  display: block;
  width: 100%;
}

/* === Depoimento (testimonial-green) foto + copy === */

/* Secao full-bleed: foto em cima, copy embaixo (a coluna ja flui pela regra global).
   Removidos position:absolute/top/left/width 400/height 820 do canvas. */
.testimonial-section {
  background: var(--testimonial-green);
  overflow: hidden;
  color: var(--green);
}

/* Foto da Renata: caixa fluida.
   Original 400x288 (~1.389) => aspect-ratio:400/288. */
.testimonial-photo {
  width: 100%;
  margin: 0;
  aspect-ratio: 400 / 288;
  overflow: hidden;
}

/* Crop convertido de translate(-7,-69) numa img 407x611 dentro da caixa 400x288:
   eixo X: sobra 7px (407-400), deslocada -7 => mostra ~100% da direita => object-position-x ~100%.
   eixo Y: sobra 323px (611-288), deslocada -69 => 69/323 ~= 21% => object-position-y ~21%. */
.testimonial-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 100% 21%;
}

/* Bloco de copy: alinhado a esquerda, mesmo padding do original (sem altura fixa 532).
   bg pode manter pois a secao ja e verde; mantido por seguranca. */
.testimonial-copy {
  padding: 37px 20px 0;
  text-align: left;
  border-radius: 0 0 8px 8px;
  background: var(--testimonial-green);
}

/* Logo "in my GREENS ERA": mantem proporcao; largura proposital de 172px, nao estoura a coluna. */
.greens-era {
  width: 172px;
  height: auto;
  max-width: 100%;
  margin: 0 0 20px;
  object-fit: contain;
}

.testimonial-copy h2 {
  margin: 0;
  font-family: var(--display-font);
  font-size: 27px;
  line-height: 1.18;
}

.testimonial-copy p {
  margin: 19px 0 0;
  font-size: 18px;
  line-height: 1.28;
}

/* strong/span ja eram block no original; mantidos como bloco com os mesmos ritmos verticais. */
.testimonial-copy strong {
  display: block;
  margin-top: 24px;
  font-family: var(--display-font);
  font-size: 21px;
  line-height: 1.1;
}

.testimonial-copy span {
  display: block;
  margin-top: 8px;
  font-size: 16px;
  line-height: 1.25;
}

/* === Videos de creators (widget Blessy Stories) === */
.video-stories-section {
  display: flex;
  justify-content: center;
  overflow: hidden;
  padding: 56px var(--gutter) 60px;
}

.video-stories-section script {
  display: none;
}

.video-stories-section blessy-stories {
  display: block;
  width: 100%;
  min-height: 100px;
  max-width: var(--desktop-max);
}

/* === Social (carrossel horizontal + 2 botoes) === */

/* Wrapper da secao: sem canvas absoluto. A coluna ja vem centralizada/limitada
   pela regra global; aqui so empilhamos o carrossel e os botoes em fluxo. */
/* Faixa social full-bleed: o slider passa de borda a borda, recortado. */
.social-section {
  display: flex;
  flex-direction: column;
  align-items: center;
  overflow: hidden;
  padding: 56px 0 60px;
}

/* Slider INFINITO (marquee): o JS duplica as imagens; a animação translada
   -50% (exatamente uma cópia) em loop contínuo, sem emenda. As imagens têm
   margin-right uniforme (em vez de gap) pra a emenda casar perfeita. */
.social-track {
  display: flex;
  width: max-content;
  user-select: none;
  animation: none;
}
.social-track.is-marquee-ready {
  animation: social-marquee 55s linear infinite;
}
.social-track.is-marquee-ready:hover {
  animation-play-state: paused;
}
.social-track img {
  flex: 0 0 auto;
  width: 210px;
  margin-right: 16px;
  aspect-ratio: 270 / 342;
  height: auto;
  border-radius: 15px;
  object-fit: cover;
  pointer-events: none;
}
@keyframes social-marquee {
  to {
    transform: translateX(-50%);
  }
}

/* Ações: dois círculos centralizados abaixo do slider. */
.social-actions {
  display: flex;
  justify-content: center;
  gap: 30px;
  margin-top: 40px;
}

.social-actions a {
  display: grid;
  place-items: center;
  width: 80px;
  height: 80px;
  border: 2px solid var(--deep-green);
  border-radius: 50%;
  color: var(--deep-green);
  text-decoration: none;
}

.social-actions a img {
  width: 38px;
  height: 38px;
  margin: 0;
}


/* ===========================================================================
   DESKTOP (>= 768px) — implementar a partir do Figma desktop.
   Até lá, a coluna mobile (max 440px) permanece centralizada e legível.
   =========================================================================== */
/* ===========================================================================
   DESKTOP — FUNDAÇÃO (>= 768px)
   Cada seção centraliza seu conteúdo numa coluna ampla (--desktop-max) e
   define o próprio layout (grid/linha) nos blocos por-seção mais abaixo.
   O fundo das faixas continua full-bleed; só o conteúdo é limitado/centralizado.
   =========================================================================== */
@media (min-width: 1024px) {
  .pdp > * {
    padding-inline: max(var(--desktop-gutter), calc((100% - var(--desktop-max)) / 2));
    align-items: stretch;
  }
  .pdp > * > * {
    /* No desktop o tamanho dos itens é definido por cada seção (grid/linha). */
    max-width: none;
  }
}

/* === Beneficios DESKTOP === */
/* A .benefits-section ja e grid no mobile (2col). No desktop viramos 3 colunas:
   [cards esquerda] [blob central] [cards direita]. A intro ocupa as 3 colunas.
   A centralizacao da coluna (--desktop-max) ja vem da fundacao (.pdp > *). */
@media (min-width: 1024px) {
  .benefits-section {
    /* Colunas laterais fixas (cards) + central fluida (blob ~433px) */
    grid-template-columns: 297px auto 297px;
    /* Linha 1 = intro; linhas 2 e 3 = pares de cards (blob cobre as duas) */
    grid-template-rows: auto auto auto;
    column-gap: 56px;
    row-gap: 48px;
    align-items: start;
    justify-content: center;
  }

  /* Intro: span nas 3 colunas, centralizada, com largura de leitura ~763px */
  .benefits-intro {
    grid-column: 1 / -1;
    max-width: 763px;
    margin: 0 auto;
  }
  .benefits-intro h1 {
    font-size: 38px;
  }
  .benefits-intro p {
    margin-top: 14px;
    font-size: 18px;
  }

  /* Cards CENTRALIZADOS no desktop (igual ao Figma): ícone, título e texto. */
  .benefit-card {
    text-align: center;
    align-self: start;
  }
  .benefit-icon {
    margin: 0 auto;
  }
  .benefit-card h2 {
    margin-top: 14px;
    font-size: 26px;
  }
  .benefit-card p {
    margin-top: 12px;
    font-size: 17px;
    line-height: 1.25;
  }
  /* zera ajustes finos do mobile que nao valem no desktop */
  .benefit-card-top p,
  .benefit-card-bottom p {
    padding: 0;
  }
  .benefit-card-bottom p {
    margin-top: 12px;
  }

  /* Coluna esquerda: bloat (linha 2) + energy (linha 3) */
  .benefit-card-bloat {
    grid-column: 1;
    grid-row: 2;
  }
  .benefit-card-energy {
    grid-column: 1;
    grid-row: 3;
  }

  /* Coluna direita: health (linha 2) + mind (linha 3) */
  .benefit-card-health {
    grid-column: 3;
    grid-row: 2;
  }
  .benefit-card-mind {
    grid-column: 3;
    grid-row: 3;
  }

  /* Blob no centro, cobrindo as duas linhas de cards, centralizado vertical */
  .benefit-blob {
    grid-column: 2;
    grid-row: 2 / 4;
    align-self: center;
    width: 100%;
    max-width: 433px;
    margin: 0;
  }
}

/* === Deficiencia DESKTOP === */

/* MOBILE: o banner largo (piquenique) so existe no desktop. Esconde no celular. */
.deficiency-banner {
  display: none;
}

@media (min-width: 1024px) {
  /* Secao = 2 linhas: banner (full) em cima, painel (3 colunas) embaixo. */
  .deficiency-section {
    display: grid;
    grid-template-rows: auto auto;
    justify-items: center;
    row-gap: 40px;
    /* Faixa de fundo verde (full-bleed). */
    background: #BFF9A4;
  }

  /* Foto retrato mobile some; quem manda no desktop e o banner largo. */
  .deficiency-photo {
    display: none;
  }

  /* Banner largo: ocupa a coluna inteira, proporcao do Figma (~1172x445). */
  .deficiency-banner {
    display: block;
    width: 100%;
    max-width: 1172px;
    aspect-ratio: 1172 / 445;
    overflow: hidden;
    border-radius: 30px;
  }
  .deficiency-banner img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  /* Painel perde o fundo lime e vira grid de 3 colunas:
     col1 (titulo+paragrafo+cta, ~1.4fr) | col2 stat 70% | col3 stat 87%. */
  .deficiency-panel {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr;
    column-gap: 56px;
    align-items: start;
    width: 100%;
    max-width: 1172px;
    padding: 0;
    border-radius: 0;
    background: transparent;
    text-align: left;
  }

  /* Promove os 2 .deficiency-stat a itens diretos do grid do painel. */
  .deficiency-stats {
    display: contents;
  }

  /* Titulo de display maior no desktop (col1). */
  .deficiency-panel h2 {
    font-size: 40px;
    line-height: 1.04;
  }

  /* Paragrafo solto na col1, sem trava de largura nem centralizacao. */
  .deficiency-panel > p {
    max-width: none;
    margin: 18px 0 0;
    font-size: 18px;
  }

  /* CTA com tamanho de conteudo (pill), nao mais largura cheia. */
  .deficiency-cta {
    width: auto;
    margin-top: 26px;
    min-height: 60px;
    padding: 0 30px;
    font-size: 18px;
  }

  /* Cards de stat perdem caixa amarela/borda: so numero grande verde + texto. */
  .deficiency-stat {
    display: block;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
  }

  /* Numeros 70%/87% grandes, verde, alinhados a esquerda. */
  .deficiency-stat strong {
    display: block;
    color: var(--green);
    font-size: 68px;
    line-height: 1;
  }

  .deficiency-stat p {
    margin: 16px 0 0;
    font-size: 16px;
    line-height: 1.2;
  }
}

/* === Testada DESKTOP === */
/* A seção .tested-section já é full-bleed e recebe da fundação o padding lateral
   que centraliza o conteúdo na coluna de --desktop-max. Aqui só rearranjo os
   filhos: copy centralizada estreita + os 4 cards numa linha (1x4). HTML intacto. */

@media (min-width: 1024px) {
  /* Copy: título + subtítulo centralizados num bloco estreito (~748px). */
  .tested-copy {
    max-width: 748px;
    margin-inline: auto;
  }

  /* Título numa única linha (igual à produção, ~44px) — desliga o <br> do mobile. */
  .tested-copy h2 {
    font-size: 44px;
  }
  .tested-copy h2 br {
    display: none;
  }

  /* Subtítulo: leve aumento, mantendo a proporção do mobile. */
  .tested-copy p {
    margin-top: 16px;
    font-size: 19px;
  }

  /* Grade vira 1x4 (uma linha). Altura pelo conteúdo (sem min-height),
     itens esticam à mesma altura via stretch. Mais respiro acima e entre cards. */
  .tested-grid {
    /* Cards mais estreitos (igual produção), centralizados com mais respiro. */
    grid-template-columns: repeat(4, minmax(0, 270px));
    justify-content: center;
    gap: 28px;
    margin-top: 40px;
    align-items: stretch;
  }

  /* Cards: sem o teto/altura mínima do mobile — a altura igual entre os 4 vem
     do stretch da grade. Mais padding interno no porte desktop. */
  .tested-card,
  .tested-card-short {
    min-height: 0;
    padding: 32px 20px;
  }

  /* Círculo de stat maior (~233px) seguindo o Figma. img e box do ícone juntos. */
  .tested-card > img,
  .tested-icon {
    width: 200px;
    height: 200px;
    margin-bottom: 22px;
  }

  /* O crop local dos ícones escala junto (mantém a sobreposição real do glifo). */
  .tested-icon img {
    height: 200px;
  }

  .tested-icon-65 img {
    left: 15px;
    width: 185px;
  }

  .tested-icon-56 img {
    left: 20px;
    width: 180px;
  }

  /* Texto do card levemente mais comprimido (igual produção). */
  .tested-card p {
    font-size: 16px;
    line-height: 1.3;
  }
}

/* === Ritual DESKTOP === */
/* Mobile = coluna unica (foto em cima, conteudo embaixo). Aqui so o >=768px:
   2 colunas [foto ~504px] [conteudo 1fr], centradas pela fundacao (.pdp > *). */

@media (min-width: 1024px) {
  /* Secao vira grid de 2 colunas; gap generoso e itens centrados na vertical.
     align-items:center sobrepoe o stretch herdado da fundacao para esta secao. */
  .ritual-section {
    display: grid;
    grid-template-columns: 504px 1fr;
    gap: 80px;
    align-items: center;
  }

  /* Foto retrato a esquerda: largura fixa, altura limitada (~700px) para nao esticar.
     Troca o crop mobile (360/351) por um portrait e recentra o sujeito. */
  .ritual-photo {
    width: 504px;
    max-width: 100%;
    aspect-ratio: 504 / 700;
    border-radius: 48px;
  }

  .ritual-photo img {
    object-position: 50% 22%;
  }

  /* Coluna de conteudo nao precisa de mais nada alem do tamanho herdado;
     a tag/h2/lista/CTA escalam abaixo. */
  .ritual-content {
    max-width: 540px;
  }

  /* Tag maior, com mais respiro interno. */
  .tag {
    width: auto;
    height: auto;
    padding: 12px 24px;
    font-size: 20px;
  }

  /* Titulo display bem maior no desktop. */
  .ritual-content h2 {
    margin-top: 24px;
    font-size: 42px;
    line-height: 1.1;
  }

  /* Lista com mais espaco entre itens. */
  .ritual-list {
    gap: 28px;
    margin-top: 36px;
  }

  /* Itens maiores: icone 52px + texto. */
  .ritual-list li {
    grid-template-columns: 52px minmax(0, 1fr);
    gap: 16px;
    min-height: 52px;
  }

  .ritual-icon {
    width: 52px;
    height: 52px;
  }

  .ritual-icon img {
    width: 30px;
    height: 30px;
  }

  .ritual-icon .icon-base {
    width: 52px;
    height: 52px;
  }

  .ritual-icon .icon-top {
    width: 26px;
    height: 26px;
  }

  .ritual-list p strong {
    font-size: 22px;
  }
  .ritual-list p span {
    font-size: 16px;
  }

  /* CTA inline (nao mais largura cheia): ajusta ao texto, alinhado a esquerda. */
  .ritual-content .primary-cta {
    width: auto;
    align-self: flex-start;
    margin-top: 40px;
    padding: 22px 40px;
    font-size: 22px;
  }
}

/* === Ingredientes inteligentes DESKTOP === */

/* ---------------------------------------------------------------------------
   MOBILE — conteudo novo: os 3 cards viram um slider horizontal.
   .ingredients-track passa de empilhamento (cada card com margin-top) para
   uma linha rolavel; cada .antioxidants-card vira item de slider (mostra 1 +
   espia o proximo). O bloco de copy continua centralizado em cima.
   --------------------------------------------------------------------------- */
.ingredients-track {
  display: flex;
  gap: 16px;
  margin-top: 28px; /* respiro que antes vinha do margin-top do 1o card */
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.ingredients-track::-webkit-scrollbar {
  display: none;
}

/* Cada card vira item do slider: largura fixa do flex (zera o margin-top de
   empilhamento que existia no mobile antigo). Visual do card permanece. */
.ingredients-track .antioxidants-card {
  flex: 0 0 82%;
  margin-top: 0;
  scroll-snap-align: start;
}

/* Controles do carrossel (setas à esquerda, dots à direita).
   Visíveis também no mobile: a pessoa clica pra passar os cards (ingredientes
   e reviews do greens club), além do swipe. */
.cards-controls {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 22px;
}
.cards-arrows {
  display: flex;
  gap: 12px;
}
.cards-arrow {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border: 1.5px solid var(--green);
  border-radius: 50%;
  background: transparent;
  color: var(--green);
  font-size: 20px;
  line-height: 1;
  transition: background 150ms ease, color 150ms ease, opacity 150ms ease;
}
.cards-arrow:hover {
  background: var(--green);
  color: #ffffff;
}
.cards-arrow:disabled {
  opacity: 0.35;
  cursor: default;
}
.cards-dots {
  display: flex;
  align-items: center;
  gap: 8px;
}
.cards-dot {
  width: 9px;
  height: 9px;
  padding: 0;
  border-radius: 50%;
  background: #c2d3c4;
  transition: background 150ms ease, transform 150ms ease;
}
.cards-dot.is-active {
  background: var(--green);
  transform: scale(1.25);
}

/* ---------------------------------------------------------------------------
   DESKTOP (>= 768px): cabecalho em 2 colunas (titulo | paragrafo) e os 3
   cards numa unica linha, sem slider. A coluna ja vem centralizada da
   fundacao (.pdp > * recebe padding lateral ate --desktop-max).
   --------------------------------------------------------------------------- */
@media (min-width: 1024px) {
  /* Inner: copy em cima, track de cards embaixo, alinhados a esquerda */
  .smart-ingredients-section {
    text-align: left;
  }

  .smart-ingredients-inner {
    gap: 48px;
  }

  /* Cabecalho em 2 colunas: titulo (~535) | paragrafo (~555) */
  .smart-ingredients-copy {
    display: grid;
    grid-template-columns: minmax(0, 535fr) minmax(0, 555fr);
    align-items: start;
    column-gap: 40px;
  }

  .smart-ingredients-copy h2 {
    font-size: 40px;
    line-height: 1.15;
  }

  .smart-ingredients-copy p {
    margin: 6px 0 0; /* alinha o topo do texto com o titulo */
    max-width: 555px;
    font-size: 18px;
    line-height: 1.5;
  }

  /* Carrossel: 3 cards por vez (rolagem + snap); setas e dots controlam. */
  .ingredients-track {
    display: flex;
    gap: 30px;
    margin-top: 0;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
  }
  .ingredients-track::-webkit-scrollbar {
    display: none;
  }

  /* Cada card = 1/3 da largura visível (3 por vez), alturas iguais. */
  .ingredients-track .antioxidants-card {
    flex: 0 0 calc((100% - 60px) / 3);
    width: auto;
    scroll-snap-align: start;
    display: flex;
    flex-direction: column;
  }

  /* Mostra as setas + dots no desktop. */
  .cards-controls {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 36px;
  }

  /* Bloco de texto cresce para igualar a altura entre os 3 cards */
  .antioxidants-card > div {
    flex: 1;
    padding: 32px 34px 36px;
  }

  .antioxidants-card h3 {
    font-size: 23px;
  }

  .antioxidants-card p {
    font-size: 17px;
  }
}

/* === Scoop DESKTOP === */
/* So regras desktop: o conteudo novo (tabela) ja tem CSS mobile no styles.css. */

@media (min-width: 1024px) {
  /* 3 colunas: copy (~338) | tabela (1fr, ~467) | foto (~306).
     A centralizacao na coluna --desktop-max vem da fundacao (.pdp > *);
     aqui so viramos a secao em grid e posicionamos os 3 filhos.
     align-items:start = blocos colados no topo, como no Figma. */
  .scoop-section {
    display: grid;
    grid-template-columns: 338px 1fr 306px;
    gap: 40px;
    align-items: start;
  }

  /* Copy passa a alinhar a esquerda (era center no mobile) */
  .scoop-copy {
    text-align: left;
  }

  /* h2 maior no desktop, seguindo a proporcao do screenshot */
  .scoop-copy h2 {
    font-size: 36px;
  }

  .scoop-copy p {
    margin-top: 20px;
    font-size: 16px;
    line-height: 1.35;
  }

  /* Botao volta a ser auto (nao full-width); margin maior pra respirar */
  .ingredients-button {
    width: auto;
    margin-top: 28px;
  }

  /* Tabela ocupa a coluna do meio inteira: solta o teto mobile (376) e a margin auto */
  .nutrition-table {
    max-width: none;
    margin: 0;
    font-size: 16px;
  }

  /* Linhas com mais respiro vertical na coluna mais larga */
  .nutrition-row {
    min-height: 44px;
    padding: 11px 20px;
  }

  /* Foto a direita: solta o teto mobile e a margin; aspect 306/416 (mais alta que no mobile) */
  .scoop-photo {
    max-width: none;
    margin: 0;
    aspect-ratio: 306 / 416;
  }
}

/* === Greens Club (secao nova) DESKTOP === */
/* Esta secao e nova: o CSS mobile completo vem primeiro (fora do @media),
   depois o bloco desktop. Mesmo HTML em ambos; so muda o arranjo via CSS. */

/* ---------- MOBILE (coluna estreita) ---------- */

/* Cartao branco com borda verde fina e cantos arredondados */
.greensclub-card {
  position: relative;
  background: #ffffff;
  border: 1.5px solid var(--green);
  border-radius: 24px;
  padding: 28px 20px;
}

/* Selo verde encaixado flush no canto superior direito (alinhado à aresta). */
.greensclub-badge {
  position: absolute;
  top: 0;
  right: 0;
  width: 90px;
  height: auto;
}

/* Cabecalho centralizado */
.greensclub-head {
  text-align: center;
}

/* Estrelas + texto pequeno de avaliacoes */
.greensclub-rating {
  margin: 0;
  font-size: 13px;
  color: var(--green);
}
.greensclub-rating .stars {
  color: #b98cff;
  letter-spacing: 1px;
}

/* Titulo de display, verde, grande no mobile */
.greensclub-head h2 {
  margin: 8px 0 6px;
  font-family: var(--display-font);
  font-weight: 700;
  font-size: 30px;
  line-height: 1.1;
  color: var(--green);
}

/* Subtitulo menor, tom verde/cinza */
.greensclub-sub {
  margin: 0;
  font-size: 14px;
  color: #6b8378;
}

/* Tabs: linha rolavel horizontal no mobile */
.greensclub-tabs {
  display: flex;
  gap: 10px;
  margin-top: 22px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.greensclub-tabs::-webkit-scrollbar {
  display: none;
}

/* Pilula de filtro */
.greensclub-tab {
  flex: 0 0 auto;
  border: 1px solid var(--green);
  border-radius: 999px;
  padding: 10px 20px;
  background: #ffffff;
  font-family: var(--display-font);
  font-size: 15px;
  color: var(--green);
  white-space: nowrap;
  cursor: pointer;
}
.greensclub-tab.is-active {
  background: var(--soft-lavender);
}

/* Reviews: slider horizontal com snap no mobile */
.greensclub-reviews {
  display: flex;
  gap: 16px;
  margin-top: 24px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.greensclub-reviews::-webkit-scrollbar {
  display: none;
}

/* Cada card de review: coluna flex; com o track esticando, todos ficam com a
   mesma altura e o nome encosta no rodapé (sem o texto colar no nome). */
.greensclub-review {
  flex: 0 0 80%;
  scroll-snap-align: start;
  display: flex;
  flex-direction: column;
  text-align: left;
}
.greensclub-review .stars {
  color: #b98cff;
  letter-spacing: 1px;
  font-size: 13px;
}
.greensclub-review h3 {
  margin: 6px 0 8px;
  font-family: var(--body-font);
  font-weight: 800;
  font-size: 16px;
  color: var(--deep-green);
}
.greensclub-review p {
  margin: 0 0 14px;
  font-size: 14px;
  line-height: 1.45;
  color: #6b8378;
}
/* Trecho em negrito dentro do depoimento mantém a cor do parágrafo. */
.greensclub-review p strong {
  color: inherit;
  font-weight: 700;
}
/* Nome da autora ancorado no rodapé do card. */
.greensclub-review-name {
  margin-top: auto;
  font-size: 14px;
  color: var(--deep-green);
}

/* ---------- DESKTOP (>= 768px) ---------- */
@media (min-width: 1024px) {
  /* Cartao largo (centralizado pela fundacao) com respiro maior */
  .greensclub-card {
    padding: 70px 110px;
    border-radius: 32px;
  }

  /* Selo encaixado flush no canto superior direito (igual ao Figma). */
  .greensclub-badge {
    width: 132px;
    top: 0;
    right: 0;
  }

  /* Titulo bem grande no desktop */
  .greensclub-head h2 {
    font-size: 44px;
    margin: 12px 0 10px;
  }
  .greensclub-rating {
    font-size: 15px;
  }
  .greensclub-sub {
    font-size: 16px;
  }

  /* Tabs centralizadas numa linha, sem scroll */
  .greensclub-tabs {
    justify-content: center;
    gap: 24px;
    margin-top: 32px;
    overflow: visible;
  }
  .greensclub-tab {
    padding: 12px 30px;
    font-size: 17px;
  }

  /* Reviews: carrossel (3 por vez) com setas/dots — comporta os 4 depoimentos. */
  .greensclub-reviews {
    display: flex;
    gap: 56px;
    margin-top: 44px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
  }
  .greensclub-reviews::-webkit-scrollbar {
    display: none;
  }
  .greensclub-review {
    flex: 0 0 calc((100% - 112px) / 3);
    max-width: none;
    scroll-snap-align: start;
  }
}

/* === Creators DESKTOP === */

/* -----------------------------------------------------------------------------
   MOBILE — conteudo novo (4 creators).
   A regra mobile antiga em styles.css usava flex:1 1 0 (2 cards iguais), que
   estoura com 4. Aqui o .creators-row vira SLIDER horizontal: mostra ~2 cards
   + espia o terceiro, com snap e barra escondida (mesma convencao do .social-track).
   -------------------------------------------------------------------------- */
.creators-row {
  flex-direction: row;
  justify-content: flex-start; /* desencosta do center pra rolar a partir da esquerda */
  align-items: flex-start;
  gap: 13px;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: none;
  scroll-padding-inline: var(--gutter);
  scrollbar-width: none;        /* Firefox/legado */
  -ms-overflow-style: none;
}

/* esconde a barra de rolagem (WebKit) */
.creators-row::-webkit-scrollbar {
  display: none;
}

/* Card: deixa de ser flex:1 1 0; vira largura fixa (~46% => 2 cards + espia). */
.creator-card {
  flex: 0 0 46%;
  max-width: none;       /* solta o teto de 200px do mobile antigo */
  min-width: 0;
  scroll-snap-align: none;
}

/* Fotos novas (Bia/Ana): recortes ja prontos, so cobrem a caixa centralizados. */
.bia-photo img,
.ana-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

/* -----------------------------------------------------------------------------
   DESKTOP (>= 768px)
   Os 4 cards numa LINHA: 4 colunas iguais (~292px dentro da coluna de 1300px),
   sem slider. A centralizacao da coluna ja vem da fundacao (.pdp > *).
   -------------------------------------------------------------------------- */
@media (min-width: 1024px) {
  /* Vira grid de 4 colunas iguais; sem scroll/snap. */
  .creators-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 22px;
    justify-content: stretch;
    align-items: start;
    overflow: visible;          /* desliga o slider do mobile */
    scroll-snap-type: none;
  }

  /* Card volta a preencher a coluna do grid (sem flex-basis fixo). */
  .creator-card {
    flex: initial;
    max-width: none;
  }

  /* Foto maior na proporcao do Figma desktop (~292x438). */
  .creator-photo {
    aspect-ratio: 292 / 438;
    border-radius: 12px 12px 0 0;
  }

  /* Handle um pouco maior e mais afastado da borda no card grande. */
  .creator-handle {
    right: 10px;
    top: 12px;
    height: 22px;
    padding: 0 9px;
    border-radius: 12px;
    font-size: 12px;
  }

  .natalia-handle {
    right: 12px;
  }

  /* Footer com mais respiro e textos levemente maiores. */
  .creator-footer {
    padding: 11px 16px;
    border-radius: 0 0 12px 12px;
  }

  .creator-footer strong {
    font-size: 16px;
  }

  .creator-footer span {
    font-size: 13px;
  }
}

/* === Comparacao DESKTOP === */

@media (min-width: 1024px) {
  /* Titulo "Blessy vs. outras" maior e centralizado. */
  .comparison-section h2 {
    font-size: 40px;
  }
  .comparison-section p {
    max-width: 660px;
    margin-inline: auto;
  }

  /* O <picture> entrega só a imagem adequada para a viewport. */
  .comparison-image-responsive {
    padding-top: 8px;
  }
  .comparison-image-responsive img {
    width: 100%;
    max-width: 1151px;
    margin-inline: auto;
    height: auto;
    aspect-ratio: 1151 / 476;
    object-fit: contain;
  }
}

/* === Depoimento DESKTOP === */
/* Sem regras mobile aqui: o conteudo desta secao ja existe e esta estilizado no styles.css.
   Abaixo so o layout desktop (>=768px). */

@media (min-width: 1024px) {
  /* Vira 2 colunas: foto da Renata a esquerda (largura fixa ~641px) e copy a direita (resto).
     A fundacao (.pdp > *) ja centraliza a coluna --desktop-max e da padding lateral;
     aqui so trocamos flex-coluna por grid e zeramos o padding vertical do base
     (a faixa verde encosta na foto/copy, como no Figma). */
  .testimonial-section {
    display: grid;
    grid-template-columns: 44fr 56fr;
    align-items: stretch;
    column-gap: 0;
    /* FULL-BLEED: foto + painel verde ocupam a tela toda (sem a trava de
       --desktop-max da fundação). A foto cola na borda esquerda. */
    padding: 0;
  }

  /* Foto a esquerda: ocupa toda a altura da linha (a copy define a altura) e
     volta a proporcao alta do desktop (~641/756). */
  .testimonial-photo {
    height: 100%;
    aspect-ratio: 641 / 756;
  }

  .testimonial-photo img {
    /* Centraliza o crop no desktop (rosto da Renata) em vez do object-position mobile. */
    object-position: 50% 20%;
  }

  /* Copy a direita: fundo verde, padding generoso, conteudo alinhado ao topo. */
  .testimonial-copy {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 72px 96px;
    border-radius: 0;
  }

  /* Logo "in my GREENS ERA" alinhada à esquerda (como no Figma). */
  .greens-era {
    width: 196px;
    margin: 0 0 28px;
  }

  /* Título de display: tamanho mais contido (estava grande demais). */
  .testimonial-copy h2 {
    font-size: 34px;
    line-height: 1.18;
  }

  .testimonial-copy p {
    margin-top: 24px;
    font-size: 17px;
    line-height: 1.5;
  }

  /* Assinatura (nome + funcao). */
  .testimonial-copy strong {
    margin-top: 32px;
    font-size: 24px;
  }

  .testimonial-copy span {
    margin-top: 10px;
    font-size: 17px;
  }
}

/* === Social DESKTOP === */
/* Mudancas minimas: a fundacao ja centraliza a faixa na coluna --desktop-max.
   Aqui so dou respiro vertical, aumento levemente os cards e mantenho o carrossel
   + os dois botoes sociais alinhados ao inicio (igual ao mobile). */

@media (min-width: 1024px) {
  /* Full-bleed (vence o padding lateral da fundação) + mais respiro vertical. */
  .social-section {
    padding-inline: 0;
    padding-block: 64px 72px;
  }

  /* Imagens um pouco maiores no desktop (margin uniforme mantém o loop perfeito). */
  .social-track img {
    width: 240px;
    margin-right: 20px;
    border-radius: 18px;
  }

  .social-actions {
    margin-top: 44px;
    gap: 24px;
  }

  .video-stories-section {
    padding: 64px var(--desktop-gutter) 72px;
  }
}


@media (prefers-reduced-motion: reduce) {
  .launch-extra-sections,
  .launch-extra-sections *,
  .launch-extra-sections *::before,
  .launch-extra-sections *::after,
  .site-footer,
  .site-footer *,
  .site-footer *::before,
  .site-footer *::after,
  .ing-modal,
  .ing-modal *,
  .ing-modal *::before,
  .ing-modal *::after {
    scroll-behavior: auto !important;
    transition-duration: 0.001ms !important;
    animation-duration: 0.001ms !important;
  }
}

/* ===========================================================================
   AJUSTES FINOS (pós-integração)
   =========================================================================== */

/* Greens Club mobile: selo menor pra não encostar no título/avaliações. */
.greensclub-badge {
  width: 64px;
}

@media (min-width: 1024px) {
  /* Deficiência desktop: agrupa título + parágrafo + CTA na coluna 1;
     70% na coluna 2 e 87% na coluna 3. (Só display:contents espalhava os
     itens na ordem do documento, quebrando o layout em 3 colunas.) */
  .deficiency-panel {
    grid-template-columns: 1.5fr 1fr 1fr;
    column-gap: 48px;
    row-gap: 0;
    align-items: start;
  }
  .deficiency-panel h2 { grid-column: 1; grid-row: 1; }
  .deficiency-panel > p { grid-column: 1; grid-row: 2; }
  .deficiency-cta { grid-column: 1; grid-row: 3; justify-self: start; }
  .deficiency-stats { display: contents; }
  .deficiency-stat:nth-child(1) { grid-column: 2; grid-row: 1 / 4; align-self: start; }
  .deficiency-stat:nth-child(2) { grid-column: 3; grid-row: 1 / 4; align-self: start; }

  /* Selo volta ao tamanho cheio no desktop. */
  .greensclub-badge {
    width: 132px;
  }
}

/* ===========================================================================
   FOOTER (#1D6B4D) — mobile-first; vira 3 colunas no desktop
   =========================================================================== */
.site-footer {
  background: #1d6b4d;
  color: #effFe9;
  font-family: var(--system-font);
}

.footer-inner {
  width: 100%;
  max-width: var(--desktop-max);
  margin: 0 auto;
  padding: 56px var(--gutter) 40px;
}

/* Topo: logo + colunas de links. Mobile = empilhado e centralizado. */
.footer-top {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  text-align: center;
}

.footer-logo img {
  width: 200px;
  height: auto;
}

.footer-col,
.footer-col-side,
.footer-col-side ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.footer-col,
.footer-col-side {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}

.footer-col-side ul {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.footer-col a {
  color: #effee9;
  text-decoration: none;
  font-size: 16px;
  transition: opacity 150ms ease;
}

.footer-col a:hover {
  opacity: 0.72;
}

/* Redes sociais (glifos cream) */
.footer-social {
  display: flex;
  align-items: center;
  gap: 22px;
}

.footer-social a {
  display: inline-flex;
  color: #effee9;
  transition: opacity 150ms ease;
}

.footer-social a:hover {
  opacity: 0.72;
}

.footer-social svg {
  width: 22px;
  height: 22px;
}

/* Base: copyright + pagamentos + reclame aqui. Mobile = empilhado centralizado. */
.footer-bottom {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 26px;
  margin-top: 44px;
  text-align: center;
}

.footer-copy {
  margin: 0;
  font-size: 15px;
}

.footer-payments {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
}

.footer-payments img {
  height: 26px;
  width: auto;
  border-radius: 4px;
}

/* Selo Reclame Aqui — versão estática limpa (sem o script bugado da produção). */
.footer-ra {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  width: 96px;
  height: 96px;
  padding: 9px;
  border-radius: 8px;
  background: #ffffff;
  text-decoration: none;
}

.footer-ra-stamp {
  width: 40px;
  height: 40px;
}

.footer-ra-label {
  color: #2a8a4a;
  font-family: var(--display-font);
  font-weight: 700;
  font-size: 13px;
}

.footer-ra-logo {
  width: 78px;
  height: auto;
}

/* Wrappers novos do topo (marca = logo + social / links = 3 colunas).
   Mobile = empilhado e centralizado; o desktop (abaixo) vira grid. */
.footer-brand,
.footer-links {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}

@media (min-width: 1024px) {
  /* Gap horizontal único (DRY) pro grid pai E pro subgrid de links, pra que
     as colunas nunca saiam de sincronia com as trilhas do grid pai. */
  .footer-top { --footer-col-gap: 48px; }

  .footer-inner {
    padding: 72px var(--desktop-gutter) 40px;
  }

  /* GRID PRINCIPAL: trilha de MARCA (flexível) + 3 trilhas de links iguais.
     O antigo margin-right:auto sumiu — o espaço livre virou a trilha de marca,
     distribuída pelo grid em vez de jogada num único vão. */
  .footer-top {
    display: grid;
    grid-template-columns: minmax(220px, 1.1fr) repeat(3, minmax(0, 1fr));
    align-items: start;
    column-gap: var(--footer-col-gap);
    row-gap: 0;
    text-align: left;
  }

  /* Bloco de marca: logo + sociais empilhados, alinhados à esquerda e ao topo. */
  .footer-brand {
    align-items: flex-start;
    gap: 28px;
  }
  .footer-logo { margin: 0; }          /* mata o margin-right:auto -> fim do vão */
  .footer-logo img { width: 220px; }
  .footer-social {
    justify-content: flex-start;
    gap: 20px;
  }

  /* SUBGRID DE LINKS: ocupa as 3 trilhas de links e repete o MESMO gap, então
     as 3 colunas coincidem exatamente com as trilhas 2/3/4 do grid pai. */
  .footer-links {
    display: grid;
    grid-column: 2 / -1;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    column-gap: var(--footer-col-gap);
    row-gap: 0;
    align-items: start;
  }

  /* Colunas: topo alinhado, ritmo vertical uniforme (sobrescreve o center mobile). */
  .footer-col,
  .footer-col-side {
    align-items: flex-start;
    gap: 18px;
  }
  .footer-col a {
    font-size: 15px;
    line-height: 1.4;
  }

  /* LINHA DE BAIXO: copyright (esq) | pagamentos (centro) | selo RA (dir).
     Grid 1fr auto 1fr + align-items:center centra o copyright verticalmente
     no selo RA de 96px; border-top dá uma base reta alinhada ao container. */
  .footer-bottom {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    column-gap: 24px;
    row-gap: 0;
    margin-top: 64px;
    padding-top: 28px;
    border-top: 1px solid rgba(239, 254, 233, 0.14);
    text-align: left;
  }
  .footer-copy {
    justify-self: start;
    font-size: 14px;
    opacity: 0.9;
  }
  .footer-payments {
    justify-self: center;
    flex-wrap: nowrap;
  }
  .footer-ra {
    justify-self: end;
  }
}

/* ===========================================================================
   AJUSTES DE ESPAÇAMENTO — MOBILE (< 1024px)
   Reduz os gaps entre as primeiras seções e afina a seção de comparação.
   O desktop mantém os valores das regras-base.
   =========================================================================== */
@media (max-width: 1023px) {
  /* Gap 1ª -> 2ª seção (benefícios -> deficiência) menor. */
  .benefits-section {
    padding-bottom: 44px;
  }
  .deficiency-section {
    padding-top: 40px;
    /* Gap 2ª -> 3ª seção (deficiência -> testada) menor. */
    padding-bottom: 44px;
  }
  .tested-section {
    padding-top: 48px;
  }

  /* Comparação: menos respiro no topo e menos espaço até a imagem da tabela. */
  .comparison-section {
    padding-top: 28px;
    padding-bottom: 12px;
  }
  /* Descrição um pouco menor (o título fica igual). */
  .comparison-section p {
    font-size: 15px;
  }

  .comparison-image {
    margin-top: 10px;
    padding-bottom: 24px;
  }

  .comparison-image img {
    height: auto;
    object-fit: contain;
  }

  .testimonial-section {
    padding: 0;
  }

  .testimonial-photo {
    width: 100%;
    max-width: none;
    aspect-ratio: 448 / 400;
    border-radius: 0;
  }

  .testimonial-photo img {
    object-position: 50% 18%;
  }

  .testimonial-copy {
    width: 100%;
    padding-bottom: 48px;
    border-radius: 0;
  }
}

/* ===========================================================================
   INGREDIENTES — card mobile estilo "foto com legenda flutuante"
   A foto preenche o card e a legenda verde flutua no rodapé, sobre a foto.
   aspect-ratio fixo => todos os cards com a MESMA altura, sempre.
   =========================================================================== */
@media (max-width: 1023px) {
  .ingredients-track .antioxidants-card {
    position: relative;
    aspect-ratio: 312 / 416;
    padding: 0;
    background: #ffffff;
    border: 1.5px solid #d4ecca;
    border-radius: 20px;
    overflow: hidden;
  }

  /* Foto preenche o card, com uma moldura branca de 8px ao redor. */
  .ingredients-track .antioxidants-card figure {
    position: absolute;
    inset: 8px;
    width: auto;
    margin: 0;
    aspect-ratio: auto;
    border-radius: 13px;
    overflow: hidden;
  }
  .ingredients-track .antioxidants-card figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  /* Legenda verde flutuando no rodapé, sobreposta à foto. */
  .ingredients-track .antioxidants-card > div {
    position: absolute;
    left: 16px;
    right: 16px;
    bottom: 16px;
    width: auto;
    padding: 16px 18px 18px;
    border-radius: 16px;
    background: var(--mint-strong);
    box-shadow: 0 8px 22px rgba(28, 60, 33, 0.12);
  }
  .ingredients-track .antioxidants-card h3 {
    font-size: 18px;
    line-height: 1.2;
  }
  .ingredients-track .antioxidants-card h3::after {
    margin: 8px 0 9px;
  }
  .ingredients-track .antioxidants-card p {
    font-size: 14px;
    line-height: 1.4;
  }
}

/* ===========================================================================
   MODAL — Tabela nutricional + lista completa de ingredientes
   Abre no clique de "ver lista completa de ingredientes" (.ingredients-button).
   Conteúdo replicado da página de produção (imagem da tabela + accordion).
   =========================================================================== */
.ing-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 220ms ease, visibility 0s linear 220ms;
}
.ing-modal.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition: opacity 220ms ease;
}

.ing-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 40, 22, 0.55);
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
}

.ing-modal__panel {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 520px;
  max-height: 88vh;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 22px;
  background: #ffffff;
  border-radius: 20px;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.28);
  transform: translateY(12px) scale(0.98);
  transition: transform 240ms cubic-bezier(0.22, 1, 0.36, 1);
  font-family: var(--system-font);
}
.ing-modal.is-open .ing-modal__panel {
  transform: none;
}

.ing-modal__close {
  position: absolute;
  top: 14px;
  right: 14px;
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border: 0;
  border-radius: 50%;
  background: #f0f4ee;
  color: var(--green);
  cursor: pointer;
  transition: background 150ms ease, color 150ms ease;
}
.ing-modal__close:hover {
  background: var(--green);
  color: #ffffff;
}
.ing-modal__close svg {
  width: 18px;
  height: 18px;
}

.ing-modal__table {
  margin: 6px 0 0;
}
.ing-modal__table img {
  width: 100%;
  height: auto;
  border-radius: 12px;
}

/* Accordion "Ingredientes" (expande via grid 0fr -> 1fr, sem medir altura no JS). */
.ing-accordion {
  margin-top: 18px;
  border-top: 1px solid #e6ddcd;
}
.ing-accordion__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
  padding: 16px 2px;
  border: 0;
  background: transparent;
  color: var(--deep-green);
  font-family: var(--display-font);
  font-size: 19px;
  text-align: left;
  cursor: pointer;
}
.ing-accordion__caret {
  flex: 0 0 auto;
  width: 20px;
  height: 20px;
  color: var(--green);
  transition: transform 240ms ease;
}
.ing-accordion.is-open .ing-accordion__caret {
  transform: rotate(180deg);
}
.ing-accordion__content {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 280ms ease;
}
.ing-accordion.is-open .ing-accordion__content {
  grid-template-rows: 1fr;
}
.ing-accordion__inner {
  overflow: hidden;
  min-height: 0;
}
.ing-accordion__inner p {
  margin: 0;
  padding: 2px 2px 18px;
  font-size: 13.5px;
  line-height: 1.6;
  color: #4a5550;
}
.ing-accordion__inner strong {
  color: var(--deep-green);
}

body.ing-modal-open {
  overflow: hidden;
}

@media (min-width: 1024px) {
  .ing-modal__panel {
    max-width: 560px;
    padding: 28px;
  }
  .ing-accordion__header {
    font-size: 21px;
  }
  .ing-accordion__inner p {
    font-size: 14px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .ing-modal,
  .ing-modal__panel,
  .ing-accordion__content,
  .ing-accordion__caret {
    transition: none;
  }
}
