@charset "UTF-8";
/*---------------------------------------------
design-width
---------------------------------------------*/
/*---------------------------------------------
vw変換

width: vw-sp(320);
@include pc-only {
  width: min(vw-pc(194), 194px);
}
@include pc-lg {
  width: vw-pc(194);
}
---------------------------------------------*/
/*---------------------------------------------
メディアクエリ
---------------------------------------------*/
@media screen and (max-width: 767px) {
  .pc {
    display: none !important;
  }
}

@media screen and (min-width: 768px) {
  .sp {
    display: none !important;
  }
}

/*---------------------------------------------
フォント用のmixinとユーティリティ

@include font-sp(26); // モバイルファースト
@include font-pc(18); // タブレット〜PC対応
---------------------------------------------*/
/*---------------------------------------------
カスタムプロパティ
---------------------------------------------*/
:root {
  --custom-vw: 97.4vw;
  --color-lavender-blue: #C0E6FF;
}

/*---------------------------------------------
リセット
---------------------------------------------*/
*, *::before, *::after {
  box-sizing: border-box;
}

* {
  margin: 0;
  padding: 0;
}

img, picture, video, canvas, svg {
  max-width: 100%;
}

input, button, textarea, select {
  font: inherit;
}

p, h1, h2, h3, h4, h5, h6 {
  overflow-wrap: break-word;
}

/*---------------------------------------------
初期設定
---------------------------------------------*/
html {
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

body {
  -webkit-text-size-adjust: 100%;
  line-height: 1.6;
  color: #000;
}

html, body {
  font-size: 100%;
}

a {
  color: #000;
}

a:hover,
a:link {
  text-decoration: none;
}

li {
  list-style: none;
}

img {
  vertical-align: bottom;
  height: auto;
}

svg {
  vertical-align: bottom;
}

sup, sub {
  font-size: 0.6em;
}

iframe {
  margin: 0 !important;
  padding: 0 !important;
  display: block;
  border: none;
}

/*---------------------------------------------
common
---------------------------------------------*/
.wrapper {
  position: relative;
}

section {
  width: 100%;
  overflow: hidden;
}

@media screen and (max-width: 767px) {
  .container {
    padding-left: calc(var(--custom-vw) * 0.0533333333);
    padding-right: calc(var(--custom-vw) * 0.0533333333);
  }
}
@media screen and (min-width: 768px) {
  .container {
    width: min(87.5vw, 1120px);
    margin-left: auto;
    margin-right: auto;
  }
}

/*---------------------------------------------
header
---------------------------------------------*/
.header {
  position: sticky;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 10;
  background-color: white;
}
.header .l-box {
  display: flex;
  align-items: center;
  height: calc(var(--custom-vw) * 0.1066666667);
}
@media screen and (min-width: 768px) {
  .header .l-box {
    height: min(6.25vw, 80px);
  }
}
.header .logo {
  width: 25.2vw;
}
@media screen and (min-width: 768px) {
  .header .logo {
    width: min(7.96875vw, 102px);
  }
}
.header .gnav {
  margin-left: auto;
  display: flex;
}
@media screen and (min-width: 768px) {
  .header .gnav li {
    margin-left: min(3.515625vw, 45px);
  }
}
.header .gnav li a {
  font-size: 3.2vw;
}
@media screen and (min-width: 768px) {
  .header .gnav li a {
    font-size: min(1.171875vw, 15px);
  }
}

/*---------------------------------------------
footer
---------------------------------------------*/
.footer {
  border-top: solid 2px #f9f9f9;
  background-color: #fff;
  padding: calc(var(--custom-vw) * 0.0533333333) 0;
}
@media screen and (min-width: 768px) {
  .footer {
    padding: min(6.25vw, 80px) 0 min(2.734375vw, 35px);
  }
}
.footer .fbox {
  display: flex;
  line-height: 1.5;
  flex-wrap: wrap;
}
.footer .fbox .cbox:nth-child(1) {
  width: 100%;
  font-size: 3.2vw;
}
@media screen and (min-width: 768px) {
  .footer .fbox .cbox:nth-child(1) {
    font-size: min(1.25vw, 16px);
  }
}
@media screen and (max-width: 767px) {
  .footer .fbox .cbox:nth-child(1) {
    display: flex;
    justify-content: space-between;
    margin-bottom: calc(var(--custom-vw) * 0.0533333333);
  }
}
@media screen and (min-width: 768px) {
  .footer .fbox .cbox:nth-child(1) {
    width: 366px;
    margin-bottom: 0;
  }
}
@media screen and (min-width: 768px) {
  .footer .fbox .cbox:nth-child(2) {
    padding-top: 80px;
    width: 42.85%;
    margin-left: auto;
  }
}
.footer a {
  text-decoration: underline;
}
.footer .logo {
  width: calc(var(--custom-vw) * 0.336);
}
@media screen and (min-width: 768px) {
  .footer .logo {
    width: 196px;
  }
}
.footer .address {
  margin-top: calc(var(--custom-vw) * 0.04);
}
@media screen and (min-width: 768px) {
  .footer .address {
    margin-top: 20px;
  }
}
.footer .company {
  margin-top: calc(var(--custom-vw) * 0.0466666667);
}
@media screen and (min-width: 768px) {
  .footer .company {
    margin-top: 25px;
  }
}
.footer .badge {
  margin-top: calc(var(--custom-vw) * 0.12);
}
@media screen and (max-width: 767px) {
  .footer .badge img {
    width: calc(var(--custom-vw) * 0.312);
  }
}
@media screen and (min-width: 768px) {
  .footer .badge {
    margin-top: 50px;
  }
}
.footer .footnav a {
  text-decoration: none;
}
.footer .footnav .parent > * {
  font-size: 3.2vw;
}
@media screen and (min-width: 768px) {
  .footer .footnav .parent > * {
    font-size: min(1.25vw, 16px);
  }
}
.footer .footnav .parent ul {
  font-size: 2.9333333333vw;
  margin-top: calc(var(--custom-vw) * 0.0133333333);
}
@media screen and (min-width: 768px) {
  .footer .footnav .parent ul {
    font-size: min(1.09375vw, 14px);
  }
}
@media screen and (min-width: 768px) {
  .footer .footnav .parent ul {
    display: flex;
    flex-wrap: wrap;
    gap: 0.2em 1em;
    margin-top: 5px;
  }
}
@media screen and (min-width: 768px) {
  .footer .footnav .parent ul li {
    min-width: 120px;
  }
}
@media screen and (max-width: 767px) {
  .footer .footnav .parent ul li + li {
    margin-top: 0.2em;
  }
}
.footer .footnav .parent + .parent {
  margin-top: calc(var(--custom-vw) * 0.06);
}
@media screen and (min-width: 768px) {
  .footer .footnav .parent + .parent {
    margin-top: 20px;
  }
}
.footer .copyright {
  color: #828282;
  text-align: right;
  font-size: 2.6666666667vw;
  margin-top: calc(var(--custom-vw) * 0.0733333333);
}
@media screen and (min-width: 768px) {
  .footer .copyright {
    font-size: min(0.9375vw, 12px);
  }
}
@media screen and (min-width: 768px) {
  .footer .copyright {
    margin-top: 85px;
  }
}

/*---------------------------------------------
Mobile Menu
---------------------------------------------*/
/* Nav items */
.menu {
  list-style: none;
  position: absolute;
  width: 100%;
  height: auto;
  top: 0;
  left: 0;
  margin-top: calc(var(--custom-vw) * 0.1066666667);
  padding: 0 0 10px 0;
  clear: both;
  background: #fff031;
  transition: 0.3192s cubic-bezier(0.04, 0.04, 0.12, 0.96) 0.1008s;
  transform: scale(1, 0);
  transform-origin: top;
  opacity: 0;
}

/* Hamburger menu button */
.menu-btn:checked ~ .menu {
  opacity: 1;
  transform: scale(1, 1);
  transform-origin: top;
  transition: 0.3192s cubic-bezier(0.04, 0.04, 0.12, 0.96) 0.1008s;
}

/* Hamburger menbu text */
.menu a {
  text-decoration: none;
  font-weight: 500;
  letter-spacing: 2px;
  font-size: 16px;
  text-transform: capitalize;
  color: #000;
  opacity: 0;
  transition: 0.5s;
  display: block;
  padding: 15px 0;
}

.menu li {
  margin: 0 54px;
  opacity: 0;
  transition: 0.5s;
}

.menu li + li {
  border-top: 1px solid rgb(75, 75, 75);
}

.menu-btn:checked ~ .menu a,
.menu-btn:checked ~ .menu li {
  opacity: 1;
  transition: 0.3192s cubic-bezier(0.04, 0.04, 0.12, 0.96) 0.2s;
}

.menu-btn {
  display: none;
}

.menu-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 0;
  right: 0;
  cursor: pointer;
  width: calc(var(--custom-vw) * 0.168);
  height: 100%;
  z-index: 10;
  overflow: hidden;
  padding-left: calc(var(--custom-vw) * 0.012);
}

