@charset "utf-8";

/* =======================================

	CommonElements

======================================= */
html{
	overflow-x: hidden;
}

body {
	-webkit-text-size-adjust: 100%;
	font-size: 100%;
	line-height: 140%;
	font-family: "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, sans-serif;
	color: #000;
	text-align: center;
	background: #fff;
	visibility: hidden;
	overflow-x: hidden;
}

.new_scroll{
	margin-top: 30px;
	margin-left: 1%;
	width: 97%;
	height: 400px;
	overflow: scroll;
	overflow-x: hidden;
	border: #CCC 1px solid;
	background: #fff;
}

a:link { text-decoration:none; color: #000;}
a:visited { text-decoration:none; color: #000;}
a:active { text-decoration:none; color: #000;}
a:hover { text-decoration:none; color: rgba(0,0,0,0.49);}

	
#container {
	width: 100%;
	text-align: center;
	background-color:#FFF;
}

h1 {
	margin-top: 50px;
	font-family: "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, sans-serif;
	text-align: left;
	color: #393939;
	font-size: 60px;
	font-weight: bold;
}

h1:before{
 position:absolute;
 content:"";
 width:30px;
 height:30px;
 display:inline-block;
 border:15px solid transparent;
 box-sizing:border-box;
 border-left-color:#ffd800;
 margin-left: -40px;
 margin-top: -10px;
}

.h1_height {
	line-height:60px;
}

.h1_sp {
	line-height:45px;
	font-family: "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, sans-serif;
	text-align: left;
	color: #393939;
	font-size: 35px;
	font-weight: bold;
	padding: 5px 0 0 50px;
}

.h1_sp_height {
	line-height:45px;
}


/* fullSlideShow
--------------------------- */
.fullSlideShow {
	width: 100%;
	text-align: left;
	position: relative;
	overflow: hidden;
}
.fullSlideShow ul {
	top: 50%;
	left: 50%;
	width: 100%;
	position: fixed; /* absolute or fixed */
	overflow: hidden;
}
.fullSlideShow ul li {
	top: 0;
	left: 0;
	width: 100%;
	display: none;
	position: absolute;
}
.fullSlideShow ul li img {
	width: 100%;
}

/* fullSlideShow コンテンツページ
--------------------------- */
.fullSlideShow_con {
	width: 100%;
	text-align: left;
	position: relative;
	overflow: hidden;
	max-height:500px;
}
.fullSlideShow_con ul {
	top: 0%;
	left: 50%;
	width: 100%;
	position: fixed; /* absolute or fixed */
	overflow: hidden;
}
.fullSlideShow_con ul li {
	top: 0;
	left: 0;
	width: 100%;
	display: none;
	position: absolute;
}
.fullSlideShow_con ul li img {
	width: 100%;
}

/* SideNavi
------------------------- */
.fullSlideShow .btnPrev,
.fullSlideShow .btnNext {
    top: 50%;
    width: 30px;
    height: 40px;
    position: fixed; /* absolute or fixed */
    z-index: 105;
}
.fullSlideShow .btnPrev {
    left: 20px;
    background: transparent url(../img/btn_slid_l.png) no-repeat center center;
}
.fullSlideShow .btnNext {
    right: 20px;
    background: transparent url(../img/btn_slid_r.png) no-repeat center center;
}


/* PagiNation
--------------------------- */
.pagiNation {
	bottom: 30px;
	left: 0;
	width: 100%;
	height: 15px;
	text-align: center;
	position: fixed; /* absolute or fixed */
	z-index: 110; /* 非表示にする場合は「90」以下に */
 	visibility: hidden; /* 非表示にする場合は「hidden」に */
}

.pagiNation a {
	margin: 0 5px;
	width: 20px;
	height: 20px;
	display: inline-block;
	overflow: hidden;
	background: #000;
}
.pagiNation a.pnActive {
	filter:alpha(opacity=100)!important;
	-moz-opacity: 1!important;
	opacity: 1!important;
}


/* Wrapper
--------------------------- */
#wrapper {
	width: 100%;
	text-align: left;
	background: #fff;
	position: relative;
	z-index: 120;
}
/*
#notice {
	max-width: 100%;
	background: #FFFFFF;
	text-align: center;
	padding-top: 30px;
	padding-bottom: 30px;
}
*/
#notice {
	max-width: 100%;
	text-align: center;
	padding-top: 50px;
	padding-bottom: 30px;
	background-image: url(../picture/scroll_comingsoon.png);
	background-repeat: repeat-x;
	/*画像のサイズを指定する*/
    -webkit-background-size: 1680px 300px;
	background-size:  1680px 300px;
	-webkit-animation: bgscroll 2s linear infinite;
	animation: bgscroll 25s linear infinite;
	background-color: #ffffff;
}
@-webkit-keyframes bgscroll {
  0% {background-position: 0 0;}
  100% {background-position: 100vw 0;}
}
 @keyframes bgscroll {
  0% {background-position: 0 0;}
  100% {background-position: 100vw 0;}
}
#notice p {
	font-size: 14px;
	text-align: center;
	color: #393939;
	letter-spacing: 1px;
	line-height: 200%;
}

#information {
	max-width: 100%;
	text-align: center;
	padding-top: 50px;
	padding-bottom: 30px;
	/*background-image: url(../picture/scroll_information.png);*/
	background-repeat: repeat-x;
	/*画像のサイズを指定する*/
    -webkit-background-size: 1680px 300px;
	background-size:  1680px 300px;
	-webkit-animation: bgscroll 2s linear infinite;
	animation: bgscroll 25s linear infinite;
	background-color: #ffffff;
}
@-webkit-keyframes bgscroll {
  0% {background-position: 0 0;}
  100% {background-position: 100vw 0;}
}
 @keyframes bgscroll {
  0% {background-position: 0 0;}
  100% {background-position: 100vw 0;}
}
#information p {
	font-size: 14px;
	text-align: center;
	color: #393939;
	letter-spacing: 1px;
	line-height: 200%;
}

