@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Outfit:wght@100..900&family=Zen+Maru+Gothic:wght@300;400;500&display=swap");
/* -----------------------------
module original
------------------------------*/
html, body, h1, h2, h3, h4, h5, h6, p, address, ul, ol, li, dl, dt, dd, table, caption, th, td, img, form, figure, button {
  margin: 0;
  padding: 0;
  border: none;
  font-style: normal;
  font-weight: normal;
  text-align: left;
  list-style-type: none;
  color: #434F55;
  font-family: "Zen Maru Gothic", sans-serif;
  font-feature-settings: normal;
}

* {
  box-sizing: border-box;
}

button {
  background-color: inherit;
}

body {
  min-width: 100%;
  width: 100%;
  overflow-x: hidden;
}

img {
  max-width: 100%;
  width: 100%;
  height: auto;
}
@media only screen and (max-width: 767px) {
  img {
    width: 100%;
    height: auto;
  }
}

a {
  text-decoration: none;
  color: inherit;
}

sup {
  font-size: 60%;
  font-weight: inherit;
  vertical-align: super;
}

em {
  font-weight: bold;
}

/*------------------------------
module　basic
------------------------------*/
.clearFix:after {
  content: "";
  display: block;
  clear: both;
}

.clearFix {
  zoom: 1;
}

.textL {
  text-align: left !important;
}

.textC {
  text-align: center !important;
}

.textR {
  text-align: right !important;
}

@media only screen and (max-width: 767px) {
  .sp-textL {
    text-align: left !important;
  }
}

@media only screen and (max-width: 767px) {
  .sp-textC {
    text-align: center !important;
  }
}

@media only screen and (max-width: 767px) {
  .sp-textR {
    text-align: right !important;
  }
}

.ps_ab {
  position: absolute;
}

.flex {
  display: flex;
}

.sp {
  display: none;
}

.pc {
  display: block;
}

.sp-inline {
  display: none !important;
}

.pc-inline {
  display: inline-block !important;
}

ul.inline li {
  display: inline-block;
  vertical-align: top;
}

