﻿/* Asia/Tokyo, 2025-11-25 17:30(UTC+09:00) /css/howtopay.css */
.howtopay-page .lead {
  margin: 0;
  font-size: var(--fs-19);
  line-height: 1.9;
  color: #333;
}
@media (max-width: 600px) {
  .howtopay-page .lead {
    font-size: var(--fs-17);
  }
}

.howtopay-page .pay-options {
  padding: 0.5rem 0 0.5rem;
  font-size: var(--fs-20);
  line-height: 1.9;
}

.howtopay-page .option-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.6rem;
}
@media (min-width: 1024px) {
  .howtopay-page .option-grid {
    grid-template-columns: 1fr;
  }
}

.howtopay-page .pay-card {
  background: linear-gradient(135deg, #f7fbff 0%, #ffffff 100%);
  border-radius: 16px;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.08);
  padding: 1.8rem 2.4rem 2.2rem;
}
@media (max-width: 768px) {
  .howtopay-page .pay-card {
    padding: 1.6rem 1.6rem 2rem;
    border-radius: 12px;
  }
}

.howtopay-page .pay-card__body {
  padding: 0;
}

.howtopay-page .pay-card__title {
  font-size: var(--fs-23);
  line-height: 1.3;
}

.howtopay-page .pay-card__caption {
  margin: 0.2rem 0 0;
  color: #555;
  font-size: var(--fs-15);
}

.howtopay-page .pay-card__figure {
  margin: 1rem 0 0;
}
.howtopay-page .pay-card__figure img {
  width: auto;
  height: 64px;
}
@media (max-width: 600px) {
  .howtopay-page .pay-card__figure img {
    height: 56px;
  }
}

.howtopay-page .pay-card__desc {
  margin: 0 0 1.6rem;
  font-size: var(--fs-18);
  line-height: 1.9;
}

/* 旧レイアウト用クラス（互換維持） */
.howtopay-page .pay-modes {
  display: grid;
  gap: 0.6rem;
}
.howtopay-page .pay-mode {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  background: #fff;
  border: 1px solid #e6f2ff;
  border-radius: 6px;
  padding: 0.8rem 1rem;
}
.howtopay-page .pay-mode__label {
  font-weight: 700;
}
.howtopay-page .pay-mode__icon {
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.howtopay-page .pay-mode__icon img {
  width: 58px;
  height: auto;
  display: block;
}
.howtopay-page .note-sup sup {
  font-size: var(--fs-12);
  line-height: 1;
  color: #a50000;
}

/* 注記リスト */
.howtopay-page .pay-notes {
  margin: 1.4rem 0 0;
  padding: 0;
  display: grid;
  gap: 0.4rem;
  font-size: var(--fs-16);
}
.howtopay-page .pay-notes__item {
  display: grid;
  grid-template-columns: 3.2em 1fr;
  gap: 0.5em;
  align-items: start;
}
.howtopay-page .pay-notes__dt {
  font-weight: 700;
  color: #a50000;
}
.howtopay-page .pay-notes__dd {
  margin: 0;
}

/* PC 基本レイアウト：2行 × 4列の表 */
.howtopay-page .pay-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
  font-size: var(--fs-18);
  background-color: #ffffff;
  margin: 0;
}

.howtopay-page .pay-table th,
.howtopay-page .pay-table td {
  padding: 1.8rem 1.6rem;
  vertical-align: middle;
  border: 1px solid #d6e3f5;
}

/* 左端：支払方法カラム */
.howtopay-page .pay-table__method {
  width: 25%;
  text-align: center;
  background: linear-gradient(180deg, #e4f0ff 0%, #f4f8ff 100%);
}
.howtopay-page .pay-table__method-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.6rem;
}
.howtopay-page .pay-table__method .pay-card__title {
  margin: 0;
}
.howtopay-page .pay-table__method .pay-card__caption {
  margin: 0;
}
.howtopay-page .pay-table__method .pay-card__figure {
  margin: 0.4rem 0 0;
}

/* 説明文カラム */
.howtopay-page .pay-table__desc {
  width: 40%;
  font-size: var(--fs-17);
  line-height: 1.9;
  color: #243b53;
}

/* 区分ラベル・マーク列 */
.howtopay-page .pay-table__label {
  width: 18%;
  font-weight: 700;
  color: #102a43;
  text-align: center;
}

.howtopay-page .pay-table__icon {
  width: 17%;
  text-align: center;
}

.howtopay-page .pay-table__icon-wrap {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.2rem;
}
.howtopay-page .pay-table__icon-wrap img {
  width: 58px;
  height: auto;
}

/* (注1)(注2) はアイコンの上に配置して重ならないように */
.howtopay-page .pay-table__note {
  position: static;
  font-size: var(--fs-13);
  line-height: 1;
  color: #a50000;
}

/* バリエーション */
.howtopay-page .pay-table--account .pay-table__method {
  background: linear-gradient(180deg, #e3f6ff 0%, #f5fbff 100%);
}
.howtopay-page .pay-table--invoice .pay-table__method {
  background: linear-gradient(180deg, #fdf3e7 0%, #fff8ef 100%);
}

/* スマホ：縦4行 × 横2列へ（視覚的に）変形 */
@media (max-width: 768px) {
  .howtopay-page .pay-table {
    border-collapse: separate;
    border-spacing: 0;
  }

  .howtopay-page .pay-table tbody {
    display: block;
  }

  .howtopay-page .pay-table tr {
    display: flex;
    flex-wrap: wrap;
  }

  .howtopay-page .pay-table th,
  .howtopay-page .pay-table td {
    padding: 1.4rem 1.2rem;
    border: 1px solid #d6e3f5;
  }

  /* 1行目：支払方法（2列分） */
  .howtopay-page .pay-table__method {
    flex: 0 0 100%;
    text-align: center;
  }

  /* 2行目：説明文（2列分） */
  .howtopay-page .pay-table__desc {
    flex: 0 0 100%;
    width: auto;
    font-size: var(--fs-16);
  }

  /* 3・4行目：ラベル＋アイコンを横2列に */
  .howtopay-page .pay-table__label,
  .howtopay-page .pay-table__icon {
    flex: 0 0 50%;
  }

  .howtopay-page .pay-table__label {
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .howtopay-page .pay-table__icon {
    text-align: center;
  }

  .howtopay-page .pay-table__icon-wrap {
    padding: 0.2rem 0;
  }
}