#column {
	max-width: 100%;
	text-align: center;
	padding-top: 50px;
	padding-bottom: 0px;
	/*
	background-image: url(../picture/scroll_column.png);
	*/
	background-repeat: repeat-x;
	/*画像のサイズを指定する*/
    -webkit-background-size: 1680px 300px;
	background-size:  1680px 300px;
	-webkit-animation: bgscroll 20s linear infinite;
	animation: bgscroll 25s linear infinite;
	background-color: #ffffff;
}
@-webkit-keyframes bgscroll {
  0% {background-position: 0 0;}
  100% {background-position: 100vw 0;}
}
 @keyframes bgscroll {
  0% {background-position: 0 0;}
  100% {background-position: 100vw 0;}
}

#column p {
	font-size: 14px;
	text-align: center;
	color: #393939;
	letter-spacing: 1px;
	line-height: 200%;
}

#about_concept {
	max-width: 100%;
	text-align: center;
	padding-top: 50px;
	padding-bottom: 30px;
	background-image: url(../picture/scroll_concept.png);
	background-repeat: repeat-x;
	/*画像のサイズを指定する*/
    -webkit-background-size: 1680px 300px;
	background-size:  1680px 300px;
	-webkit-animation: bgscroll 20s linear infinite;
	animation: bgscroll 25s linear infinite;
	background-color: #ffffff;
}

#about_concept p {
	font-size: 14px;
	text-align: center;
	color: #393939;
	letter-spacing: 1px;
	line-height: 200%;
}

#about_message {
	max-width: 100%;
	text-align: center;
	padding-top: 50px;
	padding-bottom: 30px;
	background-image: url(../picture/scroll_message.png);
	background-repeat: repeat-x;
	/*画像のサイズを指定する*/
    -webkit-background-size: 1680px 300px;
	background-size:  1680px 300px;
	-webkit-animation: bgscroll 20s linear infinite;
	animation: bgscroll 25s linear infinite;
	background-color: #ffffff;
}
#about_message p {
	font-size: 14px;
	text-align: center;
	color: #393939;
	letter-spacing: 1px;
	line-height: 200%;
}

#about_contact {
	max-width: 100%;
	text-align: center;
	padding-top: 50px;
	padding-bottom: 30px;
	background-image: url(../picture/scroll_contact.png);
	background-repeat: repeat-x;
	/*画像のサイズを指定する*/
    -webkit-background-size: 1680px 300px;
	background-size:  1680px 300px;
	-webkit-animation: bgscroll 20s linear infinite;
	animation: bgscroll 25s linear infinite;
	background-color: #ffffff;
}

#about_contact p {
	font-size: 14px;
	text-align: center;
	color: #393939;
	letter-spacing: 1px;
	line-height: 200%;
}

@-webkit-keyframes bgscroll {
  0% {background-position: 0 0;}
  100% {background-position: 1680px 0;}
}
 @keyframes bgscroll {
  0% {background-position: 0 0;}
  100% {background-position: 1680px 0;}
}



#about_open {
	max-width: 100%;
	text-align: center;
	padding-top: 50px;
	padding-bottom: 30px;
	background-repeat: repeat-x;
	/*画像のサイズを指定する*/
    -webkit-background-size: 1680px 300px;
	background-size:  1680px 300px;
	-webkit-animation: bgscroll 20s linear infinite;
	animation: bgscroll 25s linear infinite;
	background-color: #ffffff;
}

@-webkit-keyframes bgscroll {
  0% {background-position: 0 0;}
  100% {background-position: 1680px 0;}
}
 @keyframes bgscroll {
  0% {background-position: 0 0;}
  100% {background-position: 1680px 0;}
}

#about_open p {
	font-size: 14px;
	text-align: center;
	color: #393939;
	letter-spacing: 1px;
	line-height: 200%;
}

#about_price {
	max-width: 100%;
	text-align: center;
	padding-top: 50px;
	padding-bottom: 30px;
	background-image: url(../picture/scroll_price.png);
	background-repeat: repeat-x;
	/*画像のサイズを指定する*/
    -webkit-background-size: 1680px 300px;
	background-size:  1680px 300px;
	-webkit-animation: bgscroll 20s linear infinite;
	animation: bgscroll 25s linear infinite;
	background-color: #ffffff;
}
@-webkit-keyframes bgscroll {
  0% {background-position: 0 0;}
  100% {background-position: 1680px 0;}
}
 @keyframes bgscroll {
  0% {background-position: 0 0;}
  100% {background-position: 1680px 0;}
}

#about_price p {
	font-size: 14px;
	text-align: center;
	color: #393939;
	letter-spacing: 1px;
	line-height: 200%;
}

#about_event {
	max-width: 100%;
	text-align: center;
	padding-top: 50px;
	padding-bottom: 30px;
	background-image: url(../picture/scroll_event.png);
	background-repeat: repeat-x;
	/*画像のサイズを指定する*/
    -webkit-background-size: 1680px 300px;
	background-size:  1680px 300px;
	-webkit-animation: bgscroll 20s linear infinite;
	animation: bgscroll 25s linear infinite;
	background-color: #ffffff;
}
@-webkit-keyframes bgscroll {
  0% {background-position: 0 0;}
  100% {background-position: 1680px 0;}
}
 @keyframes bgscroll {
  0% {background-position: 0 0;}
  100% {background-position: 1680px 0;}
}

#about_event p {
	font-size: 14px;
	text-align: center;
	color: #393939;
	letter-spacing: 1px;
	line-height: 200%;
}

#about_ticket {
	max-width: 100%;
	text-align: center;
	padding-top: 50px;
	padding-bottom: 30px;
	background-image: url(../picture/scroll_ticket.png);
	background-repeat: repeat-x;
	/*画像のサイズを指定する*/
    -webkit-background-size: 1680px 300px;
	background-size:  1680px 300px;
	-webkit-animation: bgscroll 20s linear infinite;
	animation: bgscroll 25s linear infinite;
	background-color: #ffffff;
}
@-webkit-keyframes bgscroll {
  0% {background-position: 0 0;}
  100% {background-position: 1680px 0;}
}
 @keyframes bgscroll {
  0% {background-position: 0 0;}
  100% {background-position: 1680px 0;}
}