@media only screen and (max-width: 767px) {
  .pc {
    display: none !important;
  }
  .sp {
    display: block !important;
  }
  .sp-inline {
    display: inline-block !important;
  }
  .pc-inline {
    display: none !important;
  }
}
/*------------------------------
animation
------------------------------*/
@keyframes fadeIn {
  0% {
    opacity: 0.2;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes slideDown {
  0% {
    transform: translateY(-100%);
  }
  100% {
    transform: translateY(0);
  }
}
.animTrig.fadeInUp {
  opacity: 0;
}
.animTrig.fadeInUp.inActive {
  animation: fadeInUp 1s cubic-bezier(0.33, 1, 0.68, 1) forwards;
}

@keyframes fadeInUp {
  0% {
    opacity: 0;
    transform: translateY(100px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.animTrig.aboutfadeInUp {
  opacity: 0;
}
.animTrig.aboutfadeInUp.inActive {
  animation: aboutfadeInUp 1.2s cubic-bezier(0.33, 1, 0.68, 1) forwards 0.7s;
}

@keyframes aboutfadeInUp {
  0% {
    opacity: 0;
    transform: translateY(100px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.animTrig.baton1 {
  opacity: 0;
  transform-origin: top right;
}
.animTrig.baton1.inActive {
  animation: baton1 3s cubic-bezier(0.33, 1, 0.68, 1) forwards 0.3s;
}

@keyframes baton1 {
  0% {
    opacity: 0.5;
    transform: translateY(0px) rotate(10deg);
  }
  to {
    opacity: 1;
    transform: translateY(0) rotate(0deg);
  }
}
.animTrig.baton2 {
  opacity: 0;
}
.animTrig.baton2.inActive {
  animation: baton2 2s cubic-bezier(0.33, 1, 0.68, 1) forwards 0.5s;
}

@keyframes baton2 {
  0% {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.animTrig.showDown {
  opacity: 0;
}
.animTrig.showDown.inActive {
  animation: showDown 3s cubic-bezier(0.33, 1, 0.68, 1) forwards;
}

@keyframes showDown {
  0% {
    opacity: 0;
    height: 0;
  }
  to {
    opacity: 1;
    height: 654px;
  }
}
header {
  height: min(8.276vw, 96px);
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
  z-index: 99;
  padding: 0 min(4.31vw, 50px);
}
@media only screen and (max-width: 767px) {
  header {
    height: 23.077vw;
    padding: 0 3.846vw 0 5.128vw;
  }
}
header .header_logo {
  width: min(12.931vw, 150px);
}
@media only screen and (max-width: 767px) {
  header .header_logo {
    width: 28.205vw;
  }
}
header button {
  position: fixed;
  right: 3.846vw;
  top: 3.846vw;
  width: 15.385vw;
}
header nav {
  display: block;
}
@media print, screen and (min-width: 768px) {
  header nav {
    display: block !important;
  }
}
@media only screen and (max-width: 767px) {
  header nav {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100dvh;
    background-color: #E3EFF5;
  }
}
header nav ul {
  display: flex;
  -moz-column-gap: min(4.31vw, 50px);
       column-gap: min(4.31vw, 50px);
}
@media only screen and (max-width: 767px) {
  header nav ul {
    display: grid;
    grid-template-columns: 1fr;
    row-gap: 7.692vw;
    padding-top: 33.333vw;
  }
}
header nav ul li a {
  display: flex;
  font-family: "Outfit", sans-serif;
  letter-spacing: 0.05em;
  font-size: min(1.552vw, 18px);
  font-weight: 300;
  transition: opacity 0.3s;
}
@media only screen and (max-width: 767px) {
  header nav ul li a {
    display: flex;
    justify-content: center;
    font-size: 6.154vw;
    line-height: 1;
    padding: 2.564vw 0;
    text-align: center;
    width: 100%;
  }
}
@media print, screen and (min-width: 768px) {
  header nav ul li a:hover {
    opacity: 0.7;
  }
}

.inner_box {
  max-width: 1160px;
  width: 100%;
  margin: auto;
  padding: 0 min(1.724vw, 20px);
}
@media only screen and (max-width: 767px) {
  .inner_box {
    padding: 0 5.128vw;
  }
}

.sect_title {
  text-align: center;
  font-family: "Outfit", sans-serif;
  letter-spacing: 0.05em;
  font-size: 70px;
  font-style: normal;
  font-weight: 100;
  line-height: 1;
  margin-bottom: min(5.172vw, 60px);
}
@media only screen and (max-width: 767px) {
  .sect_title {
    font-size: 11.282vw;
    margin-bottom: 7.692vw;
  }
}
.sect_title .sub_part {
  display: block;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 20px;
  font-style: normal;
  font-weight: 300;
  line-height: 1;
  letter-spacing: normal;
  margin-top: min(0.862vw, 10px);
}
@media only screen and (max-width: 767px) {
  .sect_title .sub_part {
    font-size: 4.103vw;
    margin-top: 2.564vw;
  }
}

#kv {
  height: min(59.828vw, 694px);
  height: min(56.379vw, 654px);
  width: 100%;
}
@media only screen and (max-width: 767px) {
  #kv {
    height: 133.333vw;
  }
}
#kv .main_logo {
  display: block;
  width: min(34.483vw, 400px);
  margin: 0 auto 0;
  position: absolute;
  left: 0;
  right: 0;
  top: min(22.069vw, 256px);
}
@media only screen and (max-width: 767px) {
  #kv .main_logo {
    width: 51.282vw;
    top: 60.256vw;
  }
}
#kv .baton1 {
  position: absolute;
  top: 0;
  left: calc(50% - min(8.362vw, 97px));
  width: min(64.224vw, 745px);
}
@media only screen and (max-width: 767px) {
  #kv .baton1 {
    left: inherit;
    right: 0;
    top: 17.949vw;
    width: 73.077vw;
  }
}
#kv .baton2 {
  position: absolute;
  top: min(38.103vw, 442px);
  left: calc(50% - min(46.552vw, 540px));
  width: min(45.517vw, 528px);
}
@media only screen and (max-width: 767px) {
  #kv .baton2 {
    left: 0;
    right: inherit;
    top: 102.051vw;
    width: 55.385vw;
  }
}

#about {
  background-image: url(../img/line_about.png);
  background-size: min(116.034vw, 1346px) auto;
  background-position: top min(10vw, 116px) left calc(50% - min(6.983vw, 81px));
  background-position: top 0 left calc(50% - min(8.621vw, 100px));
  background-repeat: no-repeat;
  position: relative;
}
@media only screen and (max-width: 767px) {
  #about {
    background-image: url(../img/line_about_s.png);
    background-size: 100% auto;
    background-position: 0 13.846vw;
  }
}
#about .copy1 {
  background-image: url(../img/bg_photo1.png);
  background-size: min(51.724vw, 600px) auto;
  background-position: right calc(50% - min(17.241vw, 200px) - min(25.862vw, 300px)) top 0;
  background-repeat: no-repeat;
  padding-bottom: min(7.586vw, 88px);
}
@media only screen and (max-width: 767px) {
  #about .copy1 {
    background-image: url(../img/bg_photo1_s.png);
    background-size: 65.128vw auto;
    background-position: 43.59vw 0;
    background-position: right 2.564vw top 0;
    padding-bottom: 6.667vw;
  }
}
#about .copy1 .inner_box {
  padding-top: min(2.069vw, 24px);
  padding-top: min(5.517vw, 64px);
  padding-bottom: min(2.069vw, 24px);
  padding-left: min(14.655vw, 170px);
}
@media only screen and (max-width: 767px) {
  #about .copy1 .inner_box {
    padding-top: 58.974vw;
    padding-left: 7.692vw;
    padding-bottom: 0;
  }
}
#about .copy2 .inner_box {
  background-image: url(../img/bg_photo2.png), url(../img/bg_photo3.png);
  background-size: min(24.138vw, 280px) auto, min(17.241vw, 200px) auto;
  background-position: min(6.034vw, 70px) 0, left min(33.621vw, 390px) bottom min(18.276vw, 212px);
  background-repeat: no-repeat;
  padding-bottom: min(48.621vw, 564px);
  padding-left: min(43.879vw, 509px);
}
@media only screen and (max-width: 767px) {
  #about .copy2 .inner_box {
    background-image: url(../img/bg_photo2_s.png), url(../img/bg_photo3_s.png);
    background-size: 35.897vw auto, 25.641vw auto;
    background-position: left 7.692vw bottom 76.923vw, left 48.718vw bottom 71.282vw;
    padding-bottom: 139.744vw;
    padding-left: 7.692vw;
  }
}
#about .main_copy {
  font-size: min(4.31vw, 50px);
  font-weight: 400;
  line-height: 1.6;
  margin-bottom: min(3.707vw, 43px);
}
@media only screen and (max-width: 767px) {
  #about .main_copy {
    font-size: 9.231vw;
    margin-bottom: 6.41vw;
    text-shadow: 0 0 10px #FFF, 0 0 10px #FFF, 0 0 10px #FFF;
  }
}
#about .text1 {
  font-size: min(1.552vw, 18px);
  line-height: 1.8;
  margin-bottom: 1.8em;
}
@media only screen and (max-width: 767px) {
  #about .text1 {
    margin-bottom: 1.2em;
  }
}
#about .text1:last-child {
  margin-bottom: 0;
}
@media only screen and (max-width: 767px) {
  #about .text1 {
    font-size: 3.846vw;
  }
}
#about .text2 {
  font-size: min(2.069vw, 24px);
  line-height: 1.8;
}
@media only screen and (max-width: 767px) {
  #about .text2 {
    font-size: 5.128vw;
    text-align: center;
  }
}
@media only screen and (max-width: 767px) {
  #about .copy2 .text1 {
    text-align: center;
  }
}

