@charset "UTF-8";

/*
Readme:
・本ページでは単位指定において、主に css変数「--std」というを使用しています。
PCサイズ以上では基本的に --std: 10px と定義しており、SP~PC中間あたりからvw単位を指定することで、レスポンシブ調整を行っています。
--std は、ページ内で流用できるよう指定していますが、セクション単位で上書きしている場合もあります。

・共通コンポーネントは、c_ という接頭辞を付けて管理しています。その中で、セクション内固有のスタイル変更がある場合はセクション内で上書きしています。

・セクションごとにMediaQueryを記述しています。
*/
.page-mantenance {
  line-height: 1.4;
  font-family: var(--fontFamily-base);
  font-size: 16px;
  --fontFigtree: "Figtree", sans-serif;
  --blue: #00aeeb;
  --light-blue: #e3ecf7;
  --yellow-gray: #f9f8f4;
  --orange: #eb737d;
  --std: 10px;
}

.page-mantenance .image {
  display: block;
  width: 100%;
}

.page-mantenance a:hover {
  text-decoration: none;
}

@media screen and (max-width: 767px) {

  /* sp only */
  .page-mantenance {
    --std: 2.332vw;
  }
}
/* sp only */
.figtree {
  font-family: var(--fontFigtree);
}

.d-ib {
  display: inline-block;
}

.blue {
  color: var(--blue);
}

.black {
  color: #000;
}

.bold {
  font-weight: bold;
}

.marker {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, var(--line-color)));
  background: linear-gradient(transparent 60%, var(--line-color) 60%);
}

.indent {
  --indent: 1em;
  text-indent: calc(var(--indent) * -1);
  padding-left: calc(var(--indent) * 1);
}

sup.sup,
sub.sub {
  font-size: clamp(9px, var(--std) * 10, 12px);
}

.section__link a.-blue {
  font-weight: normal;
  font-size: 14px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  height: auto;
  max-width: 400px;
  padding: 1em 1em;
}

.section__link a.-arrow {
  position: relative;
  padding-inline: 3em;
}

.section__link a.-arrow:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: calc(var(--std) * 2);
  width: calc(var(--std) * 0.9);
  height: calc(var(--std) * 0.9);
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  -webkit-transform: rotate(45deg) translateY(-50%);
  transform: rotate(45deg) translateY(-50%);
  -webkit-transform-origin: top center;
  transform-origin: top center;
  -webkit-transition: border-color 0.5s 0s;
  transition: border-color 0.5s 0s;
}

.section__link a.-arrow:hover::after {
  border-color: var(--blue);
}

.section__link a.-multiple {
  --std: 10px;
  max-width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
  line-height: 1.4;
}

.section__link a.-multiple .sub-text {
  font-size: calc(var(--std) * 1.6);
}

.section__link a.-multiple .main-text {
  font-size: calc(var(--std) * 2);
  margin-top: 10px;
}

@media screen and (max-width: 767px) {

  /* sp only */
  .section__link a.-multiple {
    --std: 2vw;
  }

  .section__link a.-multiple .main-text {
    margin-top: 0.5em;
  }
}
/* sp only */
/* ★ ==================
* ページ内複数使用コンポーネント（接頭辞 c_ を付けてこちらに保管）
* ================== */
.container {
  --middle-w: calc(100% - 30px);
  --min-w: 0px;
  --max-w: 1200px;
  width: clamp(var(--min-w), var(--middle-w), var(--max-w));
  margin-inline: auto;
}

@media screen and (max-width: 767px) {

  /* sp only */
  .container {
    --middle-w: calc(100% - 28px);
  }
}
/* sp only */


/* ==================
* c_head-title
* ================== */
.c_head-title {
  text-align: center;
  color: var(--blue);
  font-size: calc(var(--std) * 4);
  position: relative;
  line-height: 1.5;
  letter-spacing: 0.05em;
}

.c_head-title .sub {
  display: block;
  font-size: 0.74em;
  margin: 0 0 calc(var(--std) * 1);
}

@media screen and (max-width: 767px) {

  /* sp only */
  .c_head-title {
    letter-spacing: 0;
    font-size: calc(var(--std) * 2.2);
    line-height: 1.8;
  }
}
/* sp only */
/* end c_head-title */


