/**
 * AC | Big Image Section — texto + imagem na mancha (Section/Big-Img do DS).
 * A mancha-img usa o sistema compartilhado (css/ac-mancha-img.css).
 */
/* A imagem sempre preenche a mancha aqui — sem o fallback amarelo (#FFD16C)
 * que o hero usa quando não tem imagem. */
.ac-big-img .ac-mancha-img { --ac-mancha-fill: transparent; }

.ac-big-img__inner {
  position: relative;
  max-width: var(--container-max, 1104px);
  margin-inline: auto;
  padding-inline: 16px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 24px;
}
/* Ícone decorativo posicionado relativo à seção inteira (não à mancha) — assim
 * o X/Y alcança qualquer lugar, inclusive ao lado do título. */
.ac-big-img__deco {
  position: absolute;
  display: block;
  z-index: 3;
  pointer-events: none;
  background-color: currentColor;
  -webkit-mask-size: contain;
  mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  left: var(--icon-x);
  top: var(--icon-y);
  width: var(--icon-w);
}
.ac-big-img__deco--sorriso { aspect-ratio: 70 / 32; }
.ac-big-img__deco--celula { aspect-ratio: 58 / 56; }
.ac-big-img__deco--proteina { aspect-ratio: 76 / 30; }
.ac-big-img__content {
  flex: 1 1 380px;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.ac-big-img__media {
  flex: 1 1 420px;
  min-width: 0;
  display: flex;
  justify-content: center;
}
/* Imagem à esquerda: inverte a ordem. */
.ac-big-img--img-left .ac-big-img__media { order: -1; }

.ac-big-img__title {
  margin: 0;
  font-family: Raleway, sans-serif;
  font-weight: 700;
  font-size: 32px;
  line-height: 1.2;
  color: #242424;
}
.ac-big-img__body {
  margin: 0;
  font-family: Arial, sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.6;
  color: #404040;
}
.ac-big-img__highlight {
  margin: 0;
  font-family: Raleway, sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 1.3;
  color: #0E5236;
}
.ac-big-img__secondary {
  margin: 24px 0 0;
  font-family: Arial, sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.6;
  color: #404040;
}
.ac-big-img__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
}

/* padding top/bottom (tokens DS). */
.ac-big-img--pt-0  { padding-top: 0; }
.ac-big-img--pt-24 { padding-top: 24px; }
.ac-big-img--pt-32 { padding-top: 32px; }
.ac-big-img--pt-40 { padding-top: 40px; }
.ac-big-img--pt-48 { padding-top: 48px; }
.ac-big-img--pt-56 { padding-top: 56px; }
.ac-big-img--pt-80 { padding-top: 80px; }
.ac-big-img--pb-0  { padding-bottom: 0; }
.ac-big-img--pb-24 { padding-bottom: 24px; }
.ac-big-img--pb-32 { padding-bottom: 32px; }
.ac-big-img--pb-40 { padding-bottom: 40px; }
.ac-big-img--pb-48 { padding-bottom: 48px; }
.ac-big-img--pb-56 { padding-bottom: 56px; }
.ac-big-img--pb-80 { padding-bottom: 80px; }

@media (max-width: 768px) {
  .ac-big-img__content,
  .ac-big-img__media { flex-basis: 100%; }
  .ac-big-img__title { font-size: 24px; }
  /* menos respiro entre o CTA e a imagem (Figma mobile). */
  .ac-big-img__inner { gap: 8px; }
  /* No mobile a imagem vai pro fim independente do lado. */
  .ac-big-img--img-left .ac-big-img__media { order: 0; }
  /* Imagem maior, deslocada pra direita e sangrando na borda direita (igual
   * Figma mobile). overflow-x: clip recorta só o excesso horizontal — NÃO afeta
   * o vertical (o editor controla o overflow inferior via padding-bottom). */
  .ac-big-img { overflow-x: clip; }
  .ac-big-img__media { display: block; }
  /* Figma mobile: img 573×548 num frame ~361px → ~158% de largura, sangrando
   * ~11% à esquerda e ~47% à direita. */
  .ac-big-img__media .ac-mancha-img {
    max-width: none;
    width: 158%;
    margin-left: -11%;
  }
}
