@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");
/* design size variable */
/* constance variable */
/* device width variable */
/* font responsive ratio */
/* spacer responsive ratio */
/* noto sans font weight */
/* general method */
/* linear */
/* easeSineIn */
/* easeSineOut */
/* easeSineInOut */
/* easeQuadIn */
/* easeQuadOut */
/* easeQuadInOut */
/* easeCubicIn */
/* easeCubicOut */
/* easeCubicInOut */
/* easeQuartIn */
/* easeQuartOut */
/* easeQuartInOut */
/* easeQuintIn */
/* easeQuintOut */
/* easeQuintInOut */
/* easeExpoIn */
/* easeExpoOut */
/* easeExpoInOut */
/* easeCircIn */
/* easeCircOut */
/* easeCircInOut */
/* easeBackIn */
/* easeBackOut */
/* easeBackInOut */
/* header */
#top_head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  padding: 40px 140px 40px;
  background: #fff;
}
@media only screen and (max-width: 1370px) {
  #top_head {
    padding: 40px 7.3206442167vw 40px;
  }
}
@media only screen and (max-width: 1250px) {
  #top_head {
    padding: 40px 4.7584187408vw 40px;
  }
}
@media only screen and (max-width: 940px) {
  #top_head {
    padding: 40px 3vw 40px;
  }
}
@media only screen and (max-width: 736px) {
  #top_head {
    align-items: center;
    padding: 7.2vw 5.3333333333vw;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    box-sizing: border-box;
    background: #fff;
    z-index: 999;
  }
}
#top_head .logo {
  width: 157px;
}
@media only screen and (max-width: 1250px) {
  #top_head .logo {
    width: 11.4934114202vw;
  }
}
@media only screen and (max-width: 940px) {
  #top_head .logo {
    width: 14vw;
  }
}
@media only screen and (max-width: 736px) {
  #top_head .logo {
    width: 24vw;
  }
}
#top_head .sns {
  display: flex;
  flex-wrap: wrap;
  margin-left: auto;
  margin-right: 0;
}
#top_head .sns li {
  width: 39px;
  margin-left: 15px;
}
@media only screen and (max-width: 1250px) {
  #top_head .sns li {
    width: 2.8550512445vw;
    margin-left: 1.0980966325vw;
  }
}
@media only screen and (max-width: 940px) {
  #top_head .sns li {
    width: 4vw;
  }
}
@media only screen and (max-width: 736px) {
  #top_head .sns li {
    width: 6.9333333333vw;
    margin-left: 2.5vw;
  }
}

#index_toyama {
  background: #fff;
  padding: 20px 0;
}
@media only screen and (max-width: 736px) {
  #index_toyama {
    padding: 8vw 0;
  }
}
#index_toyama .img {
  width: 200px;
  display: table;
  margin: 0 auto 20px;
}
@media only screen and (max-width: 736px) {
  #index_toyama .img {
    width: 44vw;
    margin-bottom: 4vw;
  }
}
#index_toyama .text {
  font-weight: 400;
  letter-spacing: 0;
  text-align: center;
  color: #000;
}
@media only screen and (max-width: 736px) {
  #index_toyama .text {
    font-size: 3.2vw;
  }
}
#index_toyama .text a {
  font-weight: 400;
  color: #000;
  display: inline-block;
}