/* ==================
* c_under-wave
* ================== */
.c_under-wave::after {
  content: "";
  display: block;
  background: url("/images/maintenance/icon_wave.svg") rgba(255, 255, 255, 0) no-repeat top 50% left 50%/contain;
  aspect-ratio: 63/6;
  width: calc(var(--std) * 6.3);
  margin: calc(var(--std) * 3) auto 0;
}

@media screen and (max-width: 767px) {

  /* sp only */
  .c_under-wave::after {
    width: calc(var(--std) * 5.5);
  }
}
/* sp only */
/* end c_under-wave */
.c_annotation {
  --main-font-size: calc(var(--std) * 1.8);
  font-size: clamp(9px, var(--main-font-size), 12px);
  margin-top: calc(var(--std) * 2);
  line-height: 1.55;
}

.c_movie-wrap {
  width: 100%;
  aspect-ratio: 16/9;
  margin-block: calc(var(--std) * 4.8) 0;
}

.c_movie-wrap iframe {
  width: 100%;
  height: 100%;
}

@media screen and (max-width: 767px) {

  /* sp only */
  .c_movie-wrap {
    margin-top: calc(var(--std) * 2);
  }
}
/* sp only */
.c_bg_beige {
  background-color: #F9F8F4;
}
/* ★ end ページ内複数使用コンポーネント（接頭辞 c_ を付けてこちらに保管） */


/* ==================
* mvLower
* ================== */
.mvLower svg {
  height: 50px;
}

.mvLower .mvLower__copy {
  color: var(--blue);
  text-align: center;
  font-size: clamp(18px, 1.6vw, 24px);
  -webkit-transform: translate(0px, -5%);
  transform: translate(0px, -5%);
  text-shadow: 0 0 5px rgb(255, 255, 255);
}

@media screen and (max-width: 767px) {

  /* sp only */
  .mvLower .mvLower__copy {
    font-size: 3.2vw;
  }
}
/* sp only */
/* end mvLower */


/* ==================
* sec_01
* ================== */
.sec_01 {
  margin-top: calc(var(--std) * 10);
}

.sec_01 .visual-wrap .c_annotation {
  margin-top: calc(var(--std) * 2);
}

.sec_01 .text_wrap {
  margin-top: calc(var(--std) * 2);
}

@media screen and (max-width: 767px) {

  /* sp only */
  .sec_01 {
    margin-top: calc(var(--std) * 2);
  }

  .sec_01 .c_head-title .sub {
    margin-bottom: calc(var(--std) * 2.1);
  }

  .sec_01 .flex-column {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }

  .sec_01 .flex-column .visual-wrap {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
    margin-top: calc(var(--std) * 4.5);
  }

  .sec_01 .flex-column .visual-wrap .c_annotation {
    margin-top: calc(var(--std) * -2);
  }

  .sec_01 .flex-column .text_wrap {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
    margin-top: 0;
  }
}
/* sp only */
/* end sec_01 */


/* ==================
* sec_01-2
* ================== */
.sec_01-2 {
  margin-top: calc(var(--std) * 3);
}

.sec_01-2 .flex-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  gap: 0rem;
  margin-top: calc(var(--std) * 3.9);
}

.sec_01-2 .flex-box .text_wrap {
  width: 52%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding-right: calc(var(--std) * 5);
}

.sec_01-2 .flex-box .text_wrap .sentence {
  -ms-flex-item-align: center;
  -ms-grid-row-align: center;
  align-self: center;
  margin-block: auto;
  font-size: calc(var(--std) * 1.6);
  line-height: 2.1875;
  position: relative;
  top: calc(var(--std) * 2);
}

.sec_01-2 .flex-box .text_wrap .sentence .accent {
  color: var(--blue);
  font-weight: bold;
}

.sec_01-2 .flex-box .text_wrap .c_annotation {
  margin: auto 0 0;
}

.sec_01-2 .flex-box .image-wrap {
  width: 47.8%;
}

.sec_01-2 .flex-box .image-wrap .picture {
  position: relative;
}

.sec_01-2 .flex-box .image-wrap .image {
  border-radius: calc(var(--std) * 2.6);
}

.sec_01-2 .flex-box .image-wrap .circle {
  position: absolute;
  width: 34.7%;
  left: calc(var(--std) * 0.8);
  bottom: calc(var(--std) * 0.8);
}