#about_ticket p {
	font-size: 14px;
	text-align: center;
	color: #393939;
	letter-spacing: 1px;
	line-height: 200%;
}


#message01 {
	max-width: 100%;
	background: #FEDD00;
	text-align: center;
	padding-top: 30px;
	padding-bottom: 30px;
}
#message01 p {
	font-size: 14px;
	text-align: center;
	color: #393939;
	letter-spacing: 1px;
	line-height: 200%;
}
#message02 {
	max-width: 100%;
	background: #D0006F;
	text-align: center;
	padding-top: 30px;
	padding-bottom: 30px;
}
#message02 p {
	font-size: 14px;
	text-align: center;
	color: #393939;
	letter-spacing: 1px;
	line-height: 200%;
}
#message03 {
	max-width: 100%;
	background: #787121;
	text-align: center;
	padding-top: 30px;
	padding-bottom: 30px;
}
#message03 p {
	font-size: 14px;
	text-align: center;
	color: #393939;
	letter-spacing: 1px;
	line-height: 200%;
}
#message04 {
	max-width: 100%;
	background: #e35205;
	text-align: center;
	padding-top: 30px;
	padding-bottom: 30px;
}
#message04 p {
	font-size: 14px;
	text-align: center;
	color: #393939;
	letter-spacing: 1px;
	line-height: 200%;
}
#faq{
	max-width: 100%;
	background: #f2c4b3;
	text-align: center;
	padding-top: 30px;
	padding-bottom: 30px;
}
#faq p {
	font-size: 14px;
	text-align: center;
	color: #393939;
	letter-spacing: 1px;
	line-height: 200%;
}
/*-----------------------------------------------------
#footer {
	background-color: #f0f8ff;
	padding: 20px auto;
	text-align: center;
	padding-top: 20px;
	padding-bottom: 20px;
}
#footer p {
	font-size: 10px;
	text-align: center;
	color: #393939;
}
-----------------------------------------------------*/

/*---------------FOOTER---------------*/

.footer {
	background-color: #f0f8ff;
	color:#000;
}
.footer_contents {
	max-width: 1080px;
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	padding-left:15px;
	padding-right:15px;
}
.footer_contents_sp {
	width: 100%;
	margin-left: auto;
	margin-right: auto;
}
.footer_left {
	width: 40%;
	padding-top:57px;
	float: left;
}
.footer_left p{
	padding-top:45px;
	text-align: left;
	font-size: 11px;
	line-height: 180%;
	letter-spacing: 1px;
}
.footer_right {
	width: 60%;
	padding-top:68px;
	float: left;
	text-align: right;
}
.footer_right li{
	list-style: none;
	font-size: 12px;
	margin-left: 27px;
	float: right;
}
.footer_center {
	width: 100%;
	padding-top:57px;
	text-align: center;
}
.footer_center p{
	padding-top:45px;
	text-align: center;
	font-size: 11px;
	line-height: 180%;
	letter-spacing: 1px;
}
.copyright{
	padding-top: 26px;
	padding-bottom: 50px;
	text-align: left;
	font-size: 10px;
	line-height: 180%;
	letter-spacing: 0.05em;
}
.copyright_center{
	padding-top: 26px;
	padding-bottom: 50px;
	text-align: center;
	font-size: 10px;
	line-height: 180%;
	letter-spacing: 0.05em;
}

#abuot {
	width: 100%;

	background: #696969;
	text-align: center;
}
#abuot p {
	font-size: 14px;
	text-align: center;
	color: #fff;
	letter-spacing: 1px;
	line-height: 200%;
}
#coming {
	width: 100%;
	background: #000000;
	text-align: center;
}
#coming p {
	font-size: 14px;
	text-align: center;
	color: #fff;
	letter-spacing: 1px;
	line-height: 200%;
}
#contents {
	max-width: 1080px;
	width: 100%;
	margin-left: auto;
	margin-right: auto;
}
#contents p {
	font-size: 18px;
	text-align: left;
	color: #393939;
	margin-top: 40px;
}
#center-contents {
	max-width: 1080px;
	width: 100%;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}
#center-contents p {
	font-size: 18px;
	text-align: center;
	color: #393939;
	margin-top: 40px;
}
.news {
	width: 100%;

	background: #000;
	text-align: center;
}
.news p {
	font-size: 14px;
	text-align: center;
	color: #fff;
	letter-spacing: 1px;
	line-height: 200%;
}
.abuot_news {
	width:1024px;
	margin:50px auto;
}

#feed {
	width:1032px;
	list-style:none;
	margin:0 -8px 0 0;
	padding:0;
}

.feed_li {
	width:250px;
	margin:0 8px 30px 0;
	float:left;
}

.feed_img {
	max-width:100%;
	height:auto;
}

.feed_date {
	display:block;
	margin-top:5px;
	font-size:11px;
	color:#FFF;
	line-height:20px;
	text-align:left;
}

.new {
	margin-left:1em;
	color:#F3D632;
}

.feed_title {
	display:block;
	font-size:12px;
	color:#FFF;
	line-height:23px;
	text-align:left;
}
.abuot_button {
	display:block;
	margin:0 auto;
	padding-bottom:50px;
}
.news_button {
	display:block;
	margin:0 auto;
	padding-bottom:80px;
}
.news_button02 {
	display:block;
	margin:0 auto;
	padding-bottom:0px;
}

.clearfix:after {
    visibility: hidden;
    display: block;
    content: " ";
    clear: both;
    height: 0;
}
* html .clearfix             { zoom: 1; } /* IE6 */
*:first-child+html .clearfix { zoom: 1; } /* IE7 */

.nofloat{
	overflow:hidden;
	zoom:1;
}

#project {
	width: 100%;
	position: relative;
	text-align: center;
	padding-bottom: 130px;
}