#footer {
  padding: 35px 0 70px;
  background: #109649;
}
@media only screen and (max-width: 736px) {
  #footer {
    padding: 10vw 0;
  }
}
#footer .top_box {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
}
@media only screen and (max-width: 736px) {
  #footer .top_box {
    display: block;
  }
}
#footer .top_box .logo {
  width: 157px;
  margin-right: 25px;
}
@media only screen and (max-width: 768px) {
  #footer .top_box .logo {
    margin-right: 0;
    margin-bottom: 20px;
  }
}
@media only screen and (max-width: 736px) {
  #footer .top_box .logo {
    width: 32vw;
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 8vw;
  }
}
#footer .top_box .text_box {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
@media only screen and (max-width: 736px) {
  #footer .top_box .text_box {
    display: block;
    width: 84vw;
    margin: auto;
  }
}
#footer .top_box .text_box p {
  font-size: 11px;
  font-weight: 300;
  color: #fff;
}
@media only screen and (max-width: 736px) {
  #footer .top_box .text_box p {
    font-size: 3.2vw;
  }
}
@media only screen and (max-width: 736px) {
  #footer .top_box .text_box__left {
    text-align: center;
    border-bottom: solid 1px #fff;
    margin-bottom: 2vw;
    padding-bottom: 2vw;
  }
}
#footer .top_box .text_box__right {
  border-left: solid 1px #fff;
  margin-left: 13px;
  padding-left: 13px;
  color: #fff;
  line-height: 140%;
}
@media only screen and (max-width: 736px) {
  #footer .top_box .text_box__right {
    border-left: 0;
    margin-left: 0;
    padding-left: 0;
    line-height: 160%;
  }
}
#footer .copy {
  font-size: 11px;
  font-weight: 300;
  text-align: center;
  color: #fff;
}
@media only screen and (max-width: 736px) {
  #footer .copy {
    font-size: 2.9333333333vw;
  }
}

#nav, #nav_sp {
  margin-left: 50px;
}
@media only screen and (max-width: 1366px) {
  #nav, #nav_sp {
    margin-left: 2.196193265vw;
  }
}
#nav #mobile_head, #nav_sp #mobile_head {
  display: none;
}
@media only screen and (max-width: 736px) {
  #nav #mobile_head, #nav_sp #mobile_head {
    z-index: 999;
    position: fixed;
    margin: auto;
    transform: translateX(0px);
    transition: 0.5s ease-in-out;
    display: block;
    width: 10.6666666667vw;
    height: 10.6666666667vw;
    top: 21.3333333333vw;
    left: auto;
    right: 0;
    background: #109649;
  }
}
#nav #nav_toggle, #nav_sp #nav_toggle {
  display: none;
}
@media only screen and (max-width: 736px) {
  #nav #nav_toggle, #nav_sp #nav_toggle {
    width: 100%;
    height: 100%;
    position: relative;
    cursor: pointer;
    z-index: 101;
    transition: 0.5s ease-in-out;
    opacity: 1;
    display: block;
  }
}
@media only screen and (max-width: 736px) {
  #nav #nav_toggle div, #nav_sp #nav_toggle div {
    height: 2vw;
    width: 3.8666666667vw;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    left: 0;
    right: 0;
  }
}
#nav #nav_toggle span, #nav_sp #nav_toggle span {
  display: block;
  position: absolute;
  height: 2px;
  width: 100%;
  background: #fff;
  left: 0;
  transition: 0.35s ease-in-out;
}
#nav #nav_toggle span:nth-child(1), #nav_sp #nav_toggle span:nth-child(1) {
  top: 0;
}
#nav #nav_toggle span:nth-child(2), #nav_sp #nav_toggle span:nth-child(2) {
  bottom: 0;
}
#nav #nav_list, #nav_sp #nav_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}
@media only screen and (max-width: 736px) {
  #nav #nav_list, #nav_sp #nav_list {
    position: fixed;
    /* 開いてないときは画面外に配置 */
    top: 21.3333333333vw;
    background: #fff;
    border-bottom: solid 2px #109649;
    border-top: solid 2px #109649;
    bottom: 15px;
    transition: 0.5s ease-in-out;
    opacity: 0;
    right: 0;
    box-sizing: border-box;
    margin-right: 0;
    margin-top: 0;
    display: table;
    width: 100%;
    z-index: -1;
    padding: 5vw 0;
  }
}
#nav #nav_list li, #nav_sp #nav_list li {
  border-right: solid 1px #109649;
  margin-right: 15px;
  padding-right: 15px;
  line-height: 100%;
}
@media only screen and (max-width: 1040px) {
  #nav #nav_list li, #nav_sp #nav_list li {
    margin-right: 1.9230769231vw;
    padding-right: 1.9230769231vw;
  }
}
@media only screen and (max-width: 940px) {
  #nav #nav_list li, #nav_sp #nav_list li {
    margin-right: 1.2vw;
    padding-right: 1.2vw;
  }
}
@media only screen and (max-width: 736px) {
  #nav #nav_list li, #nav_sp #nav_list li {
    padding-right: 0;
    margin-right: auto;
    margin-left: auto;
    width: 52vw;
    border-right: none;
    border-bottom: solid 1px #000;
  }
}
#nav #nav_list li a, #nav_sp #nav_list li a {
  color: #109649;
  font-size: 19px;
  font-weight: 500;
  line-height: 100%;
  letter-spacing: 0.06em;
}
@media only screen and (max-width: 1170px) {
  #nav #nav_list li a, #nav_sp #nav_list li a {
    font-size: 1.3909224012vw;
  }
}
@media only screen and (max-width: 940px) {
  #nav #nav_list li a, #nav_sp #nav_list li a {
    font-size: 1.6vw;
  }
}
@media only screen and (max-width: 736px) {
  #nav #nav_list li a, #nav_sp #nav_list li a {
    color: #000;
    font-weight: 500;
    padding: 5vw 2vw 5vw 7vw;
    font-size: 4vw;
    position: relative;
  }
}
@media only screen and (max-width: 736px) {
  #nav #nav_list li a:before, #nav_sp #nav_list li a:before {
    position: absolute;
    content: "";
    left: 2vw;
    top: 0;
    bottom: 0;
    width: 0;
    height: 0;
    margin: auto;
    display: inline-block;
    border-left: 3vw solid #000;
    border-top: 2vw solid transparent;
    border-bottom: 2vw solid transparent;
  }
}
#nav #nav_list li:last-child, #nav_sp #nav_list li:last-child {
  border-right: none;
  padding-right: 0;
  margin-right: 0;
}
@media only screen and (max-width: 736px) {
  #nav #nav_list li:last-child, #nav_sp #nav_list li:last-child {
    border-bottom: none;
    margin-right: auto;
  }
}
#nav #nav_list li.contact a, #nav_sp #nav_list li.contact a {
  color: #109649;
}
@media only screen and (max-width: 736px) {
  #nav #nav_list li.contact a:before, #nav_sp #nav_list li.contact a:before {
    border-left: 3vw solid #109649;
  }
}
#nav #nav_list li.no_link a, #nav_sp #nav_list li.no_link a {
  pointer-events: none;
  opacity: 0.4;
}
@media only screen and (max-width: 736px) {
  #nav.open, #nav_sp.open {
    overflow-y: scroll;
    background: none;
  }
}
@media only screen and (max-width: 736px) {
  #nav.open #nav_toggle div, #nav_sp.open #nav_toggle div {
    height: 6vw;
  }
}
#nav.open #nav_toggle span:nth-child(1), #nav_sp.open #nav_toggle span:nth-child(1) {
  top: 11px;
  transform: rotate(315deg);
  width: 100%;
}
#nav.open #nav_toggle span:nth-child(2), #nav_sp.open #nav_toggle span:nth-child(2) {
  top: 11px;
  transform: rotate(-315deg);
}
@media only screen and (max-width: 736px) {
  #nav.open #nav_list, #nav_sp.open #nav_list {
    opacity: 1;
    z-index: 10;
  }
}

