/* ============================================
   トップページ（ホーム）— top-* / design-tokens 準拠、--bp-*
   ============================================ */

/* ─── Hero トークン（sm ≤767 / md 768–1024 / pc 1025px+、base 変数準拠）──── */
:root {
  --hero-card-max-width: var(--bp-xl);
  --hero-inner-gap: clamp(var(--space-4), 2vw, var(--space-6));
  --hero-actions-gap-column: clamp(var(--space-4), 2.5vw, var(--space-6));
  --hero-actions-gap-row: clamp(var(--space-6), 4vw, var(--space-16));
  --hero-actions-padding-inline: clamp(var(--space-4), 4vw, var(--space-8));
  --hero-btn-min-height: clamp(
    calc(var(--size-button-sm) + var(--space-1)),
    3vw + var(--space-6),
    calc(var(--space-12) + var(--space-3))
  );
  --hero-btn-min-width: clamp(
    calc(var(--space-20) * 2),
    30vw,
    calc(var(--space-16) * 4)
  );
  --hero-btn-min-width-desktop: clamp(
    calc(35 * var(--space-unit)),
    30vw,
    calc(62.5 * var(--space-unit))
  );
  --hero-btn-max-width-sm: 85%;
  /* sm */
  --hero-btn-font-size-sm: var(--text-sm);
  --hero-btn-icon-size-sm: var(--text-xl);
  --hero-btn-arrow-size-sm: var(--text-22);
  --hero-btn-padding-block-sm: var(--space-4);
  --hero-btn-padding-inline-sm: var(--text-lg);
  --hero-btn-left-gap-sm: var(--space-3);
  --hero-btn-min-height-sm: var(--size-button-md);
  /* md */
  --hero-btn-font-size-md: var(--text-md);
  --hero-btn-icon-size-md: var(--text-22);
  --hero-btn-arrow-size-md: var(--text-26);
  --hero-btn-padding-block-md: var(--text-md);
  --hero-btn-padding-inline-md: var(--text-22);
  --hero-btn-left-gap-md: var(--space-3);
  --hero-btn-min-height-md: calc(var(--space-12) + var(--space-2));
  /* pc */
  --hero-btn-font-size-pc: var(--text-xl);
  --hero-btn-icon-size-pc: var(--text-26);
  --hero-btn-arrow-size-pc: var(--space-8);
  --hero-btn-padding-block-pc: var(--text-lg);
  --hero-btn-padding-inline-pc: var(--text-3xl);
  --hero-btn-left-gap-pc: var(--space-4);
  --hero-btn-min-height-pc: calc(var(--space-12) + var(--space-3));
  /* 初期値 md（MQ で上書き） */
  --hero-btn-font: var(--hero-btn-font-size-md);
  --hero-btn-icon-size: var(--hero-btn-icon-size-md);
  --hero-btn-arrow-size: var(--hero-btn-arrow-size-md);
  --hero-btn-padding-block: var(--hero-btn-padding-block-md);
  --hero-btn-padding-inline: var(--hero-btn-padding-inline-md);
  --hero-btn-left-gap: var(--hero-btn-left-gap-md);
  --hero-btn-min-height: var(--hero-btn-min-height-md);
  --hero-btn-img-max-height: calc(var(--space-12) + var(--space-10));
}

/* ─── メインコンテナ ───────────────────────────────────────────────── */
.top-main {
  outline: none;
  scroll-margin-top: var(--space-6);
  box-sizing: border-box;
  padding-inline: 0;
  padding-block-end: 0;
}

.top-main:focus {
  outline: none;
}

.top-main .container {
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
  margin: 0 !important;
  padding-inline: 0;
  box-sizing: border-box;
}

/* セクション共通余白：--layout-section-padding-*（トークン） */
.topics,
.top-quick-links,
.top-news,
.top-faq {
  padding-inline: var(--layout-section-padding-inline);
  padding-block: var(--layout-section-padding-block);
}

/* セクション背景：hero・クイックリンク・FAQ は暖色、トピックス・新着は中性（トークン） */
.hero--top,
.top-quick-links,
.top-faq {
  background-color: var(--color-bg-warm);
}

.topics,
.top-news {
  background-color: var(--color-bg-neutral);
}

/* ============================================
   ヒーロー領域（BEM: .hero, .hero__*, .hero--top）
   design-tokens §18 --hero-* および --bp-* を使用
   ============================================ */
.hero--top {
  padding: var(--layout-section-padding-block)
    var(--layout-section-padding-inline);
  margin: 0;
}

