@charset "UTF-8";
body {
  background-color: #fff;
  color: #222;
  font: 16px/1.7 "Noto Sans JP", sans-serif;
  position: relative;
}

a {
  color: #49bcbd;
  text-decoration: underline;
}

.mincho {
  font-family: "Noto Serif JP", serif;
}

img, iframe {
  max-width: 100%;
  height: auto;
}

body.mceContentBody {
  min-width: inherit;
}

.mceContentBody h2 {
  font-size: 2vw;
  font-weight: bold;
}
.mceContentBody h3 {
  font-size: 1.7vw;
  font-weight: bold;
}
.mceContentBody h4 {
  font-size: 1.4vw;
  font-weight: bold;
}
.mceContentBody p {
  display: block;
  margin: 1rem 0;
}
.mceContentBody ol, .mceContentBody ul {
  margin: 0 0 3rem 2rem;
  list-style: outside disc;
}
.mceContentBody ol ol, .mceContentBody ol ul, .mceContentBody ul ol, .mceContentBody ul ul {
  margin-bottom: 0;
}
.mceContentBody ol.prevention, .mceContentBody ul.prevention {
  position: relative;
  list-style: none;
}
.mceContentBody ol.prevention::before, .mceContentBody ul.prevention::before {
  content: '■';
  position: absolute;
  left: -1rem;
}
.mceContentBody ol.prevention ol, .mceContentBody ol.prevention ul, .mceContentBody ul.prevention ol, .mceContentBody ul.prevention ul {
  list-style: outside disc;
}
.mceContentBody ol.prevention ol::before, .mceContentBody ol.prevention ul::before, .mceContentBody ul.prevention ol::before, .mceContentBody ul.prevention ul::before {
  content: '';
}
.mceContentBody strong {
  font-weight: bold;
}
.mceContentBody em {
  font-style: italic;
}
.mceContentBody blockquote {
  display: block;
  -webkit-margin-before: 1rem;
  -webkit-margin-after: 1rem;
  -webkit-margin-start: 40px;
  -webkit-margin-end: 40px;
}
.mceContentBody .aligncenter {
  display: block;
  margin: 0 auto;
  text-align: center;
}
.mceContentBody .alignright {
  float: right;
  margin-left: 1rem;
}
.mceContentBody .alignleft {
  float: left;
  margin-right: 1rem;
}
.mceContentBody img[class*="wp-image-"], .mceContentBody img[class*="attachment-"] {
  height: auto;
  max-width: 100%;
  margin-top: 1rem;
  margin-bottom: 1rem;
}
.mceContentBody iframe {
  height: 400px;
  width: 100%;
}
.mceContentBody a {
  color: #49BBBC;
  text-decoration: underline;
}
.mceContentBody p.wp-caption-text {
  margin-top: -1rem;
}
.mceContentBody .embed_content {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.mceContentBody .embed_content iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

#navMenu {
  position: relative;
}
#navMenu #navMenu_btn_open {
  position: fixed;
  right: 10px;
  top: calc(100vh - 60px - 10px);
  width: 60px;
  height: 60px;
  border-radius: 60px;
  border: none;
  background-color: #DDD;
  z-index: 9;
}
#navMenu #navMenu_btn_open svg {
  width: 35px;
  height: 25px;
}
#navMenu nav {
  display: none;
  position: fixed;
  z-index: 999;
  width: 100vw;
  height: 100vh;
  overflow-y: auto;
  background-color: rgba(150, 150, 150, 0.9);
  left: 0;
  top: 0;
}
#navMenu nav p {
  text-align: center;
  padding-top: 5vh;
}
#navMenu nav p img {
  height: 27vh;
}
#navMenu nav #navMenu_btn_close {
  position: absolute;
  right: 10px;
  bottom: 10px;
  width: 60px;
  height: 60px;
  border-radius: 60px;
  border: none;
  background-color: #49bcbd;
  z-index: 9;
}
#navMenu nav #navMenu_btn_close svg {
  width: 35px;
  height: 25px;
  fill: #fff;
}
#navMenu nav div {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 3vh;
}
#navMenu nav div .nav_menu {
  flex: 0 0 60vw;
}
#navMenu nav div .nav_menu li {
  background-repeat: repeat-x;
  background-position: center;
  background-size: cover;
  margin-bottom: 1vh;
  text-align: center;
}
#navMenu nav div .nav_menu li.nav_top {
  background-image: url("img/nav_fv1_bg_top.png");
}
#navMenu nav div .nav_menu li.nav_summary {
  background-image: url("img/nav_fv1_bg_summary.png");
}
#navMenu nav div .nav_menu li.nav_news {
  background-image: url("img/nav_fv1_bg_news.png");
}
#navMenu nav div .nav_menu li.nav_program {
  background-image: url("img/nav_fv1_bg_program.png");
}
#navMenu nav div .nav_menu li.nav_access {
  background-image: url("img/nav_fv1_bg_access.png");
}
#navMenu nav div .nav_menu li.nav_qanda {
  background-image: url("img/nav_fv1_bg_qanda.png");
}
#navMenu nav div .nav_menu li.nav_mailmag {
  background-color: #fff;
}
#navMenu nav div .nav_menu li img {
  height: 10vw;
  padding: 2vw 0;
}
#navMenu nav div .nav_menu li.nav_mailmag img {
  height: inherit;
  padding: 0;
}
#navMenu nav div .nav_menu li.nav_ticketguard img {
  height: inherit;
  padding: 0;
}
#navMenu nav div .nav_sns {
  flex: 0 0 18vw;
  margin-right: 12vw;
}
#navMenu nav div .nav_sns li:not(:first-child) {
  margin-top: 2.5vw;
}

