@charset "UTF-8";

body {
font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", sans-serif;
font-size: 16px;
color: #000;
overflow-x: hidden;
}
main * { font-family: "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", sans-serif;}

@media screen and (max-width: 280px) { /*Galaxy Fold*/
  body {
  font-size: 14px;
  }
}

article{
width: 100%;
}
section{
  position: relative;
}
.active{
  opacity: 1;
}
a{
  transition: .3s;
}
a:link,
a:visited{
  color: #0952a4;
}
a:hover{
  opacity: 0.7;
}

/*
SP
==================================================== */
@media screen and (max-width: 759.9px) {
.spnone{
	display:none;
}

#container{
  position: relative;
  width: 100%;
}


/*footer*/
#footer {
	background-color: #F0F5FA;
}

#footer .inner {
	width: 96%;
	margin: 0 auto;
	padding: 2% 2%;
}

#footer .inner ul {
	font-size: 11px;
	line-height: 1.4;
    text-align: left;
}

#footer .inner ul li {
    display: inline-block;
    width: 46%;
	padding: 2% 0;
}

#footer .inner ul li:last-child {
    border-right: none;
}

#footer .copy {
	background-color: #0952a4;
    color: #FFFFFF;
    font-size: 9px;
    text-align: center;
    padding: 2% 0;
}

/*pagetop*/
#pagetop {
  display: none;
  position: fixed;
  right: 10px;
  bottom: 10px;
  z-index: 100;
}
#pagetop a {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  width: 3em;
  height: 3em;
  background-color: rgba(255,255,255,.5);
  border:solid 1px #152a8c;
  border-radius: 50vh;
}
#pagetop a::after {
  content: '';
  width: 7px;
  height: 7px;
  border-style: solid;
  border-width: 0 6px 9px 6px;
  border-color: transparent transparent #152a8c transparent;
}


}




/*
PC
==================================================== */
@media screen and (min-width: 760px),print {
.pcnone{
	display:none;
}
#container{
  position: relative;
  z-index:1;
}


/*footer*/
#footer {
	background-color: #F0F5FA;
}

#footer .inner {
	width: 990px;
	margin: 0 auto;
	padding: 20px 0;
}

#footer .inner ul {
	font-size: 13px;
	line-height: 1.4;
    text-align: center;
}

#footer .inner ul li {
    display: inline-block;
	padding: 0 6px;
	border-right: 1px solid #CCC;
}

#footer .inner ul li:last-child {
    border-right: none;
}

#footer .copy {
	background-color: #0952a4;
    color: #FFFFFF;
    font-size: 12px;
    text-align: center;
    padding: 10px 0;
}

/*pagetop*/
#pagetop {
  display: none;
  position: fixed;
  right: 50px;
  bottom: 50px;
  cursor: pointer;
  z-index: 100;
}
#pagetop a {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  width: 80px;
  height: 80px;
  background-color: rgba(255,255,255,.5);
  border:solid 1px #152a8c;
  border-radius: 50vh;
}
#pagetop a::after {
  content: '';
  width: 7px;
  height: 7px;
  border-style: solid;
  border-width: 0 6px 9px 6px;
  border-color: transparent transparent #152a8c transparent;
}
#pagetop a:hover {
  background-color: #152a8c;
}
#pagetop a:hover::after {
border-width: 0 6px 9px 6px;
border-color: transparent transparent #fff transparent;
}


}






/* =========================================================
◆lazyload
========================================================= */
.lazyload, .lazyloading {opacity: 0;}
.lazyloaded {
opacity: 1;
transition: opacity 500ms;
}

.inner{
	width: 96%;
	margin: 0 2%;
	padding: 24px 0;
	box-sizing: border-box;
}
/*760px以上*/
@media screen and (min-width: 760px),print {
.inner{
	width: 96%;
	max-width:970px;
	min-width:760px;
	margin: 0 auto;
	padding:50px 0;
	display: block;
}
}


/*main{ font-family: "Noto+Sans+JP" }*/
main img{
	border-radius: 2px;
	width: 100%; 
	max-width: 100%;
	height: auto;
}



.main-visual h1{}