#why {
	width: 100%;
	background-image:url(../img/bg_chalkboard.jpg);
	background-position: center;
	background-size: cover;
}
.why_contents {
	width: 1024px;
	margin-left: auto;
	margin-right: auto;
}
.why_left {
	width: 290px;
	padding-top:95px;
	float: left;
}
.why_right {
	width: 734px;
	padding-top:95px;
	float: left;
}
#why p {
	font-size: 13px;
	text-align: left;
	color: #fff;
	letter-spacing: 1px;
	line-height: 200%;
}

.story_ent {
	background-image:url(../img/bg_story.jpg);
	background-position: center;
	background-size: cover;
	height: 400px;
	text-align: center;
}
.story_ent p {
	font-size: 14px;
	text-align: center;
	color: #fff;
	letter-spacing: 1px;
	line-height: 200%;
}

#contact {
	width: 100%;
	text-align: center;
	background-color: #fff;
}
#contact p {
	font-size: 14px;
	text-align: center;
	color: #000;
	letter-spacing: 1px;
	line-height: 200%;
	padding-top: 10px;
}


/*---------------CONTACT---------------*/
/*
#form{
	width:820px;
	display: block;
	margin:auto auto;
	font-size: 14px;
}

input  {
	border-top: none;
	border-left: none;
	border-right: none;
	border-bottom-color: #000;
	font-size: 14px;
	border-bottom: 1px solid;
}
textarea  {
	border-top: none;
	border-left: none;
	border-right: none;
	border-bottom-color: #000;
	font-size: 14px;
}

#f_bottom{
	text-align: left;
	font-size: 11px;
	padding-top: 38px;
	padding-left: 155px;
	padding-bottom: 150px;
	letter-spacing: 1px;
	line-height: 200%;
}

#form_btn input{
	border: none;
	margin-top: 40px;
	float: right;
}
*/
/*---------------GLOBAL---------------*/

.global {
	background-color:rgba(255,255,255,0.8);
	position: fixed;
	z-index: 1000;
	width: 100%;
	height: 50px;
}
.global_contents {
	width: 1080px;
	margin-left: auto;
	margin-right: auto;
}
.global_left {
	width: 40%;
	padding:8px 0;
	float: left;
	text-align: left;
}
.global_right {
	width: 60%;
	padding-top:17px;
	float: right;
	text-align: right;
}
.global_right li{
	list-style: none;
	font-size: 14px;
	float: left;
}
.global_right_margin{
	margin-left: 20px;
}


/* =======================================
	ClearFixElements
======================================= */
.fullSlideShow ul:after {
	content: ".";
	height: 0;
	clear: both;
	display: block;
	visibility: hidden;
}
.fullSlideShow ul {
	display: inline-block;
	overflow: hidden;
}
http://black-flag.net/devel/jQueryHeaderFixedFullScreenSlideShow/css/common.css#2



/* =======================================
	全画面ナビ
======================================= */
.cp_fullscreenmenu {
position: fixed;
z-index: 10001;
top: 0;
right: 0;
}
/*menuコンテンツ*/
.cp_fullscreenmenu .menu {
z-index: 500;
position: fixed;
top: 0;
right: 0;
display: flex;
visibility: hidden;
overflow: hidden;
width: 100%;
height: 100%;
pointer-events: none;
outline: 1px solid transparent;
-webkit-backface-visibility: hidden;
backface-visibility: hidden;
align-items: center;
justify-content: center;
}
.cp_fullscreenmenu .menu > div {
display: flex;
overflow: hidden;
width: 200vw;
height: 200vw;
transition: all 0.4s ease;
-webkit-transform: scale(0);
transform: scale(0);
text-align: center;
color: #fefefe;
background: rgba(0,0,0,0.7);
flex: none;
-webkit-backface-visibility: hidden;
backface-visibility: hidden;
align-items: center;
justify-content: center;
}
.cp_fullscreenmenu .menu > div > ul {
display: block;
max-height: 100vh;
margin: 0;
padding: 0 1em;
list-style: none;
transition: opacity 0.4s ease;
opacity: 0;
}
.cp_fullscreenmenu .menu > div > ul > li {
font-size: 24px;
display: block;
margin: 1em;
padding: 0;
}
.cp_fullscreenmenu .menu > div > ul > li > a {
position: relative;
display: inline;
cursor: pointer;
transition: color 0.4s ease;
}
.cp_fullscreenmenu .menu > div > ul > li > a:hover {
color: #e5e5e5;
}
.cp_fullscreenmenu .menu > div > ul > li > a:hover:after {
width: 100%;
}
.cp_fullscreenmenu .menu > div > ul > li > a:after {
position: absolute;
z-index: 1;
bottom: -0.15em;
right: 0;
width: 0;
height: 2px;
content: '';
transition: width 0.40s ease;
background: #e5e5e5;
}

/*クリックしたらメニューが開閉の動作*/
.cp_fullscreenmenu .toggle {
position: absolute;
z-index: 1102;
top: 0;
right: 0;
width: 60px;
height: 60px;
cursor: pointer;
opacity: 0;
}
.cp_fullscreenmenu .toggle:checked + .hamburger > span {
-webkit-transform: rotate(135deg);
transform: rotate(135deg);
}
.cp_fullscreenmenu .toggle:checked + .hamburger > span:before,
.cp_fullscreenmenu .toggle:checked + .hamburger > span:after {
top: 0;
-webkit-transform: rotate(90deg);
transform: rotate(90deg);
}
.cp_fullscreenmenu .toggle:checked + .hamburger > span:after {
opacity: 0;
}
.cp_fullscreenmenu .toggle:checked ~ .menu {
visibility: visible;
pointer-events: auto;
}
.cp_fullscreenmenu .toggle:checked ~ .menu > div {
transition-duration: 0.75s;
-webkit-transform: scale(1);
transform: scale(1);
}
.cp_fullscreenmenu .toggle:checked ~ .menu > div > ul {
opacity: 1;
}
.cp_fullscreenmenu .toggle:checked ~ .menu > div > ul li:nth-of-type(1) {
transition-delay: 0.2s;
}
.cp_fullscreenmenu .toggle:checked ~ .menu > div > ul li:nth-of-type(2) {
transition-delay: 0.3s;
}
.cp_fullscreenmenu .toggle:checked ~ .menu > div > ul li:nth-of-type(3) {
transition-delay: 0.4s;
}
.cp_fullscreenmenu .toggle:checked ~ .menu > div > ul li:nth-of-type(4) {
transition-delay: 0.5s;
}
.cp_fullscreenmenu .toggle:checked ~ .menu > div > ul li:nth-of-type(5) {
transition-delay: 0.6s;
}
.cp_fullscreenmenu .toggle:checked ~ .menu > div > ul li:nth-of-type(6) {
transition-delay: 0.7s;
}
.cp_fullscreenmenu .toggle:hover + .hamburger {
box-shadow: inset 0 0 10px rgba(0, 0, 0, 0.1);
}
.cp_fullscreenmenu .toggle:checked:hover + .hamburger > span {
-webkit-transform: rotate(225deg);
transform: rotate(225deg);
}

