@charset "UTF-8";

/*--------------------------------------------------------
　ビフォーアフター（beforeafter）専用スタイル
　single-beforeafter.php 用
--------------------------------------------------------*/

/* =======================================
　ビフォーアフター 写真エリア
======================================= */

.beforeafter-photos {
  background: var(--color-gray00);
  padding: 16px 24px;
  border-radius: 16px;
  margin-top: 40px;
}

.beforeafter-photos__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.beforeafter-photos__row {
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: center;
}

h2.beforeafter-photos__angle {
  margin-bottom: 0 !important;
  text-align: center;
}

h2.beforeafter-photos__angle:after {
  content: "";
  display: block;
  width: 100px;
  height: 1px;
  border-bottom: 1px solid;
  margin: 4px auto;
}

hgroup.beforeafter-photos__angle-group {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
}

p.beforeafter-photos__angle-en {
  font-size: 14px;
  font-family: var(--type-english-font);
  padding-bottom: 0 !important;
}

.beforeafter-photos__before-after {
  display: flex;
  gap: 4px;
}

.beforeafter-photos__cell {
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* 画像の高さを統一し、縦横比を保ちつつ中央でトリミング */
.beforeafter-photos__cell img {
  width: 100%;
  height: 360px;
  object-fit: cover;
  object-position: center;
  display: block;
  vertical-align: bottom;
}

span.beforeafter-photos__label {
  line-height: 1;
  padding: 4px 8px 6px;
  color: #FFF;
  border-radius: 2px;
  margin-top: 4px;
  font-size: 11px;
}

span.beforeafter-photos__label.before_label {
  background: var(--color-bk);
}

span.beforeafter-photos__label.after_label {
  background: var(--color-primary);
}


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

  .beforeafter-photos__cell img {
    height: 75vw;
    max-height: 400px;
  }
}


/* =======================================
　ビフォーアフター メタ・成果
======================================= */

.beforeafter-meta span.beforeafter-course {
  background: var(--color-bk);
  color: var(--color-wh);
  line-height: 1.25;
  padding: 6px 12px;
  border-radius: 4px;
}

.beforeafter-results__item {
  display: flex;
  gap: 16px;
}

dl.beforeafter-results__list {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 40px;
  margin: 40px 0;
  padding: 20px 4px;
  border-top: 1px solid var(--color-gray03);
  border-bottom: 1px solid var(--color-gray03);
}

dl.beforeafter-results__list dt {
  width: 120px;
  text-align: center;
  border: 1px solid var(--color-bk);
  border-radius: 4px;
  line-height: 1.25;
  padding: 4px 8px;
}

dl.beforeafter-results__list dd span.beforeafter-results__after {
  color: var(--color-primary);
}

dl.beforeafter-results__list dd span.small_label {
  font-size: 11px;
}



/* =======================================
　ビフォーアフター お客様の声
======================================= */

.beforeafter-voice {
  padding: 40px 80px;
  margin-bottom: 80px !important;
  max-width: 1000px;
  margin: 0 auto;
  background: var(--color-gray00);
  border-radius: 16px;
}

h2.beforeafter-voice__title {
  border-bottom: 4px solid var(--color-bk);
  padding-bottom: 4px;
}

.beforeafter-voice__content {
  padding: 0 8px;
}


/* =======================================
　ビフォーアフター アーカイブ（コース別）カード
　taxonomy-beforeafter-course.php 用
======================================= */

.beforeafter-archive-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  list-style: none;
  margin: 0;
  padding: 56px 0;
}

.beforeafter-archive-card {
  margin: 0;
}

.beforeafter-archive-card__inner {
  display: flex;
  flex-direction: row;
  gap: 0;
  background: var(--color-base);
  border-radius: 12px;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
  overflow: hidden;
  height: 100%;
}

.beforeafter-archive-card__photo {
  flex: 0 0 auto;
  width: 30%;
  min-height: 200px;
  position: relative;
  background: var(--color-gray00);
}

.beforeafter-archive-card__photo-link {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 200px;
  overflow: hidden;
}

.beforeafter-archive-card__photo.beforeafter-archive-card__photo--hover a {
  opacity: 1;
}

.beforeafter-archive-card__photo-link .beforeafter-archive-card__img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: opacity 0.25s ease;
}

.beforeafter-archive-card__photo-link .beforeafter-archive-card__img--before {
  opacity: 1;
  z-index: 1;
}

.beforeafter-archive-card__photo-link .beforeafter-archive-card__img--after {
  opacity: 0;
  z-index: 2;
}

.beforeafter-archive-card__photo--hover .beforeafter-archive-card__photo-link:hover .beforeafter-archive-card__img--before {
  opacity: 0;
}

.beforeafter-archive-card__photo--hover .beforeafter-archive-card__photo-link:hover .beforeafter-archive-card__img--after {
  opacity: 1;
}