/* ナビゲーション#e50038 231816 ef3f22
----------------------------------------*/
.cp_nav { background: #231816; }
.cp_nav .inner{ padding: 1em 0 0.5em; }

.cp_nav ul{
	flex-wrap: wrap;
    display: flex;
	justify-content: space-around;
	width: 96%;
    margin: auto;
}
.cp_nav li{
	width: 21%;	
    padding: 0 0 0.5em 0;
}
.cp_nav li span{
    padding: 0.5em 0;
    color: #fff;
    font-size: 0.7rem;
    text-align: center;
    display: block;
}
.cp_nav li:hover { }	
@media screen and (min-width: 760px) {
.cp_nav .inner{ padding: 1.5em 0 0.5em; }
.cp_nav ul{ justify-content: space-between; }
.cp_nav li{
	width: 11%;
    padding: 0.5em;
}
.cp_nav li span{
    font-size: 0.9rem;
}
}


/* section 
---------------------------------*/
#map,
#event,
#plan,
#dands,
#ticket,
#banner{
	color: #554236;
	font-size: 14px;
	line-height: 1.6;
}
@media screen and (min-width: 760px) {
#map,
#event,
#plan,
#dands,
#ticket,
#banner{
	font-size: 16px;
}
}


/* プラン 
----------------------------------------*/
#plan{ 	background: #ef3f22; }
#plan h2.ti_plan {
    font-size: 2rem;
    letter-spacing: 3px;
    font-weight: bold;
    color: #231816;
    text-align: center;
}
#plan h2.ti_plan span{ color: #fff; }
#plan p{ 
	color: #fff;
	font-size: 1.1rem;
    font-weight: bold;
	text-align: center;
}
ul.planbtn{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	width: 90%;
    margin: 1.5em auto 0;
}
#plan ul.planbtn li{ 
	width: 100%;
	margin-bottom: 1.5em;
}
@media screen and (min-width: 760px) {

#plan h2.ti_plan {
    font-size: 2.8rem;
    letter-spacing: 5px;
}
#plan p{ font-size: 1.3rem; }
#plan ul.planbtn{ margin-top: 1.5em; }
#plan ul.planbtn li:nth-child(odd) { width: 65%; }
#plan ul.planbtn li:nth-child(even) { width: 32%; }
}




/* map 
---------------------------------*/
#map{ background: #ffefaa; }
#map ul.col2Box{
	position: relative;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#map ul.col2Box::before{
	position: absolute;
    content: '';
    background: url("../images/il_map_sp.png") ;
    width: 115px;
    height: 161px;
    left: 0;
	bottom: -20%;
}
#map ul.col2Box li:nth-child(odd) { width: 40%; }
#map ul.col2Box li:nth-child(even) { width: 56%; }
#map p { margin-top: 1em; }
#map span { 
	display: block; 
	/*color: #fff;*/ 
	margin-top: 1em;
	font-size: 0.8rem;
}
@media screen and (min-width: 760px) {
#map ul.col2Box::before{
	position: absolute;
    content: '';
    background: url("../images/il_map.png") ;
    width: 200px;
    height: 277px;
    left: 3%;
	bottom: -15%;
}
#map h2.ti_map{ width: 100%; }
#map ul.col2Box{ }
#map ul.col2Box li:nth-child(odd) { width: 30%; }
#map ul.col2Box li:nth-child(even) { width: 60%; }

}

/* EVENT 
----------------------------------------*/
#event{ 
	padding: 4em 0 0;
	background: #fff5e2;
	z-index: -1;
}

#event h2.ti_main{
	width: 90%;
	margin: auto;
}
#event .schedule{
	margin-bottom: 5px;
	display: flex;
}
#event .schedule h4{
	background: #ee3f22;
    color: #fff;
    font-size: 0.9rem;
    font-weight: bold;
    padding: 0.3em 1em 0.1em;
    border-radius: 20px;	
}
#event .schedule span{
	margin-left: 0.5em;
	padding-top: 0.2em;
	font-size: 1em;
	font-weight: bold;
}
#event h3.ttl{
	font-weight: bold;
    font-size: 1.3rem;
    margin-bottom: 0.5em;
}
#event ul.col3Box{
	display: block;
	margin: 3em 0 0;
}
#event ul.col3Box li{ 
	width: 92%;
    margin: 2em auto 4em;
}
#event ul.col3Box li img{ border-radius: 8px; }
#event ul.col3Box li p{ 
	margin-top: 1em;
	font-size: 15px;
	line-height: 2;
}
@media screen and (min-width: 760px) {

#event{ 
	padding: 4em 0 2em;
}

#event h2.ti_main{
	width: 500px;
}
#event .schedule span{
	font-size: 0.9em;
}
#event h3.ttl{
    font-size: 1.1rem;
}
#event ul.col3Box{
	display: flex;
	justify-content: space-between;
}
#event ul.col3Box li{ 
	width: 30%;
    margin: 2em auto;
}
}