.navicon {
  background: #000;
  display: block;
  height: 2px;
  width: calc(var(--custom-vw) * 0.076);
  position: relative;
  transition: 0.3192s cubic-bezier(0.04, 0.04, 0.12, 0.96) 0.1008s;
  z-index: 1;
}

.navicon:before,
.navicon:after {
  content: "";
  display: block;
  height: 100%;
  width: 100%;
  position: absolute;
  background: #000;
  transition: 0.3192s cubic-bezier(0.04, 0.04, 0.12, 0.96) 0.1008s;
}

.navicon:before {
  top: 7px;
}

.navicon:after {
  bottom: 7px;
}

/* Hamburger Menu Animation Start */
.menu-btn:checked ~ .menu-icon .navicon:before {
  transform: rotate(-45deg);
}

.menu-btn:checked ~ .menu-icon .navicon:after {
  transform: rotate(45deg);
}

.menu-btn:checked ~ .menu-icon:not(.steps) .navicon:before {
  top: 0;
}

.menu-btn:checked ~ .menu-icon:not(.steps) .navicon:after {
  bottom: 0;
}

.menu-btn:checked ~ .menu-icon .navicon {
  background: rgba(0, 0, 0, 0);
  transition: 0.2192s cubic-bezier(0.04, 0.04, 0.12, 0.96) 0.1008s;
}

/*---------------------------------------------
ユーティリティ
---------------------------------------------*/
/* font-weight */
.font-medium {
  font-weight: 500;
}

.font-bold {
  font-weight: 600;
}

/* text-align */
.text-center {
  text-align: center;
}

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

.text-right {
  text-align: right;
}

@media screen and (max-width: 767px) {
  .text-center-sp {
    text-align: center;
  }
  .text-left-sp {
    text-align: left;
  }
  .text-right-sp {
    text-align: right;
  }
}
/* flex */
.flex {
  display: flex;
}

.flex-pc {
  display: flex;
}
@media screen and (max-width: 767px) {
  .flex-pc {
    flex-direction: column;
  }
}

