@charset "UTF-8";

/* http://meyerweb.com/eric/tools/css/reset/
   v2.0 | 20110126
   License: none (public domain)
*/

a,
abbr,
acronym,
address,
applet,
article,
aside,
audio,
b,
big,
blockquote,
body,
canvas,
caption,
center,
cite,
code,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
embed,
fieldset,
figcaption,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
html,
i,
iframe,
img,
ins,
kbd,
label,
legend,
li,
mark,
menu,
nav,
object,
ol,
output,
p,
pre,
q,
ruby,
s,
samp,
section,
small,
span,
strike,
strong,
sub,
summary,
sup,
table,
tbody,
td,
tfoot,
th,
thead,
time,
tr,
tt,
u,
ul,
var,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  vertical-align: baseline;
  text-decoration: none;
}

/* HTML5 display-role reset for older browsers */

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

body {
  font-size: 1.6rem;
  letter-spacing: 0.02em;
  line-height: 1.8;
  -webkit-font-smoothing: antialiased;
  font-family: "Yu Gothic", "Noto Sans JP", sans-serif;
  font-weight: 500;
  font-style: normal;
}

ol,
ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:after,
blockquote:before,
q:after,
q:before {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

main {
  display: block;
}

html {
  font-size: 10px;
  margin-top: 0 !important;
}

@supports (-webkit-touch-callout: none) {
  html {
    height: -webkit-fill-available;
  }
}

* {
  box-sizing: border-box;
  -webkit-appearance: none;
  box-shadow: none;
  padding: 0;
  border: none;
  border-radius: 0;
  outline: none;
  background: none;
}

img {
  width: 100%;
  height: auto;
  display: block;
}

* {
  box-sizing: border-box;
  -webkit-appearance: none;
  box-shadow: none;
  padding: 0;
  border: none;
  border-radius: 0;
  outline: none;
  background: none;
}

img {
  width: 100%;
  height: auto;
  display: block;
}

/*///////////////////////////////

bace

/////////////////////////////*/

/*///////////////////////////////

variable

/////////////////////////////*/

/*-----------------------------
ブレークポイント
-----------------------------*/

/*-----------------------------
color
-----------------------------*/

/*///////////////////////////////

mixin

/////////////////////////////*/

/*-----------------------------
font
-----------------------------*/

/*-----------------------------
bace
-----------------------------*/

html {
  scroll-behavior: smooth;
}

header,
main,
footer {
  font-weight: 400;
  color: #323232;
}

main {
  overflow: hidden;
}

p {
  line-height: 1.8;
  font-size: 16px;
}

a {
  transition: 0.2s;
  color: #333;
}

a:hover {
  opacity: 0.7;
}

.header {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 99;
}

.header-logo {
  width: 120px;
}

.header .container {
  padding: 30px;
}
/*
.footer {
  opacity: 0;
  visibility: hidden;

  transition: opacity 0.5s ease, visibility 0.5s ease;
}

.footer.is-visible {
  opacity: 1;
  visibility: visible;
} */

.footer_btn {
  display: none;
}

.inner {
  margin-right: auto;
  margin-left: auto;
}

.inner.w-1100 {
  max-width: 1160px;
}

.inner.w-1080 {
  max-width: 1080px;
}

.inner.w-980 {
  max-width: 980px;
}

.inner.w-900 {
  max-width: 900px;
}

.inner.w-800 {
  max-width: 800px;
  box-shadow: 17px 0px 35px -8px rgb(3, 0, 0), -17px 0px 35px -8px rgb(3, 0, 0);
}

.inner.w-660 {
  max-width: 660px;
}

.w-95 {
  width: 95%;
}

.w-90 {
  width: 90%;
}

.w-85 {
  width: 85%;
}

.w-80 {
  width: 80%;
}

.txt--center {
  text-align: center;
}

.txt--center-sp {
  text-align: center;
}

.txt--left {
  text-align: left;
}

.txt--b {
  display: block;
}

.txt--s {
  font-size: 16px;
  line-height: 1.8;
}

.txt--xs {
  font-size: 12px;
  line-height: 1.5;
}

.flex {
  display: flex;
}

/* .fixed-nav {
  position: fixed !important;
  top: 0;
  left: 0;
  max-width: 1400px;
  margin: 0 auto;
  width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  top: 3%;
  opacity: 0;
  transition: opacity 1s ease, transform 1s ease;
  transition-delay: var(--d, 3ms);
}

.fixed-nav.is-in {
  transition-delay: calc(var(--d, 0ms) + 1500ms);
  opacity: 1;
}

.fixed-nav_left {
  position: absolute;
  left: 2.5rem;
  top: 18rem;
  left: 0rem;
  width: calc(50% - 400px);
  max-width: 500px;
}

.fixed-nav_left-txt {
  display: none;
}

.fixed-nav_copy-txt {
  display: none;
}

.fixed-nav_right {
  position: absolute;
  right: -5.5rem;
  bottom: -80rem;
  width: calc(50% - 300px);
  z-index: -1;
}

.fixed-banner {
  display: none;
}

.fixed-nav_right #nav-list {
  padding: 0 3rem 8rem;
}

.fixed-logo {
  display: none;
} */

.cmn__sec {
  position: relative;
  z-index: 1;
}

.abs {
  position: absolute;
}

.wrap {
  overflow: hidden;
  max-width: 100%;
  width: 100%;
  margin: 0;
  padding: 0;
  background: url(../images/fv_bg.png) no-repeat center top;
  background-size: cover;
}

.container {
  padding: 0 30px;
  position: relative;
  z-index: 1;
}

.col,
.col1,
.col2,
.col3,
.col4,
.col5,
.col6,
.col7,
.col8,
.col9,
.col10,
.col11,
.col12 {
  display: block;
  align-items: flex-start;
  align-content: flex-start;
  position: relative;
  padding: 20px;
  width: 100%;
  box-sizing: border-box;
}

.pd-b {
  padding-bottom: 30px;
}

.pd-t {
  padding-top: 30px;
}

.pd-t-100 {
  padding-top: 120px;
}

.pd-b-100 {
  padding-bottom: 120px;
}

.pd-t-60 {
  padding-top: 60px;
}

.pd-t-50 {
  padding-top: 50px;
}

.pd-b-50 {
  padding-bottom: 50px;
}

.pd-t-40 {
  padding-top: 40px;
}

.pd-b-40 {
  padding-bottom: 40px;
}

.pd-t-10 {
  padding-top: 10px;
}

.pd-b-10 {
  padding-bottom: 10px;
}

.pd-t-15 {
  padding-top: 15px;
}

.pd-b-15 {
  padding-bottom: 15px;
}

.pd-b-60 {
  padding-bottom: 60px;
}

.md-b {
  margin-bottom: 30px;
}

.md-t {
  margin-top: 30px;
}

.md-t-100 {
  margin-top: 100px;
}

.md-b-100 {
  margin-bottom: 100px;
}

.md-t-60 {
  margin-top: 60px;
}

.md-t-50 {
  margin-top: 50px;
}

.md-b-50 {
  margin-bottom: 50px;
}

.md-t-40 {
  margin-top: 40px;
}

.md-b-40 {
  margin-bottom: 40px;
}

.md-t-15 {
  margin-top: 15px;
}

.md-b-15 {
  margin-bottom: 15px;
}

.md-b-60 {
  margin-bottom: 60px;
}

.md-r-auto {
  margin-right: auto;
}

.md-l-auto {
  margin-left: auto;
}

.packing {
  letter-spacing: -10px;
}

.slick-list {
  overflow: visible !important;
}

.slick-slide {
  margin: 0 10px;
  height: inherit !important;
}

.slick-track {
  display: flex;
}

.slick-next {
  right: -3px;
  z-index: 1;
  width: 50px;
  height: 50px;
}

.slick-prev {
  left: -5px;
  z-index: 1;
  width: 50px;
  height: 50px;
}

.slick-next::before {
  content: "";
  background-image: url("../images/next-arrow.png");
  /* 「前へ」用の画像パス */
  display: block;
  width: 50px;
  height: 50px;
  background-size: contain;
  background-repeat: no-repeat;
  font-size: 0;
  color: transparent;
  opacity: 1;
}

.slick-prev::before {
  content: "";
  background-image: url("../images/prev-arrow.png");
  /* 「前へ」用の画像パス */
  display: block;
  width: 50px;
  height: 50px;
  background-size: contain;
  background-repeat: no-repeat;
  font-size: 0;
  color: transparent;
  opacity: 1;
}

.fedein {
  opacity: 0;
  -webkit-transform: translate(0, 40px);
  transform: translate(0, 40px);
  -webkit-transition: 0.7s;
  transition: 0.7s;
}

.fedein.isAnimate {
  opacity: 1;
  -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
}

.tab_container {
  padding-top: 0;
  margin-top: 30px;
  margin-bottom: 15px;
  box-shadow: 0 15px 25px rgba(0, 0, 0, 0.1);
  /* ← この行を追加 */
  border-bottom-left-radius: 15px;
  border-bottom-right-radius: 15px;
}

/* タブナビゲーション */

.tab-nav {
  display: flex;
  justify-content: space-between;
}

.tab-btn {
  width: calc(50% - 15px);
  padding: 30px 30px 20px;
  border: none;
  background-color: #d1d5db;
  /* 非アクティブなグレー */
  color: white;
  text-align: center;
  cursor: pointer;
  font-weight: bold;
  position: relative;
  transition: background-color 0.3s ease;
  display: flex;
  border-top-left-radius: 15px;
  border-top-right-radius: 15px;
}

.tab-btn:first-child {
  padding: 30px 45px 20px;
}

.tab-btn + .tab-btn.active {
  background-color: white;
  color: #374151;
  box-shadow: -10px -10px 20px -5px rgba(0, 0, 0, 0.1);
}

/* アクティブなタブのスタイル */

.tab-btn.active {
  background-color: white;
  color: #374151;
  box-shadow: 10px -10px 20px -8px rgba(0, 0, 0, 0.1);
}

/* コンテンツエリア */

.tab-content {
  background-color: white;
  padding: 30px 30px;
  border: 1px solid #e5e7eb;
  border-top: none;
  /* タブが上の枠線を兼ねる */
  border-bottom-left-radius: 15px;
  border-bottom-right-radius: 15px;
}

.tab-pane {
  display: none;
  /* デフォルトは非表示 */
}

.tab-pane.active {
  display: block;
  /* アクティブなものだけ表示 */
}

/* フローチャートのスタイル */

.flow-chart {
  text-align: center;
}

/* デフォルトでは、非アクティブ画像のみ表示し、アクティブ画像は隠す */

.tab-btn .img-active {
  display: none;
}

.tab-btn .img-inactive {
  display: block;
}

/* .activeクラスがついたタブの中では、表示・非表示を逆にする */

.tab-btn.active .img-active {
  display: block;
}

.tab-btn.active .img-inactive {
  display: none;
}

/* 画像がボタンからはみ出ないように念のため設定 */

.tab-btn img {
  max-width: 100%;
  display: block;
  /* 余白をなくす */
}

/* .tab-btn + .tab-btn img {
  height: 149px;
} */

.accordion-text {
  display: none;
  /* 初期状態ではコンテンツを非表示 */
}

.accordion-title {
  cursor: pointer;
  /* クリックできることを示すカーソル */
}

.modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
  z-index: 9999;
}

