/**
 * トレーナーカルーセル（ショートコード [trainer]）
 * 独自スタイル。左右ボタン・外枠の雰囲気のみ review を参考にした構成。
 */

/* ========== 外枠・背景 ========== */
.trainer-carousel {
  position: relative;
  max-width: var(--main-max-regular, 1280px);
  margin-left: auto;
  margin-right: auto;
  padding: 32px 48px 24px;
  background-image: url("../../images/staff/staff-staff-profile-bg.webp");
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  border-radius: 12px;
}

/* ========== トレーナー一覧リスト（カード上） ========== */
.trainer-carousel__list {
  margin-bottom: 32px;
}

.trainer-carousel__list-inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 24px 32px;
}

.trainer-carousel__list-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: min(120px, 16vw);
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
  text-align: center;
  transition: opacity 0.2s;
}

.trainer-carousel__list-item:hover {
  opacity: 0.85;
}

.trainer-carousel__list-item:focus-visible {
  outline: 2px solid var(--color-primary, #604d00);
  outline-offset: 2px;
  border-radius: 8px;
}

.trainer-carousel__list-photo {
  display: block;
  width: 80px;
  height: 80px;
  margin: 0 auto 12px;
  border-radius: 50%;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.2);
  flex-shrink: 0;
}

.trainer-carousel__list-photo-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.trainer-carousel__list-photo-placeholder {
  display: block;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.15);
}

