/* ============================================================
   page-service.css — Service overview ページ専用
   ============================================================ */

/* ── Page Hero — 左:見出し / 右:本文 の2カラム ─────────── */
.sec-svc-hero {
  background: var(--paper);
  padding: 80px 40px 56px;
}
.sec-svc-hero__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(280px, auto) 1fr;
  gap: 64px;
  align-items: start;
}
.sec-svc-hero__head { margin: 0; }
.sec-svc-hero__head-en {
  font-family: Outfit, sans-serif;
  font-weight: 700;
  font-size: 80px;
  color: var(--navy);
  line-height: 1;
  letter-spacing: .02em;
}
.sec-svc-hero__head-ja {
  font-size: 17px;
  color: var(--navy);
  margin-top: 10px;
  letter-spacing: .12em;
}
.sec-svc-hero__lede {
  font-size: 15px;
  line-height: 2;
  color: #222;
  margin: 24px 0 0;
}

@media (max-width: 1023px) {
  .sec-svc-hero { padding: 64px 32px 40px; }
  .sec-svc-hero__inner { gap: 40px; }
  .sec-svc-hero__head-en { font-size: 60px; }
  .sec-svc-hero__lede { font-size: 14.5px; }
}
@media (max-width: 767px) {
  .sec-svc-hero { padding: 40px 20px 28px; }
  .sec-svc-hero__inner { grid-template-columns: 1fr; gap: 20px; }
  .sec-svc-hero__head-en { font-size: 44px; }
  .sec-svc-hero__head-ja { font-size: 14px; }
  .sec-svc-hero__lede { font-size: 14px; line-height: 1.85; margin-top: 8px; }
}

/* Service overview の card grid セクション
   (page-top-responsive.css の .sec-service スタイルを継承)
   淡青背景バンドを大きくし、カードを内側に余裕を持って収める */
.sec-svc-list {
  padding: 96px 72px 120px;   /* 上96 / 左右72 / 下120 — カードに余白を与える */
}
.sec-svc-list .svc-grid {
  max-width: 1320px;
  gap: 28px;                    /* カード間も少し広く */
}

/* ── サービスカードを正方形(1:1)に固定 ─────────────── */
.sec-svc-list .svc-card {
  aspect-ratio: 1 / 1;
  min-height: 0;        /* page-top-responsive.css の min-height: 340px を解除 */
  overflow: hidden;     /* 念のためはみ出し防止 */
  padding: 24px 22px 18px;
}

/* イラストが正方形カード内に収まるようサイズを抑える */
.sec-svc-list .svc-card__icon {
  width: auto;
  max-width: 60%;
  max-height: 110px;
  height: auto;
  object-fit: contain;
  object-position: right bottom;
}

/* タイトル・本文を少しコンパクトに */
.sec-svc-list .svc-card__title {
  font-size: 15px;
  margin-bottom: 12px;
}
.sec-svc-list .svc-card__list li {
  font-size: 12.5px;
  line-height: 1.85;
}

@media (max-width: 1023px) {
  .sec-svc-list { padding: 72px 48px 96px; }
  .sec-svc-list .svc-grid { gap: 22px; }
  .sec-svc-list .svc-card { aspect-ratio: 1 / 1; padding: 24px 22px 20px; }
  .sec-svc-list .svc-card__icon { max-width: 55%; max-height: 130px; }
}
@media (max-width: 767px) {
  .sec-svc-list { padding: 48px 28px 72px; }
  .sec-svc-list .svc-grid { gap: 18px; }
  /* スマホは1列なのでアスペクト固定を解除し、自然な高さに */
  .sec-svc-list .svc-card { aspect-ratio: auto; padding: 22px 20px 18px; }
  .sec-svc-list .svc-card__icon { max-width: 50%; max-height: 140px; }
  .sec-svc-list .svc-card__title { font-size: 15px; }
  .sec-svc-list .svc-card__list li { font-size: 13px; }
}

/* ── Utility modifiers (移行: 旧インラインstyle置き換え用) ── */
.sec-svc-list--compact { padding-top: 64px; padding-bottom: 80px; }
.svc-grid--wide { max-width: 1320px; }
.sec-service--bare { background: transparent; padding: 0; }