.modal.show {
  opacity: 1;
  pointer-events: auto;
}

.modal.hidden {
  display: none;
}

.modal-content {
  max-width: 600px;
  width: 90%;
  margin: 0 auto;
}

.modal-content img {
  max-width: 100%;
  height: auto;
  cursor: pointer;
  /* 画像クリックできることを示す */
}

.contents-nav h3 {
  color: #f06450;
  font-weight: bold;
  letter-spacing: 6px;
  font-size: 18px;
  padding: 0 2rem 3rem;
}

.contents-nav ul {
  list-style: none;
  padding-left: 0;
}

.contents-nav li {
  margin-bottom: 1.2em;
  position: relative;
  cursor: pointer;
  /* クリックできることを示すカーソルに /
}
.contents-nav li a {
text-decoration: none;
color: #8c8c8c;
font-size: 1.1em;
pointer-events: none; / 親のli要素でクリックを検知するため、aタグのクリックイベントを無効化 */
}

.contents-nav li a {
  color: #918471;
  font-weight: bold;
}

.contents-nav li.current::before {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  background-color: #f06450;
  border-radius: 50%;
  position: absolute;
  left: -20px;
  top: 50%;
  transform: translateY(-50%);
}

.contents-nav li.current a {
  color: #000;
  font-weight: 600;
}

