@charset "UTF-8";
/*!
Theme Name: Cocoon Child
Description: Cocoon専用の子テーマ
Theme URI: https://wp-cocoon.com/
Author: わいひら
Author URI: https://nelog.jp/
Template:   cocoon-master
Version:    1.1.3
*/
/************************************
** 子テーマ用のスタイルを書く
************************************/
/*必要ならばここにコードを書く*/
@import url('https://fonts.googleapis.com/css2?family=Roboto+Condensed:wght@700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Kosugi+Maru&display=swap');
#index-tab-1:checked ~ .index-tab-buttons .index-tab-button[for=index-tab-1], #index-tab-2:checked ~ .index-tab-buttons .index-tab-button[for=index-tab-2], #index-tab-3:checked ~ .index-tab-buttons .index-tab-button[for=index-tab-3], #index-tab-4:checked ~ .index-tab-buttons .index-tab-button[for=index-tab-4] {
  color: #FFF; /*選択後の文字色*/
  background: #000 !important; /*選択後の背景色*/
}
.page-template-lp-2 {
  margin-top: 0;
}
.is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)) {
  max-width: unset !important;
  margin-left: unset !important;
  margin-right: unset !important;
}
.page-template-lp-2 .entry-content {
  margin-top: 0;
  margin-bottom: 0;
}
.wp-block-group {
  margin: 0 !important;
}
.inner {
  position: relative;
  width: 1200px;
  margin: 0 auto;
}
.block01 {
  margin-bottom: 0;
  position: relative;
  z-index: 1;
}
.parallax-bg .bg01 {
  width: 100%;
  height: 100vh;
  position: sticky;
  top: 0;
  z-index: -1;
  background: url(https://katarist.com/wp-content/themes/cocoon-master/images/bg_block01.jpg) no-repeat center center / cover;
  background-attachment: fixed; /* ← これが効くようになる */
}

.parallax-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.block01 h1 {
  position: fixed;
  bottom: 30px;
  text-align: center;
  left: 50%; /* 横位置を画面の50%に */
  transform: translateX(-50%); /* 要素の幅の半分だけ左にずらして中央に */
	  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}
.block01 h1 img {
  max-height: 6vh;
  height: auto;
  max-width: 100%;
}
.text-center {
  position: sticky;
  top: 4px;
  height: 100vh;
}
.block01 .observe-target-001 {
	height: 50vh;

}

.block01 .observe-target-002 {
	height: 50vh;

}

.block01 .observe-target-003 {
	height: 50vh;

}

.block01 .bg_catch {
    position: fixed;
    top: 39.5vh;
    left: 63.7vw;
    transform: translate(-50%, -50%);
    z-index: 10;
    width: min(70vw, 989px);
    aspect-ratio: 989 / 337;
    	  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.bg_catch .bg-image {
  width: 100%;
  height: auto;
  display: block;
}
.catch-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.catch img {
    height: auto;
    width: 45.5vw; /* 1920px × 45.5% = 約874px */
    max-width: 100%;
    margin: 0 auto;
}
/* .catch 要素たちを絶対配置に */
.catch {
  position: absolute;
  width: 45.5vw;
  height: auto;
}

/* 個別配置（例：自由に調整してOK） */
.catch01, .catch02, .catch03 {
  top: 29%;
  left: 10%;
opacity: 0;
  transition: opacity 0.1s linear;
  pointer-events: none;
}


.catch01,
.catch02,
.catch03 {
  opacity: 0;
  transition: opacity 0.3s ease;
}


.catch {
  opacity: 0;
}
.catch.active {
  opacity: 1;
}
.block01 .indicator-001-active {
  opacity: 1;
}
.block01 .indicator-001.indicator-002.indicator-001-active.indicator-002-active {
  opacity: 0;
}
.block01 .indicator-002.indicator-003.indicator-002-active {
  opacity: 1;
}
.block01 .indicator-002.indicator-003.indicator-002-active.indicator-003-active {
  opacity: 0;
}
.block01 .indicator-003-active {
  opacity: 1;
}
.block01 .indicator-002.indicator-003.indicator-003-active {
  opacity: 0;
}
.observe-target-001, .observe-target-002, .observe-target-003, .observe-target-005, .observe-target-006, .observe-target-007, .observe-target-008, .observe-target-009, .observe-target-010, .observe-target-011, .observe-target-012, .observe-target-013, .observe-target-014, .observe-target-015, .observe-target-016, .observe-target-017, .observe-target-018, .observe-target-019, .observe-target-020, .observe-target-021, .observe-target-022, .observe-target-023, .observe-target-024, .observe-target-025, .observe-target-026, .observe-target-027, .observe-target-028, .observe-target-029, .observe-target-030, .observe-target-031, .observe-target-032 {
  opacity: 0;
}


.block02 {
  margin-bottom: 0;
  position: relative;
  z-index: 1;
}
.parallax-bg .bg02 {
  width: 100%;
  height: 100vh;
  position: sticky;
  top: 0;
  z-index: -1;
  background: url(https://katarist.com/wp-content/themes/cocoon-master/images/bg_block02_night.jpg), url(https://katarist.com/wp-content/themes/cocoon-master/images/bg_block02.jpg);
  background-position: center bottom, center bottom;
  background-size: cover, cover;
  background-repeat: no-repeat, no-repeat;
  transition: background 1.3s ease-in-out;
}
.block02.indicator-005-active .parallax-bg .bg02, .block02.indicator-006-active .parallax-bg .bg02 {
  background: url(https://katarist.com/wp-content/themes/cocoon-master/images/bg_block02.jpg) no-repeat center bottom / cover;
}
.observe-target-006 {
  position: absolute;
  bottom: 0;
}
.text {
  margin: 0 auto;
  width: 80%;
  padding: 100vh 0 60vh;
  height: auto;
  color: #fff;
  text-align: center;
}
.block02 .text h2 {
  margin-bottom: 10px;
  font-size: 20px;
  font-weight: 900;
  line-height: 1em;
}
.block02 .text h2 {
  font-size: 20px;
  font-weight: 900;
}
.block02 .text p {
  margin-bottom: 44vh;
  font-size: min(3vw, 40px);
  font-weight: 800;
}
.block02 .text .last_text {
  margin-bottom: 0;
}
.block02 .observe-target-004 {
  margin-bottom: 36vh;
}
.block03 {
  position: relative;
  margin-bottom: 0 !important;
  padding: 0;
  height: 1000vh;
  overflow: visible;
  view-timeline-name: --section-pin;
  view-timeline-axis: block;
  z-index: 1;
}
.block03 h2 {
  text-align: center;
  margin-top: 90px;
  margin-bottom: 5vh;
  font-size: 68px;
}
.block03 h2 span {
  display: block;
  font-size: 35px;
  line-height: 1em;
}
.scroll_container {
  height: 1000vh;
}
.horizontal_scroll {
  height: calc(100vh - 800px);
  min-height: 390px;
  width: 900vw;
  will-change: transform;
  display: flex;
  justify-content: center;
  align-items: center;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  transition: transform 0.5s ease-in-out;
}
.scroll_contents {
  display: inline-block;
  position: relative;
  width: 100vw;
  text-align: center;
}
.scroll_contents {
  display: inline-block;
  position: relative;
  width: 100vw;
  text-align: center;
}
.scroll_contents p {
  font-size: 48px;
  font-weight: 300;
  line-height: 1.5em;
  letter-spacing: -0.03em;
  position: relative;
}


@media (max-height: 950px) {
    .scroll_contents p {
        font-size: 40px;
    }
	.block03 h2 span {
    font-size: 31px;
}
	.horizontal_scroll {
    min-height: 360px;
}
.block03 h2 {
    font-size: 54px;
}
.sticky_wrap .indicator {
    margin-bottom: 80px;
}
.s2-catch {
    font-size: 36px !important;
}
}

@media (max-height: 780px) {
    .scroll_contents p {
        font-size: 27px;
    }
	.block03 h2 span {
    font-size: 28px;
}
	.horizontal_scroll {
    min-height: 270px;
}
.block03 h2 {
    font-size: 48px;
}
.sticky_wrap .indicator {
    margin-bottom: 30px;
}
.s2-catch {
    font-size: 30px !important;
}
}





.scroll_contents .double_quotation {
  position: relative; /* 疑似要素の基準点を設定 */
  display: inline-block;
}
.scroll_contents .double_quotation::after {
  content: "";
  position: absolute;
  top: -40px;
  left: -61px;
  width: 146px;
  height: 130px;
  background: url(https://katarist.com/wp-content/themes/cocoon-master/images/bg_coron.png) no-repeat center / cover;
  z-index: -1;
}
.sticky_wrap {
  overflow: hidden;
  position: sticky;
  top: 0;
  height: 100vh;
  background: linear-gradient(to bottom, #adccef, #e7f0fe);
}
.scroll_contents h3 {
  font-size: 30px;
  margin-bottom: 30px;
}
.scroll_contents h4 {
  margin-top: 24px;
  font-size: 24px;
  display: block;
}
.s2-catch {
  font-size: 40px;
  bottom: 42px;
  text-align: center;
  font-weight: 800;
  line-height: 1.5em;
}
.s2-catch .logo_text {
  font-weight: 600;
}
.logo_orange, .orange {
  color: #ff4e00;
}
.indicator {
  margin-bottom: 15vh;
  padding: 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 50px;
}
.dot {
  width: 9px;
  height: 9px;
  background-color: white;
  border-radius: 50%;
  margin: 0 12px;
}
.s2-catch {}
.block03 .indicator-007-active.dot, .block03 .indicator-008-active.dot, .block03 .indicator-009-active.dot, .block03 .indicator-010-active.dot, .block03 .indicator-011-active.dot, .block03 .indicator-012-active.dot, .block03 .indicator-013-active.dot, .block03 .indicator-030-active.dot, .block03 .indicator-031-active.dot, .block03 .indicator-032-active.dot, .block03 .indicator-033-active.dot {
  background-color: black;
}
.scroll_container {
  position: relative;
}
.voice-target {
  position: absolute;
  top: 99vh;
}
.voice-target div {
  margin: 0 0 99vh;
}
.voice-target div:last-child {
  margin: 0 0 60vh;
}
.horizontal_scroll.indicator-008-active {
  transform: rotate3d(1, 1, 0, 0deg) translateX(-100vw);
  transition: transform 1s;
}
.horizontal_scroll.indicator-009-active {
  transform: rotate3d(1, 1, 0, 0deg) translateX(-200vw);
  transition: transform 1s;
}
.horizontal_scroll.indicator-010-active {
  transform: rotate3d(1, 1, 0, 0deg) translateX(-300vw);
  transition: transform 1s;
}
.horizontal_scroll.indicator-011-active {
  transform: rotate3d(1, 1, 0, 0deg) translateX(-400vw);
  transition: transform 1s;
}
.horizontal_scroll.indicator-012-active {
  transform: rotate3d(1, 1, 0, 0deg) translateX(-500vw);
  transition: transform 1s;
}
.horizontal_scroll.indicator-030-active {
  transform: rotate3d(1, 1, 0, 0deg) translateX(-600vw);
  transition: transform 1s;
}
.horizontal_scroll.indicator-031-active {
  transform: rotate3d(1, 1, 0, 0deg) translateX(-700vw);
  transition: transform 1s;
}
.horizontal_scroll.indicator-032-active, .horizontal_scroll.indicator-013-active {
  transform: rotate3d(1, 1, 0, 0deg) translateX(-800vw);
  transition: transform 1s;
}
.block04 {
  position: relative;
  z-index: 1;
  margin-bottom: 0;
  padding-top: 68px;
  background: #fff;
}
.block04 h2 {
  text-align: center;
  margin-top: 0;
  margin-bottom: 60px;
  font-size: 68px;
}
.block04 h2 span {
  display: block;
  font-size: 35px;
  line-height: 1em;
}
.block04 p {
  font-size: 24px;
}
.block04 p span {
  font-weight: 800;
}
.block04 .accordion {
  width: 100%;
}
.block04 .accordion-button {
  width: 270px;
  height: 40px;
  margin: 50px auto;
  padding: 8px 13px;
  background-color: #ff6600;
  color: white;
  border: none;
  cursor: pointer;
  text-align: left;
  font-size: 15px;
  display: flex;
  align-items: center;
  border-radius: 60px;
  font-weight: 600;
  transition: transform 0.4s ease-in-out;
	     position: relative;
      overflow: hidden;
}
.block04 .accordion-button.open {
  opacity: 0.5;
  transform: scale(0.9);
}
.block04 .accordion-button::before {
  content: '+';
  margin-right: 12px;
  font-size: 23px;
  font-weight: 500;
}

    .block04 .accordion-button::after {
      content: '';
      position: absolute;
      top: 0;
      left: -100%;
      width: 100%;
      height: 100%;
      background: linear-gradient(120deg, transparent, rgba(255,255,255,0.5), transparent);
    }
    .block04 .accordion-button:hover::after {
      animation: shine 1s forwards;
    }
    @keyframes shine {
      to { left: 100%; }
    }

.block04 .accordion-content {
  max-height: 0;
  overflow: hidden;
  background-color: #000000;
  transition: max-height 1s ease-out;
  position: relative;
}
.block04 .accordion-content p {
  margin: 0;
}
.block04 .close-button {
  position: absolute;
  top: 20px;
  left: 0;
  width: 47px;
  height: 47px;
  border-radius: 50%; /* 丸くする */
  background-color: #262626; /* 背景色を設定 */
  color: #bdbdbd; /* 文字色を設定 */
  border: none; /* ボーダーを消す */
  font-size: 40px; /* 文字サイズを調整 */
  display: flex; /* 中央揃え */
  align-items: center; /* 中央揃え */
  justify-content: center; /* 中央揃え */
  cursor: pointer; /* ポインターを表示 */
}
.block04 .close-button:hover {
  background-color: #3c3c3c;
  transition: 0.5s;
}
.block04 .next_backBtn .next, .block04 .next_backBtn .back {
  width: 47px;
  height: 47px;
  border-radius: 50%; /* 丸くする */
  background-color: #262626; /* 背景色を設定 */
  color: #bdbdbd; /* 文字色を設定 */
  border: none; /* ボーダーを消す */
  display: flex; /* 中央揃え */
  align-items: center; /* 中央揃え */
  justify-content: center; /* 中央揃え */
  cursor: pointer; /* ポインターを表示 */
}
.block04 .next_backBtn {}
.block04 .next_backBtn .next {
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  z-index: 10;
}
.block04 .next_backBtn .back {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  z-index: 10;
}
.block04 .next_backBtn .next:hover, .block04 .next_backBtn .back:hover {
  background-color: #3c3c3c;
  transition: 0.5s;
}
.block04 .popupBtn a {
  width: 270px;
  height: 40px;
  margin: 34px auto 0;
  padding: 8px 13px;
  background-color: #ff6600;
  color: white;
  border: none;
  cursor: pointer;
  text-align: left;
  font-size: 15px;
  display: flex;
  align-items: center;
  border-radius: 60px;
  font-weight: 600;
  transition: transform 0.4s ease-in-out;
  text-decoration: none;
}
.block04 .popupBtn a:hover {
  background: #fd761c;
}
.block04 .popupBtn a::before {
  content: '+';
  margin-right: 12px;
  font-size: 23px;
  font-weight: 500;
}
.block04 .slides h3 {
  margin-bottom: 133px;
  text-align: center;
  color: #fff;
  font-size: 42px;
  text-shadow: 0 0 0 #3b3b3b, 0 0 2px #3b3b3b, 0 0 8px #858585;
}
.block04 .slides h3 span {
  display: block;
  font-size: 24px;
  text-shadow: 0 0 0 #3b3b3b, 0 0 2px #3b3b3b, 0 0 8px #858585;
}
.block04 .slides p {
  color: #fff;
  font-size: 20px;
  text-shadow: 0 0 0 #3b3b3b, 0 0 2px #3b3b3b, 0 0 8px #404040;
}
.block04 .popupBtn {
  text-shadow: none !important;
}
.block04 .accordion-content .inner {
  position: relative;
  padding: 107px 0;
}
.block04 .slider-container {
  /* position: relative; */
  width: 1120px;
  height: 630px;
  margin: 0 auto;
  overflow: hidden;
}
.block04 .slides {
  display: flex;
  width: 11200px;
  transition: transform 0.5s ease-in-out;
}
.block04 .slide {
  width: 1120px;
  height: 630px;
  flex-shrink: 0;
  padding: 40px 110px 0;
  display: flex;
  align-items: center;
  /* justify-content: center; */
  flex-direction: column;
}
.block04 .slide:nth-child(1) {
  background: url(https://katarist.com/wp-content/themes/cocoon-master/images/bg_strengths01.png) no-repeat;
}
.block04 .slide:nth-child(2) {
  background: url(https://katarist.com/wp-content/themes/cocoon-master/images/bg_strengths05.png) no-repeat;
}
.block04 .slide:nth-child(3) {
  background: url(https://katarist.com/wp-content/themes/cocoon-master/images/bg_strengths02.png) no-repeat;
}
.block04 .slide:nth-child(4) {
  background: url(https://katarist.com/wp-content/themes/cocoon-master/images/bg_strengths03.png) no-repeat;
}
.block04 .slide:nth-child(5) {
  background: url(https://katarist.com/wp-content/themes/cocoon-master/images/bg_strengths06.png) no-repeat;
}
.block04 .slide:nth-child(6) {
  background: url(https://katarist.com/wp-content/themes/cocoon-master/images/bg_strengths07.png) no-repeat;
}
.block04 .slide:nth-child(7) {
  background: url(https://katarist.com/wp-content/themes/cocoon-master/images/bg_strengths08.png) no-repeat;
}
.block04 .slide:nth-child(8) {
  background: url(https://katarist.com/wp-content/themes/cocoon-master/images/bg_strengths04.png) no-repeat;
}
.block04 .slide:nth-child(9) {
  background: url(https://katarist.com/wp-content/themes/cocoon-master/images/bg_strengths09.png) no-repeat;
}
.block04 .slide:nth-child(10) {
  background: url(https://katarist.com/wp-content/themes/cocoon-master/images/bg_strengths12.png) no-repeat;
}

.block04 .indicators {
  position: absolute;
  display: flex;
  bottom: 48px;
  justify-content: center;
  margin-top: 10px;
  border: 0;
  /* background: #ff0000; */
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
}
.block04 .slider-container input {
  display: none;
}
.block04 .indicators label {
  width: 9px;
  height: 9px;
  margin: 0 12px;
  background-color: #666666;
  border-radius: 50%;
  cursor: pointer;
  transition: background-color 0.3s;
}
.block04 .slider-container input:checked:nth-of-type(1) ~ .indicators label:nth-of-type(1), .block04 .slider-container input:checked:nth-of-type(2) ~ .indicators label:nth-of-type(2), .block04 .slider-container input:checked:nth-of-type(3) ~ .indicators label:nth-of-type(3), .block04 .slider-container input:checked:nth-of-type(4) ~ .indicators label:nth-of-type(4), .block04 .slider-container input:checked:nth-of-type(5) ~ .indicators label:nth-of-type(5), .block04 .slider-container input:checked:nth-of-type(6) ~ .indicators label:nth-of-type(6), .block04 .slider-container input:checked:nth-of-type(7) ~ .indicators label:nth-of-type(7), .block04 .slider-container input:checked:nth-of-type(8) ~ .indicators label:nth-of-type(8), .block04 .slider-container input:checked:nth-of-type(9) ~ .indicators label:nth-of-type(9), .block04 .slider-container input:checked:nth-of-type(10) ~ .indicators label:nth-of-type(10), .block04 .slider-container input:checked:nth-of-type(11) ~ .indicators label:nth-of-type(11) {
  background-color: #ffffff;
}
.block04 .slider-container input:nth-of-type(1):checked ~ .slides {
  transform: translateX(0);
}
.block04 .slider-container input:nth-of-type(2):checked ~ .slides {
  transform: translateX(-1120px);
}
.block04 .slider-container input:nth-of-type(3):checked ~ .slides {
  transform: translateX(-2240px);
}
.block04 .slider-container input:nth-of-type(4):checked ~ .slides {
  transform: translateX(-3360px);
}
.block04 .slider-container input:nth-of-type(5):checked ~ .slides {
  transform: translateX(-4480px);
}
.block04 .slider-container input:nth-of-type(6):checked ~ .slides {
  transform: translateX(-5600px);
}
.block04 .slider-container input:nth-of-type(7):checked ~ .slides {
  transform: translateX(-6720px);
}
.block04 .slider-container input:nth-of-type(8):checked ~ .slides {
  transform: translateX(-7840px);
}
.block04 .slider-container input:nth-of-type(9):checked ~ .slides {
  transform: translateX(-8960px);
}
.block04 .slider-container input:nth-of-type(10):checked ~ .slides {
  transform: translateX(-10080px);
}
.block04 .slider-container input:nth-of-type(11):checked ~ .slides {
  transform: translateX(-11200px);
}
.block04 .overlay {
  display: none; /* 初期は非表示 */
  position: fixed; /* ブラウザ全体に固定 */
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh; /* ブラウザ全体の高さ */
  background: #fff;
  z-index: 1000;
  justify-content: center;
  align-items: center;
  opacity: 0.96;
}

.block04 .popup-img img {
  max-width: 100vw;
  max-height: 100vh;
  object-fit: contain; /* アスペクト比を保って収める */
}

/* ★ オーバーレイ表示中のみ、親コンテナを最前面に */
.block04.overlay-active {
  position: relative;         /* z-index を有効化 */
  z-index: 100000;            /* .block05(z-index:1) より上 */
}

/* （任意）表示中は背面をクリックさせない */
.block04.overlay-active *:not(.overlay) {
  pointer-events: none;
}

.block04 .popup-img img {
  width: 100%;
  height: auto;
}
.block04 .popup-close-btn {
  position: absolute;
  top: 5%;
  left: 5%;
  width: 47px;
  height: 47px;
  border-radius: 50%; /* 丸くする */
  background-color: #ececec; /* 背景色を設定 */
  color: #bdbdbd; /* 文字色を設定 */
  border: none; /* ボーダーを消す */
  cursor: pointer; /* ポインターを表示 */
}
.block04 .popup-close-btn:hover {
  background-color: #f5f3f3;
  transition: 0.5s;
}
.block04 .next_backBtn button {
  width: 47px;
  height: 47px;
  background: #fff;
  cursor: pointer;
}
.block05 {
  position: relative;
  margin-bottom: 0;
  background: #fff;
}
.popupBtn {
  position: absolute;
  bottom: 30px;
}
.block06 {
  margin-top: -100vh;
  padding-top: 100vh;
  position: relative;
  text-align: center;
  z-index: 1;
  margin-bottom: 0;

  /* 初期状態 */
  opacity: 0;
  transform: translateY(50px);
  will-change: opacity, transform;

  /* ↓ トランジションはCSS側で制御 */
  transition: opacity 0.15s linear;/* 短い easing でカクつきを抑える */
}

.block06.animate-in {
  /* 表示時 */
  opacity: 1;
  transform: translateY(0);
}


.block06::after {
  content: "";
  display: block;
}

.clearfix::after {
  content: "";
  display: block;
  clear: both;
	    min-height: 300px;
    height: 20vh;
}



.block06 .katari {
  font-size: 21px;
  letter-spacing: 0.5em;
  color: #000;
  margin: 0;
  padding: 0;
  font-weight: 500;
  letter-spacing: -0.06em;
}
.block06 .title_ja {
  font-size: 68px;
  font-weight: 700;
  color: #000;
  margin: 0 0 0 0;
  z-index: 2;
  position: relative;
  line-height: 1.3em;
}
.block06 .title_en {
  font-size: 200px; /* .clip の縮小後のサイズと一致させる */
  font-family: 'Roboto Condensed', sans-serif;
  color: #ffbc03;
  margin: -180px 0 0 0;
}



.block06-inner {
  
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -244px);
}

.block06-bg {
  position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, 33px);
  width: 1342px;
  height: 596px;
}

.observe-target-020 {
	margin-top: 25vh;
}

.block06-bg picture,
.block06-bg img {
  display: block;
  width: 100%;
  height: auto;                /* アスペクト比を保持 */
}

.block06-bg figure {
  margin: 0;                   /* figureの余白をリセット */
}
.block06-bg figure figcaption {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}



/* テキストコンテナの幅を左右半分ずつに */
.block06-bg .compare-left,
.block06-bg .compare-right {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 50%;
}
.block06-bg .compare-left { left: 0; }
.block06-bg .compare-right { right: 0; }

/* 各テキストブロックの共通スタイル */
.block06-bg .item {
  color: #fff;
  text-align: left;
  line-height: 1.4;
  transition: opacity 0.4s ease-out;
}
.block06-bg .item h4 {
  position: absolute;
  margin: 0 0 8px;
  font-size: 20px;
  font-weight: bold;
}
.block06-bg .item p {
  position: absolute;
  margin: 0;
  font-size:16px;
}

/* — 左側テキスト配置 — */
.block06-bg .compare-left .rect1 h4 {
    top: 110px;
    left: 20px;
    /* width: 280px; */
}
.block06-bg .compare-left .rect1 p {
    top: 150px;
    left: 20px;
    width: 155px;
}
.block06-bg .compare-left .rect2 h4 {
    top: 16px;
    left: 298px;
    width: 280px;
}
.block06-bg .compare-left .rect2 p {
    top: 55px;
    left: 370px;
    width: 180px;
	text-align: right;
}
.block06-bg .compare-left .rect3 h4 {
    top: 430px;
    left: 184px;
    /* width: 280px; */
}
.block06-bg .compare-left .rect3 p {
    top: 463px;
    left: 130px;
    width: 280px;
}
.block06-bg .compare-left .rect4 h4 {
    top: 347px;
    left: 470px;
    width: 170px;
    text-align: right;
}
.block06-bg .compare-left .rect4 p {
    top: 416px;
    left: 437px;
    width: 213px;
}

/* — 右側テキスト配置 — */
.block06-bg .compare-right .rect1 h4 {
    top: 109px;
    right: 355px;
    width: 280px;
}
.block06-bg .compare-right .rect1 p {
    top: 176px;
    right: 504px;
    width: 130px;
}
.block06-bg .compare-right .rect2 h4 {
    top: 355px;
    right: 50px;
    width: 280px;
    text-align: right;
}
.block06-bg .compare-right .rect2 p {
    top: 423px;
    right: 41px;
    width: 310px;
}
.block06-bg .compare-right .rect3 h4 {
    top: 16px;
    right: 126px;
    width: 280px;
    text-align: right;
}
.block06-bg .compare-right .rect3 p {
    top: 56px;
    right: 120px;
    width: 170px;
    text-align: right;
}



.head_title {
	text-align: center;
}

.head_title .katari {
    font-size: 21px;
    color: #000;
    margin: 0;
    padding: 0;
    font-weight: 500;
    letter-spacing: -0.06em;
}

.head_title .title_ja {
  font-size: 68px;
  font-weight: 700;
  color: #000;
  margin: 0 0 0 0;
  z-index: 2;
  position: relative;
  line-height: 1.3em;
}
.head_title .title_en {
    font-size: 280px;
    font-family: 'Roboto Condensed', sans-serif;
    color: #ffbc03;
    margin: -188px 0 0 0;
}




.block_leading {
}

.block_leading .head_title {
    margin-bottom: -213px;
}

.comparison-table {
	margin: 0 auto;
	padding-top: 11px;
  background: url(https://katarist.com/wp-content/themes/cocoon-master/images/bg_comparison-table.png) no-repeat center 0;
}

.comparison-table table {
  width: 100%;
  border-collapse: collapse;
  min-width: 1000px;
}
.comparison-table th,
.comparison-table td {
  padding: 10px 17px;
  text-align: left;
	border: none;
	height: 50px;
    vertical-align: middle;
    line-height: 1em;
}

.comparison-table th {
	font-size: 16px;
}

.comparison-table .katarist {
	font-size: 18px;
}

.comparison-table th:first-child,.comparison-table td:first-child {
	color: #47028c;
	font-size: 16px;
	text-align: right;
	font-weight: bold;
}
.comparison-table td {
	font-size: 15px;
}

.comparison-table td:nth-child(2) {
	font-weight: bold;
}

.comparison-table thead th {
  background-color: rgba(199, 239, 231, 0.85);
}

.comparison-table table tr:nth-of-type(2n+1) {
    background-color: #fff;
}
.comparison-table table tr {
	background-color: #ecf1f0;
}


.legal_table {
	margin: 0 0 40px;
	font-size: 16px;
}

.legal_table th {
	width: 250px;
	text-align: left;
}

.legal_table th {
	padding: 15px 15px;
	font-weight: 500;
}

.legal_table td {
	background: #fff;
	padding: 15px 15px;
}

.legal_table .del-sp {
	display: none;
}

.wp_main input[type=submit] {
    display: block;
    width: 40%;
    margin: 0 auto;
    -webkit-appearance: none;
    border: none;
    background-color: #373737;
    color: #ffffff;
}

.wpcf7 form .wpcf7-response-output {
    margin: 2em 0.5em 1em;
    padding: 0.5em 1em;
    border: 1px solid #0c0c0c !important;
    text-align: center;
    font-size: 16px;
}

.w1200 {
    width: 1200px;
    margin: 0 auto;
}


@media screen and (max-width: 834px) {
	.wp_main {
		width: 92%;
    margin: 0 auto !important;
	}
	
	.w1200 {
    width: 92%;
}
	
.table-wrapper {
  overflow-x: auto;   /* 横スクロールを有効化 */
  -webkit-overflow-scrolling: touch; /* スマホでのスムーズスクロール */
}

.comparison-table table {
  width: 100%;
  border-collapse: collapse;
  min-width: 1200px; /* 横幅を確保してスクロールを発生させる */
}
	
.comparison-table {
    margin: 0 auto;
    padding-top: 7px;
    background: url(https://katarist.com/wp-content/themes/cocoon-master/images/bg_comparison-table_sp.png) 
                no-repeat center top;
    background-size: 100% auto; /* 横幅100％、高さは自動 */
}
	

	
    /*必要ならばここにコードを書く*/
	  .del-sp {
		  display: block;
	  }
  }


.block_flow {
	margin: 200px 0 0 0;
}
.block_flow .head_title {
    margin-bottom: -214px;
}

.laptop_display {
  position: relative;
  width: 1296px;
  height: 756px;
  margin: 0 auto;
  background: url(https://katarist.com/wp-content/themes/cocoon-master/images/bg_notepc.png) no-repeat center top;
  background-size: contain;
  aspect-ratio: 1296 / 756; /* 実寸に合わせて修正 */

}

.screen_area {
width: 983px;
    height: 614px;
    position: absolute;
    top: 53px;
    left: 157px;
    overflow: hidden;
}

.screen_image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 0.8s ease;
  z-index: 1;
}

.screen_image.active {
  opacity: 1;
  z-index: 2;
}

.step_buttons {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    gap: 10px;
    background: #f5f5f5;
    width: 900px;
    margin: 50px auto 0;
    border-radius: 60px;
}


.step_buttons button {
    padding: 16px 16px;
    border: none;
    background-color: #f5f5f5;
	background: none;
    cursor: pointer;
    font-size: 16px;
}




.block_step {
	margin: 200px 0 0 0;
}

.block_step .head_title {
    margin-bottom: -202px;
}

.step_flow {
	margin: 0 auto;
	width: 1200px;
	height: 954px;
	position: relative;
}

.step_flow img {
	display: block;
    margin: 0 auto;
    transform: translateX(-13px);

}

.step_flow h3 {
	font-size: 23px;
	font-weight: bold;
}

.step_flow p {
	font-size: 16px;
}

.step_text01 {
	position: absolute;
	top: 32px;
	left: 715px;
}

.step_text02 {
	position: absolute;
	top: 192px;
	left: 42px;
	text-align: right;
}

.step_text03 {
	position: absolute;
	top: 349px;
	left: 715px;
}

.step_text04 {
	position: absolute;
	top: 519px;
	left: 42px;
	text-align: right;
}

.step_text05 {
	position: absolute;
	top: 669px;
	left: 715px;
}

.step_text06 {
	position: absolute;
	top: 839px;
	left: 42px;
	text-align: right;
}



.block_price {
	margin: 200px 0 0 0;
    background: #e9eeed;
    padding: 200px 0 200px;
}

.block_price .head_title {
    margin-bottom: -213px;
}

.pricing-table {
	margin: 0 auto;
	padding-top: 11px;
  background: url(https://katarist.com/wp-content/themes/cocoon-master/images/bg_comparison-table.png) no-repeat center 0;
}

.pricing-table table {
  width: 100%;
  border-collapse: collapse;
  min-width: 1000px;
}
.pricing-table th,
.pricing-table td {
  padding: 0 17px;
  text-align: left;
  vertical-align: top;
  border: none;
  height: 50px; /* 追加 */
	vertical-align: middle;
	line-height: 1em;
}

.pricing-table th {
	font-size: 16px;
	text-align: center;
}

.pricing-table th:first-child,.pricing-table td:first-child {
	color: #4f5cb0;
	font-size: 16px;
	text-align: right;
	font-weight: bold;
}
.pricing-table td {
	font-size: 15px;
	text-align: center;
	font-weight: bold;
}

.pricing-table .left {
	text-align: right;
}
.pricing-table .price {
	ont-family: 'Roboto Condensed', sans-serif;
    font-size: 35px;
}

.pricing-table thead th {
  background-color: rgba(79, 92, 176, 0.85);
	color: #fff;
}

.pricing-table table tr:nth-of-type(2n+1) {
    background-color: #e9eeed;
}
.pricing-table table tr {
	background-color: #fcfcfc;
}

.pricing-table th:last-child,.pricing-table td:last-child {
	padding-right: 60px;
}





























.block_offer {
	margin: 200px 0 0 0;
    background: #e9eeed;
    padding: 200px 0 200px;
}


.block_offer .head_title {
    margin-bottom: -213px;
}


.block_offer_inner {
  position: relative;
    width: 1200px;
    height: 791px;
    margin: 0 auto;
}

.background-image {
  width: 1200px;
  height: 791px;
  object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
}

.countdown-container {
}

.now-image {
  width: 152px;
    height: 60px;
    background: url(https://katarist.com/wp-content/themes/cocoon-master/images/now.png) no-repeat center center;
    background-size: contain;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 336px;
    left: 528px;
}

.countdown-text {
  font-size: 40px;
    font-weight: bold;
    color: black;
    position: absolute;
    top: 329px;
    left: 516px;
    animation: none;
}

.blinking {
  animation: blink 2s ease-in-out infinite;
}


.block_offer .offer_text01 {
	position: absolute;
	top: 75px;
	left: 0;
	width: 600px;
}

.block_offer .offer_text01 h3 {
	color: #ff4e00;
	font-size: 37px;
}

.block_offer .offer_text01 p {
	width: 380px;
	font-size: 14px;
}

.block_offer .offer_text02 {
	position: absolute;
	top: 390px;
	right: 0;
	width: 600px;
	text-align: right;
}

.block_offer .offer_text02 h3 {
	color: #0068b3;
	font-size: 37px;
}

.block_offer .offer_text02 p {
	width: 380px;
	font-size: 14px;
	display: inline-block;
}


@keyframes blink {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
}






















.block_faq {
	margin: 200px 0 0 0;
	background: #fff;
}

.block_faq .head_title {
  position: relative;
  z-index: 2;        /* faq-inner より大きい値に */
  margin-bottom: -250px; /* お好みの重なり量 */
}

/* ===== FAQ コンテナ ===== */

.faq-inner {
  max-width: 1200px;
  margin: 0 auto;
 position: relative;
  z-index: 5;
}

.faq-inner h3 {
	font-size: 27px;
	padding: 0 0 0 50px;
}

.faq-box {
	padding-top: 11px;
	background: url(https://katarist.com/wp-content/themes/cocoon-master/images/bg_comparison-table.png) no-repeat center 0;
}

/* ===== 各項目 ===== */
.faq-box .faq-item {
	margin: 0 0 10px 0;
  padding: 18px 0;
  /* block表示にしておく */
  display: block;
	background-color: rgba(233, 238, 237, 0.85);
	border: 1px solid #ffbc03;
}

/* ===== チェックボックス（非表示） ===== */
.faq-box .faq-toggle {
  display: none;
}

/* ===== 質問部分 ===== */
.faq-box .faq-question {
  display: flex;
  justify-content: space-between;
	margin-bottom: 0;
	padding: 0 50px;
  align-items: center;
  /* ←ここを追加すると、必要に応じて折り返す */
  flex-wrap: wrap;
  cursor: pointer;
  user-select: none;
}
.faq-box .q-mark {
  color: #ff6600;
  margin-right: 10px;
	font-family: sans-serif;
}
.faq-box .q-text {
    width: 90%;
    flex: 1 1 auto;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.5em;
}
.faq-box .arrow {
  flex: 0 0 auto;
  width: 28px;
  height: 12px;
  background: url(https://katarist.com/wp-content/themes/cocoon-master/images/faq_arrow.png) no-repeat center center;
  background-size: contain;
  transition: transform .3s ease;
	margin-left: 20px;
}
.faq-box .faq-toggle:checked + .faq-question .arrow {
  transform: rotate(180deg);
}

/* ===== 回答部分 ===== */
/* 幅100%＋折り返しさせつつ、高さ0→開閉アニメーション */
.faq-box .faq-answer {
    flex: 0 0 100%;
    width: 100%;
    padding: 0 50px;
    font-size: 17px;
    font-weight: 400;
    max-height: 0;
    overflow: hidden;
    transition: max-height .4s ease;
}

.faq-box .faq-answer p {
	margin-top: 20px;
	color: rgba(0, 0, 0, 0.82);
}

/* チェックが入ったら開く */
/* 「input → label → 回答」の順で並んでいる想定です */
.faq-box .faq-toggle:checked
  + .faq-question
  + .faq-answer {
  max-height: 750px;
}





.block_trial {
	margin: 200px 0 0 0;
}

.block_trial .head_title {
    position: relative;
    z-index: 2;
    margin-bottom: -200px;
}


.form-container {
  width: 100%;
	padding: 30px 0 150px;
    z-index: 5;
	position: relative;
	background-color: rgba(255, 208, 78, 0.85);
    border-top: 1px solid #b400ff;
}


.form-inner {
  margin: 0 auto;
  max-width: 1200px;
}

.form-inner .intro {
	margin-bottom: 50px;
    padding: 0 50px;
    font-size: 25px;
    font-weight: 600;
}

.form-section {
      display: flex;
	width: 950px;
	justify-content: space-between;
    }


	  
    .block_trial form {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 20px;
    }

    .block_trial .input-row {
      display: flex;
		justify-content: space-between;
      width: 420px;
		margin-bottom: 10px;
    }

    .block_trial input[type="text"] {
      width: 205px;
      height: 40px;
      padding: 15px;
     box-shadow: inset 0px 0px 4px 0px rgba(181, 80, 198, 1);
    border: 1px solid #b550c6;
      border-radius: 0;
      font-size: 16px;
    }

    .block_trial input[type="email"] {
      width: 420px;
      height: 40px;
      padding: 15px;
     box-shadow: inset 0px 0px 4px 0px rgba(181, 80, 198, 1);
    border: 1px solid #b550c6;
      border-radius: 0;
      font-size: 16px;
    }
	  
	  
.block_trial .user-type-radio {
  display: flex;
  margin-bottom: 10px;
  font-size: 16px;
  width: 420px;
}

/* ラジオ項目全体 */
.block_trial .radio-option {
  position: relative;
  padding-left: 30px;
  cursor: pointer;
  user-select: none;
  font-size: 16px;
  color: #333;
  display: inline-flex;
  align-items: center;
	margin-right: 15px;
}

/* デフォルトのラジオボタンを非表示 */
.block_trial .radio-option input[type="radio"] {
  opacity: 0;
  position: absolute;
}

/* カスタムラジオ（外枠） */
.block_trial .custom-radio {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  height: 20px;
  width: 20px;
  background-color: #fff;
  border: 1px solid #b550c6;
    box-shadow: inset 0px 0px 3px 0px rgba(181, 80, 198, 1);
  border-radius: 50%;
  transition: 0.3s;
  box-sizing: border-box;
}

/* チェックされた時の背景色や影 */
.block_trial .radio-option input[type="radio"]:checked + .custom-radio {
  background-color: #b550c6;
  box-shadow: 0 0 0 4px rgba(181, 80, 198, 0.2);
}

/* 内側の白い丸 */
.block_trial .custom-radio::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: white;
  transform: translate(-50%, -50%);
  display: none;
}

.block_trial .radio-option input[type="radio"]:checked + .custom-radio::after {
  display: block;
}


/* チェックボックス全体のラベル */
.block_trial .checkbox-label {
  position: relative;
  padding-left: 30px;
  cursor: pointer;
  font-size: 14px;
  color: #333;
  display: inline-block;
  user-select: none;
}

/* チェックボックス本体を非表示 */
.block_trial .checkbox-label input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  cursor: pointer;
}

/* カスタムチェックボックス枠 */
.block_trial .custom-checkbox {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  height: 20px;
  width: 20px;
  background-color: #fff;
    border: 1px solid #b550c6;
    box-shadow: inset 0px 0px 3px 0px rgba(181, 80, 198, 1);
  border-radius: 4px;
  box-sizing: border-box;
  transition: all 0.3s;
}

/* チェック時の中身 */
.block_trial .custom-checkbox::after {
  content: "";
  position: absolute;
  display: none;
  left: 5px;
  top: 0;
  width: 6px;
  height: 12px;
  border: solid white;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

/* チェックされたとき */
.block_trial .checkbox-label input[type="checkbox"]:checked + .custom-checkbox {
  background-color: #b550c6;
  border-color: #b550c6;
}

.block_trial .checkbox-label input[type="checkbox"]:checked + .custom-checkbox::after {
  display: block;
}


/* テキスト・メール・カスタムインプットへのフォーカス */
.block_trial .form-section input[type="text"]:focus-visible,
.block_trial .form-section input[type="email"]:focus-visible {
  outline: none;
  border-color: #b550c6;
  box-shadow: 0 0 0 3px rgba(181, 80, 198, 0.3);
}

.block_trial .form-section　input:focus {
  outline: none;
}

/* カスタムラジオにフォーカスされたとき */
.block_trial .form-section .radio-option input[type="radio"]:focus-visible + .custom-radio {
  box-shadow: 0 0 0 3px rgba(181, 80, 198, 0.5);
}

/* カスタムチェックボックスにフォーカスされたとき */
.block_trial .form-section .checkbox-label input[type="checkbox"]:focus-visible + .custom-checkbox {
  box-shadow: 0 0 0 3px rgba(181, 80, 198, 0.5);
}


.company-name-box {
  width: 420px;
  opacity: 1;
  max-height: 100px;
  overflow: hidden;
  transition: opacity 0.4s ease, max-height 0.4s ease;
  margin-bottom: 10px;
}

.company-name-box.hidden {
	margin-top: 0;
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  transition: opacity 0.4s ease, max-height 0.4s ease;
  margin-bottom: 0;
}

.company-name-box input[type="text"] {
  width: 100%;
  height: 40px;
  padding: 15px;
  box-shadow: inset 0px 0px 4px 0px rgba(181, 80, 198, 1);
  border: 1px solid #b550c6;
  border-radius: 0;
  font-size: 16px;
}
	  


.info-text {
    font-size: 14px;
    max-width: 470px;
    text-align: left;
}

    .start-button-wrapper {
      margin-top: 100px;
      display: flex;
      justify-content: center;
      width: 100%;
    }

.start-button {
    width: 125px;
    height: 125px;
    border-radius: 50%;
    /* background: radial-gradient(circle at center, #f59790 0%, #e55050 100%); */
    background: radial-gradient(circle at top left, #ff8475 0%, #b53123 100%);
    color: white;
    font-size: 25px;
    font-weight: bold;
    border: none;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 4px 7px 0px #9a2520, 4px 14px 8px rgba(0, 0, 0, 0.3);
	    font-family: 'Roboto Condensed', sans-serif;
}

.start-button::after {
    content: "";
    position: absolute;
    top: -30px;
    left: -31px;
    width: 190px;
    height: 190px;
    border-radius: 50%;
    border: 1px solid #1a1a1a;
    box-sizing: border-box;
}

    .start-button span {
      position: relative;
      z-index: 2;
    }

    .start-button:hover {
    background: radial-gradient(circle at top left, #c2473a 0%, #c2473a 100%);
    box-shadow: none;
    }

.agreement-box {
  margin-top: 20px;
  font-size: 14px;
  max-width: 470px;
}

.agreement-box label {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 5px;
}

.agreement-box input[type="checkbox"] {
  transform: scale(1.2);
}

.policy-links a {
  color: #b550c6;
  text-decoration: none;
  margin-right: 5px;
}

.policy-links a:hover {
  text-decoration: underline;
}



@media (max-width: 480px) {
  .radio-group {
    flex-direction: column;
    gap: 10px;
  }
}
.pc_clear {
  display: none;
}




.cacth-inner {
  position: relative;
  width: 100%;
  height: 100vh;
	text-align: center;
}

/* ── intro_cacth 本体を画面中央に ── */
.intro_cacth {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  white-space: nowrap; /* 改行禁止 */
    font-weight: 500;
}

.prefix,
.suffix,
.highlight,
.intro_cacth2 {
  transition: opacity 0.2s ease-out;
}
/* highlight はインラインブロックにして幅を持たせる */
.intro_cacth .highlight {
  display: inline-block;
	letter-spacing: -0.06em;
font-size: 50px;
}
/* prefix/suffix を highlight の左右に絶対配置 */
.intro_cacth .prefix {
  position: absolute;
  top: 50%;
  right: 100%;
  transform: translateY(-50%);
  margin-right: 0.3em; /* お好みで調整 */
font-size: 42px;
}
.intro_cacth .suffix {
  position: absolute;
  top: 50%;
  left: 100%;
  transform: translateY(-50%);
  margin-left: 0.3em;  /* お好みで調整 */
font-size: 42px;
}

/* intro_cacth2 も中央に */
.intro_cacth2 {
  position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    font-size: 60px;
    white-space: nowrap;
    font-weight: 700;
    line-height: 1.8;
}


/* 各文字を包む .circle */
.intro_cacth2 .circle {
  position: relative;
  display: inline-block;
  margin: 0 2px;              /* 文字間スペースお好みで */
}

/* 上に載せるオレンジの丸 */
.intro_cacth2 .circle::before {
  content: "";
  position: absolute;
  top: 7px;                  /* テキスト上端からのオフセット */
  left: 50%;
  transform: translateX(-50%);
  width: 10px;                  /* 丸の直径 */
  height: 10px;
  background-color: #ff4d02;
  border-radius: 50%;
}

/* ── 各ステージで opacity をトグル ── */
/* 017: highlight のみフェードイン */
.block05.indicator-017-active .highlight {
  opacity: 1;
}

/* 018: prefix, highlight, suffix 全部フェードイン */
.block05.indicator-018-active .prefix,
.block05.indicator-018-active .highlight,
.block05.indicator-018-active .suffix {
  opacity: 1;
}

/* 019: intro_cacth 内を全部フェードアウト→intro_cacth2 フェードイン */
.block05.indicator-019-active .prefix,
.block05.indicator-019-active .highlight,
.block05.indicator-019-active .suffix {
  opacity: 0;
}
.block05.indicator-021-active .intro_cacth2 {
  opacity: 1;
}




.block05-inner {
  position: sticky;
  top: 0;
  height: 100vh;
  background: url('https://katarist.com/wp-content/themes/cocoon-master/images/bg_block05_02.jpg') no-repeat center center;
  background-size: cover;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
}

.indicator-015-active .block05-inner {
  background: #ffbc03;
}

.indicator-020-active:not(.indicator-015-active) .block05-inner {
  background: none;
}


.top {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: transparent; /* ← none ではなく transparent を使用 */
  opacity: 0; /* フェードイン用に非表示から始める */
  display: flex;
  justify-content: center;
  align-items: center;
  mix-blend-mode: screen;
}
.clip {
  font-size: 25000px;
  font-weight: bold;
  color: black;
  background: transparent;
  text-align: center;
  user-select: none;
  white-space: nowrap;
  mix-blend-mode: multiply;
  font-family: 'Roboto Condensed', sans-serif;
  transition: none;
	transform: scale(3.15);
}
.indicator-014-active .top {
  background-color: #fff;
  opacity: 1; /* フェードインで表示状態に */
}


.indicator-014-active .clip {
}
.observe-target-016 {
  height: 0;
}
.observe-target-014 {
  height: 140vh;
}
.observe-target-015 {
line-height: 0;
}

.observe-target-017 {
  height: 20vh;
}

.observe-target-018 {
  height:20vh;
}

.observe-target-019 {
  height: 30vh;
}

.observe-target-021 {
  height: 30vh;
}

.observe-target-022 {
  height: 20vh;
}


.scroll-opacity-target {
  opacity: 0;
  transition: opacity 0.5s ease-in-out;
}


/************************************
** 以下その他のページ
************************************/

.wp_main {
	width: 900px;
	margin: 100px auto !important;
}

.wp_main h1 {margin-bottom: 30px;
	font-size: 30px;
}

.wp_main h2 {
	margin: 50px 0 20px;
	font-size: 20px;
}

.wp_main h3 {
	margin: 30px 0 10px;
	font-size: 18px;
}

.wp_main h4 {
	margin: 20px 0 5px;
	font-size: 16px;
}

.wp_main p, .wp_main li {
	font-size: 16px;
	margin: 0 0 1.5em 0;
}

.wp_main li {
	margin: 0 0 5px 0;
}

.wp_main .toc-center {
	display: none;
}

.site-footer {
	margin: 0;
  background-color: #fff;
  padding: 20px;
  text-align: center;
  font-size: 14px;
  color: #555;
}

.footer-links {
    margin-bottom: 10px;
    display: flex;
    justify-content: center;
}

.footer-links a {
  margin: 0 10px;
  text-decoration: none;
  color: #333;
font-size: 13px;
}

.footer-links a:hover {
  text-decoration: underline;
}

.footer-copy {
  color: #333;
}



@font-face {
  font-family: 'AdobeCleanUX';
  src: url('/fonts/AdobeCleanUX-Regular.woff2') format('woff2'), url('/fonts/AdobeCleanUX-Regular.woff') format('woff');
  font-weight: normal;
  font-style: normal;
}
/************************************
** レスポンシブデザイン用のメディアクエリ
************************************/
/*1023px以下*/
@media screen and (max-width: 1023px) {
  /*必要ならばここにコードを書く*/
  .mobile-menu-buttons .menu-caption {
    display: none;
  }
  .mobile-menu-buttons {
    align-items: center;
  }
  .menu-close-button {
    padding-top: 15px;
    padding-left: 25px;
    padding-bottom: 30px;
    text-align: left;
    font-size: 1.3em;
  }
  #navi-menu-input:checked ~ #navi-menu-close, #sidebar-menu-input:checked ~ #sidebar-menu-close, #search-menu-input:checked ~ #search-menu-close, #share-menu-input:checked ~ #share-menu-close, #follow-menu-input:checked ~ #follow-menu-close {
    opacity: 0;
  }
  .navi-menu-content {
    background-color: #fffffff0;
  }
  .menu-drawer a {
    font-size: 0.9em;
    line-height: 1.9em;
    border-bottom: solid 1px #e6e6e6;
  }
  .menu-drawer a:hover {
    background-color: #101010;
    color: #fff;
  }
  .sub-menu li {
    margin-left: -14px;
    font-size: 0.9em;
    color: #e6e6e6;
  }
}
/*834px以下*/
@media screen and (max-width: 834px) {
  /*必要ならばここにコードを書く*/
  .block01 h1 img {
    max-height: 5vh;
  }
  .parallax-bg .bg01 {
    width: 100%;
    min-height: 100vh;
            position: fixed;
    top: 0;
    z-index: -1;
    background: url(https://katarist.com/wp-content/themes/cocoon-master/images/bg_block01_sp.jpg) no-repeat center center / cover;
  }
  .pc_clear {
    display: block;
  }
  .sp_clear {
    display: none;
  }
  .block02 .text h2 {
    font-size: 16px;
    margin-bottom: 25px;
    font-weight: 600;
  }
  .block02 .text p {
    font-size: 23px;
  }
  .block03 h2 span {
    display: block;
    font-size: 15px;
    line-height: 1.8em;
  }
  .block03 h2 {
    text-align: center;
    margin-top: 5vh;
    margin-bottom: 3vh;
    font-size: 32px;
    padding: 0 20px;
    line-height: 1.5;
  }
  .scroll_contents h3 {
    font-size: 25px;
    margin-bottom: 30px;
  }
  .scroll_contents p {
    font-size: 21px;
    font-weight: 300;
    line-height: 1.5em;
    letter-spacing: -0.03em;
  }
  .scroll_contents h4 {
    margin-top: 15px;
    font-size: 14px;
  }
  .scroll_contents h3 {
    font-size: 17px;
    margin-bottom: 15px;
  }
  .scroll_contents .double_quotation::after {
            top: -23px;
        left: 10px;
        width: 56px;
        height: 48px;
  }
  .s2-catch {
    margin: 0 5%;
    font-size: 21px;
    bottom: 42px;
    text-align: center;
    font-weight: 800;
    line-height: 1.5em;
  }
  .inner {
    width: 90%;
  }

  .block04 p {
    font-size: 16px;
  }
  .horizontal_scroll {
    height: calc(100vh - 55vh);
    min-height: 10vh;
  }
  .indicator {
    height: 30px;
    margin-bottom: 10vh;
    padding: 0;
  }
  .block04 h2 span {
    font-size: 18px;
    line-height: 2em;
  }
  .block04 h2 {
    text-align: center;
    margin-top: 40px;
    margin-bottom: 35px;
    font-size: 35px;
    line-height: 1.4em;
  }
  .block04 .slides h3 span {
    display: block;
    font-size: 18px;
  }
  .block04 .slides h3 {
    margin-bottom: 10vh;
    text-align: center;
    color: #fff;
    font-size: 23px;
  }
  .block04 .slides p {
    color: #fff;
    font-size: 13px;
  }
  .block04 .accordion-content .inner {
    position: relative;
    padding: 65px 0;
  }
  .block04 .slider-container {
    width: 100%;
    height: auto;
    margin: 0 auto;
    overflow: hidden;
  }
  .block04 .slides {
    display: flex;
    width: 700vw; /* 7 slides */
    transition: transform 0.5s ease-in-out;
  }
  .block04 .slide {
    width: 90vw;
    height: 550px; /* Adjust height relative to viewport width */
    flex-shrink: 0;
    padding: 20px;
    display: flex;
    align-items: center;
    flex-direction: column;
    background-size: cover;
    background-position: center;
    border-radius: 20px;
  }
  .block04 .indicators {
    position: absolute;
    display: flex;
    bottom: 15px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1;
  }
  .block04 .slider-container input {
    display: none;
  }
  .block04 .indicators label {
    width: 8px;
    height: 8px;
    margin: 0 5px;
    background-color: #666;
    border-radius: 50%;
    cursor: pointer;
    transition: background-color 0.3s;
  }
.block04 .slider-container input:checked:nth-of-type(1) ~ .indicators label:nth-of-type(1), .block04 .slider-container input:checked:nth-of-type(2) ~ .indicators label:nth-of-type(2), .block04 .slider-container input:checked:nth-of-type(3) ~ .indicators label:nth-of-type(3), .block04 .slider-container input:checked:nth-of-type(4) ~ .indicators label:nth-of-type(4), .block04 .slider-container input:checked:nth-of-type(5) ~ .indicators label:nth-of-type(5), .block04 .slider-container input:checked:nth-of-type(6) ~ .indicators label:nth-of-type(6), .block04 .slider-container input:checked:nth-of-type(7) ~ .indicators label:nth-of-type(7), .block04 .slider-container input:checked:nth-of-type(8) ~ .indicators label:nth-of-type(8), .block04 .slider-container input:checked:nth-of-type(9) ~ .indicators label:nth-of-type(9), .block04 .slider-container input:checked:nth-of-type(10) ~ .indicators label:nth-of-type(10), .block04 .slider-container input:checked:nth-of-type(11) ~ .indicators label:nth-of-type(11) {
    background-color: #fff;
  }
  .block04 .slider-container input:nth-of-type(1):checked ~ .slides {
    transform: translateX(0);
  }
  .block04 .slider-container input:nth-of-type(2):checked ~ .slides {
    transform: translateX(-90vw);
  }
  .block04 .slider-container input:nth-of-type(3):checked ~ .slides {
    transform: translateX(-180vw);
  }
  .block04 .slider-container input:nth-of-type(4):checked ~ .slides {
    transform: translateX(-270vw);
  }
  .block04 .slider-container input:nth-of-type(5):checked ~ .slides {
    transform: translateX(-360vw);
  }
  .block04 .slider-container input:nth-of-type(6):checked ~ .slides {
    transform: translateX(-450vw);
  }
  .block04 .slider-container input:nth-of-type(7):checked ~ .slides {
    transform: translateX(-540vw);
  }
 .block04 .slider-container input:nth-of-type(8):checked ~ .slides {
    transform: translateX(-630vw);
  }
 .block04 .slider-container input:nth-of-type(9):checked ~ .slides {
    transform: translateX(-720vw);
  }
 .block04 .slider-container input:nth-of-type(10):checked ~ .slides {
    transform: translateX(-810vw);
  }
 .block04 .slider-container input:nth-of-type(11):checked ~ .slides {
    transform: translateX(-900vw);
  }
  .block04 .close-button {
    position: absolute;
    top: 10px;
    left: 0;
  }
  .block04 .close-button img {}
  .block04 .popup-close-btn {
    position: absolute;
    top: -50px;
    left: 10px;
  }
	

.wp_main {
    width: 92%;
    margin: 40px auto !important;
	}

.wp_main h1 {
    margin-bottom: 20px;
    font-size: 20px;
}
.legal_table th, .legal_table td {
    padding: 10px 15px;
    display: block;
    width: 100%;
    border: none;
}
.mblt-footer-mobile-buttons, .mblt-header-and-footer-mobile-buttons {
        margin-bottom: 0;
    }
.footer-links a {
	display: block;
    margin: 0 10px 5px;
    text-decoration: none;
    font-size: 11px;
}
.footer-links {
    display: block;
	margin-bottom: 15px;
}
.site-footer {
    font-size: 12px;
}
.wp_main h2 {
    margin: 40px 0 15px;
    font-size: 18px;
}
ol, ul {
    padding-left: 20px;
}
	
    .block01 .bg_catch {
                position: fixed;
        top: 46.5vh;
        left: 70.7vw;
        transform: translate(-50%, -50%);
        z-index: 10;
        width: min(47vw, 619px);
        aspect-ratio: 619 / 379;
        opacity: 0;
        pointer-events: none;
        transition: opacity 0.3s ease;
    }
	
.catch, .catch img {
    top: 30%;
        width: 57vw;
        left: -10%;
}
	
    .s2-catch {
        font-size: 19px !important;
    }
	
.block04 {
    padding-top: 18px;
}
	
.intro_cacth .highlight {
    font-size: 31px;
}
	
.intro_cacth .prefix {
    position: absolute;
    right: unset;
    margin-right: 0;
    font-size: 28px;
    top: calc(50% + -50px); /* 中央からさらに50px下 */
    left: 50%;
    transform: translate(-50%, -50%);
}
	
.intro_cacth .suffix {
    position: absolute;
    top: calc(50% + 50px); /* 中央からさらに50px下 */
    left: 50%;
    transform: translate(-50%, -50%);
    margin-left: 0;
    font-size: 28px;
}
	
.intro_cacth2 {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    font-size: 24px;
    white-space: nowrap;
    font-weight: 700;
    line-height: 1.8;
}
	
.intro_cacth2 .circle::before {
    content: "";
    position: absolute;
    top: 1px;
    left: 50%;
    transform: translateX(-50%);
    width: 6px;
    height: 6px;
    background-color: #ff4d02;
    border-radius: 50%;
}
	
	
.block06-inner {
    width: 100%;
    transform: translate(-50%, -444px);
}

.block06 .title_ja, .head_title .title_ja {
    font-size: 29px;
    line-height: 1.3em;
}
.block06 .katari, .head_title .katari {
    font-size: 16px;
}
	
.head_title .title_en {
    font-size: 100px;
    margin: -74px 0 0 0;
}
	
.block_leading .head_title {
    margin: 50px 0 -65px;
}
	
  .laptop_display {
    width: 100%;
    aspect-ratio: 1296 / 756;
    background-size: contain;
	 height: auto !important;
  }
	
.block_flow .head_title {
    margin-bottom: -72px;
}
  .screen_area {
      width: 76%;   /* 983px / 1296px ≒ 76% */
      height: 81%;  /* 614px / 756px ≒ 81% */
      top: 7%;      /* 53px / 756px ≒ 7% */
      left: 12%;    /* 157px / 1296px ≒ 12% */
  }

  .screen_area img {
      width: 100%;  /* 内部の画像も幅いっぱい */
      height: auto;
  }
.comparison-table th:first-child, .comparison-table td:first-child {
    font-size: 14px;
}
.comparison-table td {
    font-size: 14px;
}
.comparison-table .katarist {
    font-size: 16px;
}
.comparison-table th {
    font-size: 15px;
}
	
.block_flow {
    margin: 100px 0 0 0;
}
	
    .step_buttons {
        width: 92%;            /* 横幅いっぱい */
        margin: 20px auto 0;    /* 余白を少し減らす */
        border-radius: 20px;    /* 丸みも控えめに */
        gap: 3px;               /* ボタン間隔も少し縮める */
        padding: 10px;          /* 内側余白を確保 */
        justify-content: center;
    }

.step_buttons button {
    lex: 1 1 calc(33.333% - 16px);
        min-width: 140px;
        padding: 6px 2px;
        font-size: 15px;
        color: #333;
        text-align: left;
        margin-left: 6%;
}
	
.block_price {
    margin: 80px 0 0 0;
    padding: 100px 0 100px;
}


.pricing-table table {
  width: 100%;
  border-collapse: collapse;
  min-width: 1200px; /* 横幅を確保してスクロールを発生させる */
}
	
.pricing-table {
    margin: 0 auto;
    padding-top: 7px;
    background: url(https://katarist.com/wp-content/themes/cocoon-master/images/bg_comparison-table_sp.png) 
                no-repeat center top;
    background-size: 100% auto; /* 横幅100％、高さは自動 */
}

	
	
	
	
	
	
	
/* 固定列の基本設定（背景色は消しておく） */
.pricing-table th:first-child, .pricing-table td:first-child, .comparison-table th:first-child, .comparison-table td:first-child {
  position: sticky;
  left: 0;
  z-index: 2;
}

	
/* 右端にだけシャドー（実体はグラデの擬似要素）*/
.pricing-table th:first-child::after,
.pricing-table td:first-child::after,
.comparison-table th:first-child::after,
.comparison-table td:first-child::after {
  content: "";
  position: absolute;
  top: 0;
  right: -1px;                  /* 右境界にピタッと */
  width: 12px;                  /* 影の幅 */
  height: 100%;
  pointer-events: none;
  /* 見た目は「右にだけ落ちる影」 */
  background: linear-gradient(to right, rgba(0,0,0,0.18), rgba(0,0,0,0));
}
	
	
/* 固定列の背景色を元のルールに合わせる */

	.pricing-table thead th {
  background-color: #6771b9;
		
	}
	
.pricing-table th:first-child, .pricing-table td:first-child {
    font-size: 15px;
    text-align: left;
	width: 160px;
}
/* ヘッダー行（固定列） */
.pricing-table thead th:first-child {
  background-color: #6771b9;
  z-index: 3; /* 他セルより前に出す */
}

/* 奇数行（固定列） */
.pricing-table tbody tr:nth-of-type(2n+1) td:first-child {
  background-color: #e9eeed;
}

/* 偶数行（固定列） */
.pricing-table tbody tr:nth-of-type(2n) td:first-child {
  background-color: #fcfcfc;
}
	
	
/* 固定列の背景色を元のルールに合わせる */

	.comparison-table thead th {
  background-color: #cff2eb;
		
	}
	
.comparison-table th:first-child, .comparison-table td:first-child {
    font-size: 15px;
    text-align: left;
	width: 155px;
}
/* ヘッダー行（固定列） */
.comparison-table thead th:first-child {
  background-color: #cff2eb;
  z-index: 3; /* 他セルより前に出す */
}

/* 奇数行（固定列） */
.comparison-table tbody tr:nth-of-type(2n+1) td:first-child {
  background-color: #ffffff;
}

/* 偶数行（固定列） */
.comparison-table tbody tr:nth-of-type(2n) td:first-child {
  background-color: #ecf1f0;
}
	
	
	
.block_price .head_title {
    margin-bottom: -80px;
}
	
.block_step .head_title {
    margin-bottom: -40px;
}

.block_step {
    margin: 100px 0 0 0;
}
	
.step_flow{
  position: relative;
        width: 100%;
        max-width: 750px;
        margin: 0 auto;
        background: none;
        height: auto;
}
	
.step_flow img {
    display: block;
    margin: 0;
    transform: none;
}

/* 背景画像：左カラムに実画像を置く（高さ=基準） */
.step_bg{
  display: block;
  width: 33%;          /* ここを変えれば太さだけ調整可（位置は狂いません） */
  height: auto;        /* ←これで“実高さ”が決まり基準になります */
}

/* 右側のテキストは絶対配置（画像の高さを基準に%で並べる） */
.step_flow > div{
  position: absolute;
  left: calc(33% + 12px);   /* 画像の右に余白を足して開始 */
  right: 12px;              /* 右余白 */
  text-align: left;
}
	
.step_flow .step_text02, .step_flow .step_text04, .step_flow .step_text06 {
  left: calc(33% + -22px);   /* 画像の右に余白を足して開始 */
}

/* top: 画像高さ(954px)に対する割合 */
.step_text01{ top: 0%; }          /*   0 / 954 */
.step_text02{ top: 16.7715%; }    /* 160 / 954 */
.step_text03{ top: 33.5430%; }    /* 320 / 954 */
.step_text04{ top: 50.3145%; }    /* 480 / 954 */
.step_text05{ top: 67.2956%; }    /* 642 / 954 */
.step_text06{ top: 84.1719%; }    /* 803 / 954 */

/* 体裁（任意） */
.step_flow h3{ margin: 0 0 .1em; font-size: clamp(16px, 3.7vw, 20px); }
.step_flow p { margin: 0 0 1.2em; line-height: 1.6; font-size: clamp(14px, 3.4vw, 16px); }
.step_text06 p{ margin-bottom: 0; }
	
	
	
	
	.block_leading {
		margin-top: -20vh !important;
	}
	
.block_faq {
    margin: 100px 0 0 0;
}
.block_faq .head_title {
    margin-bottom: -80px;
}
	
.faq-inner {
    width: 90%;
}
.faq-inner h3 {
    font-size: 19px;
    padding: 0 0 0 15px;
}
.faq-box .faq-question {
    padding: 0 15px 0 20px;
}
.faq-box .q-text {
    font-size: 15px;
}
.faq-box .faq-item {
    padding: 10px 0 10px;
}
.faq-box .arrow {
    flex: 0 0 auto;
    width: 23px;
    height: 9px;
    transition: transform .3s ease;
    margin-left: 5px;
}
.faq-box .faq-answer {
    flex: 0 0 100%;
    width: 100%;
    padding: 0 15px;
    font-size: 14px;
    font-weight: 400;
    max-height: 0;
    overflow: hidden;
    transition: max-height .4s ease;
}
	
.block_offer .head_title {
    margin-bottom: -80px;
}
	
.block_offer {
    margin: 100px 0 0 0;
    padding: 80px 0;
}
	
  /* コンテナ：可変幅＋比率で高さを決定 */
  .block_offer_inner {
    position: relative;
    width: 100%;
    margin: 0 auto;
    height: auto;                 /* 固定高はやめる */
    aspect-ratio: 750 / 1195;     /* SP背景の実寸比(例)に合わせる */
  }

  .countdown-container {
    position: relative;
    height: 100%;
    isolation: isolate;           /* スタッキングを分離（安全策） */
  }

  /* 背景画像は全面フィット＆背面へ */
  .bg-picture {                   /* <picture class="bg-picture"> を使う場合のみ */
    position: absolute; inset: 0; z-index: 0; display: block;
  }
  .background-image {
    position: absolute;
    inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    z-index: 0;
  }

  /* テキストは前面に重ね、位置は%で固定 */
  .block_offer_inner .offer_text01,
  .block_offer_inner .offer_text02 {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);  /* 中央基準に */
    width: 90%;
    margin: 0;
    z-index: 1;
  }

  /* 位置（% は親の“高さ”基準。必要に応じて微調整） */
  .block_offer_inner .offer_text01 { top: 8%;  text-align: left; }
  .block_offer_inner .offer_text02 { top: 70%; text-align: right; }

  /* タイポ（可変） */
  .block_offer_inner .offer_text01 h3,
  .block_offer_inner .offer_text02 h3 {
    font-size: clamp(21px, 5vw, 21px);
    line-height: 1.5;
    margin: 0 0 6px;
  }
  .block_offer_inner .offer_text01 p,
  .block_offer_inner .offer_text02 p {
    font-size: clamp(13px, 4vw, 15px);
    line-height: 1.6;
    margin: 0;
    width: auto;                  /* 80%を撤廃：ボックス幅に追従 */
  }

  /* カウントダウン等をさらに前面に */
  .countdown-text, .now-image {
    position: absolute;
    z-index: 2;
  }
	
  .now-image {
    position: absolute;
    /* 位置は比率で再現（端末差でズレない） */
    top: 46.5%;   /* ＝336/791×100（背景の高さ基準） */
    left: 50%;
    transform: translateX(-50%);/* ← 横センター */

    /* サイズは可変：小さすぎ/大きすぎを防ぐ */
    width: clamp(88px, 24vw, 140px);
    aspect-ratio: 152 / 60; /* 高さは比率で自動 */
    height: auto;

    background: url(https://katarist.com/wp-content/themes/cocoon-master/images/now.png)
                no-repeat center center;
    background-size: contain;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2; /* 背景より前面に */
  }
	
.countdown-text {
    top: 45.5%;
    left: 50%;
    transform: translateX(-50%);
    font-size: 27px;
}
	
.block_trial .head_title {
    margin-bottom: -80px;
}
.block_trial {
    margin: 100px 0 0 0;
}
	
.form-inner .intro {
    margin-bottom: 50px;
    padding: 0 0;
    font-size: 17px;
    font-weight: 600;
}
.form-inner {
    width: 90%;
    margin: 0 auto;
}
.block_trial form {
    display: block;
}
	
.form-section {
    display: block;
    width: 100%;
    justify-content: space-between;
}
.block_trial input[type="text"] {
    width: 49%;
    height: 40px;
    padding: 15px;
    box-shadow: inset 0px 0px 4px 0px rgba(181, 80, 198, 1);
    border: 1px solid #b550c6;
    border-radius: 0;
    font-size: 16px;
}
	
.block_trial .input-row {
    display: flex;
    justify-content: space-between;
    width: 100%;
    margin-bottom: 10px;
}
.block_trial input[type="email"] {
    width: 100%;
    height: 40px;
    padding: 15px;
    box-shadow: inset 0px 0px 4px 0px rgba(181, 80, 198, 1);
    border: 1px solid #b550c6;
    border-radius: 0;
    font-size: 16px;
}
.block_trial .user-type-radio {
    display: flex;
    margin-bottom: 10px;
    font-size: 16px;
    width: 100%;
}
.info-text {
    margin: 30px 0 0;
    font-size: 14px;
    width: auto;
    max-width: 470px;
    text-align: left;
}
.start-button-wrapper {
    margin-top: 50px;
    display: flex;
    justify-content: center;
    width: 100%;
}
.company-name-box {
    width: 100%;
}
.company-name-box input[type="text"] {
    width: 100%;
}
	
	
.pricing-table, .comparison-table {
  position: relative; /* absolute配置の基準にする */
}


.scroll-hint {
  position: absolute;
  top: -26px; /* 調整OK */
  left: 50%;
  transform: translate(-50%, 0);  /* 中央基点 */
  font-size: 13px;
  color: #fff;
  background: rgba(0, 0, 0, 0.55);;
  padding: 3px 15px;
  white-space: nowrap;
  pointer-events: none;

  /* 初期は非表示。見えたら .is-show が付く */
  opacity: 0;
  filter: blur(0);
  transition:
    opacity .8s cubic-bezier(.22,.61,.36,1),   /* 自然なフェード */
    filter  .8s cubic-bezier(.22,.61,.36,1);   /* 溶ける感じ */
}

.scroll-hint.is-show {
  opacity: 1;
  /* サインっぽい緩急（easeInOutSine近似）＋往復で滑らかに */
  animation: sway 2.4s cubic-bezier(.445,.05,.55,.95) infinite alternate;
  will-change: transform, opacity;
}

/* 自然に消える：ふわっと透明＆わずかにブラー */
.scroll-hint.is-fadeout {
  opacity: 0;
  filter: blur(1px);
  /* アニメは走らせたままにしておくと“揺れながら溶ける”ので自然 */
  visibility: hidden; /* 最終的に非表示（SR配慮ならJSで後追いでもOK） */
}

@keyframes sway {
  /* 往復運動（中央から±10px）。往復＋ベジェで端の減速が自然 */
  from { transform: translate(-50%, 0) translateX(-10px); }
  to   { transform: translate(-50%, 0) translateX( 10px); }
}

/* 動きを控えたいユーザー配慮 */
@media (prefers-reduced-motion: reduce) {
  .scroll-hint.is-show { animation: none; }
}
	
	
.block_trial .checkbox-label {
    font-size: 13px;
}
	
	
	
}
	
	
	
  /*480px以下*/
  @media screen and (max-width: 480px) {
    /*必要ならばここにコードを書く*/
  }
	
	
	
/* =========================
   スマホ（例：～767px）専用
   ========================= */
@media (max-width: 767px) {

  /* 背景コンテナ：スマホ用画像＆アスペクト固定 */
  .block06-bg {
    position: relative;
    top: -46vh;
    left: 0;
    transform: none;

    width: 96%;           /* 画面幅にフィット */
    max-width: 100%;
    margin: 0 auto;
    padding: 0;

    /* 画像の実寸に合わせた比率（対応端末で有効） */
    aspect-ratio: 750 / 1417;

    /* 文字の自動拡大を抑止（iOS対策） */
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;

    /* （任意）レイアウト計算用。未対応でも害なし */
    container-type: inline-size;
    box-sizing: border-box;
  }
	

  /* 左右のカラム挙動を無効化して、縦並びベースに */
  .block06-bg .compare-left,
  .block06-bg .compare-right {
    position: static;   /* 絶対配置を解除 */
    width: 100%;
    height: auto;
  }

  /* テキスト要素は背景に対して絶対配置（％指定で可変対応） */
  .block06-bg .item h4,
  .block06-bg .item p {
    position: absolute; 
    margin: 0;
    line-height: 1.5;
    /* 文字サイズは端末で少しスケールするように */
    font-size: clamp(12px, 2.2vw, 16px);
  }
  .block06-bg .item h4 {
    font-weight: 700;
    font-size: clamp(14px, 2.8vw, 18px);
  }
  /* -------------------------
     ▼▼ モバイル座標マップ ▼▼
     ％は 背景画像に対する相対値（上=top％ / 左=left％）
     width も％で指定（背景横幅に対する％）
     ※数値は“例”です。実背景を見ながら微調整してください。
     ------------------------- */

  /* 左カラムの内容（縦並び1→4の順に上から） */

  .block06-bg .compare-left .rect1 h4 {top: 7%;left: 3%;width: 60%;text-align: left;}
  .block06-bg .compare-left .rect1 p  {top: 12%;left: 3%;width: 36%;text-align: left;}

  .block06-bg .compare-left .rect2 h4 {top: 2%;left: 38%;width: 49%;text-align: right;}
  .block06-bg .compare-left .rect2 p  {top: 7%;left: 46%;width: 42%;text-align: right;}

  .block06-bg .compare-left .rect3 h4 {top: 44%;left: 24%;width: 65%;text-align: left;}
  .block06-bg .compare-left .rect3 p  {top: 49%;left: 16%;width: 47%;text-align: left;}

  .block06-bg .compare-left .rect4 h4 {top: 39%;left: 61%;width: 34%;text-align: right;}
  .block06-bg .compare-left .rect4 p  {top: 48%;left: 65%;width: 30%;text-align: right;}

  /* 右カラムの内容（縦並びで続けて配置） */

  .block06-bg .compare-right .rect1 h4 { top: 78%; left: 12%; width: 60%; text-align: left; }
  .block06-bg .compare-right .rect1 p  { top: 83%; left: 12%; width: 55%; text-align: left; }

  .block06-bg .compare-right .rect2 h4 { top: 92%; left: 48%; width: 44%; text-align: right; }
  .block06-bg .compare-right .rect2 p  { top: 98%; left: 34%; width: 58%; text-align: right; }

  .block06-bg .compare-right .rect3 h4 {top: 88%;right: 8%;width: 52%;text-align: right;} /* 背景の“最上部”に置きたいなら％を小さめに */
  .block06-bg .compare-right .rect3 p  {top: 67%;right: 8%;width: 42%;text-align: right;}


  /* スマホではPC用の細かいトランジションはなくてもOK */

  .block06-bg .item { transition: none; color: #fff; }



}

	


@media screen and (min-width: 835px) {
  /* ここにPC用のスタイルを書く */
  .scroll-hint {
	  display: none;
  }
}
	
	
	
	
	