.hero--top .container {
  max-width: none;
  padding: 0;
}

.hero__card {
  width: 100%;
  box-sizing: border-box;
}

.hero__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--hero-inner-gap);
  width: 100%;
}

.hero__banner-link {
  display: block;
  width: 100%;
  max-width: 1200px;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}

.hero__banner-link:hover {
  opacity: 0.95;
}

.hero__banner-link:focus-visible {
  outline: var(--focus-width) solid var(--focus-color);
  outline-offset: var(--focus-offset);
  border-radius: var(--radius-sm);
}

.hero__banner {
  width: 100%;
  max-width: 100%;
  height: auto;
  object-fit: contain;
  object-position: center;
  display: block;
  image-rendering: -webkit-optimize-contrast;
  image-rendering: crisp-edges;
}

.hero__actions {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: stretch;
  margin: var(--layout-section-padding-block) auto;
  padding-inline: var(--hero-actions-padding-inline);
  gap: var(--hero-actions-gap-column);
  width: 100%;
  box-sizing: border-box;
}

/* ヒーローボタン（変数は :root / MQ で設定） */
.hero__btn {
  flex: 1;
  min-width: var(--hero-btn-min-width-desktop);
  max-width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--hero-btn-left-gap);
  padding: var(--hero-btn-padding-block) var(--hero-btn-padding-inline);
  min-height: var(--hero-btn-min-height);
  margin: 0;
  border: none;
  border-radius: var(--radius-sm);
  background: var(--color-brand);
  color: var(--color-text-secondary);
  font-family: var(--font-sans);
  font-size: var(--hero-btn-font);
  font-weight: var(--font-weight-bold);
  line-height: var(--leading-150);
  letter-spacing: var(--tracking-wide);
  box-shadow: var(--shadow-2);
  transition:
    background var(--motion-base),
    box-shadow var(--motion-base),
    transform var(--motion-base);
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  box-sizing: border-box;
}

.hero__btn:hover {
  background: var(--color-brand-hover);
  color: var(--color-text-secondary);
  box-shadow: var(--shadow-3);
  transform: translateY(calc(var(--space-1) * -1));
}

.hero__btn:active {
  transform: translateY(0);
  opacity: 0.95;
}

.hero__btn:focus-visible {
  outline: var(--focus-width) solid var(--color-yellow-800);
  outline-offset: var(--focus-offset);
  border-radius: var(--radius-sm);
}

.hero__btn-left {
  display: flex;
  align-items: center;
  gap: var(--hero-btn-left-gap);
  flex: 1;
  min-width: 0;
}

.hero__btn-img {
  flex-shrink: 0;
  width: var(--hero-btn-icon-size);
  height: var(--hero-btn-icon-size);
  max-width: var(--hero-btn-icon-size);
  max-height: var(--hero-btn-icon-size);
  display: block;
  object-fit: contain;
  object-position: center;
  pointer-events: none;
}

.hero__btn-text {
  flex: 1 1 auto;
  min-width: 0;
  text-align: start;
  white-space: normal;
  word-wrap: break-word;
  overflow-wrap: break-word;
  line-height: var(--leading-150);
}

/* 矢印：.material-symbols-outlined の 16px を上書き（優先度を上げる） */
.hero__btn .hero__btn-icon {
  flex-shrink: 0;
  font-size: var(--hero-btn-arrow-size) !important;
  color: inherit;
}

.hero__divider {
  width: 100%;
  border-bottom: calc(var(--focus-width) * 2) dotted var(--color-yellow-800);
  box-shadow: var(--shadow-2);
}

/* モバイル（≤767px）：固定で sm トークン・ボタン中央寄せ */
@media (max-width: 767px) {
  .hero__actions {
    align-items: center;
    gap: var(--hero-actions-gap-column);
  }
  .hero__btn {
    min-width: var(--hero-btn-min-width);
    max-width: var(--hero-btn-max-width-sm);
    --hero-btn-padding-block: var(--hero-btn-padding-block-sm);
    --hero-btn-padding-inline: var(--hero-btn-padding-inline-sm);
    --hero-btn-left-gap: var(--hero-btn-left-gap-sm);
    --hero-btn-font: var(--hero-btn-font-size-sm);
    --hero-btn-min-height: var(--hero-btn-min-height-sm);
    font-weight: var(--font-weight-bold);
  }
  .hero__btn-img {
    width: var(--hero-btn-icon-size-sm);
    height: var(--hero-btn-icon-size-sm);
    max-width: var(--hero-btn-icon-size-sm);
    max-height: var(--hero-btn-icon-size-sm);
  }
  .hero__btn .hero__btn-icon {
    font-size: var(--hero-btn-arrow-size-sm) !important;
  }
}

