/**
 * AC | Journey Card — frontend.
 * Ilustração centralizada sobre a mancha verde (mesmo sistema do hero: mask
 * mancha-N.svg). Conector (►linha + eyebrow + linha + end cap) e título abaixo.
 */

.ac-journey-card {
  flex: 0 0 342px;
  width: 342px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 16px 0;
  scroll-snap-align: start;
}

/* --- Mídia (mancha + stroke + ilustração) --- */
.ac-journey-card__media {
  position: relative;
  height: 327px;
}
.ac-journey-card__mancha {
  position: absolute;
  inset: 0;
  background-color: #D7F9D3;
  -webkit-mask-size: contain;
  mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  transform-origin: center;
  transition: transform 0.35s ease;
}
.ac-journey-card__stroke {
  position: absolute;
  inset: 0;
  line-height: 0;
  transform-origin: center;
  transition: transform 0.35s ease;
}
.ac-journey-card__stroke svg {
  width: 100%;
  height: 100%;
  display: block;
}
/* A mancha-N.svg já tem um path de stroke (stroke="currentColor"); só zeramos o
 * fill dos paths pra não virar um 2º contorno. O contorno sai do próprio SVG. */
.ac-journey-card__stroke svg path {
  fill: none;
}
.ac-journey-card__mancha--stroke-verde ~ .ac-journey-card__stroke { color: rgba(14, 82, 54, 0.5); }
.ac-journey-card__mancha--stroke-amarelo ~ .ac-journey-card__stroke { color: #F6A71C; }

.ac-journey-card__illustration {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.ac-journey-card__illustration svg,
.ac-journey-card__illustration img {
  display: block;
  width: 180px;
  height: 180px;
  object-fit: contain;
  transition: transform 0.35s ease;
}

/* Hover: mancha inclina p/ esquerda (stroke acompanha junto) + ilustração cresce. */
.ac-journey-card__media:hover .ac-journey-card__mancha,
.ac-journey-card__media:hover .ac-journey-card__stroke {
  transform: rotate(-8deg);
}
.ac-journey-card__media:hover .ac-journey-card__illustration svg,
.ac-journey-card__media:hover .ac-journey-card__illustration img {
  transform: scale(1.18);
}
@media (prefers-reduced-motion: reduce) {
  .ac-journey-card__mancha,
  .ac-journey-card__stroke,
  .ac-journey-card__illustration svg,
  .ac-journey-card__illustration img { transition: none; }
}

/* --- Conector (seta + linha + eyebrow + linha + end cap) --- */
.ac-journey-card__connector {
  display: flex;
  align-items: center;
  width: 100%;
  box-sizing: border-box;
}
/* Seta do conector: triângulo preenchido no 1º card, chevron nos demais
 * (CSS resolve via :first-child, sem índice no PHP). */
.ac-journey-card__arrow {
  flex: 0 0 14px;
  align-items: center;
  line-height: 0;
}
.ac-journey-card__arrow svg { width: 14px; height: 20px; display: block; }
.ac-journey-card__arrow--first { display: none; }
.ac-journey-card__arrow--rest { display: flex; }
.ac-journey-card:first-child .ac-journey-card__arrow--first { display: flex; }
.ac-journey-card:first-child .ac-journey-card__arrow--rest { display: none; }
.ac-journey-card__line {
  flex: 1 1 0;
  height: 3px;
  background-color: #F6A71C;
}
.ac-journey-card__eyebrow {
  flex: none;
  padding: 0 16px;
  font-family: Raleway, sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 1.2;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #774900;
  white-space: nowrap;
}
/* End cap: só no último card (CSS resolve a posição, sem índice no PHP). */
.ac-journey-card__end {
  flex: 0 0 4px;
  height: 20px;
  margin-left: 4px;
  border-radius: 8px;
  background-color: #F6A71C;
  display: none;
}
.ac-journey-card:last-child .ac-journey-card__end { display: block; }

/* --- Título / descrição --- */
.ac-journey-card__title {
  margin: 0;
  padding: 0 16px;
  text-align: center;
  font-family: Raleway, sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 1.3;
  color: #242424;
}

/* --- Mobile --- */
@media (max-width: 768px) {
  /* mais estreito pra espiar mais do próximo card. */
  .ac-journey-card {
    flex-basis: 72vw;
    width: 72vw;
  }
}