@media screen and (min-width: 768px) and (max-width: 1040px) {

  /* PC small window */
  .sec_01-2 .flex-box .text_wrap {
    padding-right: calc(var(--std) * 2);
    margin-top: 0;
  }

  .sec_01-2 .flex-box .text_wrap .sentence {
    top: auto;
  }

  .sec_01-2 .flex-box .text_wrap .c_annotation {
    margin-top: calc(var(--std) * 1);
  }
}
/* PC small window */
@media screen and (max-width: 767px) {

  /* sp only */
  .sec_01-2 .flex-box {
    display: block;
  }

  .sec_01-2 .flex-box .text_wrap {
    width: 100%;
    padding-inline: 0;
  }

  .sec_01-2 .flex-box .text_wrap .sentence {
    top: auto;
    font-size: calc(var(--std) * 1.7);
    margin-top: calc(var(--std) * 1.8);
    line-height: 1.85;
  }

  .sec_01-2 .flex-box .image-wrap {
    width: 100%;
    margin-top: calc(var(--std) * 4.8);
  }

  .sec_01-2 .flex-box .image-wrap .circle {
    left: calc(var(--std) * 1.5);
    bottom: calc(var(--std) * 1.5);
  }
}
/* sp only */
/* end sec_01-2 */


/* ==================
* index_nav
* ================== */
.index_nav {
  margin-top: calc(var(--std) * 10);
}

.index_nav .nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  gap: calc(var(--std) * 1.5);
}

.index_nav .nav li {
  width: 100%;
}

.index_nav .nav li a {
  text-decoration: none;
  color: var(--blue);
  display: block;
  font-size: calc(var(--std) * 2.2);
  font-weight: bold;
  text-align: center;
  padding-inline: calc(var(--std) * 3);
  padding-block: calc(var(--std) * 1.3) calc(var(--std) * 1.2);
  border: 2px solid;
  border-radius: 9999px;
  background: url("/images/maintenance/icon_down-arrow.png") rgba(255, 255, 255, 0) no-repeat top 50% left calc(var(--std) * 5)/calc(var(--std) * 2.1) auto;
}

@media screen and (max-width: 767px) {

  /* sp only */
  .index_nav {
    margin-top: calc(var(--std) * 5);
  }

  .index_nav .nav {
    gap: calc(var(--std) * 1);
  }

  .index_nav .nav li a {
    font-size: calc(var(--std) * 1.05);
    background-size: calc(var(--std) * 1.2) auto;
    background-position: top 50% left calc(var(--std) * 1);
    border-width: 1px;
    padding-inline: calc(var(--std) * 1);
    padding-block: calc(var(--std) * 1.2);
  }
}
/* sp only */
/* end index_nav */


/* ==================
* question_container
* ================== */
.question_container {
  margin-top: calc(var(--std) * 10.5);
  padding-block: calc(var(--std) * 7.8) calc(var(--std) * 10.7);
}

.question_container .c_head-title {
  font-size: calc(var(--std) * 3.5);
  line-height: 2;
}

@media screen and (max-width: 767px) {

  /* sp only */
  .question_container {
    margin-top: calc(var(--std) * 8);
    padding-block: calc(var(--std) * 5) calc(var(--std) * 6);
  }

  .question_container .c_head-title {
    font-size: calc(var(--std) * 2.3);
  }

  .question_container .c_under-wave::after {
    margin-top: calc(var(--std) * 1.8);
  }
}
/* sp only */
/* end question_container */


/* ==================
* question_block
* ================== */
.question_block:nth-of-type(n+2) {
  margin-top: calc(var(--std) * 11.6);
}

.question_block .sentence {
  font-size: calc(var(--std) * 1.6);
  line-height: 1.8;
  margin-top: calc(var(--std) * 4.1);
}

@media screen and (max-width: 767px) {

  /* sp only */
  .question_block:nth-of-type(n+2) {
    margin-top: calc(var(--std) * 6.2);
  }

  .question_block .sentence {
    font-size: calc(var(--std) * 1.7);
    margin-top: calc(var(--std) * 3);
  }
}
/* sp only */
/* end question_block */


/* ==================
* c_question_head
* ================== */
.c_question_head .question {
  background-color: var(--light-blue);
  border-radius: 9999px;
  color: #010101;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: calc(var(--std) * 2.2);
  font-weight: bold;
  line-height: 1;
  margin-inline: auto;
  margin-block: calc(var(--std) * 4.6) 0;
  padding-inline: calc(var(--std) * 5.5);
  padding-block: calc(var(--std) * 0.5) calc(var(--std) * 0.7);
  position: relative;
}