.fv {
  padding-top: 180px;
}

.fv .video-wrapper {
  position: relative;
  width: 100%;
  overflow: hidden;
  padding-top: 100%;
  z-index: -1;
}

.fv .video-wrapper > video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
  display: block;
}

/* 表示トリガー（JSが付与） */

.fv_txt.is-in {
  opacity: 1;
  transform: translateY(0);
}

/* 親が表示されたら子を順番にフェードインさせる（stagger） */

.fv_txt.is-in span:nth-child(1) {
  transition-delay: calc(var(--d, 0ms) + 700ms);
  opacity: 1;
  transform: translateY(0);
}

.fv_txt.is-in span:nth-child(2) {
  /* 2枚目は 180ms 遅らせて出す。数値はお好みで */
  transition-delay: calc(var(--d, 0ms) + 670ms);
  opacity: 1;
  transform: translateY(0);
}

.fv_txt.is-in span:nth-child(3) {
  /* 2枚目は 180ms 遅らせて出す。数値はお好みで */
  transition-delay: calc(var(--d, 0ms) + 670ms);
  opacity: 1;
  transform: translateY(0);
}

/* 親が表示されたら子を順番にフェードインさせる（stagger） */

.fv figure {
  width: 90%;
  margin: 0 auto 35px;
}

.fv_bottom {
  opacity: 0;
  transform: translateY(12px);
  will-change: opacity, transform;
  transition: opacity 1s ease, transform 1s ease;
  transition-delay: var(--d, 10ms);
}

.fv_bottom.is-in {
  transition-delay: calc(var(--d, 0ms) + 1000ms);
  opacity: 1;
  transform: translateY(0);
}

.color-white {
  color: #fff;
}

.back-blue {
  background-color: #5a82aa;
}

.back-orange {
  background-color: #f06450;
}

.back-black {
  background-color: #323232;
}

.back-white {
  background-color: #fff;
}

article {
  position: relative;
  background: #fff;
  max-width: 660px;
  margin: 0 auto;
  z-index: 10;
}

.fv_txt {
  position: absolute;
  top: 0;
  left: 50%;
  margin-top: 105px;
  opacity: 0;
  transform: translateX(-50%) !important;
  transform: translateY(12px);
  will-change: opacity, transform;
  transition: opacity 1.3s ease, transform 1.3s ease;
  transition-delay: var(--d, 600ms);
}

.fv_txt span {
  display: inline-block;
  opacity: 0;
  transform: translateY(8px);
  will-change: opacity, transform;
  /* ここは is-in が付いた時に遅延だけ効かせる想定 */
  transition: opacity 0.8s ease, transform 0.8s ease;
}

.fv_txt span:first-child {
  width: 400px;
}

.fv_bottom {
  position: relative;
}

