@charset "UTF-8";
/****************************************
 * Works Page — 実績紹介
 ****************************************/

/* セクション共通 */
.works-page .works-section {
  padding: clamp(56px, 7vw, 100px) 0;
}

.works-page .works-section+.works-section {
  border-top: 1px solid #eee;
}

/* 見出し（●付き日本語ラベル＋英字） */
.works-page .works-section__header {
  margin-bottom: clamp(16px, 3vw, 28px);
  text-align: left;
}

.works-page .section-label--light {
  display: inline-flex;
  align-items: center;
  color: #111;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: .05em;
}

.works-page .section-label--light::before {
  content: "●";
  margin-right: 6px;
  color: var(--blue);
  font-size: .7em;
  line-height: 1;
}

.works-page .works-hero__title.en {
  font-family: "Poppins", "Zen Kaku Gothic Antique", sans-serif;
  font-weight: 800;
  font-size: clamp(44px, 8vw, 140px);
  letter-spacing: .02em;
  line-height: 1.05;
  color: var(--blue);
  margin: 0 0 clamp(12px, 2vw, 18px);
}

.works-page .works-section__lead {
  color: var(--blue);
  font-weight: 800 !important;
  font-size: clamp(22px, 3.2vw, 48px);
  line-height: 1.7;
  letter-spacing: .04em;
  margin-bottom: clamp(8px, 1.6vw, 12px);
  margin-bottom: 40px;
}

.works-page .works-section__txt {
  font-size: 1.6rem;
  font-size: var(--fs-16);
  margin: 40px auto;
  line-height: 1.9;
  letter-spacing: .03em;
}

/* ===== 実績紹介（Works） ===== */

.works-list {
  background: #fff;
  padding: clamp(36px, 6vw, 64px) 0;
}

/* 見出し */
.works-block__title {
  font-weight: 800;
  color: var(--blue, #135ba4);
  letter-spacing: .06em;
  font-size: clamp(18px, 2.6vw, 28px);
  line-height: 1.3;
  margin: 0 0 clamp(14px, 2.6vw, 22px);
}

/* 2×2 グリッド */
.works-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(14px, 2.6vw, 24px);
  margin-bottom: clamp(14px, 2.6vw, 22px);
}

/* サムネイルのカード */
.works-shot {
  position: relative;
  overflow: hidden;
  border-radius: 16px;
  background: #f3f6fa;
  box-shadow: 0 6px 18px rgba(0, 0, 0, .08);
  isolation: isolate;
  /* 影と丸みを綺麗に */
}

/* 画像は統一比率でトリミングして並べる（画像高さを揃える） */
.works-shot img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  aspect-ratio: 4 / 3;
  /* 必要なら 16/10 や 3/2 に変更可 */
  transition: transform .5s cubic-bezier(.2, .7, .2, 1), filter .3s ease;
}


/* 説明文 */
.works-block__desc {
  color: var(--black, #333);
  font-size: clamp(14px, 1.7vw, 16px);
  line-height: 1.9;
  letter-spacing: .02em;
  margin: 0;
}

/* ブロック間の余白 */
.works-block+.works-block {
  margin-top: clamp(36px, 7vw, 72px);
  border-top: 1px solid #eef2f7;
  padding-top: clamp(24px, 5vw, 40px);
}

/* スマホ：1カラム */
@media (max-width: 720px) {
  .works-grid {
    grid-template-columns: 1fr;
  }

  .works-shot {
    border-radius: 14px;
  }
}


/* カードグリッド */
.works-page .works-section h2.works-section__title {
  color: #333;
  font-weight: 800 !important;
  font-size: clamp(22px, 3.2vw, 48px);
  line-height: 1.7;
  letter-spacing: .04em;
  margin-bottom: clamp(8px, 1.6vw, 12px);
  margin-bottom: 40px;
  margin-top: 160px;
}

.works-page .works-grid_c3 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(18px, 3vw, 28px);
}

@media (max-width:1024px) {
  .works-page .works-grid_c3 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width:600px) {
  .works-page .works-grid_c3 {
    grid-template-columns: 1fr;
  }
}

/* カード（タイトル→画像→本文） */
.works-page .works-card {
  display: grid;
  grid-template-rows: auto auto 1fr;
  row-gap: 10px;
}

.works-page .works-card__title {
  font-weight: 700;
  font-size: clamp(16px, 2vw, 18px);
  color: #111;
  line-height: 1.5;
  margin: 0;
}

/* 画像カードを正方形に */
.works-page .works-card__thumb {
  aspect-ratio: 1 / 1;
  /* 正方形 */
  border-radius: 12px;
  overflow: hidden;
  background: #f4f6f8;
}