/**
 * Eric Meyer's Reset CSS v2.0 (http://meyerweb.com/eric/tools/css/reset/)
 * http://cssreset.com
 */
html, body, 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, sub, sup, tt, var,
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-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, main {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

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

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

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

.clearfix {
  display: inline-block;
}

/* Hides from IE Mac */
* html .clearfix {
  height: 1%;
}

.clearfix {
  display: block;
}

/* End Hack */
/**
EC-CUBE リセット
 */
body {
  background: none;
}

.ec-layoutRole {
  background: none;
}
.ec-layoutRole .ec-layoutRole__contents {
  max-width: none;
}

html {
  font-size: 100%;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
  width: 100%;
  color: #007cbd;
}
@media only screen and (max-width: 736px) {
  body {
    font-size: 3.7333333333vw;
  }
}

h2, h3, h4, h5, p, li, dt, dd, input, textarea, th, td, span {
  line-height: 170%;
  letter-spacing: 0.06em;
}

a {
  color: #109649;
  text-decoration: none;
  cursor: pointer;
  font-weight: 500;
  display: block;
  transition: 0.3s;
}
a:hover {
  opacity: 0.7;
  transition: 0.3s;
  cursor: pointer;
}

@media screen and (min-width: 768px), print {
  a[href^="tel:"] {
    color: black;
    text-decoration: none;
    display: inline-block;
    pointer-events: none;
  }
}
img {
  vertical-align: bottom;
  width: 100%;
  height: auto;
}

.inner {
  width: 1080px;
  margin: 0 auto;
}
@media only screen and (max-width: 1200px) {
  .inner {
    width: 90vw;
  }
}
@media only screen and (max-width: 736px) {
  .inner {
    width: 84vw;
  }
}

.inner_in {
  width: 980px;
  margin: 0 auto;
}
@media only screen and (max-width: 1100px) {
  .inner_in {
    width: 89.0909090909vw;
  }
}
@media only screen and (max-width: 768px) {
  .inner_in {
    width: 90%;
  }
}
@media only screen and (max-width: 736px) {
  .inner_in {
    width: 76vw;
  }
}

.other_inner {
  max-width: 1080px;
  margin: 0 auto;
}
@media only screen and (max-width: 1100px) {
  .other_inner {
    width: 98.1818181818vw;
  }
}
@media only screen and (max-width: 736px) {
  .other_inner {
    width: 84vw;
  }
}

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

.sp {
  display: none !important;
}
@media only screen and (max-width: 736px) {
  .sp {
    display: block !important;
  }
}

a[href^=tel] {
  cursor: text;
}
@media only screen and (max-width: 736px) {
  a[href^=tel] {
    cursor: pointer;
    display: inline-block;
  }
}

span[data-aos],
strong[data-aos],
small[data-aos] {
  display: inline-block;
}

main {
  overflow: hidden;
}
@media only screen and (max-width: 736px) {
  main {
    margin-top: 21.3333333333vw;
  }
}

.other_page {
  background: #eef7fa;
}
@media only screen and (max-width: 736px) {
  .other_page main {
    z-index: 1;
    position: relative;
  }
}
.other_page #mv_other {
  position: relative;
  margin-bottom: 15px;
  height: 100%;
  max-width: 980px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  box-sizing: border-box;
  padding: 35px 100px;
}
@media only screen and (max-width: 940px) {
  .other_page #mv_other {
    padding: 35px 7vw;
  }
}
@media only screen and (max-width: 736px) {
  .other_page #mv_other {
    width: 100%;
    display: block;
    padding: 13vw 0 0;
    margin-bottom: 8vw;
  }
}
.other_page #mv_other:before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 13px;
  height: 100%;
  background: url(../img/other_mvline.svg) no-repeat left center/contain;
}
@media only screen and (max-width: 736px) {
  .other_page #mv_other:before {
    display: none;
  }
}
.other_page #mv_other:after {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  width: 13px;
  height: 100%;
  transform: scale(-1, 1);
  background: url(../img/other_mvline.svg) no-repeat right center/contain;
}
@media only screen and (max-width: 736px) {
  .other_page #mv_other:after {
    display: none;
  }
}
.other_page #mv_other .text_box {
  max-width: 400px;
  position: relative;
  z-index: 1;
  box-sizing: border-box;
}
@media only screen and (max-width: 940px) {
  .other_page #mv_other .text_box {
    max-width: 100%;
    width: 42.5531914894vw;
  }
}
@media only screen and (max-width: 736px) {
  .other_page #mv_other .text_box {
    width: 100%;
  }
}
.other_page #mv_other .text_box .mv_ttl {
  margin-bottom: 24px;
  width: 357px;
}
@media only screen and (max-width: 940px) {
  .other_page #mv_other .text_box .mv_ttl {
    max-width: 100%;
    width: 37.9787234043vw;
  }
}
@media only screen and (max-width: 736px) {
  .other_page #mv_other .text_box .mv_ttl {
    margin: 0 auto 3vw;
    width: 76.5333333333vw;
  }
}
.other_page #mv_other .text_box .mv_text {
  font-size: 18px;
  color: #3e3a39;
  font-weight: 400;
  letter-spacing: 0;
}
@media only screen and (max-width: 736px) {
  .other_page #mv_other .text_box .mv_text {
    text-align: center;
    margin-bottom: 4vw;
    font-size: 4vw;
  }
}
.other_page #mv_other .img_box {
  max-width: 362px;
}
@media only screen and (max-width: 940px) {
  .other_page #mv_other .img_box {
    max-width: 100%;
    width: 38.5106382979vw;
  }
}
@media only screen and (max-width: 736px) {
  .other_page #mv_other .img_box {
    margin: 0 auto;
    width: 60vw;
  }
}
.other_page .main_ttl {
  text-align: center;
  color: #109649;
  font-weight: 700;
  font-size: 40px;
  margin-bottom: 40px;
  letter-spacing: 0.04em;
}
@media only screen and (max-width: 736px) {
  .other_page .main_ttl {
    font-size: 6.4vw;
    margin-bottom: 8vw;
  }
}