/* タブレット（768–1024px）：固定で md トークン（フォント 17px、階段で小さく） */
@media (min-width: 768px) and (max-width: 1024px) {
  .hero__btn {
    --hero-btn-padding-block: var(--hero-btn-padding-block-md);
    --hero-btn-padding-inline: var(--hero-btn-padding-inline-md);
    --hero-btn-left-gap: var(--hero-btn-left-gap-md);
    --hero-btn-font: var(--hero-btn-font-size-md);
    --hero-btn-min-height: var(--hero-btn-min-height-md);
  }
  .hero__btn-img {
    width: var(--hero-btn-icon-size-md);
    height: var(--hero-btn-icon-size-md);
    max-width: var(--hero-btn-icon-size-md);
    max-height: var(--hero-btn-icon-size-md);
  }
  .hero__btn .hero__btn-icon {
    font-size: var(--hero-btn-arrow-size-md) !important;
  }
}

/* PC（≥1025px）：横並び + pc トークン */
@media (min-width: 1025px) {
  .hero__actions {
    flex-direction: row;
    gap: var(--hero-actions-gap-row);
  }
  .hero__btn {
    --hero-btn-padding-block: var(--hero-btn-padding-block-pc);
    --hero-btn-padding-inline: var(--hero-btn-padding-inline-pc);
    --hero-btn-left-gap: var(--hero-btn-left-gap-pc);
    --hero-btn-font: var(--hero-btn-font-size-pc);
    --hero-btn-min-height: var(--hero-btn-min-height-pc);
  }
  .hero__btn-img {
    width: var(--hero-btn-icon-size-pc);
    height: var(--hero-btn-icon-size-pc);
    max-width: var(--hero-btn-icon-size-pc);
    max-height: var(--hero-btn-icon-size-pc);
  }
  .hero__btn .hero__btn-icon {
    font-size: var(--hero-btn-arrow-size-pc) !important;
  }
}

/* ─── セクション見出し（.top-head）──────────────────────────────────── */
.top-head {
  text-align: center;
  margin-bottom: var(--cmp-section-head-margin-bottom);
  padding-inline: var(--space-2);
  box-sizing: border-box;
}

.top-head-label,
.top-head-title {
  font-family: var(--font-sans);
  font-weight: var(--font-weight-bold);
}

.top-head-label {
  display: block;
  font-size: var(--cmp-section-head-label-size);
  color: var(--color-text);
  line-height: var(--leading-160);
  letter-spacing: var(--tracking-wide);
  margin-bottom: clamp(var(--space-1), 0.5vw, var(--space-2));
  white-space: nowrap;
}

.top-head-title {
  font-size: var(--cmp-section-head-title-size);
  color: var(--cmp-section-head-title-color);
  line-height: var(--leading-150);
  letter-spacing: var(--tracking-wide);
  margin: 0;
  border: none;
  padding-inline-start: 0;
}

.top-head-desc {
  font-size: var(--cmp-section-head-desc-size);
  font-weight: var(--font-weight-regular);
  color: var(--cmp-section-head-desc-color);
  line-height: var(--leading-170);
  margin: clamp(var(--space-3), 2vw, var(--space-4)) 0
    clamp(var(--space-4), 3vw, var(--space-6));
  word-break: break-word;
}

/* セクション CTA（base 変数・流体） */
.top-head-cta {
  --top-head-cta-padding-block: clamp(
    var(--space-3),
    var(--space-2) + 0.5vw,
    var(--space-5)
  );
  --top-head-cta-padding-inline: clamp(
    var(--space-4),
    var(--space-3) + 1.25vw,
    var(--space-6)
  );
  --top-head-cta-gap: clamp(
    var(--space-2),
    var(--space-1) + 0.5vw,
    var(--space-4)
  );
  --top-head-cta-font: clamp(
    var(--text-sm),
    var(--text-sm) + 0.25vw,
    var(--text-lg)
  );
  --top-head-cta-min-height: clamp(
    var(--size-button-sm),
    3vw + var(--space-6),
    calc(var(--space-12) + var(--space-2))
  );
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--top-head-cta-gap);
  border: none;
  border-radius: var(--radius-sm);
  padding: var(--top-head-cta-padding-block) var(--top-head-cta-padding-inline);
  font-size: var(--top-head-cta-font);
  font-weight: var(--font-weight-bold);
  font-family: var(--font-sans);
  line-height: var(--leading-150);
  white-space: nowrap;
  background: var(--color-brand);
  color: var(--color-text-secondary);
  text-decoration: none;
  width: max-content;
  min-width: min-content;
  max-width: 100%;
  min-height: var(--top-head-cta-min-height);
  height: auto;
  box-sizing: border-box;
  box-shadow: var(--shadow-2);
  transition:
    background var(--motion-slow),
    box-shadow var(--motion-slow);
  margin-top: 0;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
}

