@charset "utf-8";
/* CSS Document */
.flow {
  max-width: 800px;
  margin: 0 auto;
  padding: 20px;
}

/* 各ステップ */
.flow__item {
  display: flex;
  align-items: flex-start;
  gap: 15px;
  background: #f4f8fb;
  border: 1px solid #d6e6f2;
  border-radius: 10px;
  padding: 15px 18px;
}

/* 番号（ここがポイント） */
.flow__num {
  flex: 0 0 40px; /* ←幅固定でズレ防止 */
  height: 40px;
  background: #9fcbe6;
  color: #fff;
  font-weight: bold;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* テキスト */
.flow__text {
  flex: 1;
  font-size: 1.2em;
  line-height: 1.8;
  color: #333;
}

/* 注釈 */
.flow__note {
	display: block;
	font-size: 0.9em;
	color: #4C6D9F;
	margin-top: 5px;
}

/* 矢印 */
.flow__arrow {
  text-align: center;
  color: #9fcbe6;
  font-size: 3em;
  margin: 8px 0;
}
/* ===== タブレット以下 ===== */
@media screen and (max-width: 768px) {
  .flow {
    padding: 15px;
  }

  .flow__item {
    padding: 12px 14px;
    gap: 12px;
  }

  .flow__num {
    flex: 0 0 34px;
    height: 34px;
    font-size: 14px;
  }

  .flow__text {
    font-size: 13px;
    line-height: 1.7;
  }

  .flow__arrow {
    font-size: 18px;
  }
}

/* ===== スマホ ===== */
@media screen and (max-width: 480px) {
  .flow {
    padding: 10px;
  }

  .flow__item {
    padding: 12px;
    gap: 10px;
    border-radius: 8px;
  }

  .flow__num {
    flex: 0 0 30px;
    height: 30px;
    font-size: 13px;
  }

  .flow__text {
    font-size: 13px;
    line-height: 1.6;
  }

  .flow__note {
    font-size: 11px;
  }

  .flow__arrow {
    font-size: 16px;
    margin: 6px 0;
  }
}