@charset "UTF-8";
/*--------------------------------
  Global
--------------------------------*/
:root {
  --color-orange: #f38f1e;
  --color-yellow: #fff000;
  --color-ocean: #63c5f1;
  --color-navy: #0098da;
  --color-red: #ff0000;
  --clip-waves: polygon(
    calc(100% - 0px) 2.94px,
    calc(100% - 0px) 2.94px,
    calc(100% - 59.94799px) 5.53532px,
    calc(100% - 113.10512px) 8.65936px,
    calc(100% - 161.89713px) 12.12324px,
    calc(100% - 208.74976px) 15.73808px,
    calc(100% - 256.08875px) 19.315px,
    calc(100% - 306.33984px) 22.66512px,
    calc(100% - 361.92877px) 25.59956px,
    calc(100% - 425.28128px) 27.92944px,
    calc(100% - 498.82311px) 29.46588px,
    calc(100% - 584.98px) 30.02px,
    calc(50% - -375.02px) 30.02px,
    calc(50% - -270.15312px) 29.17944px,
    calc(50% - -183.79216px) 26.89792px,
    calc(50% - -111.31064px) 23.53568px,
    calc(50% - -48.08208px) 19.45296px,
    calc(50% - 10.52px) 15.01px,
    calc(50% - 69.12208px) 10.56704px,
    calc(50% - 132.35064px) 6.48432px,
    calc(50% - 204.83216px) 3.12208px,
    calc(50% - 291.19312px) 0.84056px,
    calc(50% - 396.06px) 1.1100752050657e-30px,
    calc(50% - 396.06px) 0px,
    calc(50% - 479.51317px) 0.51821px,
    calc(50% - 551.11496px) 1.95928px,
    calc(50% - 613.05279px) 4.15287px,
    calc(50% - 667.51408px) 6.92864px,
    calc(50% - 716.68625px) 10.11625px,
    calc(50% - 762.75672px) 13.54536px,
    calc(50% - 807.91291px) 17.04563px,
    calc(50% - 854.34224px) 20.44672px,
    calc(50% - 904.23213px) 23.57829px,
    calc(50% - 959.77px) 26.27px,
    0px calc(50% - 0.0049999999999955px),
    0px calc(100% - 2.95px),
    0px calc(100% - 2.95px),
    59.94799px calc(100% - 5.54532px),
    113.10512px calc(100% - 8.6693599999999px),
    161.89713px calc(100% - 12.13324px),
    208.74976px calc(100% - 15.74808px),
    256.08875px calc(100% - 19.325px),
    306.33984px calc(100% - 22.67512px),
    361.92877px calc(100% - 25.60956px),
    425.28128px calc(100% - 27.93944px),
    498.82311px calc(100% - 29.47588px),
    584.98px calc(100% - 30.03px),
    calc(50% - 375.02px) calc(100% - 30.03px),
    calc(50% - 270.15312px) calc(100% - 29.18944px),
    calc(50% - 183.79216px) calc(100% - 26.90792px),
    calc(50% - 111.31064px) calc(100% - 23.54568px),
    calc(50% - 48.08208px) calc(100% - 19.46296px),
    calc(50% - -10.52px) calc(100% - 15.02px),
    calc(50% - -69.12208px) calc(100% - 10.57704px),
    calc(50% - -132.35064px) calc(100% - 6.49432px),
    calc(50% - -204.83216px) calc(100% - 3.13208px),
    calc(50% - -291.19312px) calc(100% - 0.85055999999997px),
    calc(50% - -396.06px) calc(100% - 0.0099999999999909px),
    calc(50% - -396.06px) calc(100% - 0.0099999999999625px),
    calc(50% - -479.51316px) calc(100% - 0.52820999999992px),
    calc(50% - -551.11488px) calc(100% - 1.9692799999999px),
    calc(50% - -613.05252px) calc(100% - 4.16287px),
    calc(50% - -667.51344px) calc(100% - 6.93864px),
    calc(50% - -716.685px) calc(100% - 10.12625px),
    calc(50% - -762.75456px) calc(100% - 13.55536px),
    calc(50% - -807.90948px) calc(100% - 17.05563px),
    calc(50% - -854.33712px) calc(100% - 20.45672px),
    calc(50% - -904.22484px) calc(100% - 23.58829px),
    calc(50% - -959.76px) calc(100% - 26.28px)
  );
  --font-noto-sans: "Noto Sans JP", sans-serif;
}
html {
  /* font-size: 0.78125vw; */
  font-size: 62.5%;
  overflow-x: hidden;
}
body {
  background-color: #fff;
  -webkit-text-size-adjust: 100%;
  font-family: var(--font-noto-sans);
  font-optical-sizing: auto;
  font-size: 1.8rem;
  font-weight: bold;
  line-height: 1.8;
  text-align: center;
}
main {
  overflow: hidden;
}
a {
  transition: opacity 0.3s;
}
img {
  width: 100%;
}
a:hover {
  opacity: 0.7;
}
.caution {
  color: var(--color-red);
}
main [id] {
  scroll-margin-top: 6rem;
}
@media screen and (min-width: 751px) {
  .sp {
    display: none;
  }
}
@media screen and (max-width: 1440px) {
  html {
    font-size: 1vw;
  }
}
@media screen and (max-width: 1024px) {
  html {
    font-size: 2.666666666666667vw;
  }
}
@media screen and (max-width: 750px) {
  :root {
    --clip-waves: polygon(
      calc(100% - 67px) 20px,
      calc(100% - 67px) 20px,
      calc(100% - 87.4648px) 19.44px,
      calc(100% - 104.2864px) 17.92px,
      calc(100% - 118.3756px) 15.68px,
      calc(100% - 130.6432px) 12.96px,
      calc(100% - 142px) 10px,
      calc(100% - 153.3568px) 7.04px,
      calc(100% - 165.6244px) 4.32px,
      calc(100% - 179.7136px) 2.08px,
      calc(100% - 196.5352px) 0.56px,
      calc(100% - 217px) 7.395570986447e-31px,
      calc(50% - 29.5px) 0px,
      calc(50% - 49.8528px) 0.56px,
      calc(50% - 66.3704px) 2.08px,
      calc(50% - 80.0116px) 4.32px,
      calc(50% - 91.7352px) 7.04px,
      calc(50% - 102.5px) 10px,
      calc(50% - 113.2648px) 12.96px,
      calc(50% - 124.9884px) 15.68px,
      calc(50% - 138.6296px) 17.92px,
      calc(50% - 155.1472px) 19.44px,
      calc(50% - 175.5px) 20px,
      12px 20px,
      10.740438px 20.00324px,
      9.493824px 20.01152px,
      8.260266px 20.02268px,
      7.039872px 20.03456px,
      5.83275px 20.045px,
      4.639008px 20.05184px,
      3.458754px 20.05292px,
      2.292096px 20.04608px,
      1.139142px 20.02916px,
      1.2569945084806e-15px 20px,
      0px calc(100% - 5px),
      0px calc(100% - 5px),
      4.176036px calc(100% - 4.1679359999999px),
      8.533728px calc(100% - 3.3863679999998px),
      13.106952px calc(100% - 2.664032px),
      17.929584px calc(100% - 2.009664px),
      23.0355px calc(100% - 1.432px),
      28.458576px calc(100% - 0.93977600000005px),
      34.232688px calc(100% - 0.54172800000003px),
      40.391712px calc(100% - 0.24659199999996px),
      46.969524px calc(100% - 0.063104000000067px),
      54px calc(100% - 1.1368683772162e-13px),
      54px calc(100% - 0px),
      74.4928px calc(100% - 0.55999999999995px),
      91.3904px calc(100% - 2.0799999999998px),
      105.5916px calc(100% - 4.3199999999999px),
      117.9952px calc(100% - 7.04px),
      129.5px calc(100% - 10px),
      141.0048px calc(100% - 12.96px),
      153.4084px calc(100% - 15.68px),
      167.6096px calc(100% - 17.92px),
      184.5072px calc(100% - 19.44px),
      205px calc(100% - 20px),
      calc(50% - -17.5px) calc(100% - 20px),
      calc(50% - -37.9928px) calc(100% - 19.44px),
      calc(50% - -54.8904px) calc(100% - 17.92px),
      calc(50% - -69.0916px) calc(100% - 15.68px),
      calc(50% - -81.4952px) calc(100% - 12.96px),
      calc(50% - -93px) calc(100% - 10px),
      calc(50% - -104.5048px) calc(100% - 7.04px),
      calc(50% - -116.9084px) calc(100% - 4.3200000000001px),
      calc(50% - -131.1096px) calc(100% - 2.0799999999999px),
      calc(50% - -148.0072px) calc(100% - 0.55999999999995px),
      calc(50% - -168.5px) calc(100% - 1.1368683772162e-13px),
      calc(100% - 19px) calc(100% - 0px),
      calc(100% - 16.895385px) calc(100% - 0.019116999999824px),
      calc(100% - 14.85392px) calc(100% - 0.072415999999748px),
      calc(100% - 12.868975px) calc(100% - 0.153819px),
      calc(100% - 10.93392px) calc(100% - 0.25724799999989px),
      calc(100% - 9.042125px) calc(100% - 0.37662499999999px),
      calc(100% - 7.18696px) calc(100% - 0.50587200000007px),
      calc(100% - 5.361795px) calc(100% - 0.63891100000001px),
      calc(100% - 3.5599999999999px) calc(100% - 0.76966399999992px),
      calc(100% - 1.774945px) calc(100% - 0.89205300000003px),
      calc(100% - 5.6843418860808e-14px) calc(100% - 1.0000000000001px),
      calc(100% - 0px) 12px,
      calc(100% - 0px) 12px,
      calc(100% - 4.981837px) 13.2446px,
      calc(100% - 10.174016px) 14.4448px,
      calc(100% - 15.640839px) 15.5802px,
      calc(100% - 21.446608px) 16.6304px,
      calc(100% - 27.655625px) 17.575px,
      calc(100% - 34.332192px) 18.3936px,
      calc(100% - 41.540611px) 19.0658px,
      calc(100% - 49.345184px) 19.5712px,
      calc(100% - 57.810213px) 19.8894px,
      calc(100% - 67px) 20px
    );
  }
  body {
    font-size: 1.4rem;
    letter-spacing: 0.04em;
  }
  img {
    width: 100%;
  }
  .pc {
    display: none;
  }
}
/*--------------------------------
  Components
--------------------------------*/
.campaign-block {
  padding: 4rem 0 6rem;
  position: relative;
  background: url(../images/campaign-bg.webp) repeat-x center center/ 143rem auto;
}
.campaign-block > * {
  display: block;
  max-width: 43rem;
  margin: 0 auto;
}
.campaign-block picture {
  margin-bottom: 3rem;
}
.campaign-block a {
  width: 40rem;
  position: absolute;
  left: 50%;
  top: 38.5rem;
  transform: translateX(-50%);
}
@media screen and (max-width: 750px) {
  .campaign-block {
    padding: 4rem 1.5rem;
    background-size: 66rem auto;
    background-repeat: repeat-y;
    background-position: top -4rem center;
  }
  .campaign-block a {
    width: 30rem;
    top: 30.5rem;
  }
}
/*--------------------------------
  Header
--------------------------------*/
.site-header {
  display: none;
}
@media screen and (max-width: 750px) {
  .site-header {
    display: flex;
    align-items: center;
    height: 6rem;
    width: 100%;
    background: #fff;
    position: fixed;
    left: 0;
    top: 0;
    z-index: 9;
  }
  .site-header > figure {
    flex: 1 1 auto;
  }
  .site-header > figure img {
    width: auto;
    height: 3.2rem;
  }
  .site-header .menu {
    position: relative;
    z-index: 2;
    right: 1.5rem;
    width: 3rem;
    height: 100%;
    position: relative;
  }
  .site-header .menu span {
    width: 3rem;
    height: 4px;
    margin: auto;
    background: var(--color-navy);
    position: absolute;
    inset: 0;
    transition: all 0.2s;
  }
  .site-header .menu span:before,
  .site-header .menu span:after {
    content: "";
    width: inherit;
    height: inherit;
    margin-inline: auto;
    background: var(--color-navy);
    border-radius: inherit;
    position: absolute;
    transform-origin: center center;
    transition: all 0.3s;
    left: 0;
  }
  .site-header .menu span:before {
    top: -1rem;
  }
  .site-header .menu span:after {
    bottom: -1rem;
  }
  .site-header .menu.is-activated {
    transform: rotate(180deg);
    transition: transform 0.5s;
  }
  .site-header .menu.is-activated span {
    background: none;
  }
  .site-header .menu.is-activated span:before {
    background: #fff;
    transform: rotate(45deg);
    top: 0;
  }
  .site-header .menu.is-activated span:after {
    background: #fff;
    transform: rotate(-45deg);
    bottom: 0;
  }
  .site-header .global-navi {
    width: 100%;
    padding: 10rem 2.4rem 2rem;
    min-height: 100vh;
    background: url(../images/logo-white.svg) var(--color-navy) no-repeat center 4rem / auto 3.2rem;
    position: fixed;
    top: 0;
    right: -102%;
    z-index: 1;
    transition: right 0.3s;
  }
  .site-header .global-navi.is-activated {
    right: 0;
  }
  .site-header .global-navi li a {
    color: #fff;
    font-size: 1.8rem;
    padding: 0.5rem 0;
    display: block;
  }
  .site-header .global-navi > a {
    display: block;
    margin-top: 3rem;
  }
}
/*--------------------------------
Mainvisual
--------------------------------*/
.area-mainvisual .intro {
  padding: 4rem 2rem;
}
.area-mainvisual .intro h2 {
  margin-bottom: 2rem;
}
.area-mainvisual .intro h2 img {
  width: 33.3rem;
}
@media screen and (max-width: 750px) {
  .area-mainvisual {
    padding-top: 6rem;
  }
}
/*--------------------------------
Experience
--------------------------------*/
.area-exp {
  padding: 8rem 1.5rem;
  clip-path: var(--clip-waves);
  background-color: var(--color-yellow);
}
.area-exp h2 img {
  width: 40rem;
}
.area-exp.fantasy {
  margin-top: -10rem;
  background-color: var(--color-ocean);
  position: relative;
}
.area-exp ul {
  display: grid;
  grid-template-columns: repeat(2, 21rem);
  margin: 2rem auto;
  gap: 0rem 1.5rem;
  max-width: 43rem;
}
.area-exp ul li:nth-of-type(even) {
  margin-top: 2rem;
}
.area-exp h3 {
  font-size: 2.6rem;
  letter-spacing: 0.15em;
}
.area-exp h3 + p {
  max-width: 43rem;
  margin: 2rem auto 8rem;
  font-size: 1.2rem;
  text-align: left;
}
.gsap-centering {
  position: relative;
}
.gsap-centering li img {
  position: relative;
}
.gsap-centering li:nth-of-type(1) img {
  top: 100%;
  left: 45%;
}
.gsap-centering li:nth-of-type(2) img {
  top: 95%;
  left: -45%;
}
.gsap-centering li:nth-of-type(3) img {
  left: 50%;
}
.gsap-centering li:nth-of-type(4) img {
  left: -50%;
}
.gsap-centering li:nth-of-type(5) img {
  top: -97%;
  left: 47%;
}
.gsap-centering li:nth-of-type(6) img {
  top: -100%;
  left: -47%;
}
@media screen and (max-width: 750px) {
  .area-exp ul {
    grid-template-columns: repeat(2, 16.5rem);
    margin: 2rem auto;
    gap: 0rem 1rem;
  }
  .area-exp h3 {
    font-size: 2rem;
  }
  .area-exp h3 + p {
    font-size: 1.2rem;
  }
}
/*--------------------------------
Voices
--------------------------------*/
.area-voices {
  max-width: 43rem;
  margin: 6rem auto;
}
.area-voices h2 {
  font-size: 3.5rem;
  color: var(--color-navy);
}
.area-voices ul {
  text-align: left;
  margin: 2rem auto;
}
.area-voices li {
  padding-left: 3.2rem;
  background: url(../images/ico-tick.svg) no-repeat left 0.5rem/ 2.8rem auto;
  line-height: 1.5;
}
.area-voices li + li {
  margin-top: 1rem;
}
@media screen and (max-width: 750px) {
  .area-voices {
    padding: 0 2rem;
  }
  .area-voices h2 {
    font-size: 2.6rem;
  }
  .area-voices li {
    padding-left: 2.4rem;
    background: url(../images/ico-tick.svg) no-repeat left 0.3rem/ 2rem auto;
  }
}
/*--------------------------------
Points
--------------------------------*/
.area-points {
  padding: 8rem 1.5rem;
  clip-path: var(--clip-waves);
  background-color: var(--color-yellow);
}
.area-points h2 img {
  width: 38.5rem;
}
.area-points h2 + p {
  margin-top: 1rem;
  font-size: 1.8rem;
}
.area-points ul {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  max-width: 43rem;
  margin: 2rem auto 0;
  gap: 1.2rem;
}
.area-points ul li img {
  width: 100%;
}
@media screen and (max-width: 750px) {
  .area-points h2 + p {
    font-size: 1.4rem;
  }
}
/*--------------------------------
Flow
--------------------------------*/