#contents {
  background-color: #E3EFF5;
  background-image: url(../img/line_contents.svg);
  background-size: min(145.517vw, 1688px) auto;
  background-position: top 0 left calc(50% + min(6.034vw, 70px));
  background-repeat: no-repeat;
  padding: min(10.345vw, 120px) 0 min(13.793vw, 160px);
}
@media only screen and (max-width: 767px) {
  #contents {
    background-image: url(../img/line_contents_s.svg);
    background-size: 100% auto;
    background-position: 0 10.256vw;
    padding-bottom: 20.513vw;
    padding-top: 20.513vw;
  }
}
#contents .main_list {
  display: flex;
  flex-wrap: wrap;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  row-gap: min(1.724vw, 20px);
  -moz-column-gap: min(1.724vw, 20px);
       column-gap: min(1.724vw, 20px);
}
@media only screen and (max-width: 767px) {
  #contents .main_list {
    display: flex;
    width: 100%;
    row-gap: 3.846vw;
  }
}
#contents .main_list li {
  border: 1px solid #434F55;
  border-radius: 20px;
  background-color: #fff;
  padding: min(13.793vw, 160px) min(3.448vw, 40px) min(1.724vw, 20px);
  position: relative;
  display: grid;
  grid-template-rows: auto auto;
}
@media only screen and (max-width: 767px) {
  #contents .main_list li {
    width: 100%;
    padding: 38.462vw 5.128vw 5.128vw;
  }
}
#contents .main_list li.coming::after {
  background: url(../img/comingsoon.svg) 0 0/100% auto no-repeat;
  content: "";
  display: block;
  position: absolute;
  left: min(-0.431vw, -5px);
  top: min(-0.431vw, -5px);
  width: min(11.466vw, 133px);
  height: min(11.466vw, 133px);
}
@media only screen and (max-width: 767px) {
  #contents .main_list li.coming::after {
    width: 34.103vw;
    height: 34.103vw;
  }
}
@media print, screen and (min-width: 768px) {
  #contents .main_list li.full {
    grid-column: 1/4;
    display: flex;
    -moz-column-gap: min(3.879vw, 45px);
         column-gap: min(3.879vw, 45px);
    align-items: center;
    padding: 0 0 0 min(27.845vw, 323px);
    min-height: min(17.241vw, 200px);
  }
  #contents .main_list li.full::before {
    left: min(16.034vw, 186px);
    right: inherit;
    top: 0;
    bottom: 0;
  }
  #contents .main_list li.full .ttl {
    margin-bottom: 0;
  }
  #contents .main_list li.full .dsc {
    margin-bottom: 0;
  }
  #contents .main_list li.full .dsc .txt {
    margin-bottom: 0;
  }
}
#contents .main_list li::before {
  background-position: 0 0;
  background-size: 100% auto;
  background-repeat: no-repeat;
  content: "";
  display: block;
  position: absolute;
  right: 0px;
  left: 0;
  top: min(4.31vw, 50px);
  margin: auto;
  width: min(9.483vw, 110px);
  height: min(9.483vw, 110px);
}
@media only screen and (max-width: 767px) {
  #contents .main_list li::before {
    top: 8.974vw;
    width: 25.641vw;
    height: 25.641vw;
  }
}
#contents .main_list li:nth-child(1)::before {
  background-image: url(../img/icon_1.svg);
}
#contents .main_list li:nth-child(2)::before {
  background-image: url(../img/icon_2.svg);
}
#contents .main_list li:nth-child(3)::before {
  background-image: url(../img/icon_3.svg);
}
#contents .main_list li:nth-child(4)::before {
  background-image: url(../img/icon_4.svg);
}
#contents .main_list li .ttl {
  font-size: min(2.241vw, 26px);
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: 0.05em;
  text-align: center;
  margin-bottom: min(0.776vw, 9px);
}
@media only screen and (max-width: 767px) {
  #contents .main_list li .ttl {
    font-size: 6.667vw;
    margin-bottom: 4.103vw;
  }
}
#contents .main_list li .ttl .small {
  display: block;
  font-size: min(1.724vw, 20px);
  vertical-align: bottom;
  line-height: 1.2;
}
@media only screen and (max-width: 767px) {
  #contents .main_list li .ttl .small {
    font-size: 5.128vw;
  }
}
#contents .main_list li .dsc {
  display: grid;
  grid-template-rows: auto;
}
#contents .main_list li .dsc .txt {
  font-size: min(1.379vw, 16px);
  font-style: normal;
  font-weight: 300;
  line-height: 140%;
  margin-bottom: min(1.724vw, 20px);
}
@media only screen and (max-width: 767px) {
  #contents .main_list li .dsc .txt {
    font-size: 4.103vw;
    margin-bottom: 4.359vw;
    margin-left: 3.846vw;
    margin-right: 3.846vw;
  }
}
#contents .main_list .link_detail {
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.05em;
  position: relative;
  display: flex;
  justify-content: flex-end;
}
#contents .main_list .link_detail a {
  display: inline-flex;
  align-items: center;
  -moz-column-gap: min(0.862vw, 10px);
       column-gap: min(0.862vw, 10px);
}
@media only screen and (max-width: 767px) {
  #contents .main_list .link_detail a {
    -moz-column-gap: 2.564vw;
         column-gap: 2.564vw;
  }
}
#contents .main_list .link_detail a .icon {
  background-color: #99CCE5;
  border: 1px solid #99CCE5;
  border-radius: 100vh;
  display: block;
  width: min(3.103vw, 36px);
  height: min(3.103vw, 36px);
  transition: 0.2s;
  position: relative;
}
@media only screen and (max-width: 767px) {
  #contents .main_list .link_detail a .icon {
    width: 7.692vw;
    height: 7.692vw;
  }
}
#contents .main_list .link_detail a .icon::before {
  content: "";
  display: block;
  position: absolute;
  right: 0;
  left: 0;
  top: 0px;
  bottom: 0;
  margin: auto;
  width: min(1.379vw, 18px);
  height: min(1.552vw, 16px);
  -webkit-mask: url('data:image/svg+xml,<svg width="18" height="16" viewBox="0 0 18 16" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M10.0526 1L17 8L10.0526 15M1 8H16.8261" stroke="%23434F55" stroke-miterlimit="10" stroke-linecap="round"/></svg>') no-repeat center/contain;
          mask: url('data:image/svg+xml,<svg width="18" height="16" viewBox="0 0 18 16" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M10.0526 1L17 8L10.0526 15M1 8H16.8261" stroke="%23434F55" stroke-miterlimit="10" stroke-linecap="round"/></svg>') no-repeat center/contain;
  background-color: #fff;
}
@media only screen and (max-width: 767px) {
  #contents .main_list .link_detail a .icon::before {
    width: 3.41vw;
    height: 2.974vw;
  }
}
@media print, screen and (min-width: 768px) {
  #contents .main_list .link_detail a:hover .icon {
    background-color: #fff;
    border-color: #434F55;
  }
  #contents .main_list .link_detail a:hover .icon::before {
    background-color: #434F55;
  }
}