body > section {
  width: 100%;
  position: relative;
}
body > section .btn_ticket {
  position: fixed;
  top: 0;
  right: 20px;
  text-align: center;
  z-index: 9;
}
body > section .btn_ticket a {
  width: 71px;
  height: 100px;
  display: block;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  transition: all 0.3s ease;
}
body > section .btn_ticket a img {
  width: 56px;
  padding-top: 10px;
}
body > section:not(#topFv1) .btn_ticket {
  display: none;
}
body > section nav {
  position: absolute;
  left: 0;
  bottom: 100px;
  width: 160px;
  display: none;
}
body > section nav li {
  margin-bottom: 6px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
body > section nav li a {
  display: block;
  width: 160px;
  height: 35px;
}

footer {
  background-color: #000;
}
footer div {
  font-size: 2vw;
  color: #FFF;
  padding: 10vw;
}
footer div p {
  margin-bottom: 1vw;
}

.btn_lang {
  position: absolute;
  left: 10px;
  top: 10px;
  padding: 5px 10px 2px;
  background-color: #FFF;
  z-index: 9;
}
.btn_lang a {
  color: #222;
}

.btn_readmore a {
  position: relative;
  display: inline-block;
  color: #333;
  text-decoration: none;
  outline: none;
}
.btn_readmore a::before {
  content: '';
  position: absolute;
  bottom: -8px;
  left: 0;
  width: 48vw;
  height: 1px;
  background: #333;
}
.btn_readmore a::after {
  content: '';
  position: absolute;
  bottom: -3px;
  right: -8vw;
  width: 15px;
  height: 1px;
  background: #333;
  transform: rotate(35deg);
}
.btn_readmore a svg {
  width: 40vw;
  height: 6vw;
}

section#topFv1 {
  background: url("img/bg_fv1_with.png") no-repeat center/cover;
  height: 100vh;
}
section#topFv1 .btn_ticket a {
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 192 270'%3E%3Crect fill='%2349bcbd' x='187' width='4' height='240'/%3E%3Crect fill='%2349bcbd' width='4' height='240'/%3E%3Cpolygon fill='%2349bcbd' points='182 240 95 270 10 240 10 0 182 0 182 240'/%3E%3C/svg%3E");
}
section#topFv1 .content {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100vh;
  flex-wrap: wrap;
}
section#topFv1 .content#topFv1_1st {
  background: url("img/bg_fv1_only.png") no-repeat center/cover;
}
section#topFv1 .content#topFv1_1st p {
  display: none;
}
section#topFv1 .content#topFv1_1st p img {
  width: 65vw;
}
section#topFv1 .content#topFv1_2nd h1 {
  display: none;
  margin-top: 10vw;
}
section#topFv1 .content#topFv1_2nd h1 img {
  width: 65vw;
}
section#topFv1 .content#topFv1_2nd #topFv1_giftDownload {
  margin-top: -10vw;
  background: url("img/btn_gift_bg.png") no-repeat center/cover;
  width: 80vw;
  height: 35.817vw;
}
section#topFv1 .content#topFv1_2nd #topFv1_giftDownload p {
  width: 60vw;
  margin: 22vw auto 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
section#topFv1 .content#topFv1_2nd #topFv1_giftDownload p img {
  height: 4.2vw;
}
section#topFv1 .content#topFv1_2nd #topFv1_pdfDownload {
  margin-top: -20vw;
}
section#topFv1 .content#topFv1_2nd #topFv1_pdfDownload img {
  width: 80vw;
}

section#topMessage {
  background: url("img/bg_message.png") no-repeat center/cover;
  padding: 10vw 2.5vw;
}
section#topMessage .content .contentInBox {
  display: flex;
  flex-direction: row-reverse;
}
section#topMessage .content .contentInBox h2 {
  width: 8.35714vw;
  height: 65.14286vw;
}
section#topMessage .content .contentInBox .topMessageText {
  font-size: 2.6vw;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  text-shadow: 0 0 2px #fff, 0 0 5px #fff, 0 0 10px #fff;
  margin: 1vw 2vw 0 3vw;
  padding-left: 3vw;
  border-left: 1px solid #292929;
}
section#topMessage .content .contentInBox figure {
  margin-top: 5vw;
}
section#topMessage .content .contentInBox figure img {
  width: 20.57143vw;
  height: 53.35714vw;
}
section#topMessage .content .topMessageLink {
  text-align: right;
  margin-top: 8vw;
}
section#topMessage .content .topMessageLink img {
  width: 50.92857vw;
  height: 6.28571vw;
}

section#topFv2 {
  background: url("img/bg_fv2.png") no-repeat bottom center/cover;
  min-height: 100vh;
}
section#topFv2 .content {
  padding: 10vw 5vw 100vw;
  color: #fff;
}
section#topFv2 .content h2 {
  font-size: 4.9vw;
  line-height: 1.5;
  margin: 10vw 0;
}
section#topFv2 .content p {
  font-size: 3vw;
  line-height: 1.9;
  padding: 0 4vw;
}

section#topNews {
  background-color: #ddd;
  padding: 5vw;
  position: relative;
}
section#topNews::after {
  content: '';
  width: 100%;
  height: 11.5vw;
  background: url("img/clip_mountain.png") no-repeat center bottom/cover;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 1;
}
section#topNews .content {
  width: 90vw;
  margin: 0 auto;
  padding: 5vw;
  background-color: #FFF;
}
section#topNews .content h2 {
  height: 7vw;
  margin-bottom: 7.5vw;
}
section#topNews .content h2 img {
  height: 7vw;
}
section#topNews .content .contentInBox {
  margin: 0 auto 5vw;
}

.newsLists a {
  text-decoration: none;
  display: flex;
  flex-wrap: wrap;
}
.newsLists a figure {
  flex: 0 0 20vw;
}
.newsLists a figure img {
  width: 20vw;
  height: 15vw;
  object-fit: cover;
}
.newsLists a .postGroup {
  padding-left: 2vw;
  flex: 0 0 60vw;
}
.newsLists a .postGroup h3 {
  font-size: 3.8vw;
  line-height: 1.4;
  margin-bottom: 1vw;
}
.newsLists a .postGroup p {
  font-size: 2vw;
  color: #929292;
  margin-bottom: 1vw;
}
.newsLists a .post_content {
  font-size: 2.6vw;
  color: #444;
  margin-top: 2vw;
}