.c_question_head .question::after {
  content: "";
  display: block;
  background: url("/images/maintenance/icon_question.png") rgba(255, 255, 255, 0) no-repeat top 50% left 50%/contain;
  width: calc(var(--std) * 2.5);
  aspect-ratio: 50/72;
  position: absolute;
  right: calc(var(--std) * 1.1);
  top: calc(var(--std) * -1.3);
}

.c_question_head .question .num {
  font-size: 1.75em;
}

.c_question_head .title {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-weight: bold;
  font-size: calc(var(--std) * 2.55);
  border-bottom: 3px solid var(--blue);
  margin-inline: auto;
  margin-block: calc(var(--std) * 4.1) 0;
  padding-block: 0 calc(var(--std) * 0.8);
}

.c_question_head .catch {
  color: var(--blue);
  font-weight: bold;
  text-align: center;
  font-size: calc(var(--std) * 2.2);
  margin-block: calc(var(--std) * 3.3) 0;
  line-height: 1.6;
}

.c_question_head .lead {
  font-size: calc(var(--std) * 1.6);
  line-height: 2;
  margin-block: calc(var(--std) * 1) 0;
}

.c_question_head .lead .small {
  font-size: 0.8em;
}

@media screen and (max-width: 767px) {

  /* sp only */
  .c_question_head .question {
    font-size: calc(var(--std) * 1.7);
    padding-inline: calc(var(--std) * 4.2);
    margin-top: calc(var(--std) * 3);
  }

  .c_question_head .question::after {
    width: calc(var(--std) * 2);
  }

  .c_question_head .title {
    width: 100%;
    font-size: calc(var(--std) * 2.15);
    text-align: center;
    line-height: 1.7;
    margin-top: calc(var(--std) * 2.5);
    padding-bottom: calc(var(--std) * 0.2);
  }

  .c_question_head .catch {
    font-size: calc(var(--std) * 2);
  }
}
/* sp only */
/* end c_question_head */


/* ==================
* photo_description
* ================== */
.photo_description {
  background-color: var(--light-blue);
  border-radius: calc(var(--std) * 2.6);
  padding-block: calc(var(--std) * 3) calc(var(--std) * 1.4);
  margin-block: calc(var(--std) * 5.3) 0;
}

.photo_description .image {
  width: 66%;
  margin-inline: auto;
  border-radius: calc(var(--std) * 2.6);
}

.photo_description .description {
  text-align: center;
  font-size: calc(var(--std) * 1.25);
  margin-block: calc(var(--std) * 2) 0;
}

@media screen and (max-width: 767px) {

  /* sp only */
  .photo_description {
    border-radius: 0;
    width: calc(100% + 28px);
    margin-inline: -14px;
    margin-top: calc(var(--std) * 1.8);
    padding-block: calc(var(--std) * 2);
  }

  .photo_description .image {
    width: calc(100% - 28px);
  }

  .photo_description .description {
    font-size: calc(var(--std) * 1.4);
    margin-top: calc(var(--std) * 1.4);
  }
}
/* sp only */
/* end photo_description */


/* ==================
* faq
* ================== */
.faq {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  gap: calc(var(--std) * 3);
  margin-block: calc(var(--std) * 4.3) 0;
}

.faq .faq_title {
  background-color: #C9AF86;
  border-radius: 9999px;
  color: #FFF;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  gap: calc(var(--std) * 2);
  font-size: calc(var(--std) * 2.4);
  font-weight: bold;
  padding-block: calc(var(--std) * 1.5) calc(var(--std) * 1.5);
  padding-inline: calc(var(--std) * 3) calc(var(--std) * 4.7);
  cursor: pointer;
}

.faq .faq_title:hover {
  opacity: 0.7;
}