.bg_wrap {
  background-image: url(../img/line_access_faq.svg);
  background-size: min(151.466vw, 1757px) auto;
  background-position: top 0 left calc(50% + min(0.862vw, 10px));
  background-repeat: no-repeat;
}
@media only screen and (max-width: 767px) {
  .bg_wrap {
    background-image: url(../img/line_access_faq_s.svg);
    background-size: 100% auto;
    background-position: 0 -6.41vw;
  }
}

#access {
  padding-bottom: min(3.448vw, 40px);
  padding-top: min(10.345vw, 120px);
}
@media only screen and (max-width: 767px) {
  #access {
    padding-bottom: 3.846vw;
    padding-top: 20.513vw;
  }
}
#access .map_area {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  padding-top: 44.64%;
  height: 0;
  border-radius: min(1.724vw, 20px);
  overflow: hidden;
}
@media only screen and (max-width: 767px) {
  #access .map_area {
    padding-top: 100%;
    border-radius: 5.128vw;
  }
}
#access .map_area iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
#access .store_data {
  margin-top: min(2.586vw, 30px);
}
@media only screen and (max-width: 767px) {
  #access .store_data {
    margin-top: 6.41vw;
  }
}
#access .store_data .store_name {
  font-family: "Outfit", sans-serif;
  letter-spacing: 0.05em;
  font-weight: 300;
  font-size: min(2.069vw, 24px);
  line-height: 1;
  margin-bottom: min(1.724vw, 20px);
  text-align: center;
}
@media only screen and (max-width: 767px) {
  #access .store_data .store_name {
    font-size: 5.641vw;
    margin-bottom: 3.59vw;
  }
}
#access .store_data dl {
  display: grid;
  flex-wrap: wrap;
  justify-content: center;
}
@media only screen and (max-width: 767px) {
  #access .store_data dl {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    row-gap: 2.564vw;
  }
}
#access .store_data dl > div {
  text-align: center;
}
@media only screen and (max-width: 767px) {
  #access .store_data dl > div {
    text-align: left;
    display: flex;
    justify-content: flex-start;
  }
}
#access .store_data dt, #access .store_data dd {
  text-align: center;
  font-size: min(1.207vw, 14px);
  line-height: 1.6;
  letter-spacing: 0.04em;
}
@media only screen and (max-width: 767px) {
  #access .store_data dt, #access .store_data dd {
    font-size: 3.59vw;
  }
}
#access .store_data dt {
  display: inline;
  font-weight: 400;
  margin-right: 1em;
}
#access .store_data dd {
  display: inline;
  font-weight: 300;
  text-align: left;
  flex: 1;
}