section#hanabishi {
  background-color: #5E788F;
  padding: 5vw;
}
section#hanabishi .content {
  background: url("img/bg_hanabishi.png") no-repeat center bottom/contain #fff;
}
section#hanabishi .content .contentInBox {
  padding: 5vw 5vw 8vw;
}
section#hanabishi .content .contentInBox .hanabishi_contents {
  margin-bottom: 7vw;
}
section#hanabishi .content .contentInBox .hanabishi_contents p {
  font-size: 3vw;
  padding-left: 8.5vw;
}
section#hanabishi .content .contentInBox .hanabishi_contents h3 {
  margin: 2vw 0 1vw;
}
section#hanabishi .content .contentInBox .hanabishi_contents#hanabishi_01 figure {
  margin-bottom: 7.5vw;
}
section#hanabishi .content .contentInBox .hanabishi_contents#hanabishi_01 figure img {
  width: 100%;
}
section#hanabishi .content .contentInBox .hanabishi_contents#hanabishi_02 figure img {
  width: 100%;
}
section#hanabishi .content .contentInBox .hanabishi_contents#hanabishi_02 p {
  margin-bottom: 2.5vw;
}
section#hanabishi .content .contentInBox .hanabishi_contents#hanabishi_03 figure {
  display: none;
}
section#hanabishi .content .contentInBox .hanabishi_contents#hanabishi_04 figure img {
  width: 100%;
}
section#hanabishi .content .contentInBox .hanabishi_contents#hanabishi_04 p {
  margin-bottom: 2.5vw;
}
section#hanabishi .content .contentInBox #hanabishi_footer {
  font-size: 2.6vw;
}
section#hanabishi .content .contentInBox #hanabishi_footer h3 {
  width: 50vw;
}
section#hanabishi .content .contentInBox #hanabishi_footer #hanabishi_footer_content {
  margin-top: 2.5vw;
}
section#hanabishi .content .contentInBox #hanabishi_footer #hanabishi_footer_content_inbox {
  display: flex;
  margin-top: 1vw;
}
section#hanabishi .content .contentInBox #hanabishi_footer #hanabishi_footer_content_inbox h4 {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #292A54;
  color: #fff;
  padding: 0 10px;
  flex: 0 0 3.5rem;
}
section#hanabishi .content .contentInBox #hanabishi_footer #hanabishi_footer_content_inbox ul {
  margin-left: 1.5vw;
}
section#hanabishi .content .contentInBox #hanabishi_footer #hanabishi_footer_content_inbox ul li::before {
  content: '■';
  padding-right: 1vw;
}

section#topSummary {
  background-color: #ddd;
  padding: 5vw;
  position: relative;
}
section#topSummary::after {
  content: '';
  width: 100%;
  height: 11.5vw;
  background: url("img/clip_mountain.png") no-repeat center bottom/cover;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 1;
}
section#topSummary .content {
  width: 90vw;
  margin: 0 auto;
  padding: 5vw;
  background-color: #FFF;
}
section#topSummary .content h2 {
  height: 7vw;
}
section#topSummary .content h2 img {
  height: 7vw;
}
section#topSummary .content .contentInBox {
  margin: 5vw 0;
}
section#topSummary .content .contentInBox dl {
  margin-bottom: 3vw;
}
section#topSummary .content .contentInBox dl div {
  display: flex;
}
section#topSummary .content .contentInBox dl div dt {
  font-size: 3.8vw;
  flex: 0 0 22vw;
}
section#topSummary .content .contentInBox dl div dd {
  font-size: 3.8vw;
  flex: 1 1 auto;
  border-left: 1px solid;
  padding-left: 2vw;
  line-height: 1.5;
}
section#topSummary .content .contentInBox dl div dd .attention {
  font-size: 2.6vw;
}
section#topSummary .content .contentInBox dl div dd .attention .underline {
  text-decoration: underline;
}
section#topSummary .content .contentInBox .btn_readmore {
  text-align: center;
  margin-top: 7.5vw;
}
section#topSummary .content .contentInBox .btn_readmore a {
  color: #49bcbd;
}
section#topSummary .content .contentInBox .btn_readmore a::before, section#topSummary .content .contentInBox .btn_readmore a::after {
  background: #49bcbd;
}
section#topSummary .content .topSummary_sponsorship {
  font-size: 2.1vw;
  margin-top: 7.5vw;
}

section#feature1 {
  background: url("img/bg_feature1.png") no-repeat right bottom/cover;
  position: relative;
  z-index: 1;
}
section#feature1::before {
  background-color: rgba(0, 0, 0, 0.45);
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  content: '';
  z-index: 2;
}
section#feature1 .content {
  position: relative;
  z-index: 9;
}
section#feature1 .content .contentInBox {
  padding: 5vw 5vw 30vw;
  color: #fff;
}
section#feature1 .content .contentInBox h2 {
  width: 70vw;
  margin-bottom: 5vw;
}
section#feature1 .content .contentInBox .featureText {
  font-size: 3vw;
  line-height: 1.9;
  margin-bottom: 5vw;
}
section#feature1 .content .contentInBox .btn_readmore a {
  color: #00c8e9;
}
section#feature1 .content .contentInBox .btn_readmore a::before {
  bottom: -8px;
  width: 60vw;
  background: #00c8e9;
}
section#feature1 .content .contentInBox .btn_readmore a::after {
  bottom: -3px;
  right: -10vw;
  width: 15px;
  background: #00c8e9;
}
section#feature1 .content .contentInBox .btn_readmore a img {
  width: 50vw;
}