.faq .faq_title .text {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

.faq .faq_title .icon {
  aspect-ratio: 1;
  position: relative;
  width: calc(var(--std) * 2.3);
}

.faq .faq_title .icon::before,
.faq .faq_title .icon::after {
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  border-radius: 9999px;
  background: #FFF;
  position: absolute;
  inset: 0;
  margin: auto;
}

.faq .faq_title .icon::after {
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
  -webkit-transition: opacity 0.3s 0s, -webkit-transform 0.3s 0s;
  transition: opacity 0.3s 0s, -webkit-transform 0.3s 0s;
  transition: opacity 0.3s 0s, transform 0.3s 0s;
  transition: opacity 0.3s 0s, transform 0.3s 0s, -webkit-transform 0.3s 0s;
}

.faq .faq_title.is_open .icon::after {
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
  opacity: 0;
}

.faq .faq_contents {
  display: none;
}

.faq .faq_contents .inner {
  font-size: calc(var(--std) * 1.6);
  line-height: 2.1875;
  padding-inline: calc(var(--std) * 3.4);
  padding-block: calc(var(--std) * 2.1);
}

.faq .faq_contents .inner *+p {
  margin-block: calc(var(--std) * 2) 0;
}

@media screen and (max-width: 767px) {

  /* sp only */
  .faq {
    margin-top: calc(var(--std) * 3);
    gap: calc(var(--std) * 2);
  }

  .faq .faq_title {
    font-size: calc(var(--std) * 1.75);
    padding-inline: calc(var(--std) * 2);
  }

  .faq .faq_title .icon {
    width: calc(var(--std) * 1.8);
  }

  .faq .faq_contents .inner {
    padding-inline: 0;
    line-height: 2;
    padding-block: calc(var(--std) * 0.9) calc(var(--std) * 1.5);
  }
}
/* sp only */
/* end faq */


/* ==================
* spcialist_block
* ================== */
.spcialist_block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-block: calc(var(--std) * 5.5) 0;
}

.spcialist_block .image-wrap {
  width: 45%;
}

.spcialist_block .image-wrap .picture {
  position: relative;
}

.spcialist_block .image-wrap .picture .image {
  border-radius: calc(var(--std) * 2.6);
}

.spcialist_block .image-wrap .picture .circle {
  position: absolute;
  width: 43%;
  left: -20%;
  bottom: 0;
}

.spcialist_block .image-wrap .sentence {
  font-size: calc(var(--std) * 1.6);
  line-height: 1.875;
  margin-top: calc(var(--std) * 1);
}

.spcialist_block .text_wrap {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  padding-inline: calc(var(--std) * 6.6) 0;
  font-size: calc(var(--std) * 2);
  line-height: 2;
  margin-block: calc(var(--std) * -5) 0;
}

.spcialist_annotation {
  text-align: right;
  margin-top: 0;
}

.spcialist_annotation p {
  text-align: right;
}

@media screen and (max-width: 767px) {

  /* sp only */
  .spcialist_block {
    display: block;
    margin-top: calc(var(--std) * 3.6);
  }

  .spcialist_block .image-wrap {
    width: 100%;
  }

  .spcialist_block .image-wrap .picture .circle {
    width: 35.8%;
    left: 0%;
    bottom: -19%;
  }

  .spcialist_block .image-wrap .sentence {
    font-size: calc(var(--std) * 1.5);
    margin-top: calc(var(--std) * 5);
  }

  .spcialist_block .text_wrap {
    width: 100%;
    padding-inline: 0;
    margin-top: calc(var(--std) * 1.5);
  }

  .spcialist_annotation p {
    --indent: 1.9em;
    text-align: left;
  }
}
/* sp only */
/* end spcialist_block */


/* ==================
* movie
* ================== */
.movie {
  margin-block: calc(var(--std) * 6) 0;
}

.movie .title {
  font-size: calc(var(--std) * 2.4);
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  line-height: 1;
  font-weight: bold;
}

.movie .title::before,
.movie .title::after {
  content: "";
  display: block;
  width: 1.5px;
  height: 1.2em;
  border-radius: 1em;
  background-color: #0e0e0e;
  position: absolute;
  bottom: -0.1em;
}

.movie .title::before {
  left: -0.75em;
  -webkit-transform: rotate(-30deg);
  transform: rotate(-30deg);
}

.movie .title::after {
  right: -0.5em;
  -webkit-transform: rotate(30deg);
  transform: rotate(30deg);
}

.movie .title .small {
  font-size: 0.8em;
}

.movie .title .num {
  font-size: 1.5em;
  font-weight: bold;
}

.movie-wrap {
  width: 100%;
  aspect-ratio: 16/9;
  margin-block: clamp(15px, 9.545px + 1.705vw, 30px) 0;
}