.area-flow {
  padding: 6rem 1.5rem;
}
.area-flow h2 img {
  max-width: 43rem;
}
.area-flow ul {
  max-width: 43rem;
  margin: 2rem auto;
}
.area-flow li + li {
  margin-top: 3rem;
}
.area-flow li h3 {
  line-height: 1.3;
  color: var(--color-navy);
  font-size: 2rem;
}
.area-flow li h3 strong {
  display: block;
  font-size: 2.8rem;
  line-height: 1;
}
.area-flow li p {
  font-size: 1.4rem;
}
.area-flow li figure {
  margin: 0.5rem auto 1rem;
  border-radius: 2.4rem;
  border: 4px solid var(--color-navy);
  overflow: hidden;
}
.area-flow > figure {
  max-width: 43rem;
  margin: auto;
}
@media screen and (max-width: 750px) {
  .area-flow li figure {
    margin: 0.5rem 0;
  }
  .area-flow li p {
    font-size: 1.3rem;
  }
}
/*--------------------------------
Access
--------------------------------*/
.area-access {
  max-width: 43rem;
  margin: 0 auto 5rem;
}
.area-access h2 {
  font-size: 3.6rem;
  color: var(--color-navy);
}
.area-access h2:nth-of-type(2) {
  padding: 4rem 0 0;
}
.area-access iframe {
  width: 100%;
}
.area-access img {
  width: 100%;
}
.area-access > a {
  display: block;
  margin: 1rem 0 5rem;
}
@media screen and (max-width: 750px) {
  .area-access {
    padding: 0 1.5rem;
  }
}
/*--------------------------------
FAQ
--------------------------------*/
.area-faq .inner {
  max-width: 43rem;
  margin: 5rem auto;
}
.area-faq h2 {
  font-size: 3.6rem;
  color: var(--color-navy);
}
.area-faq dl {
  text-align: left;
}
.area-faq dt {
  margin-block: 4rem 1.6rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid #333;
  font-size: 2.4rem;
  line-height: 1.3;
}
.area-faq dt:before {
  content: "Q.";
  color: var(--color-navy);
  font-size: 1.4em;
  font-weight: 400;
  padding-right: 2rem;
}
.area-faq dd {
  padding: 1.2rem;
  background: #eaf0f5;
  font-size: 2rem;
  color: #333;
}
.area-faq p strong {
  display: block;
  margin-top: 4rem;
  font-size: 1.2rem;
  text-align: left;
  font-feature-settings: "palt";
}