#form_btn, #other_form {
  position: fixed;
  top: 120px;
  right: 0;
  width: 100px;
  z-index: 99;
}
@media only screen and (max-width: 1200px) {
  #form_btn, #other_form {
    width: 80px;
  }
}
@media only screen and (max-width: 768px) {
  #form_btn, #other_form {
    width: 9vw;
  }
}
@media only screen and (max-width: 736px) {
  #form_btn, #other_form {
    position: absolute;
    top: 14vw;
    width: 12vw;
  }
}
@media only screen and (max-width: 736px) {
  #form_btn.fix, #other_form.fix {
    position: fixed;
    top: 21.3333333333vw;
  }
}
#form_btn a, #other_form a {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #109649;
  border-radius: 10px 0 0 10px;
  padding: 35px 0;
  color: #fff;
}
@media only screen and (max-width: 1200px) {
  #form_btn a, #other_form a {
    padding: 30px 0;
  }
}
@media only screen and (max-width: 736px) {
  #form_btn a, #other_form a {
    padding: 5vw 0;
    border-radius: 5px 0 0 5px;
  }
}
#form_btn a:hover, #other_form a:hover {
  opacity: 1;
  background: #87caa4;
}
#form_btn a:hover span, #other_form a:hover span {
  color: #fff;
}
#form_btn a span, #other_form a span {
  font-size: 28px;
  line-height: 60px;
  font-weight: 700;
  color: #fff;
  writing-mode: vertical-rl;
}
@media only screen and (max-width: 1200px) {
  #form_btn a span, #other_form a span {
    font-size: 26px;
  }
}
@media only screen and (max-width: 768px) {
  #form_btn a span, #other_form a span {
    font-size: 2.2222222222vw;
  }
}
@media only screen and (max-width: 736px) {
  #form_btn a span, #other_form a span {
    font-size: 3.36vw;
  }
}