.flex-col {
  flex-direction: column;
}

.justify-center {
  justify-content: center;
}

.item-center {
  align-items: center;
}

/* line-height */
.leading-sm {
  line-height: 1.5;
}

.leading-lg {
  line-height: 1.77;
}

.leading-xl {
  line-height: 2;
}

@media screen and (max-width: 767px) {
  .leading-sm-sp {
    line-height: 1.5;
  }
}
/* dashed-line */
.dashed-line {
  background-image: repeating-linear-gradient(to right, #c1c1c1, #c1c1c1 2px, transparent 2px, transparent 4px);
  background-repeat: repeat-x;
  background-position: bottom left;
  background-size: 4px 2px;
}

.dashed-line-top {
  background-image: repeating-linear-gradient(to right, #c1c1c1, #c1c1c1 2px, transparent 2px, transparent 4px);
  background-repeat: repeat-x;
  background-position: top left;
  background-size: 4px 2px;
}

/* font */
.outfit-regular {
  font-family: "Outfit", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

.outfit-medium {
  font-family: "Outfit", sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}

.outfit-bold {
  font-family: "Outfit", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
}

.m-plus-1p-regular {
  font-family: "M PLUS 1p", sans-serif;
  font-weight: 400;
  font-style: normal;
}

.m-plus-1p-medium {
  font-family: "M PLUS 1p", sans-serif;
  font-weight: 500;
  font-style: normal;
}

.m-plus-1p-bold {
  font-family: "M PLUS 1p", sans-serif;
  font-weight: 700;
  font-style: normal;
}

.map {
  width: 100%;
  position: relative;
  padding-top: 56.25%;
}
.map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/*---------------------------------------------
anime
---------------------------------------------*/
[data-anime=fadeUp] {
  opacity: 0;
  -webkit-transform: translateY(30px);
  transform: translateY(30px);
  -webkit-transition: 1s ease transform, 1s ease opacity;
  transition: 1s ease transform, 1s ease opacity;
}

[data-anime=fadeUp].is-animated {
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0);
}

[data-anime=slideRight] {
  opacity: 0;
  -webkit-transform: translateX(-30%);
  transform: translateX(-30%);
  -webkit-transition: 1s ease transform, 1s ease opacity;
  transition: 1s ease transform, 1s ease opacity;
}

[data-anime=slideRight].is-animated {
  opacity: 1;
  -webkit-transform: translateX(0);
  transform: translateX(0);
}

[data-anime=slideLeft] {
  opacity: 0;
  -webkit-transform: translateX(100%);
  transform: translateX(100%);
  -webkit-transition: 1s ease transform, 1s ease opacity;
  transition: 1s ease transform, 1s ease opacity;
}

[data-anime=slideLeft].is-animated {
  opacity: 1;
  -webkit-transform: translateX(0);
  transform: translateX(0);
}

[data-anime=scaledown] {
  opacity: 0;
  transform: scale(2);
  transition: 1s ease transform, 1s ease opacity;
}

[data-anime=scaledown].is-animated {
  opacity: 1;
  transform: scale(1);
}

[data-anime=scaleup] {
  opacity: 0;
  transform: scale(0.6);
  transition: 0.5s ease transform, 0.5s ease opacity;
}

[data-anime=scaleup].is-animated {
  opacity: 1;
  transform: scale(1);
}

/*---------------------------------------------
common
---------------------------------------------*/
.btn-cta {
  position: relative;
  border: solid 3px #000000;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #ffde00;
  max-width: 100%;
  font-size: 4.5333333333vw;
  font-weight: 600;
  width: 80vw;
  height: 17.3333333333vw;
  border-radius: 17.3333333333vw;
}
@media screen and (min-width: 768px) {
  .btn-cta {
    font-size: min(1.5625vw, 20px);
  }
}
@media screen and (min-width: 768px) {
  .btn-cta {
    width: min(28.125vw, 360px);
    height: min(6.25vw, 80px);
    border-radius: min(6.25vw, 80px);
  }
}
.btn-cta .arrow {
  position: absolute;
  top: 50%;
  right: 4.44%;
  translate: 0 -50%;
  width: 7.2vw;
  height: 7.2vw;
}
@media screen and (min-width: 768px) {
  .btn-cta .arrow {
    width: min(2.5vw, 32px);
    height: min(2.5vw, 32px);
  }
}

.btn-radio {
  border: solid 1px #0288eb;
  color: #0288eb;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  line-height: 1;
  font-size: 3.0666666667vw;
  font-weight: 500;
  background-color: #fff;
  width: 28.8vw;
  height: 6.9333333333vw;
  border-radius: 6.9333333333vw;
}
@media screen and (min-width: 768px) {
  .btn-radio {
    font-size: min(1.09375vw, 14px);
  }
}
@media screen and (min-width: 768px) {
  .btn-radio {
    width: min(10.15625vw, 130px);
    height: min(2.5vw, 32px);
    border-radius: min(2.5vw, 32px);
  }
}
.btn-radio img {
  vertical-align: middle;
  margin-left: 3px;
  width: min(1.640625vw, 21px);
}
@media screen and (max-width: 767px) {
  .btn-radio img {
    width: 4.5333333333vw;
  }
}
.btn-radio:hover {
  opacity: 0.75;
}

.bg-blue {
  background-color: var(--color-lavender-blue);
}

.content-block {
  border: solid 4px #000;
  background-color: #fff;
  border-radius: 54px;
}
@media screen and (max-width: 767px) {
  .content-block {
    border-radius: 7.2vw;
  }
}

/*---------------------------------------------
bg
---------------------------------------------*/
@keyframes floatAnimation {
  0% {
    transform: translate(0, 20px);
  }
  25% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(0, -20px);
  }
  75% {
    transform: translate(0, 0);
  }
  100% {
    transform: translate(0, 20px);
  }
}
.bgCircle-14 {
  --bgCircle-color-14: 51 159 239;
  aspect-ratio: 1/1;
  background: radial-gradient(circle, rgb(var(--bgCircle-color-14)), rgb(var(--bgCircle-color-14)/80%));
  border-radius: 50%;
  filter: blur(18px);
  position: absolute;
  z-index: -1;
  width: min(100%, 260px);
  bottom: 380px;
  left: calc(50% - 830px);
  animation-name: floatAnimation;
  animation-duration: 12s;
  animation-iteration-count: infinite;
}

.bgCircle-15 {
  --bgCircle-color-15: 255 255 255;
  aspect-ratio: 1/1;
  background: radial-gradient(circle, rgb(var(--bgCircle-color-15)), rgb(var(--bgCircle-color-15)/100%));
  border-radius: 50%;
  position: absolute;
  z-index: -1;
  width: min(100%, 64px);
  bottom: 580px;
  left: calc(50% - 700px);
  animation-name: floatAnimation;
  animation-duration: 8s;
  animation-iteration-count: infinite;
}

.bgCircle-16 {
  --bgCircle-color-16: 255 255 255;
  aspect-ratio: 1/1;
  background: radial-gradient(circle, rgb(var(--bgCircle-color-16)), rgb(var(--bgCircle-color-16)/100%));
  border-radius: 50%;
  filter: blur(4px);
  position: absolute;
  z-index: -1;
  width: min(100%, 160px);
  bottom: 20px;
  left: calc(50% + 550px);
  animation-name: floatAnimation;
  animation-duration: 12s;
  animation-iteration-count: infinite;
}

.bgCircle-17 {
  --bgCircle-color-17: 51 159 239;
  aspect-ratio: 1/1;
  background: radial-gradient(circle, rgb(var(--bgCircle-color-17)), rgb(var(--bgCircle-color-17)/100%));
  border-radius: 50%;
  position: absolute;
  z-index: -1;
  width: min(100%, 44px);
  bottom: 140px;
  left: calc(50% + 650px);
  animation-name: floatAnimation;
  animation-duration: 8s;
  animation-iteration-count: infinite;
}

.bgCircle-18 {
  --bgCircle-color-16: 255 255 255;
  aspect-ratio: 1/1;
  background: radial-gradient(circle, rgb(var(--bgCircle-color-16)), rgb(var(--bgCircle-color-16)/100%));
  border-radius: 50%;
  filter: blur(4px);
  position: absolute;
  z-index: -1;
  width: min(100%, 236px);
  bottom: -80px;
  left: calc(50% - 690px);
  animation-name: floatAnimation;
  animation-duration: 12s;
  animation-iteration-count: infinite;
}

.bgCircle-19 {
  --bgCircle-color-17: 51 159 239;
  aspect-ratio: 1/1;
  background: radial-gradient(circle, rgb(var(--bgCircle-color-17)), rgb(var(--bgCircle-color-17)/100%));
  border-radius: 50%;
  position: absolute;
  z-index: -1;
  width: min(100%, 74px);
  bottom: 60px;
  left: calc(50% - 520px);
  animation-name: floatAnimation;
  animation-duration: 8s;
  animation-iteration-count: infinite;
}

.bgCircle-20 {
  --bgCircle-color-16: 255 255 255;
  aspect-ratio: 1/1;
  background: radial-gradient(circle, rgb(var(--bgCircle-color-16)), rgb(var(--bgCircle-color-16)/100%));
  border-radius: 50%;
  filter: blur(4px);
  position: absolute;
  z-index: 0;
  width: min(100%, 236px);
  top: 450px;
  left: calc(50% - 760px);
  animation-name: floatAnimation;
  animation-duration: 12s;
  animation-iteration-count: infinite;
}

.bgCircle-21 {
  --bgCircle-color-17: 51 159 239;
  aspect-ratio: 1/1;
  background: radial-gradient(circle, rgb(var(--bgCircle-color-17)), rgb(var(--bgCircle-color-17)/100%));
  border-radius: 50%;
  position: absolute;
  z-index: 1;
  width: min(100%, 74px);
  top: 620px;
  left: calc(50% - 760px);
  animation-name: floatAnimation;
  animation-duration: 8s;
  animation-iteration-count: infinite;
}

.bgCircle-22 {
  --bgCircle-color-14: 51 159 239;
  aspect-ratio: 1/1;
  background: radial-gradient(circle, rgb(var(--bgCircle-color-14)), rgb(var(--bgCircle-color-14)/80%));
  border-radius: 50%;
  filter: blur(18px);
  position: absolute;
  z-index: 0;
  width: min(100%, 200px);
  bottom: 90px;
  left: calc(50% + 500px);
  animation-name: floatAnimation;
  animation-duration: 12s;
  animation-iteration-count: infinite;
}

.bgCircle-23 {
  --bgCircle-color-15: 255 255 255;
  aspect-ratio: 1/1;
  background: radial-gradient(circle, rgb(var(--bgCircle-color-15)), rgb(var(--bgCircle-color-15)/100%));
  border-radius: 50%;
  position: absolute;
  z-index: 1;
  width: min(100%, 60px);
  bottom: 120px;
  left: calc(50% + 650px);
  animation-name: floatAnimation;
  animation-duration: 8s;
  animation-iteration-count: infinite;
}

.bgCircle-24 {
  --bgCircle-color-14: 51 159 239;
  aspect-ratio: 1/1;
  background: radial-gradient(circle, rgb(var(--bgCircle-color-14)), rgb(var(--bgCircle-color-14)/80%));
  border-radius: 50%;
  filter: blur(18px);
  position: absolute;
  z-index: 0;
  width: 24vw;
  bottom: 208vw;
  left: -6.9333333333vw;
  animation-name: floatAnimation;
  animation-duration: 12s;
  animation-iteration-count: infinite;
}

.bgCircle-25 {
  --bgCircle-color-15: 255 255 255;
  aspect-ratio: 1/1;
  background: radial-gradient(circle, rgb(var(--bgCircle-color-15)), rgb(var(--bgCircle-color-15)/100%));
  border-radius: 50%;
  position: absolute;
  z-index: 1;
  width: 9.6vw;
  bottom: 229.3333333333vw;
  left: -5.3333333333vw;
  animation-name: floatAnimation;
  animation-duration: 8s;
  animation-iteration-count: infinite;
}

.bgCircle-26 {
  --bgCircle-color-16: 255 255 255;
  aspect-ratio: 1/1;
  background: radial-gradient(circle, rgb(var(--bgCircle-color-16)), rgb(var(--bgCircle-color-16)/100%));
  border-radius: 50%;
  filter: blur(4px);
  position: absolute;
  z-index: -1;
  width: 26.6666666667vw;
  bottom: 12vw;
  left: calc(50% + 38.6666666667vw);
  animation-name: floatAnimation;
  animation-duration: 12s;
  animation-iteration-count: infinite;
}

/*---------------------------------------------
fv
---------------------------------------------*/
.fv .fv-title {
  position: relative;
  padding: 45px 0 0;
}
@media screen and (min-width: 768px) {
  .fv h2 {
    position: absolute;
    left: 50%;
    translate: -50% 0;
    bottom: min(10.15625vw, 130px);
  }
}
.fv h2 img {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .fv h2 img {
    width: min(87.1875vw, 1116px);
  }
}
@media screen and (max-width: 767px) {
  .fv .btn-cta {
    margin: 10vw auto 0;
  }
}
@media screen and (min-width: 768px) {
  .fv .btn-cta {
    position: absolute;
    left: 50%;
    translate: -50% 0;
    bottom: min(6.640625vw, 85px);
  }
}

/*---------------------------------------------
message
---------------------------------------------*/
#message {
  position: relative;
  top: -50px;
}
@media screen and (max-width: 767px) {
  #message {
    top: -4vw;
  }
}