/*ハンバーガー*/
.cp_fullscreenmenu .hamburger {
position: absolute;
z-index: 1001;
top: 0;
right: 0;
display: block;
width: 40px;
height: 40px;
padding: 0.4em 0.5em;
cursor: pointer;
transition: box-shadow 0.4s ease;
border-radius: 0 0.12em 0.12em 0;
background: rgba(0,0,0,0);
-webkit-backface-visibility: hidden;
backface-visibility: hidden;
}
.cp_fullscreenmenu .hamburger > span {
position: relative;
top: 50%;
display: block;
width: 100%;
height: 2px;
transition: all 0.4s ease;
background: #000000;
}
.cp_fullscreenmenu .hamburger > span:before,
.cp_fullscreenmenu .hamburger > span:after {
position: absolute;
z-index: 1;
top: -10px;
right: 0;
display: block;
width: 100%;
height: 2px;
content: '';
transition: all 0.4s ease;
background: inherit;
}
.cp_fullscreenmenu .hamburger > span:after {
top: 10px;
}

/*ヘッダー 問合せボタン*/
.btn-border {
	background-color: #68b4f4;
	display: inline-block;
	max-width: 80px;
	text-align: center;
	border: 2px solid #68b4f4;
	font-size: 14px;
	color: #FFF;
	text-decoration: none;
	font-weight: bold;
	padding: 3px 6px;
	border-radius: 8px;
	transition: .4s;
	letter-spacing: 1px;
	margin-right:120px;
	margin-top: -6px;	
}
.btn-border:link {
	color: #FFF;
}
.btn-border:hover {
	background-color: #3e94dd;
	border-color: #3e94dd;
	color: #FFF;
}

/*共通ボタン*/
.btn,
a.btn,
button.btn {
  position: relative;
  display: inline-block;
  padding: 1rem 4rem;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  letter-spacing: 0.1em;
  color: #212529;
}
.btn-common {
	background-color: #FFFFFF;
	display: inline-block;
	width: 160px;
	text-align: center;
	border: 1px solid #969696;
	font-size: 14px;
	color: #969696;
	text-decoration: none;
	padding: 12px 20px;
	border-radius: 20px;
	transition: .4s;
	letter-spacing: 1px;
}
.btn-common:link {
	color: #393939;
}
.btn-common:hover {
	background-color: #969696;
	border-color: #969696;
	color: #FFFFFF;
}

/*共通ボタン 下線ver*/
.btn_line {
  position: relative;
  display: inline-block;
  color: #e41313;
  text-decoration: none;
  font-size: 18px;
  font-weight: bold;
  line-heigt: 1em;
  -webkit-transition: .8s;
  transition: .8s;
  border-bottom:2px solid #ffd800;
  padding-bottom: 10px;
}
.btn_line:hover {
  cursor: pointer;
  text-decoration: none;
}
.btn_line::after {
  position: absolute;
  bottom: -2px;
  left: 0;
  content: '';
  width: 100%;
  height: 2px;
  background: #393939;
  transform: scale(0, 1);
  transform-origin: right top;
  transition: transform .3s;
}
.btn_line:hover::after {
  transform-origin: left top;
  transform: scale(1, 1);
}


.fa-position-right {
  position: absolute;
  top: calc(50% - .5em);
  right: 1rem;
}

/*縁取りタイトル*/
.faq_title {
	margin-top: 50px;
	font-family: "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, sans-serif;
	text-align: left;
	color: #FFFFFF;
	font-size: 60px;
	font-weight: bold;
	text-shadow:
	1px 0 0 black,
	0 1px 0 black,
	-1px 0 0 black,
	0 -1px 0 black
}
.faq_title_sp {
	margin-top: 50px;
	padding: 5px 0 0 50px;
	font-family: "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, sans-serif;
	text-align: left;
	color: #FFFFFF;
	font-size: 35px;
	font-weight: bold;
	text-shadow:
	1px 0 0 black,
	0 1px 0 black,
	-1px 0 0 black,
	0 -1px 0 black
}

/*スライダー*/
.slider {
	max-width: 1080px;
	width: 100%;
	margin: 30px auto;
}
.slick-slide {
	margin: 0px 20px;
}
.slick-slide img {
	width: 100%;
}
.slick-prev:before,
.slick-next:before {
	color: black;
}
.slick-slide {
	transition: all ease-in-out .2.5s;
	opacity: 1;
}
.slick-active {
	opacity: 1;
}
.slick-current {
	opacity: 1;
}

/*斜め背景 お知らせ-コラム*/
.section1,
.section2{
  /*レイアウト用のCSS*/
  padding: 50px;
}
.section1{
  position: relative;
 
  /*上側の色*/
  background-color: #FFFFFF;
}
.section1::before{
  content:"";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 0;
  border-style: solid;
 
  /*ここで三角形のサイズを決める。
  必ず幅100vwにして、ブラウザサイズいっぱいにしてください。*/
  border-width: 60px 0px 0px 100vw ;
  
  /*下側の色*/
  border-color: transparent transparent transparent #ffddd7;
}