/* デジタルチケット 
----------------------------------------*/
#ticket {
	background: #e7d3c6; 
	padding: 4em 0;
}
#ticket h2.ti_ticket{
    position: relative;
    padding: 10px;
    border-radius: 5px;
    border: 2px solid #333;
    color: #333;
    font-weight: bold;
    font-size: 1.5em;
    text-align: center;
	letter-spacing: 2px;
}
#ticket h2.ti_ticket:before {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    height: 3px;
    width: 20px;
    background: #e7d3c6;
    content: "";
}
#ticket h2.ti_ticket:after {
    position: absolute;
    top: 90%;
    left: 50%;
    transform: translateX(-50%);
    height: 20px;
    width: 2px;
    background-color: #333;
    content: "";
}
#ticket h2.ti_ticket span{ 
	color: #d94d4f;
	position: relative;
}
#ticket h2.ti_ticket span:before{ 
    position: absolute;
    content: '';
    background: url("../images/ic_ticket_sp.png") ;
    width: 80px;
    height: 108px;
    top: -97%;
    left: -48%;
}

#ticket h3.ti_ticket02{
	color: #d94d4f;
    font-weight: bold;
    font-size: 1.3em;
    text-align: center;
	margin: 1em 0;
}

#ticket .ti_c_name{
	margin-bottom: 5px;
	display: flex;
}
#ticket .ti_c_name h4{
	background: #fff352;
    color: #000;
    font-size: 1rem;
    font-weight: bold;
    padding: 0.3em 1em 0.1em;
    border-radius: 20px;
	margin-bottom: 0.5em;
}

#ticket h3.ti_otoku{
	font-weight: bold;
    font-size: 1.3rem;
    margin-bottom: 0.5em;
	color: #C70206;
	line-height: 30px;
}

#ticket ul.col3Box{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
    margin-bottom: 4em;
}
#ticket ul.col3Box li{ 
	width: 95%;
    background: #fff;
    border-radius: 5px;
    padding: 1em;
	margin: 1em auto;
}
#ticket ul.col3Box h5{ 
	margin: 1em 0 0.5em;
    font-size: 1.1rem;
    font-weight: bold;
    line-height: 1.4;
}
#ticket ul.col3Box p.info{ 
	margin: 1em auto;
	line-height: 1.6;
}
#ticket ul.col3Box p.point{
	display: block;
	margin: 1em auto;
	font-size: 0.9rem;
	color: #C70206;
	line-height: 1.4;
	font-weight: bold;
}
@media screen and (min-width: 760px) {

#ticket h2.ti_ticket{
	font-size: 2em;
    padding: 15px;
}
#ticket h2.ti_ticket:before { }
#ticket h2.ti_ticket:after { }
#ticket h2.ti_ticket span{ }
#ticket h2.ti_ticket span:before{ 
    background: url("../images/ic_ticket.png") ;
    width: 129px;
    height: 116px;
    top: -102%;
    left: -50%;
}

#ticket h3.ti_ticket02{ font-size: 1.5em; }
#ticket h3.ti_ticket02:before{
    background: url("../images/ic_ticket.png") ;
    width: 122px;
    height: 122px;
    top: -310%;
    left: 4%;
}
	
#ticket .ti_c_name{ margin-bottom: 5px; }
#ticket .ti_c_name h4{ }
#ticket h3.ti_otoku{
    font-size: 1.1rem;
	line-height: 24px;
}

#ticket ul.col3Box{ }
#ticket ul.col3Box li{ width: 32%; }
#ticket ul.col3Box h5{ font-size: 1rem; }
#ticket ul.col3Box p.info{ font-size: 0.94rem; }
#ticket ul.col3Box p.point{ font-size: 0.9rem; }
}


/* banner 
---------------------------------*/
#banner{ background: #ebba99; }
#banner h2.ti_banner {
    font-size: 2rem;
    letter-spacing: 1px;
    font-weight: bold;
    color: #231816;
    text-align: center;
}
#banner h2.ti_banner span{ 
	color: #e74444;
	text-shadow: 2px 2px 0 #FFF, -2px -2px 0 #FFF,
              -2px 2px 0 #FFF, 2px -2px 0 #FFF,
              0px 2px 0 #FFF,  0-2px 0 #FFF,
              -2px 0 0 #FFF, 2px 0 0 #FFF;
}
#banner .cp_bnr{
    padding: 2em 1em;
	text-align: center;
}
#banner p{
    margin: 1em;
    font-size: 0.9rem;
    line-height: 1.6;
    font-weight: bold;
}
@media screen and (min-width: 760px) {
	
#banner h2.ti_banner {
    font-size: 3rem;
    letter-spacing: 3px;
}
#banner .cp_bnr{
    padding: 2em;
}
#banner p{
    font-size: 1rem;
}
}