.beforeafter-archive-card__photo-hint {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: 0;
  padding: 6px 8px;
  font-size: 11px;
  color: var(--color-base);
  background: rgba(0, 0, 0, 0.5);
  text-align: center;
  z-index: 3;
}

.beforeafter-archive-card__body {
  flex: 1;
  min-width: 0;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

p.beforeafter-archive-card__customer {
  margin: 0;
  font-size: 13px;
  color: var(--color-primary-font-main);
  padding-bottom: 0 !important;
}

p.beforeafter-archive-card__course {
  margin: 0;
  font-size: 12px;
  padding-bottom: 0 !important;
}

p.beforeafter-archive-card__course a {
  display: inline-block;
  background: var(--color-bk);
  color: var(--color-wh) !important;
  padding: 4px 10px;
  border-radius: 4px;
  line-height: 1.3;
  text-decoration: none !important;
}

.beforeafter-archive-card__course a:hover {
  opacity: 0.9;
}

.beforeafter-archive-card__title {
  margin: 4px 0;
  font-size: 19px;
  line-height: 1.4;
  font-weight: 700;
}


h2.beforeafter-archive-card__title a {
  color: var(--color-bk) !important;
  text-decoration: none !important;
}

.beforeafter-archive-card__results {
  margin-top: 4px;
  flex: 1;
  min-height: 0;
}

.beforeafter-archive-card__table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}

.beforeafter-archive-card__table th,
.beforeafter-archive-card__table td {
  padding: 8px 10px;
  border: 1px solid var(--color-gray02);
  text-align: center;
  font-size: 13px;
  line-height: 1.25;
}

.beforeafter-archive-card__table thead th {
  font-weight: 700;
}

.beforeafter-archive-card__th--before {
  background: var(--color-gray00);
  color: var(--color-primary-font-main);
}

.beforeafter-archive-card__th--after {
  background: var(--color-primary);
  color: var(--color-wh);
}

.beforeafter-archive-card__table tbody th {
  background: var(--color-base);
  font-weight: 600;
  text-align: center;
}

.beforeafter-archive-card__table .beforeafter-archive-card__after {
  color: var(--color-primary);
  font-weight: 600;
}

.beforeafter-archive-card__link-wrap {
  margin: 12px 0 0;
  padding: 0;
  display: flex;
  justify-content: flex-end;
}

main p a.beforeafter-archive-card__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--color-bk) !important;
  text-decoration: none;
  font-weight: 600;
}

.beforeafter-archive-card__link:hover {
  text-decoration: underline;
}

.beforeafter-archive-card__link-icon {
  display: inline-block;
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  position: relative;
}

.beforeafter-archive-card__link-icon::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("../../images/common/common-button-arrow-circle.webp") no-repeat center / contain;
}

.beforeafter-archive-pagination {
  margin-top: 40px;
}

@media (max-width: 781px) {
  .beforeafter-archive-card__inner {
    flex-direction: column;
  }

  /* 781px以下: ホバーではなく Before / After を横並び表示 */
  .beforeafter-archive-card__photo {
    width: 100%;
    min-height: 240px;
  }

  .beforeafter-archive-card__photo-link {
    display: flex;
    flex-direction: row;
    height: 50vw;
  }

  .beforeafter-archive-card__photo-link .beforeafter-archive-card__img {
    position: relative;
    top: auto;
    left: auto;
    width: 50%;
    flex: 0 0 50%;
    height: 100%;
    min-height: 50vw;
    object-fit: cover;
    opacity: 1;
  }

  .beforeafter-archive-card__photo-link .beforeafter-archive-card__img--before {
    opacity: 1;
  }

  .beforeafter-archive-card__photo-link .beforeafter-archive-card__img--after {
    opacity: 1;
  }

  .beforeafter-archive-card__photo--hover .beforeafter-archive-card__photo-link:hover .beforeafter-archive-card__img--before,
  .beforeafter-archive-card__photo--hover .beforeafter-archive-card__photo-link:hover .beforeafter-archive-card__img--after {
    opacity: 1;
  }

  .beforeafter-archive-card__photo-hint {
    display: none;
  }
}



@media (max-width: 639px) {
  .beforeafter-archive-cards {
    grid-template-columns: 1fr;
  }

  .beforeafter-archive-card__photo {
    width: 54vw;
    min-width: 100%;
    height: 40vh;
    margin: 0 auto;
    border-radius: 16px 16px 0 0;
    overflow: hidden;
  }

  .beforeafter-archive-card__photo-link {
    height: 40vh;
  }

  .beforeafter-archive-card__photo-link .beforeafter-archive-card__img {
    min-height: 40vh;
  }

  p.beforeafter-archive-card__customer,
  p.beforeafter-archive-card__course {
    text-align: center;
}

.beforeafter-archive-card__link-wrap {
  justify-content: center;
}

}