.trainer-carousel__list-title {
  display: block;
  font-size: 12px;
  line-height: 1.4;
  color: var(--color-wh, #fff);
  margin-bottom: 6px;
}

.trainer-carousel__list-name {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 14px;
  font-weight: 700;
  color: var(--color-wh, #fff);
  line-height: 1.4;
}

.trainer-carousel__list-arrow {
  display: inline-block;
  margin-left: 4px;
  vertical-align: middle;
  line-height: 0;
}

.trainer-carousel__list-arrow-img {
  width: 20px;
  height: 20px;
  display: block;
  object-fit: contain;
}

.trainer-carousel__list-item.is-current .trainer-carousel__list-name {
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* ========== 左右ボタン（review を参考） ========== */
.trainer-carousel__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  padding: 8px;
  border: none;
  background: transparent;
  cursor: pointer;
  line-height: 0;
  transition: opacity 0.2s;
}

.trainer-carousel__arrow:hover {
  opacity: 0.8;
}

.trainer-carousel__arrow:focus-visible {
  outline: 2px solid var(--color-primary, #604d00);
  outline-offset: 2px;
}

.trainer-carousel__arrow--prev {
  left: -12px;
}

.trainer-carousel__arrow--next {
  right: -12px;
}

.trainer-carousel__arrow-img--next {
  transform: scaleX(-1);
}

/* ========== トラック・スライド ========== */
.trainer-carousel__inner {
  overflow: hidden;
}

.trainer-carousel__track {
  position: relative;
}

.trainer-carousel__slide {
  display: none;
  width: 100%;
}

.trainer-carousel__slide.is-active {
  display: block;
}

/* ========== カード（トレーナー独自） ========== */
.trainer-carousel__box {
  padding: 40px;
  background: url("../../images/staff/staff-staff-profile-bg.webp") no-repeat center center, var(--color-bk);
  background-size: 90%;
  border-radius: 40px;
}

.trainer-carousel__box-inner {
  overflow-y: auto;
}

@media (min-width: 1024px) {
  .trainer-carousel__box-inner {
    max-height: calc(100vh - 200px - 180px);
  }
}

@media (max-width: 1023px) {
  .trainer-carousel__box-inner {
    max-height: calc(100vh - 300px - 100px);
  }
}



/* ========== 4ブロックレイアウト（A:左 / B:中央写真 / C:右 / D:下段） ========== */
.trainer-carousel__row {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 40px;
  align-items: start;
  margin-bottom: 24px;
}

.trainer-carousel__block--a {
  min-width: 0;
}

.trainer-carousel__block--b {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
}

.trainer-carousel__block--c {
  min-width: 0;
}

.trainer-carousel__block--d {
  margin-top: 0;
  padding: 40px;
  background: var(--color-wh);
  border-radius: 16px;
}

.trainer-carousel__basic {
  margin: 0 0 12px;
  font-size: 14px;
  line-height: 1.5;
  color: var(--color-bk);
}

/* ========== ページャー（review を参考） ========== */
.trainer-carousel__pager {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  margin-top: 24px;
  padding: 0;
  border: none;
  background: none;
}

.trainer-carousel__pager-dot {
  width: 8px;
  height: 8px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: #d0d0d0;
  cursor: pointer;
  transition: background 0.2s;
}

.trainer-carousel__pager-dot:hover {
  background: #b0b0b0;
}

.trainer-carousel__pager-dot:focus-visible {
  outline: 2px solid var(--color-primary, #604d00);
  outline-offset: 2px;
}

.trainer-carousel__pager-dot.is-current {
  background: #666;
}


/* ========== カード内コンテンツ（トレーナー独自） ========== */

/* 見出し */
h3.trainer-carousel__heading {
  display: inline-block;
  border: 1px solid #FFF;
  padding: 4px 10px;
  border-radius: 8px;
  font-size: 16px !important;
  font-weight: 500;
}


/* プロフィール画像 */
.trainer-carousel__photo {
  width: min(400px, 21vw);
  height: auto;
  flex-shrink: 0;
}

.trainer-carousel__photo-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  display: block;
}

/* 名前エリア */
.trainer-carousel__title {
  margin: 0 0 4px;
  padding: 0 !important;
  font-size: 14px;
  color: var(--color-wh);
}

.trainer-carousel__name-ja {
  margin: 0 0 4px;
  padding: 0 !important;
  font-size: min(40px, 3vw);
  font-weight: 500;
  color: var(--color-wh);
  line-height: 1.3;
  letter-spacing: 4px;
}

.trainer-carousel__name-en {
  font-family: var(--type-english-font);
  margin: 0 0 16px;
  padding: 0 !important;
  font-size: 12px;
  letter-spacing: 1px;
  color: var(--color-gray03);
}


/* 出身地＆生年月日 */
p.trainer-carousel__basic {
  font-size: 16px;
  padding: 0 !important;
  margin: 0;
  color: var(--color-wh);
}


.trainer-carousel__dl {
  display: grid;
  gap: 8px;
  margin: 0 0 16px;
}

.trainer-carousel__dl-row {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 12px;
  font-size: 14px;
}

.trainer-carousel__dt {
  font-weight: 700;
  color: var(--color-wh);
}

.trainer-carousel__dd {
  margin: 0;
  color: var(--color-wh);
}


/* 経歴 */
.trainer-carousel__section {
  margin-top: 48px;
}

.trainer-carousel__heading {
  margin: 0 0 8px;
  font-size: 15px;
  font-weight: 700;
  color: var(--color-wh);
}

.trainer-carousel__text {
  margin: 0;
  font-size: 16px;
  line-height: 1.75;
  color: var(--color-wh);
}


/* サブセクション */
.trainer-carousel__subsection {
  margin-top: 12px;
  margin-bottom: 32px;
}

.trainer-carousel__subsection .trainer-carousel__heading {
  font-size: 14px;
  margin-bottom: 6px;
}

.trainer-carousel__subsection .trainer-carousel__text {
  font-size: 14px;
}


/* メッセージ */
.trainer-carousel__block.trainer-carousel__block--d h3.trainer-carousel__heading {
  background: var(--color-bk);
}

.trainer-carousel__block.trainer-carousel__block--d .trainer-carousel__text {
  color: var(--color-bk);
}


/*----- リストスタイル -----*/
.trainer-carousel__list-title {
  display: block;
  font-size: 12px;
  line-height: 1.25;
  color: var(--color-bk);
}

.trainer-carousel__list-name {
  font-size: 15px;
  font-weight: 700;
  color: var(--color-bk);
  line-height: 1.25;
}



/* ========== スマホ（B→A・C横並び→D） ========== */
@media (max-width: 1023px) {

  /* レイアウト */
  .trainer-carousel__row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    margin-bottom: 24px;
  }

  .trainer-carousel__block--a {
    order: 2;
    min-width: 0;
  }

  .trainer-carousel__block--b {
    order: 1;
    grid-column: 1 / -1;
  }

  .trainer-carousel__block--c {
    order: 3;
    min-width: 0;
  }

  /* Block D は .row の外で DOM 上すでに下にあるため 4番目 */


  /* プロフィールイメージ画像 */
  .trainer-carousel__photo {
    width: min(400px, 40vw);
    height: auto;
    flex-shrink: 0;
  }
}


@media (max-width: 781px) {
  .trainer-carousel__row {
    grid-template-columns: 1fr;
  }

  .trainer-carousel__block--b {
    grid-column: auto;
  }
}


@media (max-width: 639px) {
  .trainer-carousel__block--d {
    padding: 24px;
  }

  .trainer-carousel__list {
    margin-bottom: 0;
}

  /* リスト表示：4列・プロフィール画像のみ */
  .trainer-carousel__list-inner {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
  }

  .trainer-carousel__list-photo {
    width: min(80px, 20vw);
    height: auto;
  }

  .trainer-carousel__list-item {
    width: 100%;
  }

  .trainer-carousel__list-title,
  .trainer-carousel__list-name {
    display: none !important;
  }

  .trainer-carousel__box {
    padding: 24px;
    border-radius: 20px;
  }
}


@media (max-width: 400px) {
  .trainer-carousel__box {
    padding: 16px;
    border-radius: 16px;
  }

  .trainer-carousel__block--d {
    padding: 16px;
  }

  .trainer-carousel {
    padding: 32px 24px 24px;
  }

  button.trainer-carousel__arrow img {
    width: 24px !important;
    height: 24px !important;
  }

  .trainer-carousel__list-inner {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 10px;
  }

  .trainer-carousel__list-photo {
    width: 60px;
    height: 60px;
  }
}