@charset "utf-8";

/*==============================
  ギャラリー全体レイアウト
==============================*/
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 60px;
}

/*==============================
  thumb-wrapper（共通）
==============================*/
.thumb-wrapper {
  position: relative;
  overflow: hidden;
  opacity: 0;
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

.thumb-wrapper.is-visible {
  opacity: 1;
}

/*==============================
  画像（共通設定）
==============================*/
.thumb-wrapper img {
  display: block;
  width: 100%;
  height: auto;
  transform-origin: center center;
  transition: transform 0.8s ease;
  max-height: calc(var(--vh) * 100);
}

/*==============================
  ホバー時拡大（共通）
==============================*/
@media (hover: hover) and (pointer: fine) {
  .thumb-wrapper:hover img {
    transform: scale(1.03);
  }
}
/*==============================
  縦長画像
==============================*/
.thumb-wrapper.vertical {
  grid-column: span 1;
  height: auto; /* 初期状態（レスポンシブで上書き） */
}

.thumb-wrapper.vertical img {
  height: 100%;
  object-fit: cover;
}

/*==============================
  横長画像
==============================*/
.thumb-wrapper.horizontal {
  grid-column: span 2;
}

.thumb-wrapper.horizontal img {
  height: auto;
  object-fit: cover;
}

/*==============================
  レスポンシブ対応
==============================*/
@media (max-width: 1440px) {
  .thumb-wrapper.vertical {
    height: 750px;
  }
}

@media (max-width: 1300px) {
  .thumb-wrapper.vertical {
    height: 700px;
  }
}

@media (max-width: 1250px) {
  .thumb-wrapper.vertical {
    height: 630px;
  }
}

@media (max-width: 1180px) {
  .thumb-wrapper.vertical {
    height: 580px;
  }
}

@media (max-width: 1030px) {
  .thumb-wrapper.vertical {
    height: 510px;
  }
}

@media (max-width: 910px) {
  .gallery-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .thumb-wrapper.horizontal,
  .thumb-wrapper.vertical {
    grid-column: span 1;
    height: auto;
  }

  .works__contents {
    margin-top: 40px;
  }
}