.stages__inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-7);
}

.stages__grid {
  list-style: none;
  /* только вертикальные поля: margin-left занят выравниванием .section__content */
  margin-block: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
}

.stage {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding-block: var(--space-6);
  border-top: var(--hairline);
}

.stage__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
}
.stage__num {
  flex: none;
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wide);
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
}
.stage__text {
  margin: 0;
  font-size: var(--text-md);
  line-height: var(--lh-normal);
  color: var(--text-body);
}

.stages__photo {
  /* фото в конце секции на любом размере, пока нет места для абсолютного позиционирования */
  order: 99;
  height: 200px;
  background-image: var(--media-image);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

/* ─── 768+: 2 колонки, фото ниже сетки ──────────────────── */

@media (min-width: 768px) {
  .stages__grid { grid-template-columns: 1fr 1fr; }
  .stage:nth-child(odd)  { padding-right: var(--space-7); }
  .stage:nth-child(even) { padding-left:  var(--space-7); }

  .stages__photo { height: 280px; }
}

/* ─── 1440+: декоративное фото в левом поле ─────────────── */
/* При viewport >= 1440px section__inner достигает 1280px,  */
/* а section__content занимает 1044px - остаётся 236px для  */
/* фото шириной 183px без перекрытия текста.                */

@media (min-width: 1440px) {
  .stages__inner { position: relative; }

  .stages__photo {
    position: absolute;
    left: 0;
    top: 300px;
    width: 183px;
    height: 247px;
  }
}
