@charset "UTF-8";
/* CSS Document */

@keyframes blink {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

@-webkit-keyframes blink {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

@keyframes btnHover {
  0% {
    transform: translateX(-100%);
  }

  100% {
    transform: translateX(0%);
  }
}

@-webkit-keyframes btnHover {
  0% {
    -webkit-transform: translateX(-100%);
  }

  100% {
    -webkit-transform: translateX(0%);
  }
}

/********************************/
.clear_fix {
  zoom: 1;
}

.clear_fix:after {
  content: "";
  display: block;
  clear: both;
  font-size: 0;
  line-height: 0;
  visibility: hidden;
}

/********************************/
/*
リセット
/***********************/

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

html {
  line-height: 1;
}

ol,
ul {
  list-style: none;
}

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

caption,
th,
td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle;
}

q,
blockquote {
  quotes: none;
}

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

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

a > img,
nav > img,
li > img,
div > img {
  width: 100%;
  height: auto;
}

a img {
  border: none;
}

a {
  cursor: pointer;
  text-decoration: none;
  color: #000;
}

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

button {
  appearance: none;
  -webkit-appearance: none;
  border: none;
  padding: 0;
}

a {
  display: block;
}

@media screen and (min-width: 769px) {
  .box2 a:hover {
    animation: blink_animation 0.6s ease-out;
  }
}

@keyframes blink_animation {
  0% {
    opacity: 0;
  }
  10% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

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

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

  .pc_only {
    display: none !important;
  }
}

.clearfix:after {
  font-size: 0;
}

.clearfix {
  zoom: 1;
}

.clearfix:after {
  content: ".";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
}

body {
  position: absolute;
  background-color: #fff;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 16px;
  font-family: "ヒラギノ角ゴシック Pro W3", Hiragino Kaku Gothic Pro, "メイリオ",
    Meiryo, Osaka, "MS Pゴシック", MS PGothic, sans-serif;
  overflow: visible;
}

body * {
  box-sizing: border-box;
}

div,
h1,
h2,
h3,
h4,
h5,
ul,
ol,
li,
dl,
dt,
dd {
  position: relative;
}

h1,
h2,
h3,
h4,
h5 {
  margin: 0;
  padding: 0;
  line-height: 1;
}

p,
div,
span {
  margin: 0;
  padding: 0;
}

ul,
ol,
li,
dl,
dt,
dd {
  margin: 0;
  padding: 0;
  list-style: none;
  line-height: 1;
}

img,
a img {
  border: none;
  display: inline-block;
}

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

h1,
h2,
.renner {
  font-family: "ヒラギノ角ゴシックW6", "Hiragino Sans", sans-serif;
  font-weight: 600;
}

.lato {
  font-family: "Lato", sans-serif;
}

.wrapper {
  position: relative;
  width: 100%;
  height: auto;
}

@media screen and (max-width: 768px) {
  .wrapper {
    min-width: 100%;
    overflow: hidden;
  }
}

.sp {
  display: none !important;
}

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

  .sp {
    display: block !important;
  }
}