.top-head-cta:hover {
  background: var(--color-brand-hover);
  color: var(--color-text-secondary);
  box-shadow: var(--shadow-3);
}

.top-head-cta-sm {
  --top-head-cta-padding-block: clamp(
    var(--space-2),
    var(--space-1) + 0.35vw,
    var(--space-4)
  );
  --top-head-cta-padding-inline: clamp(
    var(--space-3),
    var(--space-2) + 1vw,
    var(--space-5)
  );
  --top-head-cta-gap: clamp(
    var(--space-2),
    var(--space-1) + 0.35vw,
    var(--space-3)
  );
  --top-head-cta-font: clamp(
    var(--text-xs),
    var(--text-xs) + 0.2vw,
    var(--text-base)
  );
  --top-head-cta-min-height: clamp(
    var(--space-8),
    2.5vw + var(--space-4),
    calc(var(--space-10) + var(--space-1))
  );
  margin-top: 0;
}

/* top-head-cta レスポンシブ：小画面でタッチしやすく・PC でゆとり */
@media (max-width: 575px) {
  .top-head-cta {
    --top-head-cta-padding-block: var(--space-3);
    --top-head-cta-padding-inline: clamp(
      var(--space-4),
      5vw + var(--space-2),
      var(--space-5)
    );
    --top-head-cta-gap: var(--space-2);
    --top-head-cta-font: var(--text-sm);
    --top-head-cta-min-height: calc(var(--size-button-sm) + var(--space-1));
  }
  .top-head-cta-sm {
    --top-head-cta-padding-block: var(--space-2);
    --top-head-cta-padding-inline: clamp(
      var(--space-3),
      3vw + var(--space-2),
      var(--space-4)
    );
    --top-head-cta-gap: var(--space-2);
    --top-head-cta-font: var(--text-xs);
    --top-head-cta-min-height: calc(var(--space-4) + var(--space-5));
  }
}

@media (min-width: 992px) {
  .top-head-cta {
    --top-head-cta-padding-inline: clamp(
      var(--space-5),
      var(--space-4) + 0.5vw,
      var(--space-6)
    );
    --top-head-cta-gap: var(--space-4);
    --top-head-cta-font: var(--text-base);
    --top-head-cta-min-height: calc(var(--space-12) + var(--space-1));
  }
  .top-head-cta-sm {
    --top-head-cta-padding-inline: clamp(
      var(--space-4),
      var(--space-3) + 0.5vw,
      var(--space-5)
    );
    --top-head-cta-gap: var(--space-3);
    --top-head-cta-font: var(--text-sm);
  }
}

.top-head-cta-text {
  flex: 0 1 auto;
  min-width: 0;
  text-align: start;
  white-space: nowrap;
}

.top-head-cta-icon {
  width: 1em;
  height: 1em;
  flex-shrink: 0;
  stroke-width: 2.5;
}

.top-head-left {
  text-align: left;
  margin-bottom: 0;
}

.top-head-left .top-head-title {
  margin-top: var(--space-2);
}

@media (max-width: 576px) {
  .top-head {
    padding-inline: var(--space-2);
  }
}

/* ============================================
   トピックスブロック（セクション余白のみ）
   ============================================ */
.topics .container {
  max-width: none;
  padding: 0;
}

/* ============================================
   クイックリンクブロック
   ============================================ */
.top-quick-links {
  overflow-x: hidden;
  box-sizing: border-box;
  box-shadow: var(--shadow-inset-top);
}

.top-quick-links .container {
  max-width: 100%;
  width: 100%;
  padding: 0;
  box-sizing: border-box;
}

.top-quick-links .top-head {
  margin-bottom: var(--space-12);
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* グリッド：モバイル 1列 / タブレット 2列 / デスクトップ 3列、gap は画面に応じて流体 */
.top-quick-links-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(var(--space-2), 3vw, var(--space-4));
  max-width: 100%;
  width: 100%;
  margin: 0 auto;
  min-width: 0;
  box-sizing: border-box;
}

@media (min-width: 768px) {
  .top-quick-links-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: clamp(var(--space-3), 2vw, var(--space-5));
  }
}