section#feature2 {
  background: url("img/bg_feature2.png") no-repeat right bottom/cover;
  position: relative;
  z-index: 1;
}
section#feature2::before {
  background-color: rgba(0, 0, 0, 0.45);
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  content: '';
  z-index: 2;
}
section#feature2 .content {
  position: relative;
  z-index: 9;
}
section#feature2 .content .contentInBox {
  padding: 5vw 5vw 30vw;
  color: #fff;
}
section#feature2 .content .contentInBox h2 {
  width: 70vw;
  margin-bottom: 5vw;
}
section#feature2 .content .contentInBox .featureText {
  font-size: 3vw;
  line-height: 1.9;
  margin-bottom: 5vw;
}
section#feature2 .content .contentInBox .btn_readmore a {
  color: #f3de00;
}
section#feature2 .content .contentInBox .btn_readmore a::before {
  bottom: -8px;
  width: 60vw;
  background: #f3de00;
}
section#feature2 .content .contentInBox .btn_readmore a::after {
  bottom: -3px;
  right: -10vw;
  width: 15px;
  background: #f3de00;
}
section#feature2 .content .contentInBox .btn_readmore a img {
  width: 50vw;
}

section#feature3 {
  background: url("img/bg_feature3.png") no-repeat right bottom/cover;
  position: relative;
  z-index: 1;
}
section#feature3::before {
  background-color: rgba(0, 0, 0, 0.45);
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  content: '';
  z-index: 2;
}
section#feature3 .content {
  position: relative;
  z-index: 9;
}
section#feature3 .content .contentInBox {
  padding: 5vw 5vw 35vw;
  color: #fff;
}
section#feature3 .content .contentInBox h2 {
  width: 70vw;
  margin-bottom: 5vw;
}
section#feature3 .content .contentInBox .featureText {
  font-size: 3vw;
  line-height: 1.9;
  margin-bottom: 5vw;
}

section#feature4 .content {
  position: relative;
}
section#feature4 .content .contentInBox {
  background: url("img/bg_featureTopics.png") no-repeat left top/55%;
  padding: 84vw 5vw 15vw;
  color: #fff;
}
section#feature4 .content .contentInBox h2 {
  width: 88vw;
  position: absolute;
  left: 5vw;
  top: 12vw;
}
section#feature4 .content .contentInBox h2 img {
  width: 100%;
}
section#feature4 .content .contentInBox .featureContent {
  color: #222;
}
section#feature4 .content .contentInBox .featureContent figure {
  width: 60vw;
  margin-left: auto;
}
section#feature4 .content .contentInBox .featureContent figure img {
  width: 100%;
}
section#feature4 .content .contentInBox .featureContent p {
  margin-top: 5vw;
  font-size: 3vw;
}
section#feature4 .content .contentInBox .featureContent dl {
  margin-top: 5vw;
  padding-top: 5vw;
  border-top: 1px solid #000;
  text-align: center;
}
section#feature4 .content .contentInBox .featureContent dl dt {
  font-size: 3.8vw;
}
section#feature4 .content .contentInBox .featureContent dl dd {
  font-size: 2.6vw;
}

section#feature5 .content {
  position: relative;
}
section#feature5 .content .contentInBox {
  background: url("img/bg_featureTopics.png") no-repeat left top/55%;
  padding: 106vw 5vw 15vw;
  color: #fff;
}
section#feature5 .content .contentInBox h2 {
  width: 60vw;
  position: absolute;
  left: 5vw;
  top: 12vw;
}
section#feature5 .content .contentInBox h2 img {
  width: 100%;
}
section#feature5 .content .contentInBox .featureContent {
  color: #222;
  display: flex;
  flex-direction: column;
}
section#feature5 .content .contentInBox .featureContent figure {
  order: 1;
  width: 57vw;
  margin-left: auto;
}
section#feature5 .content .contentInBox .featureContent figure img {
  width: 100%;
}
section#feature5 .content .contentInBox .featureContent p {
  order: 2;
  margin-top: 5vw;
  font-size: 3vw;
}
section#feature5 .content .contentInBox .featureContent dl {
  order: 3;
  margin-top: 5vw;
  padding-top: 5vw;
  border-top: 1px solid #000;
  text-align: center;
}
section#feature5 .content .contentInBox .featureContent dl dt {
  font-size: 3.8vw;
}
section#feature5 .content .contentInBox .featureContent dl dd {
  font-size: 2.6vw;
}

section#topPerformance {
  background: url("img/bg_performance.png") no-repeat center right/cover;
}
section#topPerformance .content {
  width: 100%;
  margin: 0 auto;
}

section#topFugoku {
  background: url("img/bg_fugoku.png") no-repeat center/cover;
}
section#topFugoku .content {
  width: 90vw;
  background-color: rgba(0, 0, 0, 0.6);
  margin: 0 auto;
  padding: 5vw 0;
  text-align: center;
  color: #FFF;
}
section#topFugoku .content h2 {
  width: 90%;
  margin: 0 auto 5vw;
}
section#topFugoku .content p {
  padding: 0 3vw;
  font-size: 2.6vw;
}

section#topEve {
  background-color: #ddd;
  padding: 5vw;
  position: relative;
}
section#topEve .content {
  width: 90vw;
  margin: 0 auto;
  padding: 5vw;
  background-color: #FFF;
}