.message {
  position: relative;
  padding-top: 13.3333333333vw;
}
@media screen and (min-width: 768px) {
  .message {
    padding-top: min(3.515625vw, 45px);
  }
}
.message .content-block {
  padding: 9.3333333333vw 3.3333333333vw 13.3333333333vw;
}
@media screen and (min-width: 768px) {
  .message .content-block {
    padding: min(6.640625vw, 85px) min(4.6875vw, 60px) min(6.25vw, 80px) min(6.640625vw, 85px);
  }
}
@media screen and (min-width: 768px) {
  .message .content-block .l-box {
    display: flex;
    justify-content: space-between;
  }
}
@media screen and (min-width: 768px) {
  .message .content-block .l-box .title-box {
    width: 40%;
  }
}
.message .content-block .l-box .title-box h2 {
  margin-bottom: 35px;
}
@media screen and (max-width: 767px) {
  .message .content-block .l-box .title-box h2 {
    margin-bottom: 4vw;
  }
}
@media screen and (max-width: 767px) {
  .message .content-block .l-box .title-box h2 img {
    width: 46.2666666667vw;
  }
}
.message .content-block .l-box .title-box .copy {
  font-weight: 700;
  font-size: 6.6666666667vw;
  line-height: 1.368;
  margin-bottom: 50px;
}
@media screen and (min-width: 768px) {
  .message .content-block .l-box .title-box .copy {
    font-size: min(2.96875vw, 38px);
  }
}
@media screen and (max-width: 767px) {
  .message .content-block .l-box .title-box .copy {
    margin-bottom: 10px;
  }
}
.message .content-block .l-box .illust {
  padding-left: 32px;
}
@media screen and (max-width: 767px) {
  .message .content-block .l-box .illust {
    padding-left: 0;
    width: 50.9333333333vw;
    margin-inline: auto;
    margin-bottom: 6.6666666667vw;
  }
  .message .content-block .l-box .illust img {
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .message .content-block .l-box .desc-box {
    width: 59%;
  }
}
.message .content-block .l-box .desc-box p {
  font-size: 3.4666666667vw;
  line-height: 2.375;
}
@media screen and (min-width: 768px) {
  .message .content-block .l-box .desc-box p {
    font-size: min(1.25vw, 16px);
  }
}
@media screen and (max-width: 767px) {
  .message .content-block .l-box .desc-box p {
    line-height: 1.76;
  }
}
.message .content-block .btn-cta {
  margin: 35px auto 0;
}
@media screen and (max-width: 767px) {
  .message .content-block .btn-cta {
    margin-top: 10.6666666667vw;
  }
}

/*---------------------------------------------
key-speakers
---------------------------------------------*/
.key-speakers {
  position: relative;
  padding: 80px 0 100px;
}
.key-speakers h2 {
  text-align: center;
  margin-bottom: 30px;
}
@media screen and (max-width: 767px) {
  .key-speakers h2 img {
    width: 46.1333333333vw;
  }
}
.key-speakers .key-speakers_cards {
  display: flex;
  justify-content: center;
  gap: 18px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .key-speakers .key-speakers_cards {
    flex-direction: column;
    gap: 10.6666666667vw;
  }
}
.key-speakers .key-speakers_card img {
  width: 295px;
}
@media screen and (max-width: 767px) {
  .key-speakers .key-speakers_card img {
    width: 66vw;
  }
}
.key-speakers .key-speakers_card p {
  font-size: 3.4666666667vw;
  line-height: 1.3;
}
@media screen and (min-width: 768px) {
  .key-speakers .key-speakers_card p {
    font-size: min(1.09375vw, 14px);
  }
}
.key-speakers .key-speakers_card .key-speakers_name {
  font-size: 5.0666666667vw;
  font-weight: 600;
  margin-top: -15px;
  margin-bottom: 15px;
}
@media screen and (min-width: 768px) {
  .key-speakers .key-speakers_card .key-speakers_name {
    font-size: min(1.5625vw, 20px);
  }
}
@media screen and (max-width: 767px) {
  .key-speakers .key-speakers_card .key-speakers_name {
    margin-top: 2vw;
    margin-bottom: 2vw;
  }
}
.key-speakers .key-speakers_card .key-speakers_name strong {
  font-size: 6.1333333333vw;
  font-weight: 600;
}
@media screen and (min-width: 768px) {
  .key-speakers .key-speakers_card .key-speakers_name strong {
    font-size: min(1.875vw, 24px);
  }
}

/*---------------------------------------------
timetable
---------------------------------------------*/
.timetable {
  padding: 130px 74px 80px;
}
@media screen and (max-width: 767px) {
  .timetable {
    padding: 16vw 0 18.6666666667vw;
  }
}
.timetable h2 {
  margin-bottom: 75px;
}
@media screen and (max-width: 767px) {
  .timetable h2 {
    margin-bottom: 10.6666666667vw;
  }
  .timetable h2 img {
    width: 57.3333333333vw;
  }
}
.timetable .timetable_items {
  position: relative;
}
.timetable .timetable_items .timetable_item {
  position: relative;
}
.timetable .timetable_items .timetable_item + .timetable_item {
  padding-top: 95px;
}
.timetable .timetable_items .timetable_item + .timetable_item:after {
  display: block;
  content: "";
  width: 6px;
  height: 96px;
  background-image: url(../img/line-dotted.svg);
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: contain;
  position: absolute;
  top: 2px;
  left: 64px;
}
@media screen and (max-width: 767px) {
  .timetable .timetable_items .timetable_item + .timetable_item {
    padding-top: 11.3333333333vw;
  }
  .timetable .timetable_items .timetable_item + .timetable_item:after {
    width: 0.8vw;
    height: 14.1333333333vw;
    top: -0.2666666667vw;
    left: 5.2vw;
  }
}
@media screen and (max-width: 767px) {
  .timetable .timetable_items .timetable_item.timetable_item-01 h3 img {
    width: 35.4666666667vw;
  }
}
@media screen and (max-width: 767px) {
  .timetable .timetable_items .timetable_item.timetable_item-02 h3 img {
    width: 68.2666666667vw;
  }
}
@media screen and (max-width: 767px) {
  .timetable .timetable_items .timetable_item.timetable_item-03 h3 img {
    width: 33.0666666667vw;
  }
}
@media screen and (max-width: 767px) {
  .timetable .timetable_items .timetable_item.timetable_item-04 h3 img {
    width: 37.0666666667vw;
  }
}
@media screen and (max-width: 767px) {
  .timetable .timetable_items .timetable_item.timetable_item-05 h3 img {
    width: 34.4vw;
  }
}
@media screen and (max-width: 767px) {
  .timetable .timetable_items .timetable_item.timetable_item-06 h3 img {
    width: 40.1333333333vw;
  }
}
.timetable .timetable_items .illust {
  position: absolute;
  top: 0;
  right: 1.44%;
  translate: 0 -60.8%;
}
@media screen and (max-width: 767px) {
  .timetable .timetable_items .illust {
    translate: 0 -52%;
  }
  .timetable .timetable_items .illust img {
    width: 35.2vw;
  }
}
.timetable .timetable_items h3 {
  margin-bottom: 20px;
  margin-left: 57px;
  padding-left: 35px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .timetable .timetable_items h3 {
    margin-left: 4.2666666667vw;
    padding-left: 6vw;
  }
}
.timetable .timetable_items h3:after {
  display: block;
  content: "";
  width: 20px;
  height: 20px;
  background-color: #0288eb;
  border-radius: 100%;
  position: absolute;
  top: 0;
  left: 0;
  margin-top: 8px;
}
@media screen and (max-width: 767px) {
  .timetable .timetable_items h3:after {
    width: 2.6666666667vw;
    height: 2.6666666667vw;
  }
}
.timetable .timetable_cards {
  position: relative;
  z-index: 1;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .timetable .timetable_cards {
    border: solid 3px #0087eb;
    background-color: #f2f2f2;
    border-radius: 30px;
  }
}
.timetable .timetable_cards .timetable_card {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .timetable .timetable_cards .timetable_card {
    border: solid 3px #0087eb;
    border-radius: 4vw;
    overflow: hidden;
  }
  .timetable .timetable_cards .timetable_card + .timetable_card {
    margin-top: 2.6666666667vw;
  }
}
@media screen and (min-width: 768px) {
  .timetable .timetable_cards .timetable_card {
    display: flex;
  }
  .timetable .timetable_cards .timetable_card + .timetable_card .timetable_time {
    border-top: solid 3px #f2f2f2;
  }
  .timetable .timetable_cards .timetable_card + .timetable_card .timetable_content {
    border-top: solid 3px #0087eb;
  }
}
.timetable .timetable_cards .timetable_time {
  background-color: #0288eb;
  color: #fff;
  font-size: 6.1333333333vw;
  font-weight: 500;
  line-height: 1.3;
}
@media screen and (min-width: 768px) {
  .timetable .timetable_cards .timetable_time {
    font-size: min(2.03125vw, 26px);
  }
}
@media screen and (max-width: 767px) {
  .timetable .timetable_cards .timetable_time {
    padding: 2.6666666667vw 0;
    text-align: center;
  }
}
@media screen and (min-width: 768px) {
  .timetable .timetable_cards .timetable_time {
    padding: 15px 0;
    width: 13.786%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-content: center;
    text-align: center;
  }
}
.timetable .timetable_cards .timetable_content {
  flex: 1;
  padding: 45px 15px 45px 35px;
}
@media screen and (max-width: 767px) {
  .timetable .timetable_cards .timetable_content {
    padding: 3.3333333333vw 3.3333333333vw 4.6666666667vw;
    background-color: #f2f2f2;
  }
}
.timetable .timetable_cards .timetable_title {
  font-size: 4.2666666667vw;
  font-weight: 600;
  color: #0087eb;
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  .timetable .timetable_cards .timetable_title {
    font-size: min(2.03125vw, 26px);
  }
}
.timetable .timetable_cards .timetable_title + p {
  margin-top: 1em;
}
.timetable .timetable_cards .note {
  display: flex;
  margin-top: 50px;
  padding-top: 35px;
  font-size: 2.6666666667vw;
}
@media screen and (min-width: 768px) {
  .timetable .timetable_cards .note {
    font-size: min(1.09375vw, 14px);
  }
}
.timetable .timetable_cards .note .note-tn {
  width: 120px;
  margin-right: 15px;
}
@media screen and (max-width: 767px) {
  .timetable .timetable_cards .note .note-tn {
    width: 16vw;
    margin-right: 1.3333333333vw;
  }
}
.timetable .timetable_cards .note .note-text {
  flex: 1;
}
.timetable .timetable_cards .note .note-title {
  font-size: 3.4666666667vw;
  margin-bottom: 0.5em;
}
@media screen and (min-width: 768px) {
  .timetable .timetable_cards .note .note-title {
    font-size: min(1.40625vw, 18px);
  }
}
.timetable .timetable_cards .note .note-more {
  display: flex;
  margin-top: 1em;
}
@media screen and (max-width: 767px) {
  .timetable .timetable_cards .note .note-more {
    flex-direction: column;
  }
}
@media screen and (max-width: 767px) {
  .timetable .timetable_cards .btn-radio {
    margin-left: auto;
    margin-top: 10px;
  }
}
@media screen and (min-width: 768px) {
  .timetable .timetable_cards .btn-radio {
    margin-left: 12px;
  }
}
.timetable .speakers {
  display: flex;
  flex-wrap: wrap;
  gap: 25px 0;
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .timetable .speakers {
    gap: 2.4vw 0;
    margin-top: 7.3333333333vw;
  }
}
.timetable .speakers .speaker {
  width: 33.33%;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .timetable .speakers .speaker {
    width: 50%;
  }
}
.timetable .speakers .speaker.speaker-wide {
  width: 100%;
}
.timetable .speakers .speaker .speaker_photo {
  width: 94px;
  margin-right: 8px;
}
@media screen and (max-width: 767px) {
  .timetable .speakers .speaker .speaker_photo {
    width: 15.2vw;
    margin-right: 1.6vw;
  }
}
.timetable .speakers .speaker .speaker_photo img {
  width: 100%;
}
.timetable .speakers .speaker .speaker_text {
  flex: 1;
  padding-right: 5px;
}
.timetable .speakers .speaker .speaker_text p {
  font-size: 2.4vw;
  line-height: 1.4;
}
@media screen and (min-width: 768px) {
  .timetable .speakers .speaker .speaker_text p {
    font-size: min(1.09375vw, 14px);
  }
}
.timetable .speakers .speaker .speaker_text p.speaker_name {
  font-size: 3.2vw;
  font-weight: 600;
  margin-bottom: 0.3em;
}
@media screen and (min-width: 768px) {
  .timetable .speakers .speaker .speaker_text p.speaker_name {
    font-size: min(1.5625vw, 20px);
  }
}

/*---------------------------------------------
outline
---------------------------------------------*/
.outline {
  position: relative;
  padding: 130px 0 0;
}
@media screen and (max-width: 767px) {
  .outline {
    padding: 17.3333333333vw 0 0;
  }
}
.outline h2 {
  margin: 0 0 25px;
}
@media screen and (max-width: 767px) {
  .outline h2 {
    margin: 0 0 1.3333333333vw;
  }
  .outline h2 img {
    width: 42.2666666667vw;
  }
}
.outline .content-block {
  position: relative;
  z-index: 5;
  padding: 70px 60px 50px 65px;
}
@media screen and (max-width: 767px) {
  .outline .content-block {
    padding: 8vw 3.3333333333vw 6vw;
  }
}
@media screen and (min-width: 768px) {
  .outline .outline_items {
    padding-left: 55px;
  }
}
.outline .outline_items .outline_item {
  padding: 15px 0;
  display: flex;
}
@media screen and (max-width: 767px) {
  .outline .outline_items .outline_item {
    flex-direction: column;
  }
}
.outline .outline_items .outline_item .outline_title {
  font-size: 3.7333333333vw;
  color: #0087eb;
  line-height: 1.3;
  margin-bottom: 0.2em;
}
@media screen and (min-width: 768px) {
  .outline .outline_items .outline_item .outline_title {
    font-size: min(1.40625vw, 18px);
  }
}
@media screen and (min-width: 768px) {
  .outline .outline_items .outline_item .outline_title {
    margin-bottom: 0;
    width: 170px;
    margin-right: 10px;
  }
}
.outline .outline_items .outline_item .outline_content {
  flex: 1;
  font-size: 3.2vw;
}
@media screen and (min-width: 768px) {
  .outline .outline_items .outline_item .outline_content {
    font-size: min(1.25vw, 16px);
  }
}
.outline .outline_items .outline_item .outline_content a {
  text-decoration: underline;
  text-underline-offset: 6px;
}
@media screen and (max-width: 767px) {
  .outline .outline_items .outline_item .outline_content .notice {
    margin-top: 1em;
  }
}
.outline .outline_items .outline_item .outline_content .notice li {
  padding-left: 1em;
  text-indent: -1em;
  line-height: 1.3;
  font-size: 2.6666666667vw;
}
@media screen and (min-width: 768px) {
  .outline .outline_items .outline_item .outline_content .notice li {
    font-size: min(1.09375vw, 14px);
  }
}
.outline .outline_items .outline_item .outline_content .notice li + li {
  margin-top: 1em;
}

/*---------------------------------------------
access
---------------------------------------------*/
.access {
  position: relative;
  padding: 100px 0;
}
@media screen and (max-width: 767px) {
  .access {
    padding: 6.6666666667vw 0 17.3333333333vw;
  }
}
.access h2 {
  margin-bottom: 35px;
}
@media screen and (max-width: 767px) {
  .access h2 {
    margin-bottom: 4vw;
  }
  .access h2 img {
    width: 39.0666666667vw;
  }
}
.access .content-block {
  position: relative;
  z-index: 5;
  padding: 70px 60px 75px 65px;
}
@media screen and (max-width: 767px) {
  .access .content-block {
    padding: 8vw 3.3333333333vw;
  }
}
.access .btn-cta {
  margin: 70px auto 0;
}
@media screen and (max-width: 767px) {
  .access .btn-cta {
    margin: 8.6666666667vw auto 0;
  }
}
.access .l-box {
  display: flex;
}
@media screen and (max-width: 767px) {
  .access .l-box {
    flex-direction: column-reverse;
  }
}
.access .access_map {
  width: 43%;
  margin-right: 4%;
}
@media screen and (max-width: 767px) {
  .access .access_map {
    width: 100%;
    margin-right: 0;
  }
}
.access .access_content {
  flex: 1;
}
.access .access_content .access_category {
  padding: 12px 0;
  line-height: 1.875;
}
@media screen and (min-width: 768px) {
  .access .access_content .access_category:first-child {
    padding-top: 0;
  }
  .access .access_content .access_category:last-child {
    padding-bottom: 0;
  }
}

/*---------------------------------------------
faq
---------------------------------------------*/
.faq {
  padding: 80px 0 90px;
}
@media screen and (max-width: 767px) {
  .faq {
    padding: 13.3333333333vw 0 16vw;
  }
}
.faq h2 {
  margin: 0 0 45px;
}
@media screen and (max-width: 767px) {
  .faq h2 {
    margin: 0 0 6vw;
  }
  .faq h2 img {
    width: 19.4666666667vw;
  }
}
.faq .faq_items .faq_item {
  background-color: #f2f2f2;
  border-radius: 20px;
  padding: 15px 60px;
}
@media screen and (max-width: 767px) {
  .faq .faq_items .faq_item {
    border-radius: 2.6666666667vw;
    padding: 0.6666666667vw 4vw 2.6666666667vw;
  }
}
.faq .faq_items .faq_item + .faq_item {
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .faq .faq_items .faq_item + .faq_item {
    margin-top: 5.3333333333vw;
  }
}
.faq .faq_items .faq_item .faq_q {
  display: flex;
  font-size: 4vw;
  font-weight: 600;
  color: #0087eb;
  align-items: center;
  padding: 20px 10px;
}
@media screen and (min-width: 768px) {
  .faq .faq_items .faq_item .faq_q {
    font-size: min(1.875vw, 24px);
  }
}
@media screen and (max-width: 767px) {
  .faq .faq_items .faq_item .faq_q {
    padding: 2.6666666667vw 0;
  }
}
.faq .faq_items .faq_item .faq_q img:first-child {
  margin-right: 12px;
}
@media screen and (max-width: 767px) {
  .faq .faq_items .faq_item .faq_q img:first-child {
    width: 4.8vw;
    margin-right: 1.6vw;
  }
}
.faq .faq_items .faq_item .faq_q p {
  flex: 1;
}
.faq .faq_items .faq_item .faq_a {
  padding: 20px 10px;
  line-height: 1.66;
}
@media screen and (max-width: 767px) {
  .faq .faq_items .faq_item .faq_a {
    padding: 2.6666666667vw 0;
  }
}
.faq .faq_items .faq_item .faq_a p {
  font-size: 3.2vw;
}
@media screen and (min-width: 768px) {
  .faq .faq_items .faq_item .faq_a p {
    font-size: min(1.40625vw, 18px);
  }
}