/* D&S 
----------------------------------------*/
#dands{ padding: 5em 0 3em; }
#dands h2.ti_dands{
	position: relative;
	width: 70%;
	margin: 0 auto 3em;
}
#dands h2.ti_dands::before{
	position: absolute;
    content: '';
    background: url("../images/ti_dands_line_sp.png") ;
    width: 260px;
    height: 13px;
	bottom: -35px;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	-moz-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	z-index: 100;
}
#dands h2.ti_dands::after{
	position: absolute;
    content: '';
    background: url("../images/bg_dands_sp.png") ;
    width: 49px;
    height: 182px;
    bottom: -60px;
    left: -65px;
}
#dands .copy{ text-align: left; padding-top: 3em; }
#dands .dandsBox{
	position: relative;
	border: 5px solid #e50038;
	padding: 3em 1em;
	border-radius: 15px;
	margin: 3em 0;
}
#dands .dandsBox .dsBox {
	position: absolute;
    display: inline-block;
    top: -4px;
    right: 20px;
    padding: 4px 16px;
    border-radius: 5px;
    font-size: 0.8rem;
    background: #e50038;
    color: #fff;
}
#dands .ti_dands03{
	font-size: 2rem;
	font-weight: normal;
    margin-bottom: 0.7em;
	text-align: center;
	}
#dands .ti_dands03 span{
	display: block;
    font-size: 1rem;
    margin-top: -7px;
    line-height: 1.5;
}

#dands ul.col3Box,#dands ul.col2Box{
	display: block;
}
#dands ul.col3Box li,#dands ul.col2Box li{ 
	width: 92%;
    margin: 2em auto;
}
#dands ul.col3Box li img,#dands ul.col2Box li img{
	border-radius: 8px; 
}
@media screen and (min-width: 760px) {
#dands{ padding: 5em 0 3em; }
#dands h2.ti_dands {
	margin: 0 auto 4em;
	width: 347px;
}
#dands h2.ti_dands::before{
    background: url("../images/ti_dands_line.png") ;
    width: 386px;
    height: 18px;
	bottom: -50px;
}

#dands h2.ti_dands::after{
    background: url("../images/bg_dands.png") ;
    width: 99px;
    height: 371px;
    top: -60px;
    left: -300px;
}
#dands .copy{ text-align: center; }

#dands .dandsBox{
	border: 7px solid #e50038;
	padding: 2em;
}
#dands .dandsBox .dsBox {
    top: -4px;
    right: 20px;
    padding: 7px 16px;
    border-radius: 5px;
    line-height: 25px;
    font-size: 1rem;
}
	
#dands .ti_dands03{
	font-size: 3rem;
    margin-bottom: 0.7em;
	}
#dands .ti_dands03 span{
    font-size: 1.3rem;
    margin-top: -10px;
}

#dands ul.col3Box{
	display: flex;
	justify-content: space-between;
}
#dands ul.col3Box li{ width: 30%; }
#dands ul.col2Box{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	width: 65%;
    margin: 2em auto;
}
#dands ul.col2Box li{ width: 47%; }
#dands .dandsBox{ text-align: center; }
}
	


/*-----ボタン-----*/
a.btnCp,a.btn_ticket {
	display: block;
	color: #fff;
	font-size: 1rem;
	font-weight: bold;
	line-height: 1.4;
	text-align: center;
	background: #c7c7c7;
	border-radius: 60px;
	box-sizing: border-box;
	max-width: 360px;
	margin: 1em auto 0;
	position: relative;
}
	a.btnCp { padding: 1.3em 0.5em; }
	a.btn_ticket { padding: 0.9em 0.5em; }

a.btnCp span,a.btn_ticket span {
	position: relative;
	display: block;
	transform: translate(-3px, -3px);
	transition: 0.3s;
	z-index: +1;
}
a.btnCp:after,a.btn_ticket:after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	margin: auto;
	width: 100%;
	height: 100%;
	border-radius: 60px;
	box-sizing: border-box;
	transform: translate(-3px, -3px);
	transition: 0.3s;
}
	a.btnCp:after {	background: #231816; }
	a.btn_ticket:after{ background: #e13f0e;; }

a.btnCp:hover span,a.btn_ticket:hover span {
  transform: translate(0, 0);
}
a.btnCp:hover:after,a.btn_ticket:hover:after {
  transform: translate(0, 0);
}
@media screen and (min-width: 760px) {
a.btnCp{
	font-size: 1rem;
	max-width: 600px;
}
a.btn_ticket{
	font-size: 1rem;
	max-width: 250px;
}
}


/*------inview.ふわっと表示-------------------------------*/

.fadeIn_up {
  opacity: 0;
  transform: translate(0, 50%);
  transition: 1s;
}
.fadeIn_up.is-show {
  transform: translate(0, 0);
  opacity: 1;
}


@media only screen and (max-width: 759px) {
	.for_pc{ display: none; }	
}
@media only screen and (min-width: 760px) {
	.for_sp{ display: none; }
}