section#topTicket {
  background-color: #ddd;
  padding: 5vw;
  position: relative;
}
section#topTicket::after {
  content: '';
  width: 100%;
  height: 11.5vw;
  background: url("img/clip_mountain.png") no-repeat center bottom/cover;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 1;
}
section#topTicket .content {
  width: 90vw;
  margin: 0 auto;
  padding: 5vw;
  background-color: #FFF;
  /*		#topTicket_option {
  
  			h4.headline_area {
  				font-size: 3.8vw;
  				margin-top: 3vw;
  				background-color: transparent;
  				text-align: left;
  				padding: 0;
  				color: #292929;
  			}
  
  			.topTicket_option_subTitle {
  				font-size: 2.6vw;
  				margin: 0vw;
  
  				span {
  					color: #796a56;
  				}
  			}
  			.topTicket_option_price {
  				font-size: 4.42vw;
  				margin: 1.5vw 0;
  			}
  			.topTicket_option_caption {
  				margin: 0;
  				font-size: 2.6vw;
  			}
  		}
  */
}
section#topTicket .content h2 {
  height: 7vw;
}
section#topTicket .content h2 img {
  height: 7vw;
}
section#topTicket .content .headline_ticket {
  position: relative;
  font-size: 3.8vw;
  margin: 7.5vw 0 3vw;
}
section#topTicket .content .headline_ticket::after {
  content: '';
  width: 100%;
  border-bottom: 1px solid #000;
  position: absolute;
  top: 3.2vw;
  left: 0;
  z-index: 1;
}
section#topTicket .content .headline_ticket span {
  position: relative;
  padding: 2px 5px;
  background-color: #e2e3e3;
  z-index: 9;
}
section#topTicket .content p {
  font-size: 2.6vw;
  margin-bottom: 5vw;
}
section#topTicket .content .ticketAttention {
  margin-bottom: 5vw;
  padding: 2.5vw;
  border: 1px solid #fa2503;
  color: #fa2503;
  font-size: 3.2vw;
}
section#topTicket .content .headline_plan {
  font-size: 3.2vw;
}
section#topTicket .content .headline_plan#topTicket_plan_A {
  color: #fa2503;
}
section#topTicket .content .headline_plan#topTicket_plan_B {
  color: #00D0ED;
}
section#topTicket .content .headline_area {
  font-size: 4.4vw;
  margin: 10vw auto 2.5vw;
  text-align: center;
  padding: 1vw 0 1.5vw;
  border-radius: 6px;
  color: #FFF;
}
section#topTicket .content .headline_area#headline_area_exciting {
  background-color: #fa2503;
}
section#topTicket .content .headline_area#headline_area_drivein {
  background-color: #00d0ed;
}
section#topTicket .content .headline_area#headline_area_freeArea {
  background-color: #fac03a;
}
section#topTicket .content .headline_area#headline_area_option {
  background-color: #796a56;
}
section#topTicket .content #topTicket_excitingArea h5 {
  text-align: center;
  margin-top: -5vw;
}
section#topTicket .content #topTicket_excitingArea h5 img {
  width: 70%;
}
section#topTicket .content #topTicket_excitingArea #topTicket_excitingAreaPara {
  font-size: 3.8vw;
  color: #FA2503;
  line-height: 1.6;
}
section#topTicket .content #topTicket_excitingArea #figure_ticket_area figcaption {
  font-size: 2.6vw;
  margin-top: 5vw;
}
section#topTicket .content #topTicket_excitingSeatList {
  position: relative;
  margin-top: 1vw;
}
section#topTicket .content #topTicket_excitingSeatList::before {
  position: relative;
  content: '';
  display: block;
  width: 16.57143vw;
  height: 11.71429vw;
  left: -2.5vw;
  background: url(img/icon_ticket_red.png) no-repeat left top/cover;
  z-index: 9;
}
section#topTicket .content #topTicket_excitingSeatList ul {
  border-top: 2px solid #fa2503;
  border-bottom: 2px solid #fa2503;
  position: relative;
  z-index: 1;
  margin-top: -3.5vw;
  padding: 3.5vw;
  background-color: #F3F3F3;
}
section#topTicket .content #topTicket_excitingSeatList ul li:not(:first-child) {
  margin-top: 3.5vw;
  padding-top: 3.5vw;
  border-top: 2px dotted #222;
}
section#topTicket .content #topTicket_excitingSeatList ul li .topTicket_excitingSeatBox h5 {
  margin-bottom: 3vw;
}
section#topTicket .content #topTicket_excitingSeatList ul li .topTicket_excitingSeatBox h5 img {
  width: 100%;
}
section#topTicket .content #topTicket_excitingSeatList ul li .topTicket_excitingSeatBox p {
  margin: 0;
}
section#topTicket .content #topTicket_excitingSeatList ul li .topTicket_excitingSeatBox p.topTicket_excitingSeat_addition {
  font-size: 2.6vw;
}
section#topTicket .content #topTicket_excitingSeatList ul li .topTicket_excitingSeatBox p.topTicket_excitingSeat_price {
  font-size: 5vw;
}
section#topTicket .content #topTicket_excitingSeatList ul li .topTicket_excitingSeatBox p.topTicket_excitingSeat_price span {
  font-size: 2vw;
  padding-left: 2vw;
}
section#topTicket .content #topTicket_excitingSeatList ul li figure img {
  width: 100%;
}
section#topTicket .content #topTicket_otherArea #topTicket_drivein ol figcaption {
  font-size: 2.6vw;
  margin-top: 5vw;
}
section#topTicket .content #topTicket_otherArea #topTicket_drivein #topTicket_driveinList {
  position: relative;
  margin-top: 2.5vw;
}
section#topTicket .content #topTicket_otherArea #topTicket_drivein #topTicket_driveinList::before {
  position: relative;
  content: '';
  display: block;
  width: 16.57143vw;
  height: 11.71429vw;
  left: -2.5vw;
  background: url(img/icon_ticket_blue.png) no-repeat left top/cover;
  z-index: 9;
}
section#topTicket .content #topTicket_otherArea #topTicket_drivein #topTicket_driveinList ul {
  border-top: 2px solid #00d0ed;
  border-bottom: 2px solid #00d0ed;
  position: relative;
  z-index: 1;
  margin-top: -3.5vw;
  padding: 3.5vw;
  background-color: #F3F3F3;
}
section#topTicket .content #topTicket_otherArea #topTicket_drivein #topTicket_driveinList ul li:not(:first-child) {
  margin-top: 3.5vw;
  padding-top: 3.5vw;
  border-top: 2px dotted #222;
}
section#topTicket .content #topTicket_otherArea #topTicket_drivein #topTicket_driveinList ul li .topTicket_otherAreaBox h5 {
  margin-bottom: 3vw;
}
section#topTicket .content #topTicket_otherArea #topTicket_drivein #topTicket_driveinList ul li .topTicket_otherAreaBox h5 img {
  width: 100%;
}
section#topTicket .content #topTicket_otherArea #topTicket_drivein #topTicket_driveinList ul li .topTicket_otherAreaBox p {
  margin: 0;
}
section#topTicket .content #topTicket_otherArea #topTicket_drivein #topTicket_driveinList ul li .topTicket_otherAreaBox p.topTicket_otherArea_price {
  font-size: 5vw;
  margin-top: -3.5vw;
}
section#topTicket .content #topTicket_otherArea #topTicket_drivein #topTicket_driveinList ul li .topTicket_otherAreaBox p.topTicket_otherArea_price span {
  font-size: 2.6vw;
  padding-left: 1vw;
}
section#topTicket .content #topTicket_otherArea #topTicket_drivein #topTicket_driveinList ul li .topTicket_otherAreaBox p.topTicket_otherArea_addition {
  margin-top: 3.5vw;
  padding-top: 3.5vw;
  border-top: 2px dotted #222;
  font-size: 2.6vw;
}
section#topTicket .content #topTicket_otherArea #topTicket_freeArea ol {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
section#topTicket .content #topTicket_otherArea #topTicket_freeArea ol li {
  flex: 0 0 49%;
  margin-bottom: 2vw;
}
section#topTicket .content #topTicket_otherArea #topTicket_freeArea ol li img {
  width: 100%;
}
section#topTicket .content #topTicket_otherArea #topTicket_freeArea ol li figcaption {
  font-size: 2.2vw;
}
section#topTicket .content #topTicket_otherArea #topTicket_freeArea #topTicket_freeAreaAddition {
  padding-top: 2.5vw;
  margin: 2.5vw 0;
  border-top: 1px solid #f2a300;
}
section#topTicket .content #topTicket_otherArea #topTicket_freeArea #topTicket_freeAreaAddition p {
  font-size: 3.8vw;
  margin-bottom: 2vw;
}
section#topTicket .content #topTicket_otherArea #topTicket_freeArea #topTicket_freeAreaAddition p span {
  display: block;
  font-size: 2.6vw;
}
section#topTicket .content #topTicket_otherArea #topTicket_freeArea #topTicket_freeAreaAddition figure {
  position: relative;
}
section#topTicket .content #topTicket_otherArea #topTicket_freeArea #topTicket_freeAreaAddition figure img {
  position: relative;
  max-width: inherit;
  width: 104%;
  left: -4%;
}
section#topTicket .content #topTicket_otherArea #topTicket_freeArea #topTicket_freeAreaAddition figure figcaption {
  font-size: 2.6vw;
}
section#topTicket .content #topTicket_otherArea #topTicket_freeArea #topTicket_freeAreaList {
  position: relative;
  margin-top: -0.5vw;
}
section#topTicket .content #topTicket_otherArea #topTicket_freeArea #topTicket_freeAreaList::before {
  position: relative;
  content: '';
  display: block;
  width: 16.57143vw;
  height: 11.71429vw;
  left: -2.5vw;
  background: url(img/icon_ticket_yellow.png) no-repeat left top/cover;
  z-index: 9;
}
section#topTicket .content #topTicket_otherArea #topTicket_freeArea #topTicket_freeAreaList ul {
  border-top: 2px solid #f2a300;
  border-bottom: 2px solid #f2a300;
  position: relative;
  z-index: 1;
  margin-top: -3.5vw;
  padding: 3.5vw;
  background-color: #F3F3F3;
}
section#topTicket .content #topTicket_otherArea #topTicket_freeArea #topTicket_freeAreaList ul li:not(:first-child) {
  margin-top: 3.5vw;
  padding-top: 3.5vw;
  border-top: 2px dotted #222;
}
section#topTicket .content #topTicket_otherArea #topTicket_freeArea #topTicket_freeAreaList ul li .topTicket_otherAreaBox h5 {
  margin-bottom: 3vw;
}
section#topTicket .content #topTicket_otherArea #topTicket_freeArea #topTicket_freeAreaList ul li .topTicket_otherAreaBox h5 img {
  width: 100%;
}
section#topTicket .content #topTicket_otherArea #topTicket_freeArea #topTicket_freeAreaList ul li .topTicket_otherAreaBox p {
  margin: 0;
}
section#topTicket .content #topTicket_otherArea #topTicket_freeArea #topTicket_freeAreaList ul li .topTicket_otherAreaBox p.topTicket_otherArea_addition {
  font-size: 2.6vw;
}
section#topTicket .content #topTicket_otherArea #topTicket_freeArea #topTicket_freeAreaList ul li .topTicket_otherAreaBox p.topTicket_otherArea_price {
  font-size: 5vw;
}
section#topTicket .content #topTicket_otherArea #topTicket_freeArea #topTicket_freeAreaList ul li .topTicket_otherAreaBox#topTicket_otherAreaBox_adult p {
  margin-top: -13vw;
}
section#topTicket .content #topTicket_otherArea #topTicket_freeArea #topTicket_freeAreaList ul li .topTicket_otherAreaBox#topTicket_otherAreaBox_child p {
  margin-top: -0.5vw;
}
section#topTicket .content .headline_parking {
  font-size: 3.8vw;
  line-height: 1.4;
  margin-bottom: 1vw;
}
section#topTicket .content .headline_parking#headline_parking_A {
  color: #d94b4b;
}
section#topTicket .content .headline_parking#headline_parking_A span {
  background-color: #d94b4b;
}
section#topTicket .content .headline_parking#headline_parking_B {
  color: #02a56f;
  border-top: 2px dotted #000;
  margin-top: 2vw;
  padding-top: 2vw;
}
section#topTicket .content .headline_parking#headline_parking_B span {
  background-color: #02a56f;
}
section#topTicket .content .headline_parking#headline_parking_C {
  color: #8e3ecc;
  border-top: 2px dotted #000;
  margin-top: 2vw;
  padding-top: 2vw;
}
section#topTicket .content .headline_parking#headline_parking_C span {
  background-color: #8e3ecc;
}
section#topTicket .content .headline_parking span {
  color: #fff;
  padding-right: 5px;
}
section#topTicket .content #topTicket_option {
  overflow: hidden;
  position: relative;
  border-top: 2px solid #796a56;
  border-bottom: 2px solid #796a56;
  padding: 2.5vw 0;
  margin-top: 5vw;
}
section#topTicket .content #topTicket_option > div {
  width: 60%;
  float: left;
}
section#topTicket .content #topTicket_option > div h4.headline_area {
  font-size: 4.4vw;
  margin-top: 3vw;
  background-color: transparent;
  text-align: left;
  padding: 0;
  color: #292929;
  line-height: 1.4;
}
section#topTicket .content #topTicket_option > div .topTicket_option_subTitle {
  font-size: 3.8vw;
  margin: 0;
}
section#topTicket .content #topTicket_option > div .topTicket_option_subTitle span {
  color: #796a56;
}
section#topTicket .content #topTicket_option > div .topTicket_option_price {
  font-size: 5vw;
  margin: 1.5vw 0;
}
section#topTicket .content #topTicket_option > div .topTicket_option_caption {
  margin: 0;
  font-size: 2.6vw;
}
section#topTicket .content #topTicket_option figure {
  width: 36%;
  float: right;
  overflow: hidden;
}
section#topTicket .content #topTicket_option figure img {
  width: 100%;
}
section#topTicket .content #topTicket_sellerSite {
  border-top: 1px solid #000;
  margin-top: 10vw;
  padding: 10vw 0 5vw;
}
section#topTicket .content #topTicket_sellerSite .headline_sellerSite {
  font-size: 4.4vw;
}
section#topTicket .content #topTicket_sellerSite .headline_sellerSite span {
  font-size: 2.6vw;
  display: block;
}
section#topTicket .content #topTicket_sellerSite .headline_sellerSite#topTicket_sellerSite_bus {
  padding-top: 3vw;
  border-top: 2px dotted #000;
}
section#topTicket .content #topTicket_sellerSite ul {
  margin-bottom: 5vw;
}
section#topTicket .content #topTicket_sellerSite ul li {
  margin-top: 5vw;
}
section#topTicket .content #topTicket_sellerSite ul li img {
  height: 8vw;
}
section#topTicket .content #topTicket_sellerSite ul li#topTicket_sellerSite_ticketguard {
  text-align: center;
}
section#topTicket .content #topTicket_sellerSite ul li#topTicket_sellerSite_ticketguard img {
  height: 15vw;
}
section#topTicket .content #topTicket_sellerSite #topTicket_sellerSite_flowchart {
  padding-top: 3vw;
  border-top: 2px dotted #000;
}
section#topTicket .content #topTicket_sellerSite #topTicket_sellerSite_flowchart a {
  display: block;
  text-align: center;
}
section#topTicket .content #topTicket_sellerSite #topTicket_sellerSite_flowchart a span {
  display: block;
  text-decoration: underline;
  color: #c40;
  margin-top: -2.5vw;
  font-size: 3vw;
}
section#topTicket .content #figure_ticket_map_01 {
  margin-bottom: 6vw;
}
section#topTicket .content #figure_ticket_map_01 img {
  width: 100%;
}
section#topTicket .content #figure_ticket_map_01 figcaption {
  display: block;
  padding-top: 2vw;
  font-size: 2.6vw;
}
section#topTicket .content #figure_ticket_map_01 figcaption .text_red {
  color: #f62503;
}
section#topTicket .content #figure_ticket_map_01 figcaption .text_yellow {
  color: #f2a300;
}
section#topTicket .content #figure_ticket_area {
  width: 100%;
}
section#topTicket .content #figure_ticket_area img {
  width: 100%;
}
section#topTicket .content #figure_ticket_map_02 {
  width: 100%;
}
section#topTicket .content #figure_ticket_map_02 img {
  width: 100%;
}
section#topTicket #topTicket_bottom {
  display: none;
}

