@charset "UTF-8";

body.post-type-archive-service .c-archive-header {
    margin-bottom: 65px;
}

.l-contents {
    max-width: 1200px;
    width: 90%;
}

.p-service-cards-item__link {
    position: relative;
}

.p-service-cards-item__link:nth-child(1)::after {
    content: "";
    background-image: url(../images/activity1_icon.png);
    position: absolute;
    top: -50px;
    right: -50px;
    width: 111px;
    height: 111px;
    background-repeat: no-repeat;
    background-size: contain;
}

.p-service-cards-item {
    column-gap: 16px;
    justify-content: space-between;
}

.p-service-cards-item__content {
    border: 1px solid #707070;
    border-left: 1px solid #707070;
}

.p-service-cards-item__title {
    border-bottom: 1px solid #707070;
    padding-left: 25px;
}

/* 454x298 / 143x94 を基準にする（最大時にそのサイズ） */
.p-service-gallery{
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: stretch;
  max-width: 100%;
}

/* 左：常に 454:298 の比率（最大で 454x298） */
.p-service-gallery__main{
  margin: 0;
  overflow: hidden;
}


.p-service-gallery__main{
  position: relative;
  overflow: hidden;
  min-width: 0;
}

/* 既存のデザインを活かしつつ、左のメイン画像上に配置 */
.p-service-gallery__main .p-service-cards-elements{
  position: absolute;
  right: 0;
  z-index: 2;
}

/* 右：縦3枚。各枠は 143:94 の比率（最大で 143x94） */
.p-service-gallery__side{
  width: clamp(7rem, -7.474rem + 21.05vw, 9.5rem);
  /* max-width: 35%;   狭い時は自動で縮む */
  display: grid;
  grid-template-rows: repeat(3, 1fr);
  gap: 8px;
}

/* 各ボタン（枠）自体に比率を持たせる */
.p-service-gallery__side-btn{
  padding: 0;
  border: 2px solid transparent;
  background: none;
  cursor: pointer;
  overflow: hidden;
}

.p-service-gallery__main-img,
.p-service-gallery__side-img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.p-service-gallery__side-btn.is-active{
  border-color: #14a06f;
}

/* タイトルの色を元に戻す */
.p-service-cards-item__link:hover .p-service-cards-item__title {
  color: inherit;
}

/* 矢印を非表示に戻す */
.p-service-cards-item__link:hover .p-service_title_arrow {
  opacity: 0;
}

/* 矢印アニメーションを止める */
.p-service-cards-item__link:hover .p-service_title_arrow::before {
  animation: none;
}

.p-service-cards-item__content:hover .p-service-cards-item__title {
  color: var(--tcd-accent-color);
}

.p-service-cards-item__content:hover .p-service_title_arrow {
  opacity: 1;
}

.p-service-cards-item__content:hover .p-service_title_arrow::before {
  animation-name: arrowFloatLeft;
}

.p-service-cards-item__content {
    width: 46%;
}

.p-service-cards-item__image {
    width: 50%;
}

.p-service-cards-item__desc {
    padding-left: 25px;
    padding-right: 25px;
    padding-top: 25px;
    padding-bottom: 25px;
    align-items: flex-start;
}

.p-service-cards-item__desc span {
    --tcd-line-clamp: initial;
    line-height: 1.9;
}

@media screen and (max-width: 1220px) {
    .p-service-cards-item__desc span {
        --tcd-line-clamp: 3;
    }
}

/* 991px以下：サイドを下に回して横3枚にする */
@media (max-width: 991px){
  .p-service-cards-item__link:nth-child(1)::after {
    top: -30px;
    right: -20px;
    width: 95px;
    height: 95px;
  }
  .p-service-gallery{
    grid-template-columns: 1fr;   /* 1列に */
  }

  .p-service-gallery__side{
    width: auto;
    grid-template-columns: repeat(3, 1fr); /* 横3枚 */
    grid-template-rows: none;
  }

  /* 右（下段）の各画像の比率は維持 */
  .p-service-gallery__side-btn{
    aspect-ratio: 143 / 94;
  }
  .p-service-cards-item__content {
    width: 100%;
  }
    .p-service-cards-item__image {
        width: 100%;
        height: 100%;
    }

    .p-service-cards-item__desc span {
        --tcd-line-clamp: initial;
    }
}

/* スマホは縦並びにしたい場合（任意） */
@media (max-width: 768px){
  .p-service-gallery{
    grid-template-columns: 1fr;
  }
  .p-service-gallery__side{
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: none;
  }
}
