/******* Do not edit this file *******
Simple Custom CSS and JS - by Silkypress.com
Saved: Jun 08 2026 | 18:11:30 */
/* 各セクションのアニメーション */
/* =========================================
   初期状態
========================================= */
.swell-block-fullWide .ani-title,
.swell-block-fullWide .ani-left,
.swell-block-fullWide .ani-right,
.swell-block-fullWide .ani-under {
  opacity: 0;
  will-change: transform, opacity;
}

/* 左→右 */
.swell-block-fullWide .ani-left {
  transform: translateX(-50px);
}

/* 右→左 */
.swell-block-fullWide .ani-right {
  transform: translateX(50px);
}

/* 下→上 */
.swell-block-fullWide .ani-under {
  transform: translateY(50px);
}

/* =========================================
   ani-title（カーテン表示）
========================================= */
.swell-block-fullWide .ani-title {
	position: relative;
	display: block;
	overflow: hidden;
	margin-left: auto;
	margin-right: auto;
	width: max-content;
}

/* JSで包む文字本体 */
.swell-block-fullWide .ani-title .ani-curtain-text {
  display: inline-block;
  opacity: 0;
  transform: translateX(-12px);
  position: relative;
  z-index: 1;
  will-change: transform, opacity;
}

/* カーテン */
.swell-block-fullWide .ani-title::after {
  content: "";
  position: absolute;
  inset: 0;
  background: #6b6b6b;
  transform: translateX(-101%);
  z-index: 2;
  pointer-events: none;
  will-change: transform;
}

/* =========================================
   発火後
========================================= */

/* タイトル自体を表示可能に */
.swell-block-fullWide.is-animated .ani-title {
  opacity: 1;
}

/* カーテン */
.swell-block-fullWide.is-animated .ani-title::after {
  animation: curtainReveal 1s cubic-bezier(0.77, 0, 0.18, 1) forwards;
}

/* 文字はカーテンに覆われたタイミングで出す */
.swell-block-fullWide.is-animated .ani-title .ani-curtain-text {
  animation: curtainTextReveal 1s steps(1, end) forwards;
}

/* 左 */
.swell-block-fullWide.is-animated .ani-left {
  opacity: 1;
  transform: translateX(0);
  transition:
    opacity 0.9s ease,
    transform 0.9s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: 0.15s;
}

/* 右 */
.swell-block-fullWide.is-animated .ani-right {
  opacity: 1;
  transform: translateX(0);
  transition:
    opacity 0.9s ease,
    transform 0.9s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: 0.3s;
}

/* 下 */
.swell-block-fullWide.is-animated .ani-under {
  opacity: 1;
  transform: translateY(0);
  transition:
    opacity 0.9s ease,
    transform 0.9s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: 0.45s;
}

/* =========================================
   Keyframes
========================================= */
@keyframes curtainReveal {
  0% {
    transform: translateX(-101%);
  }
  45% {
    transform: translateX(0%);
  }
  55% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(101%);
  }
}

@keyframes curtainTextReveal {
  0% {
    opacity: 0;
    transform: translateX(-12px);
  }
  54% {
    opacity: 0;
    transform: translateX(-12px);
  }
  55% {
    opacity: 1;
    transform: translateX(0);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}




/* =========================
   下層ページトップ カーテン表示
========================= */

/* 全体を最初は見えない状態に */
#top_title_area {
  position: relative;
  overflow: hidden;
}

#top_title_area .l-topTitleArea__img,
#top_title_area .c-pageTitle {
  opacity: 0;
}

/* カーテン本体 */
#top_title_area::after {
  content: "";
  position: absolute;
  inset: 0;
  background: #444; /* カーテン色。必要なら変更 */
  transform: scaleX(1);
  transform-origin: left center;
  z-index: 2;
  pointer-events: none;
  opacity: 0;
}

/* アニメーション開始 */
#top_title_area.is-animated::after {
  opacity: 1;
  animation: topTitleCurtainOpen .6s cubic-bezier(0.77, 0, 0.175, 1) forwards;
}

/* 画像は少し遅れて表示 */
#top_title_area.is-animated .l-topTitleArea__img {
  animation: topTitleImageReveal .6s ease forwards;
  animation-delay: 0s;
}

/* タイトルも少し遅れて表示 */
#top_title_area.is-animated .c-pageTitle {
  animation: topTitleTextReveal .8s ease forwards;
  animation-delay: 0.45s;
}

/* カーテンが左→右に開く */
@keyframes topTitleCurtainOpen {
  0% {
    opacity: 1;
    transform: scaleX(1);
    transform-origin: left center;
  }
  49% {
    opacity: 1;
    transform: scaleX(1);
    transform-origin: left center;
  }
  50% {
    opacity: 1;
    transform: scaleX(1);
    transform-origin: right center;
  }
  100% {
    opacity: 1;
    transform: scaleX(0);
    transform-origin: right center;
  }
}

/* 画像表示 */
@keyframes topTitleImageReveal {
  0% {
    opacity: 0;
    transform: scale(1.06);
    filter: blur(6px);
  }
  100% {
    opacity: 1;
    transform: scale(1);
    filter: blur(0);
  }
}

/* タイトル表示 */
@keyframes topTitleTextReveal {
  0% {
    opacity: 0;
    transform: translateY(18px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}