section#topClothes {
  background-color: #FFF;
  padding: 5vw;
  position: relative;
}
section#topClothes .content {
  width: 100%;
  margin: 0 auto;
}

section#topAccess {
  background-color: #d4dd9a;
  padding: 5vw;
  position: relative;
}
section#topAccess::after {
  content: '';
  width: 100%;
  height: 11.5vw;
  background: url("img/clip_mountain.png") no-repeat center bottom/cover;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 1;
}
section#topAccess .content {
  width: 90vw;
  margin: 0 auto;
  padding: 5vw;
  background-color: #FFF;
}
section#topAccess .content h2 {
  height: 7vw;
}
section#topAccess .content h2 img {
  height: 7vw;
}
section#topAccess .content .contentInBox {
  margin: 5vw 0;
}
section#topAccess .content .contentInBox dl {
  margin-bottom: 5vw;
}
section#topAccess .content .contentInBox dl div {
  display: flex;
}
section#topAccess .content .contentInBox dl div dt {
  font-size: 4vw;
  color: #49BCBD;
}
section#topAccess .content .contentInBox dl div dd {
  font-size: 3.8vw;
  padding-left: 1vw;
}
section#topAccess .content .contentInBox dl div dd span {
  font-size: 2.6vw;
  display: block;
  margin-top: -1vw;
}
section#topAccess .content .contentInBox iframe {
  width: 100%;
  height: 50vw;
  margin-bottom: 5vw;
}
section#topAccess .content .contentInBox p {
  font-size: 2.6vw;
}