.fv_bottom::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  background-image: url(../images/fv_bottom_bg.png);
  background-position: top;
  background-repeat: no-repeat;
  background-size: cover;
  width: 100%;
  height: 100%;
  z-index: -1;
}

.fv_bottom .col12 {
  padding: 60px 0 0;
}

.fv_bottom_txt a {
  position: absolute;
  right: 11%;
  bottom: 15%;
  width: 65%;
}

#award::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  background-image: url(../images/award_bg.png);
  background-position: top;
  background-repeat: no-repeat;
  background-size: cover;
  width: 100%;
  height: 100%;
  z-index: -1;
}

#award .col12 {
  padding: 60px 0 0;
}

#award .award-list {
  flex-wrap: wrap;
  justify-content: space-between;
}

#award .award-list li {
  width: calc(50% - 15px);
}

#award .award-list li:nth-of-type(3),
#award .award-list li:nth-of-type(4) {
  margin-top: 30px;
}

#award .txt--xs {
  padding: 30px 0;
}

#happiness::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  background-image: url(../images/happiness_bg.png);
  background-position: top;
  background-repeat: no-repeat;
  background-size: cover;
  width: 100%;
  height: 100%;
  z-index: -1;
}

#happiness .wrapper {
  padding: 60px 0 0;
}

#happiness .trouble-list {
  margin-top: 20px;
}

#happiness .trouble-list li + li {
  margin-top: 25px;
}

#ad {
  background-color: #5b82ab;
}

#ad::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  background-image: url(../images/ad_bg02.png);
  background-position: top;
  background-repeat: no-repeat;
  background-size: cover;
  width: 100%;
  height: 100%;
  z-index: 1;
}

#ad .wrapper {
  padding: 56% 0 20px;
}

#ad .abs {
  width: 350px;
  bottom: 30%;
  z-index: -1;
  overflow: hidden;
}

#survey::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  background-image: url(../images/survey_bg.png);
  background-position: top;
  background-repeat: no-repeat;
  background-size: cover;
  width: 100%;
  height: 100%;
  z-index: -1;
}

#survey .wrapper h2 {
  width: 85%;
  margin-right: auto;
}

#survey .survey_wrap ul {
  gap: 4rem;
}

#approach .approach_txt01 {
  flex-flow: row-reverse;
  width: 170px;
  top: 57%;
  left: 11%;
  gap: 0 15px;
  transform: translateY(-50%);
}

#approach .approach_txt01 .glow-effect::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 27px;
}

#approach .approach_txt02 .glow-effect::before {
  position: absolute;
  top: 0;
  right: 0;
  left: unset;
  width: 27px;
}

#approach .approach_txt02 {
  flex-flow: row-reverse;
  width: 350px;
  top: 50%;
  right: 11%;
  gap: 0 15px;
  transform: translateY(-50%);
}

#approach .mt-t-40 {
  margin-top: -40px;
}

#approach .banner_txt01 {
  width: 110px;
  top: 31%;
  left: 15%;
  overflow: hidden;
  transition: 1000ms linear;
}

@keyframes SlideIn {
  0% {
    opacity: 0;
    transform: translateY(64px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

.js-scroll-animation {
  opacity: 0; /* 最初は透明にしておく */
}

/* 2. is-visibleクラスが付与されたら「アニメーションを開始」 */
.js-scroll-animation.is-visible {
  animation-name: SlideIn;
  animation-duration: 1.5s;
  animation-timing-function: cubic-bezier(0.22, 1, 0.36, 1);
  animation-fill-mode: forwards;
}

#approach .wrapper > .col12 {
  padding: 120px 30px 0;
}

#approach .approach-list {
  display: flex;
}

#approach .video-wrapper {
  position: relative;
  width: 100%;
  overflow: hidden;
  padding-top: 56.8%;
  z-index: -1;
}

#approach .video-wrapper > video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
  display: block;
}

#approach .video-wrapper .play-button {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80px;
  height: auto;
  cursor: pointer;
  z-index: 2;
  transition: opacity 0.3s ease;
}

#approach .video-wrapper .play-button.hide {
  opacity: 0;
  pointer-events: none;
}

#feeling .video-wrapper {
  position: relative;
  width: 100%;
  overflow: hidden;
  padding-top: 56.8%;
  z-index: -1;
}

#feeling .video-wrapper > video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
  display: block;
}

#feeling .video-wrapper .play-button {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80px;
  height: auto;
  cursor: pointer;
  z-index: 2;
  transition: opacity 0.3s ease;
}

#feeling .video-wrapper .play-button.hide {
  opacity: 0;
  pointer-events: none;
}

#feeling .video-wrapper {
  position: relative;
  width: 100%;
  overflow: hidden;
  padding-top: 56.8%;
  margin: -30px 0 0px;
  z-index: -1;
}

#feeling .video-wrapper > video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
  display: block;
}

#feeling .video-wrapper .play-button {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80px;
  height: auto;
  cursor: pointer;
  z-index: 2;
  transition: opacity 0.3s ease;
}

#feeling .video-wrapper .play-button.hide {
  opacity: 0;
  pointer-events: none;
}

#feeling .wrapper.flex {
  justify-content: space-between;
}

#feeling .wrapper.flex .txt--b {
  width: 43%;
}

