/* service.css — サービスページ専用（サービス詳細 / 制作フロー）。serviceページ表示時のみ読み込み。 */

/* ================================================
   Page Hero（サービスページ固有の上書き）
   ================================================ */
/*
  components.css の .page-hero__subtitle は max-width:560px だが、
  サービスページのサブタイトルは1行に収めるため広げている。
  ここを変えると折り返し位置が変わる（小さくすると途中で折れる）。
*/
.page-hero__subtitle {
  max-width: 1080px;
}

/* ================================================
   Service List
   ================================================ */
.section-service-list {
  background: var(--color-white);
}

.service-detail {
  padding-block: var(--space-6);
  border-bottom: 1px solid var(--color-gray-border);
}

.service-detail:last-child {
  border-bottom: none;
}

@media (min-width: 1024px) {
  .service-detail {
    padding-block: var(--space-7);
  }

  /*
    上段（タイトル・説明 ＋ イラスト）を 7:3 で横並び。
    ここを変えると各カラムの横幅が変わる（例: 6fr 4fr なら 60:40 になる）。
  */
  .service-detail__top {
    display: grid;
    grid-template-columns: 7fr 3fr;
    gap: var(--space-8);
    align-items: center;
  }

  /*
    偶数番目はイラストを左に。列幅を 3fr 7fr に逆転させてイラストを小さい列に収める。
  */
  .service-detail:nth-child(even) .service-detail__top {
    grid-template-columns: 3fr 7fr;
  }

  .service-detail:nth-child(even) .service-detail__visual {
    order: -1;
  }
}

.service-detail__number {
  font-size: 3.5rem;
  font-weight: var(--fw-bold);
  color: rgba(42, 157, 143, 0.15);
  line-height: 1;
  letter-spacing: -0.04em;
  margin-bottom: var(--space-3);
  font-variant-numeric: tabular-nums;
}

.service-detail__title {
  font-size: 1.5rem;
  font-weight: var(--fw-bold);
  color: var(--color-navy);
  margin-bottom: var(--space-4);
}

@media (min-width: 1024px) {
  .service-detail__title {
    font-size: 1.75rem;
  }
}

.service-detail__desc {
  font-size: 1.0625rem;
  color: var(--color-gray-body);
  line-height: 1.85;
}

.service-detail__features {
  /*
    モバイルは縦1列。タブレット以上で 2×2 グリッドに切り替わる。
    上段（タイトル＋イラスト）と分離して全幅を使う。
  */
  margin-top: var(--space-5);
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-3);
  list-style: none;
  padding: 0;
}

@media (min-width: 768px) {
  .service-detail__features {
    /* 2×2 グリッド。列数を変えると 1×4 や 4×1 にできる */
    grid-template-columns: 1fr 1fr;
    gap: var(--space-3) var(--space-6);
  }
}

.service-detail__feature-item {
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
}

.service-detail__feature-icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  margin-top: 2px;
  color: var(--color-teal);
}

.service-detail__feature-text {
  font-size: 0.9375rem;
  color: var(--color-gray-body);
  line-height: 1.6;
}

.service-detail__visual {
  margin-top: var(--space-5);
}

@media (min-width: 1024px) {
  .service-detail__visual {
    margin-top: 0;
  }
}

.service-detail__visual-box {
  aspect-ratio: 4 / 3;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: linear-gradient(135deg, var(--color-navy) 0%, var(--color-navy-light) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
}

/* SVGイラストファイルを <img> で読み込む際のサイズ調整。
   差し替え時にここの width を変えると見た目の大きさが変わる（88% = 余白が残る程度）。 */
.service-detail__visual-img {
  width: 88%;
  height: auto;
  display: block;
}

.service-detail__visual-label {
  font-size: clamp(1.25rem, 3vw, 2rem);
  font-weight: var(--fw-bold);
  color: rgba(255,255,255,0.12);
  text-align: center;
  padding: var(--space-5);
  letter-spacing: -0.02em;
}

/* ================================================
   Flow
   ================================================ */
.section-flow {
  background: var(--color-gray-light);
}

.flow-steps {
  display: flex;
  flex-direction: column;
  gap: 0;
}

@media (min-width: 768px) {
  .flow-steps {
    flex-direction: row;
    gap: 0;
  }
}

.flow-step {
  position: relative;
  flex: 1;
  padding: var(--space-5);
  background: var(--color-white);
  border-radius: var(--radius-md);
  text-align: center;
}

@media (max-width: 767px) {
  .flow-step {
    display: flex;
    text-align: left;
    gap: var(--space-4);
    align-items: flex-start;
  }

  .flow-step + .flow-step {
    margin-top: var(--space-3);
  }
}

@media (min-width: 768px) {
  .flow-step + .flow-step {
    margin-left: 2px;
  }

  .flow-step:first-child { border-radius: var(--radius-md) 0 0 var(--radius-md); }
  .flow-step:last-child  { border-radius: 0 var(--radius-md) var(--radius-md) 0; }
  .flow-step:not(:first-child):not(:last-child) { border-radius: 0; }
}

.flow-step__num {
  font-size: 0.75rem;
  font-weight: var(--fw-bold);
  color: var(--color-teal);
  letter-spacing: 0.1em;
  margin-bottom: var(--space-3);
  flex-shrink: 0;
}

@media (max-width: 767px) {
  .flow-step__num {
    margin-bottom: 0;
    padding-top: 2px;
    min-width: 36px;
  }
}

.flow-step__title {
  font-size: 1rem;
  font-weight: var(--fw-semibold);
  color: var(--color-navy);
  margin-bottom: var(--space-2);
}

.flow-step__desc {
  font-size: 0.875rem;
  color: var(--color-gray-sub);
  line-height: 1.65;
}