.movie .title + .c_movie-wrap {
  margin-top: calc(var(--std) * 2);
}

.movie-wrap iframe {
  width: 100%;
  height: 100%;
}

@media screen and (max-width: 767px) {

  /* sp only */
  .movie {
    margin-top: calc(var(--std) * 8);
  }

  .movie .title {
    font-size: calc(var(--std) * 2.2);
  }
}
/* sp only */
/* end movie */


/* ==================
* sec_03
* ================== */
.sec_03 {
  margin-block: calc(var(--std) * 8) 0;
}

.sec_03 .lead {
  font-size: calc(var(--std) * 1.6);
  line-height: 2;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  margin-block: calc(var(--std) * 4.3) 0;
}

.sec_03 .main-image {
  margin-block: calc(var(--std) * 6.3) 0;
}

@media screen and (max-width: 767px) {

  /* sp only */
  .sec_03 .lead {
    font-size: calc(var(--std) * 1.7);
    margin-top: calc(var(--std) * 1.8);
  }

  .sec_03 .main-image {
    margin-top: calc(var(--std) * 1.4);
  }
}
/* sp only */
/* end sec_03 */


/* ==================
* sec_maintenance
* ================== */
.sec_maintenance {
  margin-block: calc(var(--std) * 9) 0;
  padding-block: calc(var(--std) * 5) calc(var(--std) * 10.5);
}

.sec_maintenance .section__link {
  margin-top: calc(var(--std) * 4);
}

@media screen and (max-width: 767px) {

  /* sp only */
  .sec_maintenance {
    margin-top: calc(var(--std) * 3.6);
    padding-block: calc(var(--std) * 3.7) calc(var(--std) * 7);
  }
}
/* sp only */
/* end sec_maintenance */


/* ==================
* message
* ================== */
.message {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  padding-inline: calc(var(--std) * 4.5) calc(var(--std) * 3);
  padding-block: calc(var(--std) * 3);
  background-color: #FFF;
  margin-block: calc(var(--std) * 7.3) 0;
  border-radius: calc(var(--std) * 2.6);
}

.message .text_wrap {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  padding-inline: 0 calc(var(--std) * 2.8);
}

.message .image_wrap {
  width: 43%;
}

.message .image_wrap .image {
  border-radius: calc(var(--std) * 2.6);
}