#feature {
  background-color: #5a82aa;
  padding: 20px 30px 200px;
}

.jetgraph-reveal {
  display: inline-block;
  font-size: 45px;
  font-weight: normal;
  color: #fff;
  letter-spacing: 10px;
  line-height: 1.4;
  margin: 20px 0;
}

#feature .head-txt {
  max-width: 190px;
  bottom: 28px;
  right: -15px;
}

#feature .video-wrapper {
  position: relative;
  width: 100%;
  padding-top: 56.8%;
  /* margin: 50px 0 0px; */
}

#feature .video-head {
  position: absolute;
  top: 0px;
  z-index: 2;
  width: 70%;
}

#feature .video-wrapper > video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
  display: block;
  top: 65px;
}

#feature .video-wrapper .play-button {
  position: absolute;
  top: 65%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80px;
  height: auto;
  cursor: pointer;
  z-index: 2;
  transition: opacity 0.3s ease;
}

#feature .video-wrapper .play-button.hide {
  opacity: 0;
  pointer-events: none;
}

#behind .flex {
  align-items: baseline;
  justify-content: center;
  gap: 0 30px;
}

#behind .behind-txt {
  width: 62%;
}

#behind figure {
  width: 30%;
}

#behind .abs {
  top: 1.4%;
  right: -3%;
  height: 98.5%;
}

#behind .abs img {
  height: inherit;
  object-fit: contain;
  width: auto;
}

#recommend .accordion-title h3 {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

#recommend .accordion-title h3 .txt--l {
  width: 28%;
  display: block;
}

#recommend .accordion-title .icon {
  width: 8%;
}

#recommend .accordion-item {
  position: relative;
}

#recommend .accordion-item img {
  width: 101%;
  position: relative;
  right: 1%;
}

#recommend .accordion-item.step04 .txt02 {
  bottom: 42%;
  left: 5%;
  width: 90%;
  margin: 0 auto;
}

#recommend .accordion-item.step04 .txt03 {
  bottom: 4%;
  left: 6.5%;
  width: 88.5%;
  margin: 0 auto;
}

#recommend .accordion-text .recommend_cont {
  padding: 15px 30px 30px;
}

#recommend .accordion-item::after {
  content: "";
  position: absolute;
  bottom: -68px;
  left: 47.5%;
  transform: translateY(-50%);
  width: 28px;
  height: 50px;
  background-image: url(../images/arrow-bottom.png);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 28px;
  z-index: 1;
}

#recommend .accordion-item:last-child::after {
  content: none;
}

/* #recommend .accordion-item.step04::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #e6ecf3;
  z-index: -1;
} */

#recommend .wrapper02 .step01-txt-list {
  width: 89%;
  margin: 0 auto;
  left: 6%;
  bottom: 6%;
  gap: 0 2rem;
}

#recommend .wrapper02 .step01-txt-list li {
  flex: 1;
}

#recommend .wrapper02 .txt--xs {
  font-size: 16px;
}

/* #recommend .accordion-item.step04::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #e6ecf3;
  z-index: -1;
} */

#faq {
  background-color: #e6ecf3;
}

#faq .accordion-title h3 {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

#faq .accordion-title h3 .txt--l {
  width: 38%;
  display: block;
  margin-left: 0;
  border-bottom: none;
}

#faq .accordion-title .icon {
  width: 8%;
}

#faq .faq-list {
  position: relative;
}

/* #faq .faq-list .icon_q {
  width: 35px;
  margin-left: -50px;
}

#faq .faq-list .icon_a {
  position: absolute;
  left: -0.1%;
  top: 4%;
  width: 35px;
}

#faq .faq-list:nth-child(2) .icon_a {
  position: absolute;
  left: -0.1%;
  top: 15%;
  width: 35px;
} */

#faq .faq-cont .col12 {
  position: relative;
  background-color: #fff;
}

#faq .faq-cont .wrapper {
  gap: 0 15px;
}

#faq .faq-cont .wrapper .icon {
  width: 8%;
  padding-top: 5px;
}

#faq {
  background-color: #e6ecf3;
}

#faq .accordion-title h3 {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

#faq .faq-list {
  position: relative;
}

#faq .faq-list .txt--l {
  font-size: 22px;
  font-weight: bold;
  color: #6781a9;
  width: 92%;
  border-bottom: 1.5px solid #000;
  padding-bottom: 10px;
}

#faq .faq-list .txt--s {
  font-size: 22px;
}

#faq .faq-list a {
  text-decoration: underline;
  display: inline;
}

#faq .faq-list .txtbox {
  width: 91%;
}

#faq .faq-list .txtbox .space {
  margin-left: -10px;
}

#faq .faq-list .txtbox .txt-xs {
  font-size: 16px;
}

#spec .accordion-title h3 {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

#spec .accordion-title h3 .txt--l {
  width: 14%;
  display: block;
  margin-left: 0;
  border-bottom: none;
}

#spec .accordion-title .icon {
  width: 8%;
}

#spec .accordion-item {
  border-top: 1.5px solid #000;
}

#spec .accordion-item:last-child {
  border-bottom: 1.5px solid #000;
}

#spec .accordion-item p {
  font-size: 22px;
  line-height: 1.4;
}