section#topFaq {
  background-color: #fff;
  padding: 5vw;
  position: relative;
}
section#topFaq::after {
  content: '';
  width: 100%;
  height: 11.5vw;
  background: url("img/clip_mountain.png") no-repeat center bottom/cover;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 1;
}
section#topFaq .content {
  width: 90vw;
  margin: 0 auto;
  padding: 5vw;
  background-color: #ddd;
}
section#topFaq .content h2 {
  height: 7vw;
  margin-bottom: 5vw;
}
section#topFaq .content h2 img {
  height: 7vw;
}
section#topFaq .content h3 {
  font-size: 3.8vw;
}
section#topFaq .content p {
  font-size: 2.6vw;
}
section#topFaq .content #faq_qanda {
  margin-top: 5vw;
  padding-top: 5vw;
  border-top: 2px solid #222;
}
section#topFaq .content #faq_qanda h3 {
  padding: 2vw 20px 2vw 0;
  background: url("img/icon_arrow_carrotDown.svg") no-repeat right center/20px 20px;
}
section#topFaq .content #faq_qanda dl {
  display: none;
}
section#topFaq .content #faq_qanda dl dt {
  padding: 3vw 20px;
  font-size: 3.8vw;
  background: url("img/icon_arrow_carrotDown.svg") no-repeat right center/20px 20px;
  cursor: pointer;
  border-top: 1px solid #ccc;
}
section#topFaq .content #faq_qanda dl dd {
  display: none;
  padding: 0 20px 3vw;
  font-size: 2.6vw;
  color: #666;
}
section#topFaq .content #faq_prevention h2 {
  height: 7vw;
}
section#topFaq .content #faq_prevention h2 img {
  height: 7vw;
}
section#topFaq .content #faq_prevention p {
  margin-top: 5vw;
  font-size: 2.6vw;
}
section#topFaq .content #faq_prevention ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
section#topFaq .content #faq_prevention ul li {
  flex-basis: 37vw;
  margin: 2vw 0 1vw;
  text-align: center;
  font-size: 2.6vw;
  line-height: 1.4;
}
section#topFaq .content #faq_prevention ul li img {
  margin-bottom: 5px;
}
section#topFaq .content #faq_contact {
  margin-top: 5vw;
  padding-top: 5vw;
  border-top: 2px solid #222;
}
section#topFaq .content #faq_contact h2 {
  height: 7vw;
  margin-bottom: 5vw;
}
section#topFaq .content #faq_contact h2 img {
  height: 7vw;
}
section#topFaq .content #faq_contact #faq_contact_mail {
  margin-top: 5vw;
}
section#topFaq .content #faq_contact #faq_contact_mail h3 {
  font-size: 3.8vw;
}
section#topFaq .content #faq_contact #faq_contact_mail p {
  font-size: 2.6vw;
}
section#topFaq .content #faq_contact #faq_contact_web {
  margin-top: 5vw;
}
section#topFaq .content #faq_contact #faq_contact_web h3 {
  font-size: 3.8vw;
}
section#topFaq .content #faq_contact #faq_contact_web p a {
  display: inline-block;
  padding: 3vw 5vw;
  background-color: #49BCBD;
  color: #FFF;
  font-size: 3.8vw;
  text-decoration: none;
}

