@charset "UTF-8";

/****************************************
 * WE CRAFT ページ
 ****************************************/

/*メイン画像*/
.m-wc{
	width: 1000px;
	margin: 0 auto;	
}
.m-wc img{
	width: 100%;
}

/*２つのWE CRAFT*/
.wc-second, .w-syokai{
	margin: 0 auto;
}
.wc-second article{
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
	padding: 20px 0;
}
.wc-second article:first-of-type{
	border-bottom: 1px solid #999;
}
.wc-second article figure{
	width: 20%;
}
.wc-second article figure img{
	width: 100%;
}
.wc-second article div{
	width: 75%;
	position: relative;
}
.second-text{
	width: 100% !important;
	position: absolute;
	top:50%;
	transform: translateY(-50%);
}
.second-text h3{
	font-size: 2.5em;
	margin-bottom: 10px;
}
.second-text p{
	font-size: 1.2em;
}
.w-syokai{
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
	margin-top: 60px;
}
.w-syokai article{
	width: 48%;
}
.w-syokai article h3{
	font-size: 1.8em;
	text-align: center;
}
.w-syokai article h3, .w-syokai article figure{
	margin-bottom: 10px;
}
.w-syokai article figure, .w-syokai article figure img{
	width: 100%;
}
.w-syokai article figure img{
	border-radius: 20px;
}
.w-syokai article p{
	width: 90%;
	margin: 0 auto;
	font-size: 1.2em;
}
.wc-itembtn{
	display: block;
	background: #E54244;
	color: #FFF;
	padding: 10px 40px;
	font-size: 1.2em;
	box-shadow: 0 4px 0 #000;
	border-radius: 50px;
	text-align: center;
	overflow: hidden;
	position: relative;
	z-index: 1;
	margin: 0 auto;
	width: 300px;
	height: 40px;
}
.wc-itembtn::after {
	background: #2783E8;
	position: absolute;
	top: 0;
	left: 0;
	content: '';
	width: 100%;
	height: 100%;
	transform: scale(0, 1);
	transform-origin: left top;
	transition: .2s cubic-bezier(0.45, 0, 0.55, 1);
	z-index: -1;
}
.wc-itembtn:hover{
	color: #FFF;
	transform: translateY(4px);
	box-shadow: none;
}
.wc-itembtn:hover::after{
	transform: scale(1, 1);
}

@media screen and (max-width: 1100px) {
	.m-wc{
	width: 90%;
	}	
}

@media screen and (max-width: 800px) {
	.wc-second article{
		display: grid;
	}
	.wc-second article figure{
		width: 100%;
		text-align: center;
		margin-bottom: 10px;
	}
	.second-text h3{
	font-size: 1.5em;
	margin-bottom: 10px;
	}
	.wc-second article figure img{
	width: auto;
	}
	.wc-second article div{
	width: 94%;
	padding: 0 3%;
	}
	.w-syokai{
		display: inherit;
	}
	.w-syokai article{
		width: 100%;
		margin-bottom: 60px;
	}
	.w-syokai article figure{
		width: 90%;
		margin: 0 auto 40px;
	}
	
	
	
	
}














/****************************************
 * 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%;
  }
}