.message .profile {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.message .profile .icon {
  width: 34%;
}

.message .profile .icon .image {
  border-radius: 9999px;
}

.message .profile .pos_name {
  font-size: calc(var(--std) * 1.6);
  font-weight: bold;
  line-height: 2.1875;
  padding-inline: calc(var(--std) * 2.8) 0;
}

.message .sentence {
  font-size: calc(var(--std) * 1.6);
  line-height: 2.1875;
  margin-top: calc(var(--std) * 2);
}

@media screen and (max-width: 767px) {

  /* sp only */
  .message {
    display: block;
    margin-top: calc(var(--std) * 3);
    padding-inline: calc(var(--std) * 2);
    padding-block: calc(var(--std) * 1.2) calc(var(--std) * 1.9);
  }

  .message .text_wrap {
    padding-inline: 0;
  }

  .message .image_wrap {
    width: 100%;
    margin-top: calc(var(--std) * 3);
  }

  .message .profile {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }

  .message .profile .icon {
    width: 33.4%;
  }

  .message .profile .pos_name {
    padding-inline: calc(var(--std) * 2.1) 0;
    line-height: 1.8;
  }

  .message .sentence {
    line-height: 1.8;
    margin-top: calc(var(--std) * 1.3);
  }
}
/* sp only */
/* end message */


/* ==================
* sec_05
* ================== */
.sec_05 {
  margin-block: calc(var(--std) * 9.3) 0;
}

.sec_05 .lead {
  font-size: calc(var(--std) * 1.6);
  text-align: center;
  line-height: 2;
  margin-block: calc(var(--std) * 4) 0;
}

.sec_05 .flow_wrap {
  background-color: #ddeff9;
  max-width: 1345px;
  padding-block: calc(var(--std) * 6) calc(var(--std) * 2.6);
  margin-inline: auto;
  margin-block: calc(var(--std) * 6) 0;
  border-radius: calc(var(--std) * 2.6);
}

.sec_05 .flow_wrap .inner {
  width: 100%;
  padding-inline: calc(var(--std) * 14.7);
}

@media screen and (max-width: 767px) {

  /* sp only */
  .sec_05 {
    margin-top: calc(var(--std) * 6.3);
  }

  .sec_05 .lead {
    text-align: left;
    margin-top: calc(var(--std) * 2.2);
  }

  .sec_05 .flow_wrap {
    border-radius: 0;
    margin-top: calc(var(--std) * 4);
    padding-block: calc(var(--std) * 4.5) calc(var(--std) * 6.6);
  }

  .sec_05 .flow_wrap .inner {
    padding-inline: calc(var(--std) * 1.6);
  }

  .sec_05 .flow_wrap .c_annotation {
    margin-top: calc(var(--std) * 3.5);
  }
}
/* sp only */
/* end sec_05 */


/* ==================
* bridge
* ================== */
.bridge {
  text-align: center;
  line-height: 1.8;
  margin-block: calc(var(--std) * 19) 0;
}

.bridge .title {
  font-weight: bold;
  font-size: calc(var(--std) * 2.2);
  color: var(--blue);
}

.bridge .sentence {
  font-size: calc(var(--std) * 1.8);
  margin-block: calc(var(--std) * 3.2) 0;
}

.bridge .sentence *+p {
  margin-block: calc(var(--std) * 3) 0;
}

.bridge .section__link {
  margin-top: calc(var(--std) * 5);
}

@media screen and (max-width: 767px) {

  /* sp only */
  .bridge {
    margin-top: calc(var(--std) * 5.9);
  }

  .bridge .title {
    font-size: calc(var(--std) * 1.9);
  }

  .bridge .sentence {
    font-size: calc(var(--std) * 1.6);
  }

  .bridge .sentence *+p {
    margin-top: calc(var(--std) * 2);
  }

  .bridge .section__link {
    margin-top: calc(var(--std) * 3.5);
  }
}
/* sp only */
/* end bridge */


/* ==================
* movie-list
* ================== */
.movie-list {
  margin-block: calc(var(--std) * 19) 0;
}

.movie-list .lead {
  font-size: calc(var(--std) * 1.6);
  text-align: center;
  margin-block: calc(var(--std) * 4) 0;
}

.movie-list .item-list {
  display: -ms-grid;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
  gap: calc(var(--std) * 6) calc(var(--std) * 2.5);
  margin-block: calc(var(--std) * 10) 0;
}


.movie-list .item-list li .movie_wrap {
  width: 100%;
  aspect-ratio: 16/9;
}

.movie-list .item-list li .movie_wrap iframe {
  width: 100% !important;
  height: 100% !important;
}

.movie-list .item-list li .thumb {
  display: block;
  width: 100%;
}

.movie-list .item-list li .text {
  font-weight: bold;
  font-size: calc(var(--std) * 2);
  color: var(--blue);
  margin-block: calc(var(--std) * 1.8) 0;
}

@media screen and (max-width: 767px) {

  /* sp only */
  .movie-list {
    margin-top: calc(var(--std) * 12);
  }

  .movie-list .lead {
    margin-top: calc(var(--std) * 2.4);
  }

  .movie-list .item-list {
    grid-template-columns: repeat(auto-fit, minmax(40vw, 1fr));
    margin-top: calc(var(--std) * 3.5);
    gap: calc(var(--std) * 4) calc(var(--std) * 1.2);
  }

  .movie-list .item-list li .text {
    font-size: calc(var(--std) * 1.3);
    margin-top: calc(var(--std) * 0.7);
    line-height: 1.6;
  }
}
/* sp only */
/* end movie-list */


/* ==================
* sec_reccomend
* ================== */
.sec_reccomend {
  margin-block: calc(var(--std) * 17.6) 0;
}

@media screen and (max-width: 767px) {

  /* sp only */
  .sec_reccomend {
    margin-top: calc(var(--std) * 13);
  }
}
/* sp only */
/* end sec_reccomend */


/* ==================
* product-card
* ================== */
.product-card-list {
  display: -ms-grid;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  grid-auto-rows: 1fr;
  gap: clamp(30px, 22.766px + 2.128vw, 50px);
  margin-inline: auto;
  margin-block: calc(var(--std) * 5) 0;
}

.product-card {
  container: product-card/inline-size;
  /* ※container-query使用 */
  border-radius: 26px;
  -webkit-box-shadow: 0px 0px 6px rgba(52, 137, 178, 0.1);
  box-shadow: 0px 0px 6px rgba(52, 137, 178, 0.1);
  background: #FFF;
  overflow: hidden;
}

.product-card .inner {
  width: 100%;
  height: 100%;
  position: relative;
  padding-block: 13cqw;
}

.product-card .name {
  text-align: center;
  font-size: 6.5cqw;
  height: 100cqw;
  font-weight: bold;
  color: var(--blue);
  line-height: 1.3;
  height: 18cqw;
  position: relative;
}

.product-card .name.-putio {
  letter-spacing: 0.15em;
}

.product-card .image {
  display: block;
  width: 50cqw;
  margin-inline: auto;
  margin-block: -2cqw 0;
}

.product-card .style,
.product-card .point {
  position: absolute;
}

.product-card .style {
  top: 0;
  right: 0;
  width: 28.5cqw;
}

.product-card .point {
  left: 6cqw;
  width: 18cqw;
  top: 55cqw;
}

.product-card .link {
  margin-block: 8cqw;
}

.product-card .link a {
  padding-inline: 8cqw;
  font-size: 4cqw;
  font-weight: bold;
}

.product-card .link a svg {
  width: 6cqw;
  fill: #fff;
  -webkit-transition: fill 0.5s 0s;
  transition: fill 0.5s 0s;
  margin-left: 1em;
}

.product-card .link a:hover svg {
  fill: var(--blue);
}

@media screen and (max-width: 650px) {

  /* sp only */
  .product-card-list {
    max-width: 400px;
    padding-inline: 10px;
    margin-block: calc(var(--std) * 5) 0;
  }

  .product-card .inner {
    padding-block: 13cqw 6cqw;
  }
}
/* sp only */
/* end product-card */


/* ==================
* sec_news
* ================== */
.sec_news {
  margin-block: calc(var(--std) * 19) 0;
}

.sec_news .news_list {
  margin-block: calc(var(--std) * 7) 0;
}

.sec_news .news_list li {
  border-bottom: 1px solid #b3bfc6;
  padding-block: 0 calc(var(--std) * 1.8);
}

.sec_news .news_list li:not(:last-child) {
  margin-block: 0 calc(var(--std) * 2);
}

.sec_news .news_list li a.inner {
  text-decoration: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  gap: calc(var(--std) * 2);
}

.sec_news .news_list li a.inner time {
  font-weight: bold;
  font-size: calc(var(--std) * 1.4);
}

.sec_news .news_list li a.inner .title {
  font-size: calc(var(--std) * 1.5);
}

.sec_news .news_list li a.inner:hover {
  text-decoration: underline;
}

@media screen and (max-width: 767px) {

  /* sp only */
  .sec_news {
    margin-top: calc(var(--std) * 12);
  }

  .sec_news .news_list {
    margin-top: calc(var(--std) * 2.3);
  }

  .sec_news .news_list li:not(:last-child) {
    margin-bottom: calc(var(--std) * 2.3);
  }

  .sec_news .news_list li a.inner time {
    font-size: calc(var(--std) * 1.3);
  }

  .sec_news .news_list li a.inner .title {
    font-size: calc(var(--std) * 1.3);
  }
}
/* sp only */
/* end sec_news */


/* ==================
* sec_end-button
* ================== */
.sec_end-button {
  margin-block: calc(var(--std) * 10) calc(var(--std) * 7);
}

.btn {
  text-align: center;
}

.btn a {
  font-size: calc(var(--std) * 1.4);
  text-decoration: none;
  background-color: #e9f4fb;
  padding: 1em 5em;
  border-radius: 3em;
  display: inline-block;
  position: relative;
  font-weight: bold;
}

.btn a::after {
  content: "";
  vertical-align: middle;
  position: absolute;
  top: 50%;
  margin-top: -0.25em;
  right: 2em;
  width: 0.5em;
  height: 0.5em;
  border-top: 0.15em solid #00aeeb;
  border-right: 0.15em solid #00aeeb;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

@media screen and (max-width: 767px) {

  /* sp only */
  .sec_end-button {
    margin-block: calc(var(--std) * 19.4) calc(var(--std) * 6);
  }
}
/* sp only */
/* end sec_end-button */