.works-page .works-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  /* 中央トリミング */
  display: block;
}

.works-page .works-card__desc {
  font-size: 14px;
  line-height: 1.9;
  color: #444;
  letter-spacing: .02em;
}



@media (prefers-reduced-motion: reduce) {
  .works-page .works-card__thumb img {
    transition: none;
  }
}

/* === タイトルを写真上に重ねるバリアント（DOM順そのまま） === */
.works-page .works-card--overlay {
  display: grid;
  grid-template-areas:
    "media"
    "desc";
}

.works-page .works-card--overlay .works-card__thumb {
  grid-area: media;
  position: relative;
}

.works-page .works-card--overlay .works-card__title {
  grid-area: media;
  align-self: end;
  justify-self: start;
  position: relative;
  z-index: 1;
  margin: 0 0 clamp(10px, 1.6vw, 14px) clamp(10px, 1.6vw, 14px);
  color: #fff;
  text-shadow: 0 2px 10px rgba(0, 0, 0, .45), 0 0 1px rgba(0, 0, 0, .6);
  font-size: clamp(17px, 2.1vw, 20px);
  line-height: 1.3;
}

.works-page .works-card--overlay .works-card__thumb::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top,
      rgba(0, 0, 0, .36) 0%,
      rgba(0, 0, 0, .16) 38%,
      rgba(0, 0, 0, 0) 62%);
}

.works-page .works-card--overlay .works-card__desc {
  grid-area: desc;
}

/* セクション別の軽いアクセント（任意） */
.works-page .works-section--digital .works-hero__title.en {
  color: var(--blue);
}

.works-page .works-section--promotion .works-hero__title.en {
  color: var(--blue);
}

/* 常時ちょい明るめ（リンクでないので hover なし） */
:root {
  --thumb-bright: 1.06;
  --thumb-contrast: 1.02;
  --thumb-sat: 1.03;
}

/* 画像サムネのみ（YouTube除外） */
.works-page .works-card__thumb:not(.works-card__thumb--video) img {
  filter: brightness(var(--thumb-bright)) contrast(var(--thumb-contrast)) saturate(var(--thumb-sat));
  transition: none !important;
  /* 念のためアニメ無効 */
  transform: none !important;
  /* 念のため拡大無効 */
}

/* 万が一、他所に残っている :hover を無効化（保険） */
.works-page .works-card__thumb:hover img {
  filter: brightness(var(--thumb-bright)) contrast(var(--thumb-contrast)) saturate(var(--thumb-sat)) !important;
  transform: none !important;
}

/* タイトルを写真に重ねるタイプは弱めに（任意） */
.works-page .works-card--overlay .works-card__thumb:not(.works-card__thumb--video) img {
  filter: brightness(1.10) contrast(.99) saturate(1.04);
}

/* YouTube 埋め込みは 16:9 を維持 */
.works-page .works-card__thumb--video {
  aspect-ratio: 16 / 9;
  background: #000;
  position: relative;
  /* 子のabsolute基準 */
}

.works-page .works-card__thumb--video .video-embed {
  position: absolute;
  inset: 0;
}

.works-page .works-card__thumb--video iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

/*画像の上にカテゴリ載せる*/
.works-card__thumb span {
  position: absolute;
  right: 10px;
  top: 10px;
  display: table;
  color: white;
  border-radius: 8px;
  padding: 6px 10px;
  font-size: 16px;
  z-index: 10;
  border: 1px solid white;
}

/*カテゴリで色分け*/
.c-tikikoho {
  background-color: black;
}

.c-jimotoevent {
  background-color: indianred;
}

.c-kanko {
  background-color: forestgreen;
}

.c-joho {
  background-color: cornflowerblue;
}

.c-shotenkassei {
  background-color: darkorange;
}

/* 古いブラウザ向けフォールバック（aspect-ratio 非対応） */
@supports not (aspect-ratio: 1 / 1) {

  /* 画像=正方形 */
  .works-page .works-card__thumb:not(.works-card__thumb--video) {
    position: relative;
  }

  .works-page .works-card__thumb:not(.works-card__thumb--video)::before {
    content: "";
    display: block;
    padding-top: 100%;
  }

  .works-page .works-card__thumb:not(.works-card__thumb--video)>* {
    position: absolute;
    inset: 0;
  }

  /* YouTube=16:9 */
  .works-page .works-card__thumb--video {
    position: relative;
  }

  .works-page .works-card__thumb--video::before {
    content: "";
    display: block;
    padding-top: 56.25%;
    /* 9/16 */
  }

  .works-page .works-card__thumb--video .video-embed,
  .works-page .works-card__thumb--video iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
  }
}