#spec .accordion-item p small {
  font-size: 18px;
}

#spec .accordion-item .line-blue {
  position: relative;
  width: 40%;
}

#spec .accordion-item .line-blue::before {
  content: "";
  position: absolute;
  top: -12px;
  left: 0;
  width: 100%;
  height: 3px;
  background-color: #5a82aa;
}

#caution h2 {
  width: 32%;
  margin: 0 auto;
  background-color: #fff;
}

#caution .wrapper {
  position: relative;
  padding-left: 40px;
  padding-right: 40px;
}

#caution .wrapper::before {
  content: "";
  position: absolute;
  top: 3%;
  left: 0%;
  height: 100%;
  width: 100%;
  background-size: 100%;
  background-position: top;
  background-repeat: no-repeat;
  background-image: url(../images/caution-frame.png);
  z-index: -1;
}

#order {
  background-color: #5a82aa;
}

#order h2 img {
  width: 40%;
  margin: 0 auto;
}

#order .order-list li .btn {
  position: absolute;
  left: 10%;
  bottom: 10%;
  width: 81%;
}

#order .order-list li + li .btn {
  bottom: 16%;
}

.sp-none {
  display: none;
}

@media (min-width: 660px) {
  .wrap {
    background-attachment: fixed;
  }

  article {
    box-shadow: 0px 5px 20px 10px rgba(107, 50, 47, 0.2);
  }

  .pc-none {
    display: none;
  }

  .sp-none {
    display: block;
  }
}

@media (min-width: 960px) {
  .fixed-nav_left-txt {
    display: block;
    /* padding-top: 18rem; */
    width: 100%;
  }

  .fixed-nav_copy-txt {
    display: block;
    padding-top: 6rem;
  }

  .fixed-banner {
    display: block;
  }

  .fixed-logo {
    display: block;
    width: 15rem !important;
    position: absolute;
    top: 4%;
    left: 1%;
  }
}

@media screen and (max-width: 1400px) {
  .fixed-nav_left {
    left: 2.5rem;
  }

  .fixed-nav_right {
    right: 1rem;
    width: calc(50% - 360px);
  }
}

@media screen and (max-width: 1280px) {
  html {
    font-size: 0.78125vw;
  }
}

@media (max-width: 990px) {
  .fixed-nav_right #nav-list {
    padding: 0 3rem 10rem 3rem;
  }

  .contents-nav h3 {
    padding: 0 3rem 3rem 2rem;
    font-size: 2rem;
    letter-spacing: 0.5rem;
  }
}

@media screen and (max-width: 768px) {
  html {
    font-size: 1.33333vw;
  }
}