@media (min-width: 992px) {
  .top-quick-links-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(var(--space-4), 2vw, var(--space-6));
  }
}

/* クイックリンクボタン（base 変数・流体） */
.top-quick-links-item {
  --top-quick-padding-block: clamp(
    var(--space-3),
    var(--space-2) + 0.6vw,
    var(--space-5)
  );
  --top-quick-padding-inline: clamp(
    var(--space-5),
    var(--space-3) + 1.25vw,
    var(--space-8)
  );
  --top-quick-text-icon-gap: clamp(
    var(--space-3),
    var(--space-2) + 0.6vw,
    var(--space-5)
  );
  --top-quick-font: clamp(
    var(--text-sm),
    var(--text-sm) + 0.35vw,
    var(--text-lg)
  );
  --top-quick-min-height: clamp(
    calc(var(--size-button-sm) + var(--space-1)),
    4vw + var(--space-8),
    calc(var(--space-12) + var(--space-2))
  );
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--top-quick-text-icon-gap);
  width: 100%;
  min-width: 0;
  min-height: var(--top-quick-min-height);
  padding: var(--top-quick-padding-block) var(--top-quick-padding-inline);
  background: var(--color-bg);
  border: var(--focus-width) solid var(--color-yellow-700);
  border-radius: var(--radius-md);
  text-decoration: none;
  color: var(--color-text);
  font-family: var(--font-sans);
  font-weight: var(--font-weight-bold);
  font-size: var(--top-quick-font);
  line-height: var(--leading-150);
  transition:
    background var(--motion-base),
    box-shadow var(--motion-base);
  box-shadow: var(--shadow-2);
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  text-align: left;
  box-sizing: border-box;
}

@media (max-width: 767px) {
  .top-quick-links-item {
    --top-quick-padding-block: var(--space-4);
    --top-quick-padding-inline: clamp(
      var(--space-5),
      2vw + var(--space-3),
      var(--space-6)
    );
    --top-quick-font: clamp(
      var(--text-sm),
      var(--text-xs) + 0.3vw,
      var(--text-base)
    );
    --top-quick-min-height: calc(var(--size-button-md) + var(--space-1));
  }
}

@media (min-width: 992px) {
  .top-quick-links-item {
    --top-quick-padding-block: var(--space-4);
    --top-quick-padding-inline: clamp(
      var(--space-6),
      var(--space-5) + 0.5vw,
      var(--space-8)
    );
    --top-quick-font: var(--text-lg);
    --top-quick-min-height: calc(var(--space-12) + var(--space-2));
  }
}

@media (max-width: 575px) {
  .top-quick-links-item {
    --top-quick-padding-block: var(--space-3);
    --top-quick-padding-inline: clamp(
      var(--space-4),
      2.5vw + var(--space-2),
      var(--space-5)
    );
    --top-quick-font: var(--text-sm);
    --top-quick-min-height: calc(var(--size-button-sm) + var(--space-1));
    --top-quick-text-icon-gap: var(--space-3);
  }
}

.top-quick-links-item:hover {
  background: var(--color-yellow-100);
  box-shadow: var(--shadow-3);
  color: var(--color-text);
}

.top-quick-links-text {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.top-quick-links-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.1em;
  height: 1.1em;
  flex-shrink: 0;
  stroke-width: 2.5;
  font-size: 0.95em;
}

@media (max-width: 991px) {
  .top-quick-links .top-head {
    margin-bottom: var(--space-8);
  }
}

/* ============================================
   新着情報ブロック
   ============================================ */
.top-news .container {
  max-width: none;
  padding: 0;
}

.top-news-toolbar {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  width: 100%;
  margin-top: var(--space-6);
  margin-bottom: var(--space-8);
}

.top-news-toolbar .top-head-cta {
  margin-left: auto;
}

/* ============================================
   よくあるお問い合わせ（FAQ）ブロック
   ============================================ */
.top-faq .container {
  max-width: none;
  padding: 0;
}

.top-faq__row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-6);
}

.top-faq__col--head,
.top-faq__col--main {
  flex: 1 1 100%;
  min-width: 0;
}

@media (min-width: 992px) {
  .top-faq__col--head {
    flex: 0 0 calc(41.666667% - var(--space-6) / 2);
  }
  .top-faq__col--main {
    flex: 0 0 calc(58.333333% - var(--space-6) / 2);
  }
}

.top-faq-more {
  text-align: left;
  margin-top: var(--space-8);
}

.top-faq-more .top-head-cta {
  margin-top: 0;
}