@media screen and (max-width: 750px) {
  .area-faq .inner {
    padding: 0 1.5rem;
  }
  .area-faq dt {
    font-size: 1.5rem;
    padding-bottom: 1rem;
  }
  .area-faq dt:before {
    padding-right: 1rem;
    font-size: 1.6em;
  }
  .area-faq dd {
    font-size: 1.5rem;
  }
}

/*--------------------------------
  Attention
--------------------------------*/
.area-attention {
  max-width: 43rem;
  margin: 2rem auto 5rem;
  font-size: 1rem;
  color: #333;
  font-weight: 500;
}
.area-attention > p {
  text-align: left;
}
.area-attention ul {
  min-width: 47rem;
  text-align: left;
}
.area-attention ul + ul {
  margin-top: 4rem;
}
.area-attention li {
  text-indent: -1em;
  margin-left: 1em;
}
@media screen and (max-width: 750px) {
  .area-attention {
    margin: 3rem 1.5rem;
    font-size: .8rem
  }
  .area-attention ul {
    min-width: auto;

  }
}
/*--------------------------------
  Footer
--------------------------------*/
.site-footer {
  height: 14.8rem;
  padding-top: 5rem;
  background: url(../images/footer-bg.svg) no-repeat top center/ 100% auto, linear-gradient(to bottom, transparent 10rem, var(--color-navy) 10rem);
  color: #fff;
  font-size: 1rem;
  font-weight: 400;
  overflow: hidden;
}
.site-footer img {
  width: 29rem;
  margin: 0 auto 2rem;
}

@media screen and (max-width: 750px) {
  .site-footer {
    background: url(../images/footer-bg.svg) no-repeat top center/ 100% auto, linear-gradient(to bottom, transparent 2rem, var(--color-navy) 2rem);
  }
}