@media (max-width: 660px) {
  p {
    font-size: 1.6rem;
  }

  .header-logo {
    width: 14.5rem;
  }

  .header .container {
    padding: 3rem;
  }

  .footer_btn {
    display: block;
    position: fixed;
    bottom: 0;
    left: 0;
    z-index: 999;
  }

  .txt--center-sp {
    text-align: left;
  }

  .txt--s {
    font-size: 14px;
  }

  .txt--xs {
    font-size: 10px;
  }

  .flex-sp {
    display: block;
  }

  .container {
    padding: 0 4rem;
  }

  .col,
  .col1,
  .col2,
  .col3,
  .col4,
  .col5,
  .col6,
  .col7,
  .col8,
  .col9,
  .col10,
  .col11,
  .col12 {
    padding: 1.5rem;
  }

  .pd-b {
    padding-bottom: 4rem;
  }

  .pd-t {
    padding-top: 4rem;
  }

  .pd-t-100 {
    padding-top: 12.5rem;
  }

  .pd-b-100 {
    padding-bottom: 12.5rem;
  }

  .pd-t-60 {
    padding-top: 7.5rem;
  }

  .pd-t-50 {
    padding-top: 6.5rem;
  }

  .pd-b-50 {
    padding-bottom: 6.5rem;
  }

  .pd-b-60 {
    padding-bottom: 7.5rem;
  }

  .pd-t-40 {
    padding-top: 5.5rem;
  }

  .pd-b-40 {
    padding-bottom: 5.5rem;
  }

  .pd-t-10 {
    padding-top: 1.5rem;
  }

  .pd-b-10 {
    padding-bottom: 1.5rem;
  }

  .pd-t-15 {
    padding-top: 2rem;
  }

  .pd-b-15 {
    padding-bottom: 2rem;
  }

  .md-b {
    margin-bottom: 4.5rem;
  }

  .md-t {
    margin-top: 4.5rem;
  }

  .md-t-100 {
    margin-top: 11.5rem;
  }

  .md-b-100 {
    margin-bottom: 11.5rem;
  }

  .md-t-60 {
    margin-top: 7.5rem;
  }

  .md-t-50 {
    margin-top: 6.5rem;
  }

  .md-b-50 {
    margin-bottom: 6.5rem;
  }

  .md-t-40 {
    margin-top: 5.5rem;
  }

  .md-b-40 {
    margin-bottom: 5.5rem;
  }

  .md-t-15 {
    margin-top: 1.5rem;
  }

  .md-b-15 {
    margin-bottom: 2.5rem;
  }

  .packing {
    letter-spacing: -1rem;
  }

  .slick-slide {
    margin: 0 2rem;
  }

  .slick-next {
    right: 0rem;
    width: 7rem;
    height: 7rem;
  }

  .slick-prev {
    left: -1%;
    width: 7rem;
    height: 7rem;
  }

  .slick-next::before {
    width: 7rem;
    height: 7rem;
  }

  .slick-prev::before {
    width: 7rem;
    height: 7rem;
  }

  .tab_container {
    margin-bottom: 2.5rem;
    margin-top: 3.5rem;
    border-bottom-left-radius: 2.5rem;
    border-bottom-right-radius: 2.5rem;
  }

  .tab-btn {
    width: calc(50% - 2.2rem);
    padding: 4rem 4rem 2rem;
    border-top-left-radius: 2.5rem;
    border-top-right-radius: 2.5rem;
  }

  .tab-btn:first-child {
    padding: 4rem 5.6rem 2rem;
  }

  .tab-btn + .tab-btn.active {
    box-shadow: -1.5rem -1.5rem 2rem -0.8rem rgba(0, 0, 0, 0.1);
  }

  .tab-btn.active {
    box-shadow: 1.5rem -1.5rem 2rem -0.8rem rgba(0, 0, 0, 0.1);
  }

  /* .tab-btn + .tab-btn img {
    height: 15rem;
  } */

  .tab-content {
    padding: 4rem;
    box-shadow: 0 2rem 3.5rem rgba(0, 0, 0, 0.1);
    /* ← この行を追加 */
    border-bottom-left-radius: 2.5rem;
    border-bottom-right-radius: 2.5rem;
  }

  .fv {
    padding-top: 18rem;
  }

  .fv_txt {
    margin-top: 10rem;
  }

  .fv_txt span:first-child {
    width: 43rem;
  }

  #award .col12 {
    padding: 6rem 0 0;
  }

  #award .award-list li {
    width: calc(50% - 2rem);
  }

  #award .award-list li:nth-of-type(3),
  #award .award-list li:nth-of-type(4) {
    margin-top: 3rem;
  }

  #award .txt--xs {
    padding: 4rem 0;
  }

  #happiness .wrapper {
    padding: 7.5rem 0 0rem;
  }

  #happiness .trouble-list {
    margin-top: 3rem;
  }

  #happiness .trouble-list li + li {
    margin-top: 3rem;
  }

  #ad .wrapper {
    padding: 37rem 0 2rem;
  }

  #ad .abs {
    width: 38rem;
    bottom: 28%;
  }

  #ad .wrapper .col10 {
    padding: 1.5rem 3.5rem;
  }

  #ad .wrapper .connection {
    width: 25rem;
    margin: 3.5rem auto 0;
  }

  #care .wrapper {
    padding: 4.5rem 0 8rem;
  }

  #care h2 span + span {
    padding: 0 15rem;
  }

  #approach .wrapper > .col12 {
    padding: 13rem 4.5rem 0;
  }

  #approach .mt-t-40 {
    margin-top: -4.5rem;
  }

  #approach .approach_txt01 {
    flex-flow: row-reverse;
    width: 20rem;
    top: 57%;
    left: 11%;
    gap: 0 1.5rem;
    transform: translateY(-50%);
  }

  #approach .approach_txt01 .glow-effect::before {
    position: absolute;
    top: 0;
    left: 0;
    width: 2.8rem;
  }

  #approach .approach_txt02 .glow-effect::before {
    position: absolute;
    top: 0;
    right: 0;
    left: unset;
    width: 2.8rem;
  }

  #approach .approach_txt02 {
    flex-flow: row-reverse;
    width: 40rem;
    top: 49%;
    right: 11%;
    gap: 0 1.5rem;
    transform: translateY(-50%);
  }

  #approach .banner_txt01 {
    width: 12.5rem;
  }

  #feeling .video-wrapper {
    margin: -3rem 0 0;
  }

  #feature {
    padding: 0rem 4rem 22rem;
  }

  #feature .wrapperh2 .txt--b {
    font-size: 2.5rem;
  }

  #feature .wrapper h2 span {
    font-size: 3.5rem;
  }

  .jetgraph-reveal {
    display: inline-block;
    font-size: 5.5rem;
    font-weight: normal;
    color: #fff;
    letter-spacing: 1rem;
    line-height: 1.4;
    margin: 2rem 0;
    width: 100%;
  }

  .jetgraph-reveal span {
    font-size: 5rem !important;
  }

  #feature .head-txt {
    max-width: 100%;
    width: 21rem;
    bottom: 3.5rem;
    right: -2.5rem;
  }

  #feature .video-wrapper {
    /* margin: 6.5rem 0; */
  }

  #feature .video-wrapper > video {
    top: 7.5rem;
  }

  #recommend .video-wrapper {
    margin: 0rem auto 2.5rem;
  }

  #recommend .accordion-item::after {
    bottom: -8.5rem;
    width: 3.5rem;
    height: 6.5rem;
    background-size: 3.5rem;
  }

  #recommend .wrapper02 .txt--xs {
    font-size: 10px;
  }

  #faq .faq-cont .col12 {
    padding: 2.5rem;
  }

  #faq .faq-cont .wrapper {
    gap: 0 2.5rem;
  }

  #faq .faq-cont .wrapper .icon {
    margin-top: 0.5rem;
  }

  #faq .faq-list .txt--l {
    font-size: 2.5rem;
    padding-bottom: 1rem;
    display: flex;
    align-items: end;
  }

  #faq .faq-list .txt--s {
    font-size: 2.5rem;
  }

  #faq .faq-list .txtbox .txt-xs {
    font-size: 10px;
  }

  #spec .accordion-item p {
    font-size: 2.5rem;
  }

  #spec .accordion-item p small {
    font-size: 12px;
  }

  #caution h2 {
    padding-bottom: 4.5rem;
  }

  #spec .accordion-item .line-blue::before {
    height: 0.3rem;
    top: -1.7rem;
  }

  #caution .wrapper {
    padding-left: 4.5rem;
    padding-right: 4.5rem;
    padding-bottom: 3rem;
  }

  #order .wrapper {
    padding-top: 7rem;
    padding-bottom: 7rem;
  }
}