#p-index #other_form {
  display: none;
}
#p-index main {
  background: #eef7fa;
  border-bottom: solid 5px #109649;
}
#p-index #mv {
  width: 85.8711566618%;
  margin-left: 0;
  overflow: unset;
  padding-bottom: 30px;
}
@media only screen and (max-width: 736px) {
  #p-index #mv {
    width: 100%;
    padding-bottom: 0;
  }
}
#p-index #mv .swiper-wrapper {
  border-radius: 0 10px 10px 0;
  overflow: hidden;
  height: 570px;
}
@media only screen and (max-width: 736px) {
  #p-index #mv .swiper-wrapper {
    border-radius: 0;
    height: 84vw;
  }
}
#p-index #mv .swiper-slide {
  height: 570px;
}
@media only screen and (max-width: 736px) {
  #p-index #mv .swiper-slide {
    height: 84vw;
  }
}
#p-index #mv .swiper-slide img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
#p-index #mv .swiper-pagination {
  display: table;
  width: auto;
  margin-left: auto;
  margin-top: 30px;
  z-index: 98;
  position: unset;
}
@media only screen and (max-width: 736px) {
  #p-index #mv .swiper-pagination {
    display: none;
  }
}
#p-index #mv .swiper-pagination-bullet {
  width: 16px;
  height: 16px;
  border: solid 1px #333;
  background: #fff;
  margin: 0 11px;
  opacity: 1;
  box-sizing: border-box;
}
@media only screen and (max-width: 1200px) {
  #p-index #mv .swiper-pagination-bullet {
    width: 1.3333333333vw;
    height: 1.3333333333vw;
    margin: 0 0.9166666667vw;
  }
}
@media only screen and (max-width: 768px) {
  #p-index #mv .swiper-pagination-bullet {
    margin: 0 0.8vw;
  }
}
#p-index #mv .swiper-pagination-bullet:last-child {
  margin-right: 0;
}
#p-index #mv .swiper-pagination-bullet-active {
  background: #333;
}
#p-index #index_top {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-end;
  position: relative;
  z-index: 2;
}
@media only screen and (max-width: 736px) {
  #p-index #index_top {
    display: block;
    width: 100%;
  }
}
@media only screen and (max-width: 736px) {
  #p-index #index_top.fix {
    position: unset;
  }
}
#p-index #index_top .logo_box {
  position: relative;
  width: 630px;
  margin-top: -70px;
  padding-bottom: 75px;
}
@media only screen and (max-width: 1200px) {
  #p-index #index_top .logo_box {
    width: 52.5vw;
  }
}
@media only screen and (max-width: 736px) {
  #p-index #index_top .logo_box {
    width: 100%;
    margin-top: -2vw;
    padding-bottom: 8vw;
    padding-left: 7.4666666667vw;
  }
}
#p-index #index_top .logo_box:after {
  content: "";
  width: calc(100% + 60px);
  height: calc(100% + 60px);
  background: #eef7fa;
  position: absolute;
  top: -60px;
  left: -60px;
  z-index: 0;
}
@media only screen and (max-width: 736px) {
  #p-index #index_top .logo_box:after {
    top: -7vw;
    width: 74.6666666667vw;
    height: 71.4666666667vw;
    left: 0;
  }
}
#p-index #index_top .logo_box .catch {
  color: #231815;
  letter-spacing: 0.1em;
  font-size: 30px;
  font-weight: 700;
  margin-bottom: 20px;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 1200px) {
  #p-index #index_top .logo_box .catch {
    font-size: 2.5vw;
  }
}
@media only screen and (max-width: 736px) {
  #p-index #index_top .logo_box .catch {
    margin-bottom: 3vw;
    font-size: 3.2vw;
  }
}
#p-index #index_top .logo_box .logo {
  width: 550px;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 1200px) {
  #p-index #index_top .logo_box .logo {
    width: 45.8333333333vw;
  }
}
@media only screen and (max-width: 736px) {
  #p-index #index_top .logo_box .logo {
    width: 66.6666666667vw;
  }
}
#p-index #index_top .logo_box .img {
  position: absolute;
  top: -60px;
  right: -170px;
  width: 395px;
  z-index: 1;
}
@media only screen and (max-width: 1200px) {
  #p-index #index_top .logo_box .img {
    width: 32.9166666667vw;
    top: -5vw;
    right: -14.1666666667vw;
  }
}
@media only screen and (max-width: 736px) {
  #p-index #index_top .logo_box .img {
    top: -7vw;
    right: 14vw;
    width: 42.6666666667vw;
  }
}
#p-index #index_top .logo_box .img02 {
  position: absolute;
  width: 219px;
  right: 70px;
  bottom: 0;
  z-index: 10;
}
@media only screen and (max-width: 1200px) {
  #p-index #index_top .logo_box .img02 {
    width: 18.1666666667vw;
    right: 5.8333333333vw;
  }
}
@media only screen and (max-width: 736px) {
  #p-index #index_top .logo_box .img02 {
    width: 29vw;
    right: 24vw;
    bottom: -6vw;
  }
}
#p-index #index_top .info_box {
  width: 430px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 100px;
}
@media only screen and (max-width: 1200px) {
  #p-index #index_top .info_box {
    width: 35.8333333333vw;
  }
}
@media only screen and (max-width: 736px) {
  #p-index #index_top .info_box {
    width: 76vw;
    margin: 0 auto 12vw;
    z-index: 12;
    position: relative;
  }
}
#p-index #index_top .info_box .day {
  width: 250px;
  margin-bottom: 15px;
}
@media only screen and (max-width: 1200px) {
  #p-index #index_top .info_box .day {
    width: 20.8333333333vw;
  }
}
@media only screen and (max-width: 736px) {
  #p-index #index_top .info_box .day {
    margin-bottom: 1vw;
    width: 40.5333333333vw;
  }
}
#p-index #index_top .info_box .time {
  width: 186px;
}
@media only screen and (max-width: 1200px) {
  #p-index #index_top .info_box .time {
    width: 15.5vw;
  }
}
@media only screen and (max-width: 736px) {
  #p-index #index_top .info_box .time {
    width: 32.5333333333vw;
  }
}
#p-index #index_top .info_box .free {
  width: 175px;
}
@media only screen and (max-width: 1200px) {
  #p-index #index_top .info_box .free {
    width: 14.5833333333vw;
  }
}
@media only screen and (max-width: 736px) {
  #p-index #index_top .info_box .free {
    width: 30.6666666667vw;
  }
}
#p-index #index_top .info_box .place {
  font-size: 22px;
  letter-spacing: 0.06em;
  margin-top: 10px;
  color: #333333;
}
@media only screen and (max-width: 1200px) {
  #p-index #index_top .info_box .place {
    font-size: 1.8333333333vw;
  }
}
@media only screen and (max-width: 736px) {
  #p-index #index_top .info_box .place {
    margin-top: 2vw;
    font-size: 3.7333333333vw;
  }
}
#p-index #index_top .info_box .text_box {
  width: 100%;
  margin-top: 30px;
}
@media only screen and (max-width: 736px) {
  #p-index #index_top .info_box .text_box {
    margin-top: 6vw;
  }
}
#p-index #index_slider {
  overflow: hidden;
  margin-bottom: 80px;
}
@media only screen and (max-width: 736px) {
  #p-index #index_slider {
    margin-bottom: 16vw;
  }
}
#p-index #index_slider .swiper-wrapper {
  transition-timing-function: linear !important;
  -webkit-transition-timing-function: linear !important;
  -o-transition-timing-function: linear !important;
}
#p-index #index_slider .swiper-slide img {
  height: auto;
  width: 100%;
}
#p-index #form_bnr {
  margin-bottom: 60px;
  position: relative;
}
@media only screen and (max-width: 736px) {
  #p-index #form_bnr {
    width: 84vw;
    margin-bottom: 21vw;
  }
}
#p-index #form_bnr .illust01 {
  width: 155px;
  position: absolute;
  top: -50px;
  left: -110px;
  z-index: -1;
}
@media only screen and (max-width: 736px) {
  #p-index #form_bnr .illust01 {
    bottom: -11vw;
    top: auto;
    left: -8vw;
    width: 17.6vw;
  }
}
@media only screen and (max-width: 736px) {
  #p-index #form_bnr .illust02 {
    position: absolute;
    top: -12vw;
    right: -8vw;
    z-index: -1;
    width: 23.4666666667vw;
  }
}
#p-index #index_booth {
  margin-bottom: 65px;
}
#p-index #index_booth .ttl_box {
  position: relative;
}
#p-index #index_booth .illust01 {
  width: 202px;
  position: absolute;
  top: -100px;
  left: -70px;
  z-index: -1;
}
@media only screen and (max-width: 736px) {
  #p-index #index_booth .illust01 {
    width: 20.2666666667vw;
    top: -7vw;
    left: 3vw;
  }
}
#p-index #index_booth .illust02 {
  width: 168px;
  position: absolute;
  top: -30px;
  right: -70px;
  z-index: -1;
}
@media only screen and (max-width: 736px) {
  #p-index #index_booth .illust02 {
    width: 16vw;
    right: 6vw;
    bottom: -4vw;
    top: auto;
  }
}
#p-index #index_booth .booth_ttl {
  text-align: center;
  font-size: 30px;
  letter-spacing: 0.06em;
  margin-bottom: 20px;
  font-weight: 700;
}
@media only screen and (max-width: 768px) {
  #p-index #index_booth .booth_ttl {
    background: #eef7fa;
  }
}
@media only screen and (max-width: 736px) {
  #p-index #index_booth .booth_ttl {
    font-size: 4vw;
    margin-bottom: 8vw;
    background: none;
  }
}
#p-index #index_booth .top_btn {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 30px;
}
@media only screen and (max-width: 736px) {
  #p-index #index_booth .top_btn {
    display: block;
    width: 84vw;
    margin: 0 auto;
  }
}
@media only screen and (max-width: 736px) {
  #p-index #index_booth .top_btn .flex {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-end;
  }
}
#p-index #index_booth .top_btn li {
  width: 360px;
  margin-bottom: 30px;
}
@media only screen and (max-width: 736px) {
  #p-index #index_booth .top_btn li {
    width: 100%;
  }
}
#p-index #index_booth .top_btn li .img {
  width: 260px;
  margin: 0 auto 20px;
  position: relative;
}
@media only screen and (max-width: 736px) {
  #p-index #index_booth .top_btn li .img {
    width: 32vw;
    margin: 0;
  }
}
#p-index #index_booth .top_btn li .img:before {
  content: "";
  position: absolute;
  width: 120px;
  height: 50px;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  background: url(../img/prepare.webp) no-repeat left top/contain;
}
@media only screen and (max-width: 736px) {
  #p-index #index_booth .top_btn li .img:before {
    width: 18vw;
    height: 8vw;
    top: 4vw;
  }
}
@media only screen and (max-width: 736px) {
  #p-index #index_booth .top_btn li .box {
    width: 48.5333333333vw;
    position: relative;
  }
}
#p-index #index_booth .top_btn li .ttl {
  height: 46px;
  margin: 0 auto 14px;
  display: block;
}
@media only screen and (max-width: 736px) {
  #p-index #index_booth .top_btn li .ttl {
    margin-bottom: 3vw;
    height: 7.4666666667vw;
  }
}
#p-index #index_booth .top_btn li .ttl img {
  height: 100%;
  width: auto;
  display: block;
  margin: auto;
}
@media only screen and (max-width: 736px) {
  #p-index #index_booth .top_btn li .ttl img {
    margin: 0;
  }
}
#p-index #index_booth .top_btn li .text {
  font-size: 18px;
  font-weight: 400;
  text-align: center;
  line-height: 130%;
  color: #333333;
}
@media only screen and (max-width: 736px) {
  #p-index #index_booth .top_btn li .text {
    text-align: left;
    line-height: 150%;
    font-size: 3.2vw;
  }
}
@media only screen and (max-width: 736px) {
  #p-index #index_booth .top_btn li .arrow {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 6.4vw;
  }
}
#p-index #index_booth .btm_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 20px;
}
@media only screen and (max-width: 736px) {
  #p-index #index_booth .btm_list {
    display: block;
    margin-bottom: 9vw;
  }
}
#p-index #index_booth .btm_list li {
  padding: 0 70px;
  margin-bottom: 20px;
  border-right: dotted 4px #007cbd;
}
@media only screen and (max-width: 736px) {
  #p-index #index_booth .btm_list li {
    padding: 7vw 0 0;
    margin-bottom: 0;
    border-right: none;
  }
}
@media only screen and (max-width: 736px) {
  #p-index #index_booth .btm_list li:after {
    content: "";
    display: table;
    margin: 7vw auto 0;
    width: 53.3333333333vw;
    border-bottom: dotted 3px #007cbd;
  }
}
#p-index #index_booth .btm_list li:last-child {
  border-right: none;
}
@media only screen and (max-width: 736px) {
  #p-index #index_booth .btm_list li:last-child:after {
    display: none;
  }
}
#p-index #index_booth .btm_list li .ttl {
  font-size: 30px;
  letter-spacing: 0.06em;
  margin-bottom: 10px;
  text-align: center;
  font-weight: 700;
  line-height: 140%;
}
@media only screen and (max-width: 736px) {
  #p-index #index_booth .btm_list li .ttl {
    margin-bottom: 1vw;
    font-size: 4.8vw;
  }
}
#p-index #index_booth .btm_list li .text {
  font-size: 18px;
  font-weight: 400;
  text-align: center;
  color: #333333;
}
@media only screen and (max-width: 736px) {
  #p-index #index_booth .btm_list li .text {
    font-size: 3.2vw;
  }
}
#p-index #index_staff {
  color: #fff;
  text-align: center;
  background: #ea601f;
  font-size: 18px;
  font-weight: 500;
  border-radius: 30px;
  width: 690px;
  margin: 0 auto;
  padding: 15px 0;
}
@media only screen and (max-width: 700px) {
  #p-index #index_staff {
    width: 90%;
  }
}
@media only screen and (max-width: 736px) {
  #p-index #index_staff {
    width: 80%;
    padding: 4vw 0;
    line-height: 140%;
    border-radius: 60px;
    font-size: 4.2666666667vw;
  }
}