/*コラム記事*/
.column_box{
  position:relative;
  background-color: #FFFFFF;
  width: 70%;
  height: 150px;
  box-shadow: 0px 10px 10px 0px rgba(0, 0, 0, 0.3);
  margin-top: 30px;
  margin-bottom: 40px;
}
.column_box_sp{
  position:relative;
  background-color: #FFFFFF;
  margin: 30px 5% 40px 5%;
  width: 90%;
  box-shadow: 0px 10px 10px 0px rgba(0, 0, 0, 0.3);
}
/*コラム記事画像*/
.column_box_picture{
  width: 37%;
}
/*コラム記事タイトル*/
.column_box_title{
  font-weight:bold;
  text-align:left;
  font-size:15px;
  padding: 20px 30px 20px 30px;
  line-height:20px;
  vertical-align:top;
}
.column_box_title_sp{
  font-weight:bold;
  text-align:left;
  font-size:13px;
  padding: 15px 15px 10px 15px;
  line-height:20px;
  vertical-align:top;
}
/*コラム記事本文*/
.column_box_text{
  text-align:left;
  font-size:13px;
  padding: 0 30px 0px 30px;
  line-height:20px;
  vertical-align:top;
}
.column_box_text_sp{
  text-align:left;
  font-size:12px;
  padding: 0 15px 15px 15px;
  line-height:20px;
  vertical-align:top;
}
/*コラム記事背景*/
.back_columnbox{
  background-image:url(../picture/back_columnbox.png);
  background-repeat: no-repeat;
  background-position: left top;
  margin-top: 30px;
}
/*コラム下 About背景*/
.back_about{
  background-image:url(../picture/sample_about_back.png);
  background-repeat: no-repeat;
  background-position: left top;
  margin-top: 100px;
  padding-top: 40px;
  padding-left: 25%;
  text-align:right;
  height: 420px;
}
.back_about_sp{
  background-image:url(../picture/sample_about_back_sp02.png);
  background-repeat: no-repeat;
  background-position: left top;
  margin-top: 50px;
  padding-top: 5px;
  padding-left: 0%;
  text-align:right;
  height: 580px;
}
.back_about_sp_whitebox{
  background:rgba(255,255,255,0.7);
  padding: 5px 0 5px 0;
}
/*コラム下 About本文*/
.about_text{
  margin-top: 50px;
  text-align:left;
  vertical-align:top;
  font-weight:bold;
}
/* 画面外にいる状態 */
.scroll_fadein {
  opacity : 0;
  transform : translate(0, 50px);
  transition : all 500ms;
}

/* 画面内に入った状態 */
.scroll_fadein.scrollin {
  opacity : 1;
  transform : translate(0, 0);
}


/*メニュー記事*/
.menu01_back{
  background-image:url(../picture/menu01_back.png);
  position:relative;
  width: 100%;
  height: 440px;
}
.menu01_back_sp{
  background-image:url(../picture/menu01_back_sp.png);
  position:relative;
  max-height: 800px;
  background-repeat:no-repeat;
}
.menu02_back{
  background-image:url(../picture/menu02_back.png);
  position:relative;
  width: 100%;
  height: 440px;
}
.menu02_back_sp{
  background-image:url(../picture/menu02_back_sp.png);
  position:relative;
  max-height: 800px;
  background-repeat:no-repeat;
}
.menu03_back{
  background-image:url(../picture/menu03_back.png);
  position:relative;
  width: 100%;
  height: 440px;
}
.menu03_back_sp{
  background-image:url(../picture/menu03_back_sp.png);
  position:relative;
  max-height: 800px;
  background-repeat:no-repeat;
}
.menu04_back{
  background-image:url(../picture/menu04_back.png);
  position:relative;
  width: 100%;
  height: 440px;
}
.menu04_back_sp{
  background-image:url(../picture/menu04_back_sp.png);
  position:relative;
  max-height: 800px;
  background-repeat:no-repeat;
}

/*メニュー文字*/
.menu_box_title {
	padding-top:100px;
	padding-left: 30px;
	font-size: 26px;
	text-align: left;
	color: #393939;
	height:60px;
	font-weight: bold;
}
.menu_box_title_sp {
	padding-left: 15px;
	padding-top: 25px;
	font-size: 30px;
	text-align: left;
	color: #393939;
	font-weight: bold;
	vertical-align:top;
}
.menu_box_txt {
	padding-left: 30px;
	font-size: 16px;
	text-align: left;
	color: #393939;
	font-weight: bold;
	line-height:26px;
	height:60px;
	padding-bottom:40px
}
.menu_box_txt_sp {
	padding-left: 15px;
	padding-right: 15px;
	padding-top: 25px;
	font-size: 14px;
	text-align: left;
	color: #393939;
	font-weight: bold;
	line-height:24px;
	padding-bottom:40px
}
.menu_box_button {
	text-align: center;
	padding-left: 30px;
}
.menu_box_button_sp {
	text-align: center;
	padding-bottom: 20px;
}


/*斜め背景 コラム-メッセージ01*/
.section2,
.section3{
  /*レイアウト用のCSS*/
  padding: 50px;
}
.section2{
  position: relative;
 
  /*上側の色*/
  background-color: #FEDD00;
}
.section2::before{
  content:"";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 0;
  border-style: solid;
 
  /*ここで三角形のサイズを決める。
  必ず幅100vwにして、ブラウザサイズいっぱいにしてください。*/
  border-width: 0px 0px 100px 100vw;
  
  /*下側の色*/
  border-color: transparent transparent transparent #ffffff;
}

.box01 {
  z-index: 500;
  position: relative;
  top: 100px;
  left: 85%;
  width: 100px;
  height: 100px;
  margin-top: -100px;
  border-radius:3px;
  background: #1f8fad;
  opacity : 0.3;
  animation: mochimochi 1.2s infinite;
}
.box01_sp {
  z-index: 500;
  position: relative;
  top: 110px;
  left: 60%;
  width: 80px;
  height: 80px;
  margin-top: -100px;
  border-radius:3px;
  background: #1f8fad;
  opacity : 0.2;
  animation: mochimochi 1.2s infinite;
}