section#konohana {
  background: url("img/bg_konohana.png") no-repeat center top/cover;
}
section#konohana .content .contentInBox {
  background: url("img/bg_hanabishi.png") no-repeat bottom right/contain;
  padding: 10vw 0;
  margin: 0 5vw;
  display: flex;
  align-items: center;
  flex-direction: row-reverse;
  justify-content: space-between;
}
section#konohana .content .contentInBox h2 {
  flex: 0 0 21.47619vw;
}
section#konohana .content .contentInBox h2 img {
  width: 21.47619vw;
}
section#konohana .content .contentInBox div {
  flex: 0 0 64vw;
}
section#konohana .content .contentInBox div figure img {
  width: 100%;
}
section#konohana .content .contentInBox div figure figcaption {
  text-align: right;
  font-size: 2vw;
  margin-top: 1vw;
}
section#konohana .content .contentInBox div .konohanaText {
  font-size: 2.5vw;
  margin-top: 5vw;
}

.lowerContent {
  background-color: #ddd;
  padding: 5vw;
  position: relative;
}
.lowerContent::after {
  content: '';
  width: 100%;
  height: 11.5vw;
  background: url("img/clip_mountain.png") no-repeat center bottom/cover;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 1;
}
.lowerContent .content {
  width: 90vw;
  margin: 0 auto;
  padding: 5vw;
  background-color: #FFF;
}
.lowerContent .content #titlebar_news {
  height: 7vw;
  margin-bottom: 7.5vw;
}
.lowerContent .content #titlebar_news img {
  height: 7vw;
}
.lowerContent .content .contentInBox {
  margin: 0 auto 5vw;
}
.lowerContent .content .contentInBox h1 {
  font-size: 3.8vw;
  line-height: 1.4;
  margin-bottom: 1vw;
}
.lowerContent .content .contentInBox time {
  font-size: 2vw;
  color: #929292;
  margin-bottom: 1vw;
}
.lowerContent .content .contentInBox .post_content {
  font-size: 2.6vw;
  color: #444;
  margin-top: 2vw;
}

.post_navigation {
  overflow: hidden;
  background-color: #eee;
  width: 100%;
  margin-top: 10vw;
}
.post_navigation > div {
  width: 50%;
}
.post_navigation > div a {
  padding: 2.5vw;
  display: block;
  text-align: center;
}
.post_navigation > div a:hover {
  background-color: #f0f0f0;
}
.post_navigation .prev {
  float: left;
}
.post_navigation .next {
  float: right;
}

#contact dl {
  margin-top: 7vw;
}
#contact dl dt {
  margin-top: 3vw;
}
#contact dl dd input, #contact dl dd textarea {
  padding: 2vw;
}
#contact dl dd .inquiry_phone {
  width: 25vw;
}
#contact #contact_submit {
  text-align: center;
  margin-top: 2.85714vw;
}
#contact #contact_submit input {
  font-size: 18px;
  display: inline-block;
  margin: 0 1vw;
  padding: 0.85714vw 1.19048vw;
  border: 2px solid #000;
}
#contact #contact_submit input[name=submitConfirm], #contact #contact_submit input[name=submitButton] {
  background-color: #49BBBC;
}
#contact #contact_submit input[name=submitBack] {
  background-color: #e8e8e8;
}

.pc_only {
  display: none !important;
}

.sp_only {
  display: block;
}

.is-error {
  color: #cc0044;
}

.clear::after {
  content: "";
  display: block;
  clear: both;
}

/*# sourceMappingURL=style_sp.css.map */