@keyframes blink {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

@-webkit-keyframes blink {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

@keyframes btnHover {
  0% {
    transform: translateX(-100%);
  }

  100% {
    transform: translateX(0%);
  }
}

@-webkit-keyframes btnHover {
  0% {
    -webkit-transform: translateX(-100%);
  }

  100% {
    -webkit-transform: translateX(0%);
  }
}

/********************************/
.clear_fix {
  zoom: 1;
}

.clear_fix:after {
  content: "";
  display: block;
  clear: both;
  font-size: 0;
  line-height: 0;
  visibility: hidden;
}

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

body {
  background-image: url(../img/back.png);
  background-size: 5.625rem;
  background-position: top center;
  padding: 0;
  margin: 0;
}

.main{
  background-color: #fff;
}

@media screen and (min-width: 1200px) {
  html,
  body {
    font-size: 16px;
  }
}

@media screen and (max-width: 1199px) {
  html,
  body {
    font-size: 1.33vw;
  }
}

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

body.noscroll {
  height: 100%;
  overflow: hidden;
}

.box img {
  pointer-events: none;
  margin: 0;
}

.main{
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
}

.box1 img {
  display: block;
}

.box1__place-box {
  width: 100%;
  height: 2.775em;
  padding-top: 0.6em;
}

.box1__place {
  margin: 0 auto;
  width: 25.25em;
}
.box2 {
  line-height: 0;
}
.box2__content1{
  position: relative;
  margin-top: -2.9%;
}
.box2__content1 .btn{
  position: absolute;
  width: 50%;
  bottom: 8%;
  left: 50%;
  -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}


.box2__content2{
  margin-top: -2.3%;
}
.box2__content3{
  margin-top: -1.6%;
}

/* ----- box4のcss ----- */

.box5 {
  margin: 0 auto;
}

.box5-1 {
  margin: 0 auto 3.7em;
  padding-top: 2em;
}

.box5__title-sub {
  text-align: center;
  font-size: 2em;
  font-weight: bold;
  border: 0.15em solid #e61873;
  border-bottom: none;
  border-radius: 0.4em 0.4em 0em 0em;
  -webkit-transition: border 0.3s ease-out, color 0.3s ease-out;
  transition: border 0.3s ease-out, color 0.3s ease-out;
  color: #e61873;
  line-height: 1.4;
  padding: 0.4em 0;
}

.box5__title-box {
  padding: 0.7em 0.6em 0.92em;
  background-color: #e61673;
  margin: 0 auto;
  border-radius: 0.5em 0.5em 0.5em 0.5em;
  -webkit-transition: background-color 0.3s ease-out;
  transition: background-color 0.3s ease-out;
  width: auto;
  display: inline-block;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}

.box5__title-box {
  border-radius: 0;
  display: block;
  text-align: center;
  padding: 0.92em 0.6em 0.92em;
}

.box5__title-box:after {
  content: "";
  width: 2.129em;
  height: 2.129em;
  margin-right: 0.3em;
  display: inline-block;
  background-image: url(../img/box5-link-arrow2.png);
  background-repeat: no-repeat;
  background-size: cover;
  transform: translateY(0.24em) rotate(0deg);
  -webkit-transform: translateY(0.24em) rotate(0deg);
}

.box5__title-box a {
  text-decoration: none;
  color: #fff;
}

@media screen and (min-width: 769px) {
  .box5:hover .box5__title-sub {
    border: 0.15em solid #f29600;
    border-bottom: none;
    color: #f29600;
  }
}

.box6-flow-item__text .link-btn {
  margin-right: 0.2em;
  padding: 0.32em 0.3em;
  border-radius: 4px;
  background-color: #e61673;
  line-height: 2;
  color: #fff;
}

.box6-flow-item__text .link-btn:after {
  content: "";
  width: 1.07em;
  height: 1.07em;
  margin-left: 0.2em;
  background-image: url(../img/box5-link-arrow.png);
  background-repeat: no-repeat;
  background-size: 100% auto;
  display: inline-block;
  transform: translateY(0.13em);
  -webkit-transform: translateY(0.13em);
}

.box5__title {
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  font-size: 2.4em;
  font-weight: bold;
  line-height: 1;
  font-feature-settings: "palt";
  color: #fff;
  text-align: center;
  display: inline-block;
}

.box5__title-box .arrow {
  width: 1.07em;
  height: 1.07em;
  margin-left: 0.2em;
  display: inline-block;
  position: relative;
  top: 0.13em;
  vertical-align: initial;
}

.box5__title-box .arrow img {
  display: block;
}

.box5__title img.rev {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  -webkit-transition: opacity 0.3s ease-out;
  transition: opacity 0.3s ease-out;
  opacity: 0;
}

.box5__content-box {
  padding-top: 1em;
}

.box5__lead-text {
  margin-bottom: 0.8em;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  font-size: 2em;
  font-weight: bold;
  text-align: center;
  color: #595757;
}

.box5__map-box {
  margin: 0 12.93em;
  position: relative;
}

.box5__map-box a {
  position: absolute;
}

.box5__map-box img {
  display: block;
}

[class*="box5-map-box__rounds"] {
  width: 3.22em;
}

.rounds__icon {
  padding-bottom: 0.19em;
}

.rounds__shadow {
  width: 77.32%;
  margin: 0 auto;
}

.box5-map-box__rounds01 {
  top: 49.63%;
  left: 30.07%;
}

.box5-map-box__text01 {
  width: 16.78%;
  top: 49.27%;
  left: 13.13%;
}

.box5-map-box__rounds02 {
  top: 26.86%;
  left: 88.27%;
}

.box5-map-box__text02 {
  width: 16.79%;
  top: 22.05%;
  left: 85.61%;
}

.box5-map-box__rounds03 {
  top: 30.88%;
  left: 75.21%;
}

.box5-map-box__text03 {
  width: 16.69%;
  top: 32.25%;
  left: 58.28%;
}

.box5-map-box__rounds04 {
  top: 18.99%;
  left: 27.52%;
}

.box5-map-box__text04 {
  width: 19.51%;
  top: 14.03%;
  left: 18.75%;
}

.box5-map-box__rounds05 {
  top: 31.59%;
  left: 82.34%;
}

.box5-map-box__text05 {
  width: 19.61%;
  top: 40.82%;
  left: 78.51%;
}

.box5-map-box__rounds06 {
  top: 86.55%;
  left: 76.05%;
}

.box5-map-box__text06 {
  width: 16.79%;
  top: 89.51%;
  left: 60.07%;
}

.box5-map-box__rounds07 {
  top: 68.44%;
  left: 14.3%;
}

.box5-map-box__text07 {
  width: 16.79%;
  top: 63.6%;
  left: 5.48%;
}

.box5-map-box__rounds08 {
  top: 13.93%;
  left: 46.43%;
}

.box5-map-box__text08 {
  width: 22.22%;
  top: 9.36%;
  left: 37.94%;
}

.box5-map-box__rounds09 {
  top: 18.23%;
  left: 76.7%;
}

.box5-map-box__text09 {
  width: 25.02%;
  top: 13.49%;
  left: 71.41%;
}

.box5-map-box__rounds10 {
  top: 21.48%;
  left: 70.58%;
}

.box5-map-box__text10 {
  width: 18.88%;
  top: 20.87%;
  left: 52.75%;
}

.box5-map-box__rounds11 {
  top: 58.2%;
  left: 67.97%;
}

.box5-map-box__text11 {
  width: 18.76%;
  top: 60.96%;
  left: 74.87%;
}

.box5-map-box__rounds12 {
  top: 68.27%;
  left: 34.65%;
}

.box5-map-box__text12 {
  width: 20.98%;
  top: 58.5%;
  left: 25.9%;
}

.box5-map-box__rounds13 {
  top: 8.79%;
  left: 62.57%;
}

.box5-map-box__text13 {
  width: 22.56%;
  top: 1.9%;
  left: 67.8%;
}

.box5-map-box__rounds14 {
  top: 70.28%;
  left: 48.2%;
}

.box5-map-box__text14 {
  width: 18.73%;
  top: 69.23%;
  left: 54.78%;
}

.box5-map-box__rounds15 {
  top: 43.82%;
  left: 55.69%;
}

.box5-map-box__text15 {
  width: 18.73%;
  top: 43.37%;
  left: 37.48%;
}

.box5-map-box__rounds16 {
  top: 28.82%;
  left: 42%;
}

.box5-map-box__text16 {
  width: 21.73%;
  top: 29.37%;
  left: 20%;
}

.box5__btn {
  width: 100%;
  margin-bottom: 0.625em;
  padding-left: 0.9em;
  border-radius: 2em;
  display: block;
  font-size: 0.95em;
  line-height: 1.6;
  color: #fff;
  font-weight: bold;
  background-color: #00a0e9;
}

.box6__title-box {
  padding: 0em 3.8em 3em;
}

.box6-flow-item {
  width: 43em;
  margin: 0 auto;
}

.box6-flow__number {
  position: absolute;
  width: 3em;
  left: -4.5em;
}

.box6-flow-item:not(:last-child) .box6-flow__text {
  margin-bottom: 2em;
}

.box6-flow__text p {
  font-size: 1.65em;
  font-weight: bold;
  line-height: 1.55;
  letter-spacing: -0.05em;
  /* font-feature-settings: "palt"; */
}
/* ---------------<span>---------------- */
.link-btn {
  background-color: #e61673;
  display: inline-block;
  padding: 0 0.5em;
  color: #fff;
  letter-spacing: 0.02em;
  border-radius: 0.5rem;
  position: relative;
  margin-right: 0.5rem;
}

.link-btn::after {
  content: "";
  display: inline-block;
  background-image: url(../img/box5-link-arrow.png);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  position: relative;
  top: 0.1em;
  width: 1.75rem;
  height: 1.75rem;
  margin-left: 0.5rem;
}
/* ----------------<span>--------------- */
.coming-btn {
  background-color: #ffc646;
  display: inline-block;
  padding: 0 0.5em;
  color: #fff;
  letter-spacing: 0.02em;
  border-radius: 0.5rem;
  position: relative;
  margin-right: 0.5rem;
}

.coming-btn::before {
  content: "";
  display: inline-block;
  background-image: url(../img/box6-flow-btn-icon.svg);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  position: relative;
  top: 0.15em;
  width: 2.25rem;
  height: 2rem;
  margin-right: 0.5rem;
}

.text-pink {
  color: #e61673;
  line-height: 1.43;
}

.box6-flow__icon1,
.box6-flow__icon2,
.box6-flow__icon3,
.box6-flow__icon4 {
  position: absolute;
  right: 0em;
  transform: translateX(50%);
}

.box6-flow__icon1 {
  width: 10.37em;
  top: -1em;
}
.box6-flow__icon2 {
  width: 10.37em;
  top: 1em;
}
.box6-flow__icon3 {
  width: 10.8em;
  top: -1em;
}
.box6-flow__icon4 {
  width: 11.25em;
  top: -5em;
}

.box6-flow__arrow {
  width: 3.125em;
  margin: 0 auto 1.5em;
}
.box6-flow-list {
  margin-bottom: 4rem;
}

/* .box6__note-area{
    margin-bottom: 3em;
    padding: 2em 10.4em 2.1em;
    background-color: #1d2088;
} */

.box6__note-area img {
  display: block;
}

.box6__note-text {
  font-size: 1.75em;
  line-height: 1.42;
  color: #fff;
  padding-left: 1em;
  text-indent: -1em;
}

footer {
  font-size: 1.1em;
  text-align: center;
  color: #4772b5;
}

.gotop {
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 3em;
}

.gotop__up {
  width: 4.8em;
  cursor: pointer;
  margin: 0 auto;
}

.footer_content {
  padding: 0.5em 0;
  width: 100%;
  margin: 0 auto;
  font-size: 1.5em;
  line-height: 1;
  background-color: #00a0cb;
  color: #fff;
}

.footer-small {
  font-size: 0.75rem;
}

@media screen and (min-width: 769px) {

  

  .box3__merit-list {
    width: 67.5em;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
  }

  .box3__merit-box {
    width: 23.61%;
  }

  .kerning-dot {
    margin-right: -0.45em;
  }

  .box5__btn-area {
    padding: 1.75em 3.07em 3em;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }

  .box5__btn {
    width: 24.32%;
  }
}

@media screen and (max-width: 768px) {
  .box1__place-box {
    height: 9.87vw;
    padding-top: 2.5vw;
  }

  .box1__place {
    width: 89.07vw;
  }

.box1__main-box {
  /* margin-top: -9.87vw; */
}

.box2__content1 .btn{
  width: 84%;
  bottom: 5%;
}



.box2__content1{
  margin-top: -6.2%;
}

.box2__content2{
  margin-top: -5%;
}
.box2__content3{
  margin-top: -1.7%;
}

  /* ----- box4のcss ----- */

  .box5 {
    width: 90%;
    margin-bottom: 0;
  }

  .box5-1 {
    margin: 0 auto 8vw;
  }

  .box5-2 {
    padding-top: 3vw;
  }

  .box5__title-box {
    margin-bottom: 4.5vw;
    padding: 2.9vw 0 2.7vw;
    width: 111%;
  }

  .box5__title {
    display: block;
    letter-spacing: 0.05em;
  }

  .box5__title-box:after {
    width: 8vw;
    height: 8vw;
    position: absolute;
    right: -2.5vw;
    top: 50%;
    -webkit-transform: translateY(-50%) rotate(0deg);
    transform: translateY(-50%) rotate(0deg);
    margin-right: 1.75em;
  }

  .box5__title-sub {
    font-size: 5.5vw;
    border: 1vw solid #e61873;
    border-bottom: none;
    line-height: 1.4;
    padding: 1.6vw 0;
  }

  .box5__title {
    font-size: 6vw;
    line-height: 1.2;
    margin-right: 1.5em;
  }

  .box5__title:after {
    width: 5.1vw;
    height: 5.1vw;
    margin-left: 1vw;
    transform: translateY(0.25vw);
    -webkit-transform: translateY(0.25vw);
  }

  .box5__lead-text {
    margin-bottom: 5vw;
    font-size: 4.5vw;
    line-height: 1.36;
  }

  .box5__map-box {
    margin: 0 5.3vw;
  }

  [class*="box5-map-box__rounds"] {
    width: 5.6vw;
  }

  .rounds__icon {
    padding-bottom: 0.306vw;
  }

  .box5__btn-area {
    width: 100%;
    margin: 0 auto;
    padding: 7.94vw 9.55% 8.5vw;
  }

  .box5__btn {
    padding-left: 3.9vw;
    margin-bottom: 1.78vw;
    font-size: 4vw;
  }

  .box5__btn:last-child {
    margin-bottom: 0;
  }

  .box6__title-box {
    padding: 0vw 5vw 5vw;
  }

  .box6-flow-item {
    width: auto;
    margin-left: 13.5vw;
  }
  .box6-flow__number {
    width: 6.666vw;
    left: -9vw;
    top: 0.5vw;
  }

  .box6-flow-item:not(:last-child) .box6-flow__text {
    margin-bottom: 5vw;
  }

  .box6-flow__text p {
    font-size: 3.6vw;
    line-height: 1.6;
    letter-spacing: -0.01em;
    font-feature-settings: "palt";
  }

  .link-btn {
    padding: 0 2vw;
    letter-spacing: 0.02em;
    border-radius: 1.066vw;
    margin-right: 1vw;
  }

  .link-btn::after {
    top: 0.1em;
    width: 3.466vw;
    height: 3.466vw;
    margin-left: 1vw;
  }

  .coming-btn {
    padding: 0 2vw;
    letter-spacing: 0.02em;
    border-radius: 1.066vw;
    margin-right: 1vw;
  }

  .coming-btn::before {
    top: 0.15em;
    width: 4.853vw;
    height: 4.32vw;
    margin-right: 0.5rem;
  }

  .text-pink {
    line-height: 1.6;
  }

  .box6-flow__icon1,
  .box6-flow__icon2,
  .box6-flow__icon3,
  .box6-flow__icon4 {
    position: absolute;
    right: 15vw;
  }

  .box6-flow__icon1 {
    width: 18.4vw;
    top: 6vw;
  }
  .box6-flow__icon2 {
    width: 18.4vw;
    top: 16.5vw;
  }
  .box6-flow__icon3 {
    width: 19vw;
    top: 12vw;
  }
  .box6-flow__icon4 {
    width: 20.13vw;
    top: 17vw;
  }

  .box6-flow__arrow {
    width: 6.666vw;
    margin: 0 auto 2.5vw;
    margin-left: 33.5vw;
  }

  .box6-content-box {
    margin-bottom: 6vw;
  }

  .box6-link-area {
    margin-bottom: 8vw;
  }

  .box6-note-box {
    padding: 4.106vw 4.133vw;
  }

  .box6-note-box p {
    font-size: 3.5vw;
    line-height: 1.45;
    letter-spacing: -0.02em;
  }

  /* .box6__note-area{
        padding: 4.8vw 5.3vw 4.8vw;
    } */

  .box6__note-text {
    font-size: 3.73vw;
    line-height: 1.42;
  }

  .gotop__up {
    width: 17.45%;
  }

  .footer-small {
    font-size: 2.666vw;
  }
}