.box02 {
  z-index: 500;
  position: relative;
  top: 398px;
  left: 44%;
  width: 50px;
  height: 50px;
  margin-top: -50px;
  border-radius:3px;
  background: #0107fb;
  opacity : 0.3;
  animation: mochimochi 1.2s infinite;
}
.box02_sp {
  z-index: 500;
  position: relative;
  top: 398px;
  left: 20%;
  width: 50px;
  height: 50px;
  margin-top: -50px;
  border-radius:3px;
  background: #0107fb;
  opacity : 0.2;
  animation: mochimochi 1.2s infinite;
}

.box03 {
  z-index: 500;
  position: relative;
  top: 220px;
  left: 95%;
  width: 100px;
  height: 100px;
  margin-top: -100px;
  border-radius:3px;
  background: #fdcd82;
  opacity : 0.3;
  animation: mochimochi 1.2s infinite;
}
.box03_sp {
  z-index: 500;
  position: relative;
  top: 220px;
  left: 75%;
  width: 80px;
  height: 80px;
  margin-top: -100px;
  border-radius:3px;
  background: #fdcd82;
  opacity : 0.3;
  animation: mochimochi 1.2s infinite;
}

.box04 {
  z-index: 500;
  position: relative;
  top: 520px;
  left: 8%;
  width: 50px;
  height: 50px;
  margin-top: -50px;
  border-radius:3px;
  background: #7b6505;
  opacity : 0.3;
  animation: mochimochi 1.2s infinite;
}
.box04_sp {
  z-index: 500;
  position: relative;
  top: 300px;
  left: 4%;
  width: 50px;
  height: 50px;
  margin-top: -50px;
  border-radius:3px;
  background: #7b6505;
  opacity : 0.3;
  animation: mochimochi 1.2s infinite;
}

.box05 {
  z-index: 500;
  position: relative;
  top: 85px;
  left: -2%;
  width: 100px;
  height: 100px;
  margin-top: -100px;
  border-radius:3px;
  background: #0b7752;
  opacity : 0.3;
  animation: mochimochi 1.2s infinite;
}
.box05_sp {
  z-index: 500;
  position: relative;
  top: 85px;
  left: 2%;
  width: 80px;
  height: 80px;
  margin-top: -100px;
  border-radius:3px;
  background: #0b7752;
  opacity : 0.3;
  animation: mochimochi 1.2s infinite;
}

.box06 {
  z-index: 500;
  position: relative;
  top: 85px;
  left: 80%;
  width: 65px;
  height: 65px;
  margin-top: -50px;
  border-radius:3px;
  background: #15a909;
  opacity : 0.3;
  animation: mochimochi 1.2s infinite;
}
.box06_sp {
  z-index: 500;
  position: relative;
  top: 150px;
  left: 82%;
  width: 65px;
  height: 65px;
  margin-top: -50px;
  border-radius:3px;
  background: #15a909;
  opacity : 0.3;
  animation: mochimochi 1.2s infinite;
}

.box07 {
  z-index: 500;
  position: relative;
  top: 400px;
  left: 50%;
  width: 30px;
  height: 30px;
  margin-top: -50px;
  border-radius:3px;
  background: #07c081;
  opacity : 0.3;
  animation: mochimochi 1.2s infinite;
}
.box07_sp {
  z-index: 500;
  position: relative;
  top: 350px;
  left: 30%;
  width: 35px;
  height: 35px;
  margin-top: -50px;
  border-radius:3px;
  background: #07c081;
  opacity : 0.3;
  animation: mochimochi 1.2s infinite;
}
.box08 {
  z-index: 500;
  position: relative;
  top: 220px;
  left: 8%;
  width: 50px;
  height: 50px;
  margin-top: -50px;
  border-radius:3px;
  background: #7b6505;
  opacity : 0.3;
  animation: mochimochi 1.2s infinite;
}
.box08_sp {
  z-index: 500;
  position: relative;
  top: 100px;
  left: 4%;
  width: 50px;
  height: 50px;
  margin-top: -50px;
  border-radius:3px;
  background: #7b6505;
  opacity : 0.3;
  animation: mochimochi 1.2s infinite;
}


/*
@keyframes mochimochi {
  0% {
    transform: scale(1, 0.8);
  }
  20% {
    transform: scale(0.8, 1.1);
  }
  90% {
    transform: scale(1, 1);
  }
  100% {
    transform: scale(1, 0.8);
  }
}

@keyframes fuwafuwa {
  0% {
    transform: translateY(0px);
  }
  50% {
    transform: translateY(-20px);
  }
  100% {
    transform: translateY(0px);
  }
}
*/

/*斜め背景 メッセージ01-メッセージ02*/
.section3,
.section4{
  /*レイアウト用のCSS*/
  padding: 50px;
}
.section3{
  position: relative;
 
  /*上側の色*/
  background-color: #FEDD00;
}
.section3::before{
  content:"";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 0;
  border-style: solid;
 
  /*ここで三角形のサイズを決める。
  必ず幅100vwにして、ブラウザサイズいっぱいにしてください。*/
  border-width: 40px 0px 0px 100vw;
  
  /*下側の色*/
  border-color: transparent transparent transparent #D0006F;
}


/*斜め背景 メッセージ02-メッセージ03*/
.section4,
.section5{
  /*レイアウト用のCSS*/
  padding: 50px;
}
.section4{
  position: relative;
 
  /*上側の色*/
  background-color: #787121;
}
.section4::before{
  content:"";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 0;
  border-style: solid;
 
  /*ここで三角形のサイズを決める。
  必ず幅100vwにして、ブラウザサイズいっぱいにしてください。*/
  border-width: 0px 0px 100px 100vw;
  
  /*下側の色*/
  border-color: transparent transparent transparent #D0006F;
}