#faq {
  padding: min(10.345vw, 120px) 0 min(13.793vw, 160px);
}
@media only screen and (max-width: 767px) {
  #faq {
    padding: 20.513vw 0 20.513vw;
  }
}
#faq .faq_cat {
  font-size: min(2.241vw, 26px);
  font-weight: 400;
  line-height: 1;
  margin-top: min(2.586vw, 30px);
  margin-bottom: min(2.586vw, 30px);
  padding-top: min(2.586vw, 30px);
}
@media only screen and (max-width: 767px) {
  #faq .faq_cat {
    font-size: 5.128vw;
    margin-top: 2.564vw;
    margin-bottom: 5.128vw;
    padding-top: 5.128vw;
  }
}
#faq .cat_list {
  display: flex;
  justify-content: center;
  -moz-column-gap: min(1.724vw, 20px);
       column-gap: min(1.724vw, 20px);
}
@media only screen and (max-width: 767px) {
  #faq .cat_list {
    flex-wrap: wrap;
    row-gap: 2.564vw;
    margin-bottom: 7.692vw;
  }
}
@media only screen and (max-width: 767px) {
  #faq .cat_list li {
    width: 74.359vw;
  }
}
#faq .cat_list li a {
  position: relative;
  background-position: right min(0.862vw, 10px) center;
  background-repeat: no-repeat;
  background-size: min(3.103vw, 36px) auto;
  background-color: #E3EFF5;
  border-radius: min(1.724vw, 20px);
  display: flex;
  align-items: center;
  height: min(4.828vw, 56px);
  font-size: min(1.379vw, 16px);
  font-weight: 400;
  padding: 0 min(4.828vw, 56px) 0 min(1.724vw, 20px);
  transition: 0.2s;
}
@media only screen and (max-width: 767px) {
  #faq .cat_list li a {
    border-radius: 4.615vw;
    height: 12.821vw;
    font-size: 4.103vw;
    padding: 0 12.821vw 0 5.128vw;
  }
}
#faq .cat_list li a::after {
  content: "";
  display: block;
  position: absolute;
  right: min(1.724vw, 20px);
  top: 0px;
  bottom: 0;
  margin: auto;
  width: min(1.379vw, 16px);
  height: min(1.552vw, 18px);
  -webkit-mask: url('data:image/svg+xml,<svg width="16" height="18" viewBox="0 0 16 18" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M15 10.0526L8 17L1 10.0526M8 1V16.8261" stroke="%23434F55" stroke-miterlimit="10" stroke-linecap="round"/></svg>') no-repeat center/contain;
          mask: url('data:image/svg+xml,<svg width="16" height="18" viewBox="0 0 16 18" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M15 10.0526L8 17L1 10.0526M8 1V16.8261" stroke="%23434F55" stroke-miterlimit="10" stroke-linecap="round"/></svg>') no-repeat center/contain;
  background-color: #434F55;
  transition: background-color 0.2s;
}
@media only screen and (max-width: 767px) {
  #faq .cat_list li a::after {
    right: 4.359vw;
    width: 3.41vw;
    height: 2.974vw;
  }
}
#faq .cat_list li a::before {
  background-color: #fff;
  border-radius: 100vh;
  content: "";
  display: block;
  position: absolute;
  right: min(0.862vw, 10px);
  top: 0px;
  bottom: 0;
  margin: auto;
  width: min(3.103vw, 36px);
  height: min(3.103vw, 36px);
}
@media only screen and (max-width: 767px) {
  #faq .cat_list li a::before {
    right: 2.308vw;
    width: 7.692vw;
    height: 7.692vw;
  }
}
@media print, screen and (min-width: 768px) {
  #faq .cat_list li a:hover {
    color: #fff;
    background-color: #99CCE5;
  }
  #faq .cat_list li a:hover::after {
    background-color: #99CCE5;
  }
}
#faq .mdl-faq_box {
  border: solid 1px #434F55;
  border-radius: min(1.724vw, 20px);
  background-color: #fff;
  margin-bottom: min(0.862vw, 10px);
}
@media only screen and (max-width: 767px) {
  #faq .mdl-faq_box {
    border-radius: 4.615vw;
    margin-bottom: 2.564vw;
  }
}
#faq .mdl-faq_box:last-child {
  margin-bottom: 0;
}
#faq .mdl-faq_box .acc_head {
  cursor: pointer;
  display: flex;
  align-items: center;
  font-size: min(1.724vw, 20px);
  font-weight: 400;
  line-height: 1.6;
  position: relative;
  transition: background-color 0.6s;
  padding: min(1.466vw, 17px) min(2.586vw, 30px);
}
@media only screen and (max-width: 767px) {
  #faq .mdl-faq_box .acc_head {
    font-size: 4.103vw;
    padding: 3.59vw 17.949vw 3.59vw 7.436vw;
  }
}
#faq .mdl-faq_box .acc_head .icon {
  background-color: #99CCE5;
  border: 1px solid #99CCE5;
  border-radius: 100vh;
  display: block;
  width: min(3.103vw, 36px);
  height: min(3.103vw, 36px);
  position: absolute;
  right: min(1.638vw, 19px);
  top: 0;
  bottom: 0;
  margin: auto;
  transition: 0.3s;
}
@media only screen and (max-width: 767px) {
  #faq .mdl-faq_box .acc_head .icon {
    width: 7.692vw;
    height: 7.692vw;
    right: 4.872vw;
  }
}
#faq .mdl-faq_box .acc_head .icon::before {
  background-color: #fff;
  content: "";
  display: block;
  width: min(1.293vw, 15px);
  height: 1px;
  border-radius: 100vh;
  position: absolute;
  right: 0;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  transition: 0.3s;
}
@media only screen and (max-width: 767px) {
  #faq .mdl-faq_box .acc_head .icon::before {
    width: 2.821vw;
  }
}
#faq .mdl-faq_box .acc_head .icon::after {
  background-color: #fff;
  content: "";
  display: block;
  width: 1px;
  height: min(1.293vw, 15px);
  border-radius: 100vh;
  position: absolute;
  right: 0;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  transition: 0.3s;
}
@media only screen and (max-width: 767px) {
  #faq .mdl-faq_box .acc_head .icon::after {
    height: 2.821vw;
  }
}
@media print, screen and (min-width: 768px) {
  #faq .mdl-faq_box .acc_head:hover .acc_head__text::after {
    filter: brightness(130%);
  }
  #faq .mdl-faq_box .acc_head:hover .acc_head__text::before {
    opacity: 0.7;
  }
}
#faq .mdl-faq_box .acc_head.opened .acc_head__text::after {
  opacity: 0;
}
#faq .mdl-faq_box .acc_head.opened .icon {
  background-color: #fff;
  border: 1px solid #434F55;
}
#faq .mdl-faq_box .acc_head.opened .icon::before {
  background-color: #434F55;
}
#faq .mdl-faq_box .acc_head.opened .icon::after {
  opacity: 0;
}
#faq .mdl-faq_box .acc_head.opened + .acc_body {
  border-top: 1px dotted #434F55;
}
#faq .mdl-faq_box .acc_body {
  display: none;
  padding-bottom: min(2.759vw, 32px);
  padding-top: min(2.069vw, 24px);
  padding: min(1.293vw, 15px) min(2.586vw, 30px);
  position: relative;
  transition: border 0s;
}
@media only screen and (max-width: 767px) {
  #faq .mdl-faq_box .acc_body {
    padding: 5.385vw 5.128vw 4.872vw 5.128vw;
  }
}
#faq .mdl-faq_box .acc_body .acc_body__text {
  display: flex;
  align-items: flex-start;
}
@media only screen and (max-width: 767px) {
  #faq .mdl-faq_box .acc_body .acc_body__text {
    align-items: flex-start;
  }
}
#faq .mdl-faq_box .acc_body .text {
  font-size: min(1.207vw, 14px);
  font-weight: 300;
  line-height: 1.6;
  width: 100%;
  flex: 1;
}
@media only screen and (max-width: 767px) {
  #faq .mdl-faq_box .acc_body .text {
    font-size: 3.59vw;
    line-height: 1.6;
  }
}
#faq .mdl-faq_box .acc_body a {
  text-decoration: underline;
  transition: 0.3s;
}
@media print, screen and (min-width: 768px) {
  #faq .mdl-faq_box .acc_body a:hover {
    text-decoration: none;
  }
}