@media (max-width: 400px) {
  .slick-prev {
    left: 0.8%;
  }
}

/* fixed btn */
.fixed_btn {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  transform: translateY(5px);
  opacity: 0;
  transition: opacity 1s ease, transform 1s ease;
  transition-delay: var(--d, 3ms);
}

.fixed_btn.is-in {
  transition-delay: calc(var(--d, 0ms) + 1500ms);
  opacity: 1;
}

/* nav (SP only) */
.fixed_btn .fixed_nav_sp {
  box-sizing: border-box;
}
.fixed_btn .fixed_nav_sp > a {
  display: block;
  width: 100%;
  text-align: center;
}
/* nav (PC only) */
.fixed_btn .fixed_nav_pc {
  display: none;
  position: relative;
  z-index: 1;
  color: #fff;
}

.fixed_nav_pc > div.right_nav {
  /* padding-right: 20px;
  padding-left: min(2vw, 40px); */
  position: absolute;
  left: -0.5%;
  width: calc(50% - 380px);
  max-width: 400px;
  bottom: 0;
}

@media screen and (min-width: 980px) {
  .fixed_btn {
    display: block;
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    max-width: 1500px;
    z-index: 1;
  }
  .fixed_btn .fixed_nav_sp {
    display: none;
  }
  .fixed_btn .fixed_nav_pc {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 100%;
    z-index: -1;
  }
  .fixed_nav_pc > div {
    padding-bottom: 3rem;
    box-sizing: border-box;
    width: calc(50% - 330px);
    max-width: 350px;
  }
  .fixed_nav_pc h2.en {
    font-size: 20px;
    margin: 3rem 0 0.5rem;
    font-weight: 500;
  }
  .fixed_nav_pc > div.left_nav {
    padding-left: 20px;
    padding-right: min(1vw, 20px);
    font-size: min(3vw, 21px);
    color: #fff;
  }

  .fixed_nav_pc > div.left_nav h1 {
    padding-top: 20rem;
  }

  .fixed_nav_pc > div.left_nav .copy {
    padding-top: 5rem;
  }

  .fixed_nav_pc > div.left_nav a {
    display: block;
    /* padding: 0.8rem 1rem; */
    box-sizing: border-box;
    font-weight: 600;
    font-size: min(1.3vw, 22px);
    color: var(--middlebrown);
  }
  .fixed_nav_pc > div.left_nav a + a {
    margin-top: 10px;
  }
} /* min-width:660px */

@media screen and (min-width: 1600px) {
  .fixed_nav_pc > div.right_nav {
    /* padding-right: 20px;
    padding-left: min(2vw, 40px); */
    position: absolute;
    left: -2%;
    width: calc(50% - 330px);
    max-width: 500px;
    bottom: 0;
  }
  /* .fixed_nav_pc > div.left_nav {
    width: calc(50% - 400px);
    max-width: 300px;
  } */

  .fixed_nav_pc > div.left_nav h1 {
    padding-top: 17rem;
  }

  /* .fixed_nav_pc > div.left_nav h1 img {
    width: 90%;
    margin: 0 auto;
  } */
}

@media screen and (min-width: 1400px) {
  .fixed_nav_pc > div.left_nav {
    /* padding-bottom: 60px; */
    padding-right: 0;
  }
  .fixed_nav_pc > div.right_nav {
    padding: 0 0 60px;
  }
} /* min-width:1300px */

@media screen and (max-height: 600px) and (min-width: 980px) {
  .fixed_nav_pc > div.left_nav {
    padding-bottom: 20px;
  }
  .fixed_nav_pc > div.right_nav {
    padding: 0 0 20px;
  }
  .fixed_nav_pc h2.en {
    font-size: 20px;
    margin: 0.5rem 0 0.5rem;
  }
}

*, ::before, ::after {
	-webkit-box-sizing: content-box;
	box-sizing: content-box;
}

@media screen and (max-width:768px) {
  footer {
    margin: 0 auto;
    padding-bottom: 13vw;
  }
}

.sans {
  font-family: "Yu Gothic", "Noto Sans JP", sans-serif;
  text-align: left;
}

.footer_logo {
  width: 157px;
  margin-bottom: 10px;
  margin-left: 10px;
}