/*斜め背景 メッセージ03-キャンペーン*/
.section5,
.section6{
  /*レイアウト用のCSS*/
  padding: 50px;
}
.section5{
  position: relative;
 
  /*上側の色*/
  background-color: #787121;
}
.section5::before{
  content:"";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 0;
  border-style: solid;
 
  /*ここで三角形のサイズを決める。
  必ず幅100vwにして、ブラウザサイズいっぱいにしてください。*/
  border-width: 70px 0px 0px 100vw;
  
  /*下側の色*/
  border-color: transparent transparent transparent #e35205;
}


/*斜め背景 キャンペーン-FAQ*/
.section6,
.section7{
  /*レイアウト用のCSS*/
  padding: 50px;
}
.section6{
  position: relative;
 
  /*上側の色*/
  background-color: #FFFFFF;
}
.section6::before{
  content:"";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 0;
  border-style: solid;
 
  /*ここで三角形のサイズを決める。
  必ず幅100vwにして、ブラウザサイズいっぱいにしてください。*/
  border-width: 70px 0px 0px 100vw ;
  
  /*下側の色*/
  border-color: transparent transparent transparent #f2c4b3;
}

/*FAQ 吹き出し*/
.bln {
  position: relative;
  display: inline-block;
  margin: 30px 10px 40px 10px;
  padding: 25px;
  background: #FFFFFF;
  border-radius: 50%;
}
 
.bln:before {
  position: absolute;
  content: "";
  top: 95%;
  left: 50%;
  margin-left: -15px;
  border: 15px solid transparent;
  border-top: 20px solid #FFFFFF;
}


/*-----------------以下Aboutページ-----------------*/
.image_message{
  background-image:url(../picture/image_message.png);
  background-repeat: no-repeat;
  background-position: right top;
  margin-top: 100px;
  padding-top: 140px;
  padding-left: 5%;
  text-align:left;
  height: 250px;
}

.image_message_sp{
  background-image:url(../picture/image_message_sp.png);
  background-repeat: no-repeat;
  background-position: left top;
  margin-top: 100px;
  padding-top: 140px;
  padding-left: 5%;
  text-align:left;
  height: 250px;
}

.image_about{
  background-image:url(../picture/image_contact.jpg);
  background-repeat: no-repeat;
  background-position: right top;
  margin-top: 100px;
  padding-top: 140px;
  padding-left: 5%;
  text-align:left;
  height: 250px;
}

.image_about_sp{
  background-image:url(../picture/image_contact_sp.jpg);
  background-repeat: no-repeat;
  background-position: left top;
  margin-top: 100px;
  padding-top: 140px;
  padding-left: 5%;
  text-align:left;
  height: 250px;
}
.image_payment{
  background-image:url(../picture/image_payment.png);
  background-repeat: no-repeat;
  background-position: right top;
  margin-top: 100px;
  padding-top: 140px;
  padding-left: 5%;
  text-align:left;
  height: 250px;
}

.image_payment_sp{
  background-image:url(../picture/image_payment_sp.png);
  background-repeat: no-repeat;
  background-position: left top;
  margin-top: 100px;
  padding-top: 140px;
  padding-left: 5%;
  text-align:left;
  height: 250px;
}
.image_profile{
  background-image:url(../picture/image_profile.png);
  background-repeat: no-repeat;
  background-position: right top;
  margin-top: 100px;
  padding-top: 140px;
  padding-left: 5%;
  text-align:left;
  height: 250px;
}

.image_profile_sp{
  background-image:url(../picture/image_profile_sp.png);
  background-repeat: no-repeat;
  background-position: left top;
  margin-top: 100px;
  padding-top: 140px;
  padding-left: 5%;
  text-align:left;
  height: 250px;
}
.image_open{
  background-image:url(../picture/image_open.png);
  background-repeat: no-repeat;
  background-position: right top;
  margin-top: 100px;
  padding-top: 140px;
  padding-left: 5%;
  text-align:left;
  height: 250px;
}

.image_open_sp{
  background-image:url(../picture/image_open_sp.png);
  background-repeat: no-repeat;
  background-position: left top;
  margin-top: 100px;
  padding-top: 140px;
  padding-left: 5%;
  text-align:left;
  height: 250px;
}

.image_menu{
  background-image:url(../picture/image_menu.png);
  background-repeat: no-repeat;
  background-position: right top;
  margin-top: 100px;
  padding-top: 140px;
  padding-left: 5%;
  text-align:left;
  height: 250px;
}

.image_menu_sp{
  background-image:url(../picture/image_menu_sp.png);
  background-repeat: no-repeat;
  background-position: left top;
  margin-top: 100px;
  padding-top: 140px;
  padding-left: 5%;
  text-align:left;
  height: 250px;
}

.image_event{
	background-image:url(../picture/image_event.png);
	background-repeat: no-repeat;
	background-position: right top;
	margin-top: 100px;
	padding-top: 140px;
	padding-left: 5%;
	text-align:left;
	height: 250px;
}

.image_event_sp{
	background-image:url(../picture/image_event_sp.png);
	background-repeat: no-repeat;
	background-position: left top;
	margin-top: 100px;
	padding-top: 140px;
	padding-left: 5%;
	text-align:left;
	height: 250px;
}

.image_p-tickets{
	background-image:url(../picture/image_p-ticket.png);
	background-repeat: no-repeat;
	background-position: right top;
	margin-top: 100px;
	padding-top: 140px;
	padding-left: 5%;
	text-align:left;
	height: 250px;
}

.image_p-tickets_sp{
	background-image:url(../picture/image_p-ticket_sp.png);
	background-repeat: no-repeat;
	background-position: left top;
	margin-top: 100px;
	padding-top: 140px;
	padding-left: 5%;
	text-align:left;
	height: 250px;
}

.company_profile_text {
	font-size: 14px;
	text-align: center;
	color: #393939;
	letter-spacing: 1px;
	line-height: 200%;
	margin-top:70px;
}

.scroll_txt {
	font-size: 24px;
	text-align: center;
	color: #393939;
	letter-spacing: 1px;
	line-height: 200%;
	white-space:nowrap;
}