footer {
  background-color: #E3EFF5;
  background-image: url(../img/line_footer.svg);
  background-size: min(78.19vw, 907px) auto;
  background-position: top 0 right calc(50% - min(39.052vw, 453px));
  background-repeat: no-repeat;
  padding-bottom: min(8.621vw, 100px);
  padding-top: min(8.621vw, 100px);
}
@media only screen and (max-width: 767px) {
  footer {
    background-image: url(../img/line_footer_s.svg);
    background-size: 72.564vw auto;
    background-position: bottom 0 right 0;
    padding-bottom: 20.513vw;
    padding-top: 15.385vw;
  }
}
footer .msg {
  text-align: center;
}
footer .msg_en {
  font-family: "Outfit", sans-serif;
  letter-spacing: 0.05em;
  font-size: min(5.517vw, 64px);
  font-weight: 100;
  line-height: 1;
  position: relative;
  padding-top: min(6.81vw, 79px);
  margin-bottom: min(3.448vw, 40px);
}
@media only screen and (max-width: 767px) {
  footer .msg_en {
    font-size: 12.308vw;
    line-height: 1.2;
    padding-top: 8.974vw;
    margin-bottom: 7.692vw;
  }
}
footer .msg_en::before {
  background: url(../img/illust_baton.svg) 0 0/100% auto no-repeat;
  content: "";
  display: block;
  position: absolute;
  right: 0px;
  left: 0;
  top: 0px;
  margin: auto;
  width: min(7.586vw, 88px);
  height: min(5.948vw, 69px);
}
@media only screen and (max-width: 767px) {
  footer .msg_en::before {
    width: 11.282vw;
    height: 8.974vw;
  }
}
footer .msg_jp {
  font-size: min(1.724vw, 20px);
  font-weight: 300;
  line-height: 1.8;
}
@media only screen and (max-width: 767px) {
  footer .msg_jp {
    font-size: 4.103vw;
  }
}
footer .font-en {
  font-family: "Outfit", sans-serif;
  letter-spacing: 0.05em;
  font-size: min(1.897vw, 22px);
  font-weight: 100;
}
@media only screen and (max-width: 767px) {
  footer .font-en {
    font-size: 4.615vw;
  }
}
footer .tomail {
  font-size: min(1.897vw, 22px);
  font-weight: 400;
  color: #83BFDD;
}
@media only screen and (max-width: 767px) {
  footer .tomail {
    font-size: 5.128vw;
    display: block;
  }
}
footer .footer_logo {
  text-align: center;
  margin-top: min(6.897vw, 80px);
  margin-bottom: min(3.448vw, 40px);
  font-size: 0;
}
@media only screen and (max-width: 767px) {
  footer .footer_logo {
    margin-top: 15.385vw;
    margin-bottom: 5.128vw;
  }
}
footer .footer_logo img {
  width: min(14.655vw, 170px);
}
@media only screen and (max-width: 767px) {
  footer .footer_logo img {
    width: 38.462vw;
  }
}
footer .copyright {
  font-family: "Outfit", sans-serif;
  letter-spacing: 0.05em;
  font-weight: 100;
  font-size: min(1.034vw, 12px);
  line-height: 1;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  footer .copyright {
    font-size: 2.564vw;
  }
}