@charset "utf-8";

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

@import url('//fonts.googleapis.com/earlyaccess/notosansjapanese.css');
@import url('//fonts.googleapis.com/css?family=M+PLUS+1p:400,700,900');


html {
    background: #fff;
    font-family: "Noto Sans Japanese", "Mplus 1p", sans-serif;
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
    position: relative;
}

body {
    line-height: 1;
    -webkit-text-size-adjust: 100%;
    margin: 0;
    width: 100%;
    position: relative;
    z-index: 1;
}

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

.movie {
    margin: 0 auto 0 auto;
    position: relative;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
    max-width: 100%;
}

iframe {
    overflow-y: hidden;
    z-index: 1 !important;
}


.colorbox {
    display: none;
}
/*===================sp=*/
@media screen and (max-width: 860px) {}

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

/*-----------------------------------------------------------
	base setting
-----------------------------------------------------------*/
p {
    margin: 0 0 0 0;
}

a {
    text-decoration: underline;
    color: #00bdad;
}

a:hover {
    text-decoration: none;
}

a:focus {
    outline: none;
}

.pc {
    display: block !important;
}

.sp {
    display: none !important;
}

/*===================sp=*/
@media screen and (max-width: 860px) {

    .pc {
        display: none !important;
    }

    .sp {
        display: block !important;
    }

}

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

/*-----------------------------------------------------------
	text setting
-----------------------------------------------------------*/
h2 img,
h3 img,
h4 img {
    pointer-events: none !important;
}

.flt {
    text-decoration: line-through;
}

.fcG {
    color: #a4a4a4;
}

.fcB {
    color: #abebef;
}

.fcY {
    color: #ffa282;
}

.fcR {
    color: #960b0b;
}


.note {
    color: #939393;
    font-size: 14px;
}

/*===================sp=*/
@media screen and (max-width: 860px) {}

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

/*-----------------------------------------------------------
	header setting
-----------------------------------------------------------*/
#header {
    width: 100%;
    position: relative;
    margin: 0 0 0 0;
    top: 0;
    left: 0;
    z-index: 11;
}

.headerWrap {
    width: 100%;
    padding: 0 0 0 0;
    position: relative;
    z-index: 9;
}

/*----------------------------------#g_menu setting----------*/
#g_navi {
    margin: 0;
    width: 100%;
    height: auto;
    text-align: center;
    z-index: 9;
    padding: 0 0 0 0;
    top: 0;
    position: absolute;
}

#header.fix #g_navi {
    top: 0;
    position: fixed;
}

#g_menu .hdBox {
    width: 100%;
    padding: 0 0 0 0;
    overflow: hidden;
    position: fixed;
    z-index: 9;
}

#g_menu .hdBox2 {
    width: 100%;
}

#g_navi .btn {
    width: 12.5%;
    float: left;
}

#g_navi .logo {
    width: 30%;
    margin: 5vw auto 10px auto;
    padding: 0% 0 0 0;
    display: none;
}

#g_navi .hdBox2 .logo {
    display: block;
}

#g_navi #menuBtn {
    width: 10%;
    margin: 15px 15px 10px 0;
    float: right;
    line-height: 0;
    /* 		background: #a9153b; */
    /* 		box-shadow: 0 0 0 3px #000000; */
    /* 		background: #ed6c00; */
}

.f #g_navi #menuBtn {
    display: none;
}

#g_navi #menuClose {
    width: 10%;
    margin: 15px 15px 0 0;
    float: right;
}

#g_navi .navi {
    /* 		height: 60px; */
    position: relative;
    overflow: hidden;
    display: block;
    width: 100%;
    margin: 0 auto 0 auto;
    padding: 0 0 0 0;
    /* 		background: #ed6c00; */
}

#g_navi .nav {
    width: 100%;
    margin: 5% 0 5% 0;
    font-size: 4.0vw;
    color: #EEEEEE;
    overflow: hidden;
}

#g_navi .nav li {
    width: 100%;
    color: #ffffff;
    margin: 0 auto 0 auto;
    height: auto;
    border-left: none;
    line-height: 0;
    font-weight: 900;
}

.hdBox2 {
    padding: 0 0 0 0;
    overflow: hidden;
    position: relative;
    z-index: 2;
    background: #000000;
}

#g_navi .nav li a {
    height: auto !important;
    display: block;
    line-height: 1.0;

}

#g_navi .nav li.txt {
    font-size: 6.0vw;
    padding: 10px 0 0 0;
    color: #ffffff;
}

#g_navi .nav li p {
    line-height: 1.0;
    padding: 3% 0 3% 0;
}

body div#g_navi a {
    color: #ffffff;
    text-decoration: none;
}

body div#g_navi a:hover {
    text-decoration: none;
    opacity: 0.8;
}

#g_menu {
    position: absolute;
    width: 100%;
    margin: 0 0 0 0;
    padding: 0 0 0 0;
    z-index: 1000;
    display: none;
    top: 0;
    bottom: 0;
}

.fix #g_menu {
    top: 0;
}

#g_navi .navBox {
    background: #000000;
    width: 100%;
    margin: 0 auto 0 auto;
    overflow: hidden;
    padding: 0 0 200vw 0;
}

#g_navi .nav li.off p {
    color: #595959;
}

/*
		#g_navi .shareBox {
			width: 50%;
			line-height: 0;
			margin: 0 auto 0 auto;
			padding-bottom: 20px;
		}
			#g_navi .shareBox .tit {
				width: 50%;
				margin: 0 auto 0 auto;
			}
				#g_navi .shareBox ul {
					width: 100%;
					display: flex;
					justify-content: center;
					margin: 15px 0 0 0;
				}
				#g_navi .shareBox ul li {
					width: 15%;
					margin: 0 2.5% 0 2.5% ;
				}
					#g_navi .shareBox ul li a {
						width: auto;
						float: none;
					}
					#g_navi .shareBox ul li img {
						width: 100%;
						height: auto;
					}
					
					
*/
#g_navi .nav {
    width: 70%;
    margin: 0 auto 0 auto;
    padding: 0 5% 0 5%;
    text-align: left;
}

#g_navi .nav li {
    position: relative;
}

#g_navi .nav li {
    border: 1px solid rgba(204, 157, 106, 0.50);
    border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    margin: 0 0 2vw 0;

    text-align: center;
}

#g_navi .nav li.off p {
    display: -webkit-flex;
    display: flex;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

#g_navi .nav li.off p:after {
    content: "Coming soon";
    display: block;
    font-size: 11px;
    color: #a9153b;
    position: relative;
    margin-left: 3%;
    text-align: center;
    line-height: 1;
    letter-spacing: 0;
}




/*===================sp=*/
@media (min-width: 860px) {

    #header.fix {
        top: 0;
        position: fixed;
    }

    #header.fix #g_navi {
        top: 0;
        position: relative;
    }

    #g_navi #menuBtn {
        display: none;
    }

    #g_navi #menuClose {
        display: none;
    }

    #g_navi .navi {
        display: none;
    }

    #g_navi .shareBox {
        display: none;
    }

    #header {
        width: 100%;
        position: relative;
        margin: 0 0 0 0;
        top: 0;
        left: 0;
        z-index: 9;
        background: none;

        background: rgba(0, 0, 0, 0.70);
    }

    #header {
        position: absolute;
        top: 0;
        padding: 10px 0;
        z-index: 1000;
    }

    .headerWrap {
        width: 100%;
        max-width: 960px;
        background: none;
        padding: 0 0 0 0;
        margin: 0 auto 0 auto;
        position: relative;
        z-index: 9999;
    }

    #header.fix {
        top: 0;
        position: fixed;
    }

    #header.fix #g_navi {
        top: 0;
        position: relative;
    }

    #g_navi {
        background: none;
        padding: 0 0 0 0;
        position: relative;
        top: 0;

    }

    #g_menu {
        padding: 0 0 0 0;
        width: 100%;
        background: none;
        position: relative;
        display: block !important;
        overflow: auto;
        overflow-x: auto;
        overflow-y: auto;
        top: 0;
    }

    #g_menu .hdBox {
        padding: 0 0 0 0;
        border-bottom: none;
        z-index: 99;
    }

    #g_menu .hdBox2 {
        /* 			display: none; */
        width: 13%;
        background: none;
        padding: 0 0 0 0;
        margin-right: 0;
        overflow: hidden;
    }

    .inner #g_menu .hdBox2 {
        /* 			display: none; */
    }

    #g_navi .logo {
        width: 100%;
        margin: 0 auto 0 auto;
        padding: 0 0 0 0;
        display: block;
    }

    #g_navi .nav li.logo {
        width: 8%;
        padding: 0 0 0 0;
        margin: 0 0 0 0;
    }

    #g_navi .nav li.logo:hover {
        opacity: 0.5;
        filter: alpha(opacity=50);
        -ms-filter: "alpha(opacity=50)";
        -moz-opacity: 0.5;
        -khtml-opacity: 0.5;
    }

    #g_navi .navBox {
        width: 100%;
        margin: 0 0 0 0;
        padding: 0 0 0 0;
        border: none;
        background: none;

        display: -webkit-flex;
        display: flex;
        -webkit-align-items: center;
        align-items: center;
        -webkit-justify-content: space-between;
        justify-content: space-between;
    }

    #g_navi .nav {
        width: 100%;
        border: none;
        margin: 0 auto 0 auto;

        display: -webkit-flex;
        display: flex;

        -webkit-align-items: center;
        align-items: center;
        -webkit-justify-content: space-between;
        justify-content: space-between;

        -ms-flex-wrap: wrap;
        flex-wrap: wrap;

        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;


        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;

    }

    #g_navi .nav li {
        width: auto;
        color: #ffffff;
        margin: 0 0 0 0;
        padding: 0 1% 0 2%;
        border: none;
        font-size: 16px;
        position: relative;
        letter-spacing: 0.2em;

        background: url(../img/nav_sl.svg) no-repeat left center;
        background-size: auto 15px;
    }

    #g_navi .nav li:first-child {
        background: none;
    }

    #g_navi .nav li.off {
        color: #595959;
        font-size: 14px;
        font-weight: bold;
    }

    #g_navi .nav li.off p {
        display: block;
    }

    #g_navi .nav li.off p:after {
        content: "Coming soon";
        display: block;
        font-size: 11px;
        color: #a9153b;
        position: absolute;
        left: -50%;
        bottom: 0;
        width: 200%;

        text-align: center;
        line-height: 1;
        letter-spacing: 0;
    }

    #g_navi .nav li.cr,
    #g_navi .nav li.cr a {
        color: #e3ac2b;
    }

    #g_navi .nav li img {}

    #g_navi .nav li p {
        position: relative;
        padding: 15px 0 15px 0;
    }

    #g_navi .nav li a {
        display: block;
        text-decoration: none;
        color: #ffffff;
        font-weight: bold;
        padding: 0 0 0 0;
    }

    #g_navi .nav li:hover p {
        opacity: 0.5 !important;
        filter: alpha(opacity=50) !important;
        -ms-filter: "alpha(opacity=50)" !important;
        -moz-opacity: 0.5 !important;
        -khtml-opacity: 0.5 !important;
    }

    #g_navi .nav li.off:hover p {
        opacity: 1.0 !important;
        filter: alpha(opacity=100) !important;
        -ms-filter: "alpha(opacity=50)" !important;
        -moz-opacity: 1.0 !important;
        -khtml-opacity: 1.0 !important;
    }

    #g_navi .nav {
        background: none;
        width: 100%;
        margin: 0 auto 0 auto;
        padding: 0 0 0 0;
        text-align: left;
    }

}

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

/*-----------------------------------------------------------
	#parallax setting
-----------------------------------------------------------*/

/*固定する背景*/
#parallax .box {
    box-sizing: border-box;
    height: 100%;
    align-items: center;
}

#parallax.contentWrap {
    padding-bottom: 0;
}

.parallax-bg {
    /*background-attachment: fixed;*/
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    height: calc(100vh * 0.2);
}

/*各背景の画像*/
.img-bg-01 {
    background-image: url('../img/bg_par00.png');

    display: table;
    width: 100%;
    text-align: center;
    background-color: rgba(0, 0, 0, 0.8);
    background-blend-mode: lighten;
    padding: 1rem 0;
}

.img-bg-01 img {
    height: 60px;
}

.img-bg-01 span {
    display: table-cell;
    vertical-align: middle;
    color: #fff;
    text-shadow: 0 0 0.5em rgba(0, 0, 0, 1);

}

.img-bg-02 {
    background-image: url('../img/bg_par01.png');
    background-color: rgba(0, 0, 0, 0.8);
    background-position: top;
}

.img-bg-03 {
    background-image: url('../img/bg_par02.png');
    background-color: rgba(0, 0, 0, 0.8);
}

.img-bg-04 {
    background-image: url('../img/bg_par03.png');
    background-color: rgba(0, 0, 0, 0.8);
}

.img-bg-05 {
    background-image: url('画像のURL');
}

/*スクロールするコンテンツ*/
.scrollbox1 {
    /*background-color: #111;*/
}

.scrollbox2 {
    /*background-color: #222;*/
}

.scrollbox3 {
    /*background-color: #333;*/
}

.scrollbox4 {
    background-color: #444;
}

.scrollbox5 {
    background-color: #555;
}

.scrollbox6 {
    background-color: #666;
}

/*===================sp=*/
@media screen and (max-width: 860px) {
    .parallax-bg {
        background-size: 120%;
        height: calc(100vh * 0.2);
    }
}

/*-----------------------------------------------------------
	#content setting
-----------------------------------------------------------*/
body {
    background-image: url(../img/bg_main2.png), url(../img/bg_moyou.png);
    background-size: 100%, 100%;
    background-repeat:
        no-repeat,
        repeat-y;
    background-position:
        top, top;
    background-color: #f0f0f0;
}

body.inner {
    background: #f0f0f0;
}

body.inner.event {
    background: #000000;
}


#content {
    font-family: 'Noto Sans Japanese', sans-serif;
    width: 100%;
    margin: 0 auto 0 auto;
    padding: 0 0 40px 0;
    z-index: -2;
    position: relative;
    font-size: 14px;
    line-height: 1.8;
    color: #000;
    overflow: hidden;
}

.contentWrap {
    width: 100%;
    max-width: 100%;
    margin: 30px auto 0 auto;
    padding: 70px 0 70px 0;
    position: relative;
    z-index: 2;
}

.contentBox {
    width: 90%;
    max-width: 960px;
    margin: 50px auto 0 auto;
    padding: 0 0 0 0;
}

#content h2 {
    width: 100%;
    margin: 1rem auto 0 auto;
    text-align: center;
    color: #960b0b;
}

#content h2 img {
    width: 100%;
    max-width: 400px;
    /*filter:
		drop-shadow(1px 1px 10px rgba(0, 0, 0, 0.2))
		drop-shadow(-1px -1px 10px rgba(0, 0, 0, 0.2))
		drop-shadow(1px -1px 10px rgba(0, 0, 0, 0.2))
		drop-shadow(-1px 1px 10px rgba(0, 0, 0, 0.2))
		
		drop-shadow(1px 0px 5px rgba(0, 0, 0, 0.1))
		drop-shadow(-1px 0px 5px rgba(0, 0, 0, 0.1))
		drop-shadow(0px 1px 5px rgba(0, 0, 0, 0.1)) 
		drop-shadow(0px -1px 5px rgba(0, 0, 0, 0.1));*/
}

#content h2.tyL img {
    max-width: 700px;
}

#content h2 span {
    display: block;
    line-height: 1;
    margin-bottom: 2rem;
}

#content h3.deco {
    font-size: 120%;
    color: #007976;
    text-align: center;
    margin: 3rem auto 1rem auto;
    position: relative;
    line-height: 1.4;
    padding: 0.25em 2em;
    display: inline-block;
    top: 0;
    letter-spacing: 0.3em;
}

#content h3.deco:before,
#content h3.deco:after {
    position: absolute;
    top: 0;
    content: '';
    width: 8px;
    height: 100%;
    display: inline-block;
}

#content h3.deco:before {
    border-left: solid 1px #007976;
    border-top: solid 1px #007976;
    border-bottom: solid 1px #007976;
    left: 0;
}

#content h3.deco:after {
    content: '';
    border-top: solid 1px #007976;
    border-right: solid 1px #007976;
    border-bottom: solid 1px #007976;
    right: 0;
}

#content .normalbtn {
    display: block;
    padding: 5px ;
    margin: 10px auto;
    background-color: #000;
    color: #fff;
    text-decoration: none;
    max-width: 320px;
}

#content .normalbtn:hover{
    opacity: 0.8;
}

#content .normalbtn:link{
    color: #fff;
}

#content .normalbtn span {
    color: #960b0b;
    margin-right: 5px;
}

.movie iframe,
.movie object,
.movie embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}


/*===================sp=*/
@media screen and (max-width: 860px) {

    body {
        background-image: url(../img/bg_main2.png), url(../img/bg_moyou.png);
        background-size: 100%, 100%;
        background-repeat:
            no-repeat, repeat-y;
        background-position:
            top,
            /* 最前面の背景レイヤーに対応 */
            top;
    }

    #content {
        padding: 0 0 0 0;
    }

    .contentWrap {
        width: 100%;
        max-width: 960px;
        margin: 5vw auto 0 auto;
        padding: 5vw 0 10vw 0;
        position: relative;
    }

    .contentBox {
        margin: 5vw auto 0 auto;
        padding: 0 0 0 0;
    }

    #content h2 img {
        width: 100%;
        max-width: 80%;
    }

    #content h2.tyL img {
        max-width: 90%;
    }


}

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


#content .btnArea {
    max-width: 320px;
    margin: 2rem auto;
}

#content .btnArea img {
    width: 100%;
    max-width: 320px;
}

/*-----------------------------------------------------------
	mv setting
-----------------------------------------------------------*/
#main {
    width: 100%;
    max-width: 100%;
    height: 100%;
    margin: 0 auto 0 auto;
    padding: 60px 0 0 0;
    position: relative;
    z-index: -1;

}

#main .mainWrap {
    width: 100%;
    /*max-width: 1200px;*/

    height: 100%;
    margin: 0 auto 0 auto;
    line-height: 0;
    z-index: 2;
    position: relative;

    display: flex;
    flex-wrap: wrap;

    -webkit-box-align: stretch;
    -ms-flex-align: stretch;
    align-items: stretch;
    justify-content: space-between;
    
}

#main .mainBox {
    width: 100%;
    position: relative;
    /*height: 600px;*/
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    background-color: #040203;
}

#main .mainBox .pc {
    width: 100%;
    max-width: 920px;
}

#main .mainBox .tit {
    width: 70%;
    max-width: 707px;
    line-height: 0;
    margin-top: 42vw;
}

#main .mainBox .tit img {
    margin-bottom: 0;
}

#main .logo {
    width: 30%;
    max-width: 125px;
    position: absolute;
    right: 20px;
    top: 20px;
    opacity: 0.6;
}

#main .txt {
    width: 80%;
    max-width: 640px;
    margin: 0.5rem auto;
}


/*===================sp=*/
@media screen and (max-width: 860px) {
    #main .mainBox {
        /* height: 70vh;  */
        background-color:  transparent;

    }

    #main .mainBox img {
        width: 90%;
    }

    #main .mainBox .tit {
        width: 70%;
        max-width: 707px;
        line-height: 0;
        margin-top: 15vw;
        margin-bottom: 10vw;
    }

    #main .logo {
        width: 20%;
        position: absolute;
        right: 20px;
        top: 20px;
        opacity: 0.6;
    }

    #main .txt {
        width: 95%;
        /*width: 5.5vw;
		max-width: 5.5vw;
		position: absolute;
		left: 4%;
		right: auto;
		top: -10%;*/
    }

}

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

.inner #main {
    width: 100%;
    max-width: 100%;
    height: 100%;
    margin: 0 auto 0 auto;
    padding: 0 0 0 0;
    position: relative;
    z-index: -1;

}

.inner #main .mainWrap {
    width: 100%;
    max-width: 1200px;

    height: 100%;
    margin: 0 auto 0 auto;
    line-height: 0;
    z-index: 2;
    position: relative;

    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.inner .bgBox {
    position: relative;
    padding-top: 41%;
}

.inner.faq .mainWrap {
    background: url(../img/bg_faq.png) no-repeat left top;
    background-size: cover;
}

.inner #main .mainBox {
    width: 100%;
    height: 100%;
    position: relative;

    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.inner #main .mainBox .tit {
    width: 100%;
    max-width: 500px;
    line-height: 0;
    margin-top: 0;
}

.inner #main .mainBox .tit img {
    margin-bottom: 0;
    filter:
        drop-shadow(1px 1px 10px rgba(0, 0, 0, 0.2)) drop-shadow(-1px -1px 10px rgba(0, 0, 0, 0.2)) drop-shadow(1px -1px 10px rgba(0, 0, 0, 0.2)) drop-shadow(-1px 1px 10px rgba(0, 0, 0, 0.2)) drop-shadow(1px 0px 5px rgba(0, 0, 0, 0.1)) drop-shadow(-1px 0px 5px rgba(0, 0, 0, 0.1)) drop-shadow(0px 1px 5px rgba(0, 0, 0, 0.1)) drop-shadow(0px -1px 5px rgba(0, 0, 0, 0.1));
}


/*===================sp=*/
@media screen and (max-width: 860px) {


    .inner #main .mainBox .tit {
        width: 80%;
        max-width: 500px;
        line-height: 0;
        margin-top: 0;
    }

}

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

/*-----------------------------------------------------------
	#photo setting
-----------------------------------------------------------*/

#photo {
    width: 100%;
    padding: 30px 0 0 0;
    overflow: hidden;
}

#photo .section_wrap {
    width: 100%;
    position: relative;
}

#photo .images {
    width: 100%;
    position: relative;
    height: 180px;
}

#photo ul {
    list-style: none;
    position: absolute;
    top: 0;

    left: 0;
    width: 1560px;
    /*width: 2080px; 8枚の場合*/
    height: 100%;
    margin-left: -115px;
}

#photo ul li {
    width: 230px;
    line-height: 0;
    position: absolute;
    top: 0;
    left: 0;
    box-shadow: 0px 0px 8px -2px #000000;
}

#photo ul li img {
    width: 100%;
    height: auto;
    /* 	box-shadow: 0px 8px 15px 0px rgba(8, 1, 3, 0.5); */
}

#photo ul li:nth-child(1) {
    left: 0;
}

#photo ul li:nth-child(2) {
    left: 260px;
}

#photo ul li:nth-child(3) {
    left: 520px;
}

#photo ul li:nth-child(4) {
    left: 780px;
}

#photo ul li:nth-child(5) {
    left: 1040px;
}

#photo ul li:nth-child(6) {
    left: 1300px;
}

#photo ul li:nth-child(7) {
    left: 1560px;
}

#photo ul li:nth-child(8) {
    left: 1820px;
}

/*

#photo ul li:nth-child(9) { left: 2640px; }
#photo ul li:nth-child(10) { left: 2970px; }
#photo ul li:nth-child(11) { left: 3300px; }
#photo ul li:nth-child(12) { left: 3630px; }
#photo ul li:nth-child(13) { left: 3960px; }
#photo ul li:nth-child(14) { left: 4290px; }
#photo ul li:nth-child(15) { left: 4620px; }
#photo ul li:nth-child(16) { left: 4950px; }
#photo ul li:nth-child(17) { left: 5280px; }
*/


#photo .loopanime {
    -webkit-animation: image_list_animation 60s linear infinite;
    animation: image_list_animation 50s linear infinite;
}

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

    100% {
        transform: translateX(-1560px);
    }
}

@keyframes image_list_animation {
    0% {
        transform: translateX(0%);
    }

    100% {
        transform: translateX(-1560px);
    }
}

/*===================sp=*/
@media screen and (max-width: 860px) {}

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


/*-----------------------------------------------------------
	.icongroup setting
-----------------------------------------------------------*/
.icongroup p {
    margin: 3rem auto;
    text-align: center;
}

.icongroup img {
    width: 100%;
    margin: 0 auto;
    max-width: 540px;
}

/*-----------------------------------------------------------
	.stance setting
-----------------------------------------------------------*/
.stance h2 {
    font-size: 110%;
    padding-bottom: 1rem;
    line-height: 1.2;
}

.stance .bgcol {
    max-width: 600px;
    margin: 0 auto;
    padding: 1rem;
    background-color: rgba(255, 255, 255, 0.8);
}

.stance .bgcol p {
    font-size: 80%;
    margin-bottom: 1rem;
}

/*-----------------------------------------------------------
	.accordion setting
-----------------------------------------------------------*/
.acd-check {
    display: none;
}

.acd-label { 
    color: #fff;
    display: block;
    margin-bottom: 1px;
    padding: 10px;
    font-size: 80%;
    text-align: center;
}
.acd-label.bg {
    background: #333;
}
.acd-label img {
    max-width: 490px;
    margin: 0 auto;
}
.acd-content {
    border: 1px solid #333;
    height: 0;
    opacity: 0;
    padding: 0 10px;
    transition: .5s;
    visibility: hidden;
}

.acd-check:checked + .acd-label + .acd-content {
    height: auto;
    opacity: 1;
    padding: 10px;
    visibility: visible;
}

/*-----------------------------------------------------------
	#cm setting8}
-----------------------------------------------------------*/

#cm {
    padding: 0 0 0 0;
}

#cm .contentBox {
    width: 90%;
    max-width: 580px;
    margin: 50px auto 0 auto;
    padding: 0 0 0 0;
}


/*===================sp=*/
@media screen and (max-width: 860px) {

    #cm {}

    #cm .contentBox {
        width: 70%;
        margin: 7vw auto 0 auto;

    }



}

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



/*-----------------------------------------------------------
	#special setting
-----------------------------------------------------------*/

#special {
    padding: 0 0 0 0;
}

#special.contentWrap {
    margin-top: 0;
}

#special .contentBox {
    margin-top: 0;
    margin-bottom: 1rem;
}

.bnrBox {
    width: 100%;
    margin: 20px auto 0 auto;

    display: flex;
    justify-content: center;
    align-items: stretch;
    text-align: left;

}

.bnrBox li {
   /* width: 23%; 4つ*/
    width: 40%;
    margin: 0 1% 0 1%;

    background: #000000;
    /*box-shadow: 0 0 10px 2px rgba(232, 109, 0, 0.70);*/
    border: 1px solid rgba(232, 109, 0, 0.40);
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;

    line-height: 0;
    overflow: hidden;
    padding: 0 0 0 0;
}



/*===================sp=*/
@media screen and (max-width: 860px) {

    #special .bnrBox {
        margin: 2vw auto 0 auto;
        padding: 2vw 0 0 0;

        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    #special .bnrBox li {
        width: 80%;
    /*    width: 42%;*/
        margin: 0 2% 10px 2%;
    }


}

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



/*-----------------------------------------------------------
	#campaign setting
-----------------------------------------------------------*/

#campaign {
    margin: 80px auto 0 auto;
    padding: 0 0 0 0;
}

#campaign .bnrBox {
    width: 100%;
    margin: 30px auto 0 auto;

    display: flex;
    justify-content: center;
    align-items: stretch;
    text-align: left;


}

#campaign .bnrBox li {
    width: 23%;
    margin: 0 1% 0 1%;

    background: #000000;
    box-shadow: 0 0 10px 2px rgba(232, 109, 0, 0.70);
    border: 1px solid rgba(232, 109, 0, 0.40);

    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;

    line-height: 0;
    overflow: hidden;
    padding: 0 0 0 0;
}



/*===================sp=*/
@media screen and (max-width: 860px) {

    #campaign .bnrBox {
        margin: 2vw auto 0 auto;
        padding: 2vw 0 0 0;

        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    #campaign .bnrBox li {
        width: 42%;
        margin: 0 2% 20px 2%;
    }


}

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

/*-----------------------------------------------------------
	#news setting
-----------------------------------------------------------*/
#news {
    margin: 0 auto 0 auto;
    padding-bottom: 0;
    text-align: center;
    padding-top: 0px;
}

#news .box {
    width: 90%;
    /*min-height: 100px;*/
    text-align: center;
    border: 2px solid #664f35;
    border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;

    padding: 3% 5% 3% 5%;
}

#news .box_srcollbar {
    overflow:auto;
    width:100%;
    height:90px;
    color:#000;
    font-size:12px;
}

#news ul li {
    width: 100%;
}

#news ul li {
    margin: 0 0 10px 0;

    display: flex;

    text-align: left;

    line-height: 1.8;
}

#news ul li .date {
    margin-right: 3%;
    color:#007976;
    font-weight: bold;
}

#news ul li .txt {
    padding-left: 0;
    position: relative;
    font-weight: bold;
}

#news ul li .txt span {
    color: #007976;
}

#news ul li .txt::before {
    content: "";
    width: 30px;
    height: 100%;
    background: url(../img/item_db_01.svg) no-repeat top left;
    background-size: 100% auto;
    position: absolute;
    left: 0;
    top: 0;
}
/*アコーディオン*/


.demo__link {
    position: relative;
}

.demo__text {
    display: inline-block;
    margin: 10px 15px 10px 0;
    color: #007976;
    border-bottom: 1px solid #007976;
    text-decoration: none;
    transition: all .2s ease 0s;
}

.demo__text.close .icon-plus:after {
    display: none;
}

.demo__text .icon-plus {
    display: inline-block;
    margin-left: 3px;
    width: 14px;
    height: 14px;
    position: absolute;
    background-color: #007976;
    border-radius: 2px;
    margin-top: 0.5em;
}

.demo__text .icon-plus:before {
    width: 10px;
    height: 1px;
    position: absolute;
    top: 6px;
    left: 2px;
    color: #fff;
    background-color: currentColor;
    content: '';
}

.demo__text .icon-plus:after {
    width: 10px;
    height: 1px;
    position: absolute;
    top: 6px;
    left: 2px;
    color: #fff;
    background-color: currentColor;
    content: '';
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
}

.demo__body {
    margin: 15px 0;
}



/*===================sp=*/
@media screen and (max-width: 860px) {
    #news {
        margin-top: 0;
    }

    #news ul li {
        width: 100%;
        font-size: 2.5vw;
    }

    #news ul li .txt {
        padding-left: 8%;
        position: relative;
    }

    #news ul li .txt::before {
        content: "";
        width: 16%;
        height: 100%;
        background: url(../img/item_db_01.svg) no-repeat top left;
        background-size: auto 80%;
        position: absolute;
        left: 0;
        top: 0;
    }


}

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


/*-----------------------------------------------------------
	#story setting
-----------------------------------------------------------*/
#story {
    background: url(../img/bg_story.png) no-repeat center top;
    background-size: cover;
    margin: 0 auto 0 auto;
    padding: 10px 0 20px 0;
    text-align: center;
}

#story .txtBox {
    width: 80%;
    color: #000;
    line-height: 1;
    margin: 0 auto 0 auto;
    padding: 1em;

}

#story .txtBox p {
    position: relative;
    z-index: 2;
    margin-top: 30px;
    line-height: 1.8;
    font-size: 14px;
    text-shadow: 0 0 1em rgba(255, 255, 255, 0.8);
}

#story .txtBox p strong {
    font-size: 120%;
    font-weight: bold;
    letter-spacing: 0.2em;
}

#story .contentBox {
    position: relative;
}

#story .itemBox {}

#story .comment {
    margin: 3rem auto 1rem;
    padding: 20px 1rem 1rem;
    max-width: 640px;
    border: 1px solid #999;
    color: #fff;
    background-color: rgba(0, 0, 0, 0.7);
}

#story .comment p {
    margin: 1rem auto;
    font-size: 90%;
}

#comment01 .txtBox {
    color: #ffffff;
}

/*===================sp=*/
@media screen and (max-width: 860px) {

    #story {
        margin: 0 auto 0 auto;
        background-position: -900px;
    }

    #story .txtBox {
        font-size: 3.4vw;
        padding: 0 2% 0 2%;
    }

    #story .txtBox span {
        font-size: 4.0vw;
    }

    #story .txtBox {
        width: 100%;
        z-index: 2;
        position: relative;
    }

    #story .comment img {
        width: 100%;
        margin-top: 2rem;
    }
}

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


/*-----------------------------------------------------------
	#shop setting
-----------------------------------------------------------*/

#shop {
    margin: 0 auto 60px;
}


#shop table {
    margin: 20px auto;
    font-size: 90%;
    border-collapse: collapse !important;
    border-spacing: 1;
}

#shop .tbl-r02 th {
    text-align: left;
    padding: 10px 10px 0;
}

#shop .tbl-r02 td {

    padding: 10px;
}

#shop .pointBox {
    width: 100%;
    margin: 10px auto 0 auto;
    display: flex;
    justify-content: space-between;
}

#shop .pointBox li {
    width: 33%;
    position: relative;
}

#shop .pointBox li .details {
    position: relative;
}

#shop .pointBox .comm {
    width: 22%;
    position: absolute;
    left: 4%;
    top: -3%;
    z-index: 2;
}

#shop .pointBox .comm img {
    width: 100%;
    height: auto;
}

#shop .pointBox .img {
    margin: 0 5% 0 5%;
    z-index: 1;
}

#shop .pointBox .tit {
    font-size: 18px;
    line-height: 0;
    text-align: center;
    margin: 0 5% 0 5%;
}

#shop .pointBox .tit img {
    margin: 0 auto 0 auto;
}

#shop .pointBox .txt {
    line-height: 1.6;
    padding: 0 10px;
    text-align: center;
    margin: 15px 0 0 0;
}
#shop .pointBox .txt span {
    display: block;
    font-weight: bold;
    margin:0 0 5px 0;
    font-size: 120%;
}

#shop .pointBox .btn {
    margin: 10px 12% 0 12%;
}

@media screen and (max-width: 640px) {
    #shop .last td:last-child {
        border-bottom: solid 1px #ccc;
        width: calc(100% - 20px);
    }

    #shop .tbl-r02 {
        width: 100%;
    }

    #shop .tbl-r02 tr {
        display: block;
        margin-bottom: 10px;
    }

    #shop .tbl-r02 th,
    #shop .tbl-r02 td {
        border-bottom: none;
        line-height: 1.5;
        padding: 5px 0px 0;
        display: block;
        width: 100%;
    }
}
/*===================sp=*/
@media screen and (max-width: 860px) {

    #shop .pointBox {
        width: 100%;

        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
    }

    #shop .pointBox li {
        width: 48%;
        margin: 0 auto 5vw auto;
        position: relative;
    }

    #shop .pointBox .comm {
        position: absolute;
        left: 0;
        top: 0;
    }

    #shop .pointBox .img {
        margin: 3vw 3% 0 3%;
    }
    
    #shop .pointBox .img img {
        width: 100%;
    }


    #shop .pointBox .tit {
        width: 100%;
        margin: 0 auto 0 auto;
    }

    #shop .pointBox .txt {
        font-size: 2.8vw;
        margin: 10px 0 0 0;
        padding: 0;
    }

    #shop .cap {
        width: 80%;
        margin-top: 20px;
        margin-bottom: 20px;
        font-size: 2.6vw;
    }


}

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

/*-----------------------------------------------------------
	#play setting
-----------------------------------------------------------*/
#play {
    background: url(../img/bg_play.png) repeat center top;
    background-size: 100% auto;
    margin: 0 auto 0 auto;
    padding: 0 0 60px 0;
    text-align: center;
    overflow: hidden;
}

#play .contentBox {
    margin: 0 auto 0 auto;
    padding: 20px 0 0 0;
}

#play p {
    text-align:left;
}

#play p strong {
    text-decoration: underline;
}

/*#play:before {
		content: "";
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		background: url(../img/silence.png) no-repeat center top;
		background-size: 100%;
		height: 7%;
	}
	#play:after {
		content: "";
		display: block;
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		
		-moz-transform: rotate(180deg);
		-webkit-transform: rotate(180deg);
		transform: rotate(180deg);
		
		background: url(../img/bg_play_item.svg) no-repeat center top;
		background-size: 100% auto;
		height: 7%;
	}*/
#play .pointBox {
    width: 100%;
    margin: 10px auto 0 auto;
    display: flex;
    justify-content: space-between;
}

#play .pointBox li {
    width: 25%;
    position: relative;
}

#play .pointBox li .details {
    position: relative;
}

#play .pointBox .comm {
    width: 22%;
    position: absolute;
    left: 4%;
    top: -3%;
    z-index: 2;
}

#play .pointBox .comm img {
    width: 100%;
    height: auto;
}

#play .pointBox .img {
    margin: 0 8% 0 8%;
    z-index: 1;
}

#play .pointBox .tit {
    font-size: 18px;
    line-height: 0;
    text-align: center;
    margin: 0 5% 0 5%;
}

#play .pointBox .tit img {
    margin: 0 auto 0 auto;
}

#play .pointBox .txt {
    font-size: 14px;
    line-height: 1.6;
    padding: 0 10px;
    text-align: left;
    margin: 15px 0 0 0;
}

#play .pointBox .btn {
    margin: 10px 12% 0 12%;
}

.cap {
    width: 60%;
    max-width: 500px;
    margin: 10px auto 30px auto;
}

.cap {
    text-align: center;
    font-size: 12px;
}

/*===================sp=*/
@media screen and (max-width: 860px) {

    #play .pointBox {
        width: 100%;

        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
    }

    #play .pointBox li {
        width: 48%;
        margin: 0 auto 5vw auto;
        position: relative;
    }

    #play .pointBox .comm {
        position: absolute;
        left: 0;
        top: 0;
    }

    #play .pointBox .img {
        margin: 3vw 5% 0 5%;
    }

    #play .pointBox .tit {
        width: 100%;
        margin: 0 auto 0 auto;
    }

    #play .pointBox .txt {
        font-size: 2.8vw;
        margin: 10px 0 0 0;
    }

    .cap {
        width: 80%;
        margin-top: 20px;
        margin-bottom: 20px;
        font-size: 2.6vw;
    }


}

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

/*-----------------------------------------------------------
	#point setting
-----------------------------------------------------------*/
#point {
    margin: 20px auto 0 auto;
    text-align: center;
    padding-bottom: 0;
}

#point h2 {
    /*
		width: 12%;
		margin: 0 auto 0 auto;
*/
}

#point .pointBox {
    width: 100%;
    margin: 0 auto 0 auto;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: space-between;
}

#point .pointBox li {
    width: 31%;
    position: relative;
    margin-bottom: 70px;
}

#point .pointBox .details {}

#point .pointBox .comm {
    width: 30%;
    position: absolute;
    left: 0;
    top: 0;
}

#point .pointBox .comm img {
    width: 100%;
    height: auto;
}

#point .pointBox .img {
    margin: 0 0 0 0;
    padding: 0 0 0 0;
}

#point .pointBox .txt {
    font-size: 14px;
    line-height: 1.6;
    text-align: left;
    margin: 25px 0 0 0;
}

#point .cap {}

/*===================sp=*/
@media screen and (max-width: 860px) {
    #point {
        margin: 5vw auto 0 auto;
    }

    #point h2 {
        /*
		width: 30%;
		margin: 0 auto 10px auto;
*/
    }

    #point .pointBox {
        width: 100%;

        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
    }

    #point .pointBox li {
        width: 70%;
        margin: 0 auto 4vw auto;
        position: relative;
    }

    #point .pointBox .comm {
        position: absolute;
        left: 0;
        top: 0;
    }

    #point .pointBox .img {
        margin: 0 5% 0 5%;
    }

    #point .pointBox .txt {
        font-size: 2.4vw;
        line-height: 2.0;
        text-align: left;
        margin: 10px 0 0 0;
    }


}

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

/*-----------------------------------------------------------
	#voice setting
-----------------------------------------------------------*/
#voice {
    width: 100%;
    position: relative;
    text-align: center;
    padding: 20px 0 20px 0;
    margin-top: 0;
}

#voice ul {
    width: 100%;
    max-width: 700px;
    margin: 30px auto 0 auto;
}

#voice ul li {
    margin: 0 0 30px 0;
}

#voice ul li .cap {
    font-size: 14px;
    color: rgba(255, 255, 255, 0.50);
    margin: 45px auto 0 auto;
    text-align: center;
}

/*===================sp=*/
@media screen and (max-width: 860px) {

    #voice {
        margin: 30px auto 0 auto;
    }

    #voice ul {
        margin: 20px auto 0 auto;
    }

    #voice ul li {
        margin: 0 0 30px 0;
    }

    #voice ul li .cap {
        font-size: 2.4vw;
        margin: 30px auto 0 auto;
    }
}

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

/*-----------------------------------------------------------
	#event setting
-----------------------------------------------------------*/

#event {
    width: 100%;
    position: relative;
    text-align: center;
    padding: 20px 0 20px 0;
    margin-top: 0;

}

#event section table {
    width: 100%;
    margin: 1rem auto;
}

#event section th,
#event section td {
    padding: 10px;
    border: 1px solid #ddd;
    background: #fff;
}

#event section th {
    background: #007976;
    color: #fff;
    text-align: center;
}

#event .wm640 {
    max-width: 640px;
    margin: 0 auto;
}

/*----------------------------------------------------
  .style01
----------------------------------------------------*/
#event .style01 th {
    line-height: 1.5;
}

#event .style01 td {
    width: 35%;
}

#event .stl {
    background-color: #555;
    color: #fff;
    padding: 8px 15px;
    border-radius: 3px;
}



#event .style01 td span {
    margin:0 5px;
}
@media only screen and (max-width:480px) {
    #event .style01 {
        margin: 1rem -10px;
    }

    #event .style01 th,
    #event .style01 td {
        width: 100%;
        display: block;
        border-top: none;
    }

    #event .style01 tr:first-child th {
        border-top: 1px solid #ddd;
    }
}

#event .boxstyle01 {
    padding: 0.5rem;
    border: 1px solid #222;
    background-color: #ddd;
}

#event .btn {
    width: 200px;
    margin: 1rem auto;

}

#event .scheduleList {
    width: 100%;
    margin: 40px auto 0 auto;

    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-pack: distribute;
    justify-content: space-around;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    /*justify-content: space-between;*/
    justify-content: space-evenly;
}

/*
		#event .info {
			position: absolute;
			top: calc(50% - 20px);
			left: 0;
			width: 100%;
			text-align: center;
			font-size: 33px;
			color: #ffffff;
			font-weight: bold;
			z-index: 10;
		}
		
*/
#event .scheduleList li {
    width: 30%;
    /*
			width: 23%;
			max-width: 23%;*/
    padding: 0 0 0 0;
    margin: 0 0 30px 0;
    position: relative;
}
#event .scheduleList li {
    background: rgba(0, 0, 0, 0.70);

    /*box-shadow: 0 0 8px rgba(0, 0, 0, 0.80), 0 0 8px rgba(0, 0, 0, 0860) inset;*/

    border: 1px solid #222;
    /* 				padding: 15px 1% 15px 1%; */

    border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;

    display: -webkit-flex;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;

}

#event .scheduleList li:hover {
    opacity: 0.7;
}
#event .scheduleList li.off {
   background: rgba(0, 0, 0, 0.40);
    border: 1px solid #555;
}

#event .scheduleList li.off:hover {
    opacity: 1;
}
#event .scheduleList li.none{
     opacity: 0;
}
#event .scheduleList li.none:hover {
    opacity: 0;
}

#event .scheduleList li a {
    padding: 15px 1% 15px 1%;
}

#event .scheduleList li a {
    text-decoration: none;
    display: block;
}

#event .scheduleList li a:hover {
    text-decoration: none;
}

#event .scheduleList li .place {
    margin: 0 0 5px 0;
    font-size: 18px;
    color: #fff;
    font-weight: 500;
    text-shadow: 0 0 5px rgba(0, 0, 0, 0.80);
}

#event .scheduleList li .hall {
    font-size: 12px;
    color: #fff;
    line-height: 1.2;
    text-align: left;
    padding: 0 5% 0 5%;
    text-align: center;
}

#event .scheduleList li .date {
    display: block;
    font-size: 12px;
    font-weight: 700;
    line-height: 1.4;
    margin: 15px auto 0;
    text-align: left;
    padding: 5px ;
    text-align: center;
    background-color: #fff;
        max-width: 150px;
    border-radius: 1em;
}

#event .scheduleList li .btn {
    width: 80%;
    margin: 0 auto 0 auto;
}

#event .scheduleList li.fs {
    box-shadow: none;
    border: none;
}

#event .scheduleList li .cs {
    margin: 0 0 0 0;
    font-size: 14px;
    color: #a62b29;
    font-weight: 900;
}

#event .scheduleList li.pd15 {
    padding: 15px 0 15px 0;   
}

#event .scheduleList li.off .date {
    background-color: #777;
   color: #fff; 
}

#event .scheduleList li .atte {
    font-size: 80%;
    color: #fff;
    margin:5px;
    line-height: normal;
}

#event .scheduleList li .atte a {
    padding: 0;
    display: inline;
    text-decoration: underline;
}

/*===================sp=*/
@media screen and (max-width: 860px) {

    #event .scheduleList {
        margin-top: 1rem;
    }

    #event .scheduleList li {
        width: 48%;
        /*width: 30%;
			max-width: 30%;*/
        padding: 0 0 10px 0;
        margin: 0 0 15px 0;


        position: relative;
    }

    #event .scheduleList li .place {
        margin: 5px 0 5px 0;
        font-size: 3.5vw;
        line-height: 1.5;
        color: #fff;
        font-weight: 900;
        text-shadow: 0 0 5px rgba(0, 0, 0, 0.80);
    }

    #event .scheduleList li .date {
        font-size: 12px;
        font-weight: 700;
        line-height: 1.4;
        padding: 5px 0;
        border-radius: 1.5rem;
        max-width: 130px;
    }

    #event .scheduleList li .cs {
        margin: 10px 0 0 0;
        padding: 20% 0 20% 0;
    }

    #event .info {
        position: absolute;
        top: 25vw;
        left: 0;
        width: 100%;
        text-align: center;
        font-size: 6vw;
        color: #ffffff;
        font-weight: bold;
    }


}

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

/*-----------------------------------------------------------
	#eventdetails setting
-----------------------------------------------------------*/

#eventdetails {
    margin: 0 0 0 0;
    padding: 0 0 0 0;
}

#eventdetails .contentWrap {
    background: #001219;
    padding: 0 0 30px 0;
    margin: 0 0 0 0;
}

#eventdetails .contentBox {
    padding: 0 0 0 0;
    margin: 0 auto 0 auto;
}

#eventdetails h3 {
    font-size: 34px;
    color: #007976;
    text-align: center;
    margin: 0 auto 0 auto;
    padding: 30px 0 0 0;
    border-bottom: 5px solid #007976;
}

#eventdetails h4 {
    font-size: 28px;
    color: #ffffff;
    text-align: center;
    margin: 50px auto 30px auto;
}

#eventdetails #ticket_api h4 {
    margin: 0 0 0 0;
    padding: 0 0 5px 0;
    font-size: 15px;
    letter-spacing: 0;
    line-height: 1;
    border-bottom: 2px solid #bfbfbf;
    position: relative;
    text-align: left;
    color: #000000;
}

#eventdetails .btnBox {
    width: 40%;
    margin: 0 auto 30px auto;
    display: -webkit-flex;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

#eventdetails .btnBox .btn {
    width: 46%;
}

/*日程*/
#schedule.contentWrap {
    background: none;
    margin-top: 70px;
}

#schedule .contentBox {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
}

#schedule .contentBox .imgBox {
    width: 28%;
    padding: 0 9% 0 9%;
}

#schedule .contentBox .imgBox img {
    filter:
        drop-shadow(1px 1px 10px rgba(0, 0, 0, 0.2)) drop-shadow(-1px -1px 10px rgba(0, 0, 0, 0.2)) drop-shadow(1px -1px 10px rgba(0, 0, 0, 0.2)) drop-shadow(-1px 1px 10px rgba(0, 0, 0, 0.2)) drop-shadow(1px 0px 5px rgba(0, 0, 0, 0.1)) drop-shadow(-1px 0px 5px rgba(0, 0, 0, 0.1)) drop-shadow(0px 1px 5px rgba(0, 0, 0, 0.1)) drop-shadow(0px -1px 5px rgba(0, 0, 0, 0.1));
}

#schedule .contentBox .txtBox {
    width: 54%;
    text-align: left;
}

#schedule .contentBox .txtBox h2 {
    width: 100%;
    max-width: 500px;
    color: #00bdad;
    text-align: left;
    margin: 0 0 0 0;
    border-bottom: none;
}

#schedule .contentBox .txtBox h3 {
    color: #00bdad;
    text-align: left;
    font-size: 22px;
    border-bottom: none;
}

#schedule .contentBox .txtBox .txt01 {
    text-align: left;
    font-size: 18px;
    font-weight: bold;
}

#schedule .contentBox .txtBox .txt02 {
    text-align: left;
    font-size: 16px;
    margin: 20px 0 0 0;
}

/*API*/

#ticket_api.contentWrap {
    background: none;
    margin: 10px auto 30px auto;
}

#scheduler.contentWrap .contentBox {}

#ticket_api .note {
    margin: 30px auto 0 auto;
    color: #ffffff;
}


#eventdetails .txtWrap {
    width: 100%;
    max-width: 700px;
    margin: 50px auto 0 auto;

}

#eventdetails .txtBox {
    font-size: 16px;
}

#eventdetails .txtWrap.col2 {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;

    -ms-flex-wrap: wrap;
    flex-wrap: wrap;

}

#eventdetails .txtWrap.col2 .txtBox {
    width: 60%;
    margin: 10px 0 0 0;
}

#eventdetails .txtWrap.col2 .btnBox {
    width: 30%;
    margin: 10px 0 0 0;
    padding: 0 0 0 10%;
    display: block;
}

#eventdetails .txtWrap.col2 .btnBox .btn {
    width: 100%;
    margin: 50px 0 50px 0;
}

#eventdetails .txtWrap .tit {
    width: 100%;
    font-size: 20px;
    font-weight: bold;
}

#eventdetails .txtWrap .txt {
    margin: 20px 0 0 0;
}

#eventdetails #back {
    padding-top: 80px;
}


/*===================sp=*/
@media screen and (max-width: 860px) {


    #eventdetails h3 {
        font-size: 6.0vw;
    }

    #eventdetails h4 {
        font-size: 4.0vw;
    }

    #eventdetails #ticket_api h4 {
        font-size: 6.0vw;
    }

    /*日程*/
    #schedule.contentWrap {
        background: none;
        margin-top: 50px;
    }

    #schedule .contentBox {
        display: block;
    }

    #schedule .contentBox .imgBox {
        width: 76%;
        padding: 0 0 0 0;
        margin: 0 auto 0 auto;
    }

    #schedule .contentBox .txtBox {
        width: 100%;
        text-align: left;
        margin: 20px auto 0 auto;
    }

    #schedule .contentBox .txtBox h2 {
        width: 100%;
        color: #00bdad;
        text-align: left;
        margin: 0 0 0 0;
        border-bottom: none;
    }

    #schedule .contentBox .txtBox h3 {
        color: #00bdad;
        text-align: left;
        font-size: 4.0vw;
        border-bottom: none;
    }

    #schedule .contentBox .txtBox .txt01 {
        text-align: left;
        font-size: 3.4vw;
        font-weight: bold;
    }

    #schedule .contentBox .txtBox .txt02 {
        text-align: left;
        font-size: 3.4vw;
        margin: 20px 0 0 0;
    }

    #eventdetails .txtWrap.col2 {
        display: block;
    }

    #eventdetails .txtWrap.col2 .txtBox {
        width: 100%;
        margin: 10px 0 0 0;
    }

    #eventdetails .txtWrap.col2 .btnBox {
        width: 100%;
        margin: 30px auto 0 auto;
        padding: 0 0 0 0;
        display: -webkit-flex;
        display: flex;
        -webkit-justify-content: space-between;
        justify-content: space-between;

        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    #eventdetails .txtWrap.col2 .btnBox .btn {
        width: 48%;
        margin: 0 0 10px 0;
    }

    #eventdetails #back {
        padding-top: 80px;
    }

    #eventdetails .btnBox .btn {
        width: 100%;
    }

}

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





.ticketWrap {
    background: #007976;
    margin: 30px auto 0 auto;
    padding: 20px 3% 20px 3%;
    position: relative;
}

.ticketWrap .naviBox {
    height: 80px;
    margin: 0 60px 0 60px;
    padding: 0 0 0 0;
    overflow: hidden;
}

.ticketWrap .naviBox .prevBtn {
    width: 50px;
    height: 80px;
    background: #ffffff;
    z-index: 5;
    -webkit-transition: all .3s;
    transition: all .3s;
    cursor: pointer;
    position: absolute;
    top: 20px;
    left: 3%;
}

.ticketWrap .naviBox .prevBtn:before {
    content: '';
    width: 12px;
    height: 12px;
    border: 0;
    border-top: solid 3px #626262;
    border-right: solid 3px #626262;
    top: 50%;
    left: 50%;
    -webkit-transform: translate3d(-50%, -50%, 0);
    transform: translate3d(-50%, -50%, 0);
    -webkit-transform: rotate(-135deg);
    transform: rotate(-135deg);
    margin: -8px 0 0 -3px;
    position: absolute;
}

.ticketWrap .naviBox .nextBtn {
    width: 50px;
    height: 80px;
    background: #ffffff;
    z-index: 5;
    -webkit-transition: all .3s;
    transition: all .3s;
    cursor: pointer;
    position: absolute;
    top: 20px;
    right: 3%;
}

.ticketWrap .naviBox .nextBtn:before {
    content: '';
    width: 12px;
    height: 12px;
    border: 0;
    border-top: solid 3px #626262;
    border-right: solid 3px #626262;
    top: 50%;
    left: 50%;
    -webkit-transform: translate3d(-50%, -50%, 0);
    transform: translate3d(-50%, -50%, 0);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    margin: -8px 0 0 -10px;
    position: absolute;
}

.ticketWrap .naviBox .prevBtn:hover,
.ticketWrap .naviBox .nextBtn:hover {
    opacity: 0.7;
}

.ticketWrap .naviBox .prevBtn span,
.ticketWrap .naviBox .nextBtn span {
    display: none;
}

.ticketWrap .naviBox .comm {
    width: 100%;
    top: 25px;
    font-size: 14px;
    color: #ffffff;
    text-align: center;
    font-weight: bold;
    position: relative;
    display: none;
}

.ticketWrap .naviBox ul {
    background: #007976;
    height: 80px;
    list-style: none;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    overflow-x: scroll;
    overflow-scrolling: touch;
    width: 100%;
    margin: 0;
    padding: 0;
    z-index: 2;
    position: relative;
}

.ticketWrap .naviBox ul::-webkit-scrollbar {
    height: 0;
}

.ticketWrap .naviBox ul li {
    margin: 0 2px 0 0;
    position: relative;
    cursor: pointer;
    opacity: 0.85;
}

.ticketWrap .naviBox ul li .scheduleBox {
    background: #ffffff;
    display: block;
    width: 80px;
    height: 80px;
    text-align: center;
    cursor: pointer;
    -webkit-transition: all .3s;
    transition: all .3s;
    position: relative;
    color: #676767;
    text-align: center;

    display: -webkit-flex;
    display: flex;
    -webkit-flex-direction: column;
    flex-direction: column;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: center;
    align-items: center;
}

.ticketWrap .naviBox ul li.cr {
    opacity: 1.0;

}

.ticketWrap .naviBox ul li.cr .scheduleBox {
    background: #fbe663;
}

.ticketWrap .naviBox ul li .scheduleBox:hover {
    opacity: 0.7;
}

.ticketWrap .naviBox ul li .scheduleBox .date {
    width: 100%;
    font-size: 14px;
    font-weight: 500;
    line-height: 1;
    top: 28px;
}

.ticketWrap .naviBox ul li .scheduleBox .state {
    bottom: 10px;
    width: 100%;
    font-size: 10px;
    font-weight: 500;
    line-height: 1;
    color: #676767;
    margin-top: 10px;
}

.ticketWrap .naviBox ul li .scheduleBox .state span {
    font-size: 10px;
    font-weight: 500;
}

.ticketWrap .naviBox ul li .scheduleBox.present .state span {
    color: #32b16c;
}

.ticketWrap .naviBox ul li .scheduleBox.present .state span:before {
    content: "○";
}

.ticketWrap .naviBox ul li .scheduleBox.sold .state {
    color: #9d9d9d;
}

.ticketWrap .naviBox ul li .scheduleBox.sold .state span:before {
    content: "✕";
}

.ticketWrap .naviBox ul li .scheduleBox.few .state {
    color: #960b0b;
}

.ticketWrap .naviBox ul li .scheduleBox.few .state span:before {
    content: "△";
}


.ticketWrap .detailsBox {}

.ticketWrap .detailsBox .tit {
    margin: 0;
    padding: 20px 0 20px 0;
    font-size: 20px;
    letter-spacing: .1em;
    line-height: 1;
    color: #fff;
    font-weight: 500;
    text-align: center;

    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: flex-end;
    align-items: flex-end;
}

.ticketWrap .detailsBox .tit .tit01 {
    font-size: 25px;
}

.ticketWrap .detailsBox .details {
    background: #ffffff;
    padding: 2%;
}

.ticketWrap .detailsBox .details h4 {
    margin: 0 0 0 0;
    padding: 0 0 5px 0;
    font-size: 15px;
    letter-spacing: 0;
    line-height: 1;
    border-bottom: 2px solid #bfbfbf;
    position: relative;
}

.ticketWrap .detailsBox .details a.scrap {
    position: absolute;
    top: 0;
    right: 0;
    padding-right: 15px;
    color: #0e70bb;
    font-size: 15px;
}

/*===================sp=*/
@media screen and (max-width: 860px) {

    .ticketWrap .detailsBox .details h4 {
        margin: 0 0 0 0;
        padding: 0 0 5px 0;
        font-size: 15px;
        letter-spacing: 0;
        line-height: 1;
        border-bottom: 2px solid #bfbfbf;
        position: relative;

        line-height: 2.0;
    }

    .ticketWrap .detailsBox .details a.scrap {
        position: relative;
        right: 0;
        text-align: right;

    }
}

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

.ticketWrap .detailsBox .details a.scrap:after {
    content: '';
    width: 8px;
    height: 8px;
    border: 0;
    border-top: solid 2px #0e70bb;
    border-right: solid 2px #0e70bb;
    top: 50%;
    right: 0;
    -webkit-transform: translate3d(-50%, -50%, 0);
    transform: translate3d(-50%, -50%, 0);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    margin: -5px 0 0 0px;
    position: absolute;
}

.ticketWrap .detailsBox .details a.scrap:hover {
    text-decoration: none;
    opacity: 0.7;
}

.ticketWrap .detailsBox .details ul {
    margin-left: -15px;
    margin-right: -15px;
    list-style: none;
    display: block;
    margin: 0 -7px;
    padding: 0;
    margin-bottom: 50px;
}

.ticketWrap .detailsBox .details ul:before,
.ticketWrap .detailsBox .details ul:after {
    content: " ";
    display: table;
}

.ticketWrap .detailsBox .details ul:after {
    clear: both;
}

.ticketWrap .detailsBox .details ul li {
    position: relative;
    float: left;
    width: 23%;
    min-height: 1px;
    padding-left: 15px;
    padding-right: 15px;
    padding: 0 0 0 5px;
    margin: 15px 10px 0 0;

}


/*===================sp=*/
@media screen and (max-width: 860px) {
    .ticketWrap .detailsBox .details ul li {
        position: relative;
        float: left;
        width: 90%;
        min-height: 1px;
        padding-left: 5%;
        padding-right: 5%;
        margin: 15px auto 0 auto;

    }
}

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



.ticketWrap .detailsBox .details ul li .scheduleBox {
    position: relative;
    padding: 1em 8%;
    background: #fff;
    -webkit-transition: all .3s;
    transition: all .3s;
    z-index: 1;
    color: #ffffff;

    display: -webkit-flex;
    display: flex;

    -webkit-justify-content: space-between;
    justify-content: space-between;

    -webkit-align-items: center;
    align-items: center;
}

.ticketWrap .detailsBox .details ul li .scheduleBox a {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    color: #ffffff;
}

.ticketWrap .detailsBox .details ul li .scheduleBox .time {
    font-size: 14px;
    font-weight: 600;
    line-height: 1;

    margin-right: 10px;
}

.ticketWrap .detailsBox .details ul li .scheduleBox .state {
    font-size: 14px;
    font-weight: 500;
    line-height: 1;

    margin-left: 10px;
}

.ticketWrap .detailsBox .details ul li .scheduleBox:hover {
    opacity: 0.7;
}

.ticketWrap .detailsBox .details ul li .scheduleBox.present {
    background: #32b16c;
}

.ticketWrap .detailsBox .details ul li .scheduleBox.present .state span:before {
    content: "○";
}

.ticketWrap .detailsBox .details ul li .scheduleBox.sold {
    background: #969696;
}

.ticketWrap .detailsBox .details ul li .scheduleBox.sold .state span:before {
    content: "✕";
}

.ticketWrap .detailsBox .details ul li .scheduleBox.few {
    background: #960b0b;
}

.ticketWrap .detailsBox .details ul li .scheduleBox.few .state span:before {
    content: "△";
}

.ticketWrap .detailsBox .details ul li .scheduleBox.remaining {
    color: #f84141;
}

.ticketWrap .detailsBox .details .buyWrap {
    width: 100%;
    margin: 20px auto 0 auto;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
}

.ticketWrap .detailsBox .details .buyWrap .ticketBox {
    width: 48%;
}

/*===================sp=*/
@media screen and (max-width: 860px) {

    .ticketWrap .detailsBox .details .buyWrap {
        width: 100%;
        margin: 20px auto 0 auto;
        display: block;
    }

    .ticketWrap .detailsBox .details .buyWrap .ticketBox {
        width: 100%;
        margin: 0 0 0 0;
    }
}

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

.ticketWrap .detailsBox .details .ticketBox {
    margin-left: -15px;
    margin-right: -15px;
    margin: 0 -7px 0 -7px;
}

.ticketWrap .detailsBox .details .ticketBox:before,
.ticketWrap .detailsBox .details .ticketBox:after {
    content: " ";
    display: table;
}

.ticketWrap .detailsBox .details .ticketBox:after {
    clear: both;
}

.ticketWrap .detailsBox .details .ticketBox .ticketItem {
    position: relative;
    min-height: 1px;
    padding-left: 15px;
    padding-right: 15px;
    margin: 0 0 15px;
    padding: 0 7px 0 7px;
}

.ticketWrap .detailsBox .details .ticketBox .ticket-item:last-child {
    margin-bottom: 0;
}

.ticketWrap .detailsBox .details .ticketBox .ticketItem:nth-of-type(2n) + div.ticketItem {
    clear: left;
}

.ticketWrap .detailsBox .details .ticketBox .ticketItem p {
    font-size: 10px;
    margin: 0;
}

.ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket {
    display: block;
    margin: 0 0 15px 0;
    padding: 10px 2% 10px 2%;
    width: 96%;
    color: #fff;
    font-size: 12px;
    font-weight: 500;
    line-height: 1;
    text-align: center;
    text-decoration: none;
    border: none;
    background: #ffffff;
}

.ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket:hover {
    opacity: 0.7;
}

.ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket.scrap {
    background: #f34f49;
}

.ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket.scrap:hover {
    opacity: 0.7;
}

.ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket.eplus {
    background: #e85298;
}

.ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket.eplus:hover {
    opacity: 0.7;
}

.ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket.pia {
    background: #36c;
}

.ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket.pia:hover {
    opacity: 0.7;
}

.ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket.lawson {
    background: #1a9fdd;
}

.ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket.lawson:hover {
    opacity: 0.7;
}




/*-----------------------------------------------------------
	#faq setting
-----------------------------------------------------------*/

#faq {
    margin: 0 0 0 0;
    padding: 0 0 0 0;
}

#faq .contentWrap {
    padding: 0 0 50px 0;
    margin: 0 0 0 0;
}

#faq .contentBox {
    padding: 0 0 0 0;
    margin: 0 auto 0 auto;
}

#faq h3 {
    font-size: 1.2vw;
    margin: 10px auto;
    border-left: 4px solid #007976;
    padding-left: 10px;
}

#faq .btnBox {
    width: 40%;
    margin: 0 auto 30px auto;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
}

#faq .btnBox .btn {
    width: 46%;
}

#faq .faqWrap {
    margin: 10px auto 0 auto;
    padding: 0 0 20px 0;
}

#faq .faqWrap ul {
    width: 100%;
    max-width: 670px;
    margin: 0 auto 0 auto;
}

#faq .faqWrap ul li {
    padding: 0 0 20px 0;
}

#faq .faqWrap ul li .q {
    font-size: 16px;
    color: #007976;
    font-weight: bold;
    display: block;
    padding-left: 2em;
    margin: 0 0 2% 0;
}

#faq .faqWrap ul li .q::before {
    content: "Q：";
    display: block;
    float: left;
    margin-left: -2em;
    width: 2em;
    text-align: center;
}

#faq .faqWrap ul li .a {
    line-height: 1.8;
    display: block;
    padding-left: 2em;
}

#faq .faqWrap ul li .a::before {
    content: "A：";
    font-size: 16px;
    font-weight: bold;
    display: block;
    float: left;
    margin-left: -2em;
    width: 2em;
    text-align: center;
}

#faq .faqWrap ul li .n {
    line-height: 1.8;
    display: block;
    /* 				padding-left: 1em; */
    margin: 0 0 0 0;
}

/*
			#faq .faqWrap ul li .n::before {
				content: "・";
				font-size: 16px;
				font-weight: bold;
				display: block;
				float: left;
				margin-left: -1em;
				width: 1em;
				text-align: center;
			}
*/
#faq .faqWrap .bnr {
    width: 100%;
    max-width: 250px;
    margin: 0 auto 0 auto;
}

#faq .faqWrap .note {
    font-size: 14px;
    color: #000000;
    opacity: 0.6;
}

#faq .faqWrap a {
    color: #00bdad;
    text-decoration: underline;
}

#faq .faqWrap a:hover {
    text-decoration: none;
}


/*===================sp=*/
@media screen and (max-width: 860px) {


    #faq {
        width: 100%;
        padding: 20px 0 0 0;
    }

    #faq h2 {
        width: 94%;
        margin: 0 auto 0 auto;
    }

    #faq .btnBox {
        width: 90%;
        margin: 3% auto 0 auto;
    }

    #faq .btnBox .btn {
        width: 48%;
        margin-bottom: 20px;
    }

    #faq h3 {
        font-size: 4.0vw;
        margin-bottom: 10px;
    }

    #faq h4 {
        font-size: 4.0vw;
        margin-top: 20px;
        margin-bottom: 10px;
    }

    #faq .faqWrap ul {
        width: 94%;
    }

    #faq .faqWrap ul li .q {
        font-size: 2.9vw;
    }

    #faq .faqWrap ul li .a {
        font-size: 2.9vw;
        padding-left: 2em;
    }

    #faq .faqWrap ul li .a::before {
        font-size: 2.9vw;
        margin-left: -2em;
        margin-top: 0;
    }

    #faq .faqWrap ul li .n {
        font-size: 2.9vw;
    }

    #faq .faqWrap ul li .n::before {
        font-size: 2.9vw;
    }

    #faq .faqWrap .bnr {
        width: 60%;
        max-width: 200px;
        margin: 0 auto 5% auto;
    }

    #faq .faqWrap .note {
        font-size: 2.9vw;
    }

}

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


/*-----------------------------------------------------------
	#gamedetails setting
-----------------------------------------------------------*/

#game.contentWrap {
    margin: 0 0 0 0!important;
    padding: 0 0 0 0!important;
}

#gamedetails {
    width: 100%;
    position: relative;
    text-align: center;
    padding-top: 0;
    margin: 0 0 0 0;
}

#gamedetails .contentBox {
    margin: 10px auto 0 auto;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
}

#gamedetails .acd-content {
    margin: 0 auto;
    padding: 1rem ;
    border: none;
}

#gamedetails h2 img {
    max-width: 500px;
}

#gamedetails h3 {
    color: #fff;
}

#gamedetails .txtBox {
    width: 100%;
    max-width: 445px;
    margin: 20px auto 0 auto;
}

#gamedetails .txtBox .txt {
    width: 100%;
    line-height: 1.8;
    font-size: 16px;
    text-align: left;
}

#gamedetails .movieBox {
    width: 47%;
    max-width: 450px;
    margin: 20px auto 0 auto;
}

#gamedetails .tit {
    text-align: center;
    font-size: 16px;
    font-weight: bold;
    width: 100%;
    margin-bottom: 10px;
}

#gamedetails .link2site {
    width: 47%;
    max-width: 450px;
    margin: 30px auto 0 auto;
}

/*===================sp=*/
@media screen and (max-width: 860px) {

    #gamedetails {
        padding-top: 10%;
    }

    #gamedetails .txtBox {
        width: 100%;
        margin-top: 10px;
    }

    #gamedetails .txtBox .txt {
        font-size: 2.9vw;
        line-height: 2.0;
    }

    #gamedetails .colBox {
        width: 100%;
        display: block;
        margin-top: 0;
    }

    #gamedetails .colBox .movieBox {
        width: 100%;
        margin: 0 0 0 0;
    }

    #gamedetails .colBox .movieBox h2 {
        width: 50%;
        margin: 8% 0 5% 5%;
    }

    #gamedetails .colBox .txt {
        width: 100%;
        margin-top: 8%;
        font-size: 14px;
    }

    #gamedetails .contentBox .video {
        max-width: 100%;
        margin-top: 0;
    }

    #gamedetails .colBox .txtBox {
        width: 100%;
        margin: 0 auto 0 auto;
    }

    #gamedetails .colBox .logo {
        width: 40%;
        max-width: 205px;
        margin: 0 auto 0 auto;
        line-height: 0;
    }

    #gamedetails .colBox .txtBox .txt {
        line-height: 1.6;
        font-size: 14px;
    }

    #gamedetails .movieBox {
        width: 100%;
        max-width: 450px;
        margin: 30px auto 0 auto;
    }

    #gamedetails .tit {
        font-size: 3.0vw;
    }

    #gamedetails .link2site {
        width: 90%;
        max-width: 450px;
        margin: 20px auto 0 auto;
    }

}

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

/*----------------------------------btn setting----------*/
ul.link2site {
    width: 100%;
    display: table;
    margin: 30px 0 0 0;
    padding: 0;
    list-style: none;
}

ul.link2site li {
    width: 32%;
    float: left;
    margin-right: 2%;
}

ul.link2site li:last-child {
    margin-right: 0;
}

ul.link2site li a {
    display: block;
    padding: 4% 0 4% 0;
    color: #fff;
    height: 50px;
    font-size: 13px;
    text-decoration: none;
    text-align: center;
    border-radius: 5px;
    line-height: 50px;
    font-weight: normal;
}

ul.link2site li.link-item-web a {
    background: #32b16c;
    font-size: 11px;
}

ul.link2site li.link-item-twitter a {
    background: #55acee;
}

ul.link2site li.link-item-twitter img {
    width: 10%;
    height: auto;
}

ul.link2site li.link-item-facebook a {
    background: #3b5a9a;
}

ul.link2site li.link-item-facebook img {
    width: 5%;
    height: auto;
}

ul.link2site li a:hover {
    opacity: 0.5;
    filter: alpha(opacity=50);
    -ms-filter: "alpha(opacity=50)";
    -moz-opacity: 0.5;
    -khtml-opacity: 0.5;
}

/*===================sp=*/
@media screen and (max-width: 860px) {

    ul.link2site {
        width: 100%;
        margin: 3% auto 0 auto;
    }

    ul.link2site li a {
        height: 30px;
        line-height: 30px;
    }

}


/*-----------------------------------------------------------
	#campaign setting
-----------------------------------------------------------*/
.campaign {
    width: 100%;
    margin: 0 auto 0 auto;
    z-index: -1;
}

.campaign .bnr {
    width: 100%;
}

/*===================sp=*/
@media screen and (max-width: 860px) {

    .campaign {
        margin-top: 0;
        padding-top: 0;
    }


}

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



/*-----------------------------------------------------------
	#specialcp01 setting
-----------------------------------------------------------*/
#specialcp01.contentWrap,
#specialcm.contentWrap {
    margin: 0 0 0 0;
}

#specialcp01,
#specialcm {
    width: 100%;
    position: relative;
    text-align: center;
    padding-top: 0;
    margin: 0 0 0 0;
    padding: 12% 0 8% 0;
}

#specialcp01 .contentBox,
#specialcm .contentBox {
    margin: 0 auto 0 auto;
}

#specialcp01 .img {
    width: 90%;
    max-width: 700px;
    margin: 0 auto 0 auto;
    padding: 0 0 0 0;
}

#specialcp01 .txtBox {
    width: 90%;
    max-width: 600px;
    margin: 20px auto 0 auto;
}

#specialcp01 .txtBox .txt {
    width: 100%;
    line-height: 1.8;
    font-size: 16px;
    text-align: left;
    margin: 20px 0 0;
    color: #ffffff;
}

#specialcp01 .btn {
    width: 70%;
    max-width: 240px;
    margin: 20px auto auto;
}

.video {
    position: relative;
    height: 0;
    padding: 30px 0 56.25%;
    overflow: hidden;
}

.video iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}


/*===================sp=*/
@media screen and (max-width: 860px) {

    #gamedetails {
        padding-top: 10%;
    }

    #gamedetails .txtBox {
        width: 100%;
    }

    #specialcp01 .txtBox .txt {
        width: 100%;
        line-height: 1.8;
        font-size: 3.4vw;
        text-align: left;
        margin: 20px 0 0;
        color: #ffffff;
    }
}

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

/*-----------------------------------------------------------
	#footer setting
-----------------------------------------------------------*/
#footer {
    width: 100%;
    text-align: center;
    margin: 0 auto 0 auto;
    padding: 60px 0;
    position: relative;
    line-height: 1.6;
    background-color: rgba(0,0,0,0.1);
}

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

#footer .copyright {
    font-size: 15px;
    margin: 0 0 8px 0;
}

#footer .logoBox {
    width: 60%;
    margin: 40px auto 30px auto;

    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

#footer .logoBox .logo01 {
    width: 40%;
    max-width: 158px;
    margin: 0 30px 0 30px;
}

/*===================sp=*/
@media screen and (max-width: 860px) {

    #footer {
        margin: 30px auto 0 auto;
    }
    
    #footer .footerWrap{
        width: calc(100% - 20px);
        padding: 0 10px;
    }

    #footer .copyright {
        font-size: 12px;
    }

    #footer .logoBox {
        width: 80%;
    }

    #footer .logoBox .logo01 {
        width: 40%;
        max-width: 158px;
        margin: 0 2% 0 2%;
    }

}

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


#footer .bnrBox {
    width: 100%;
    margin: 0 auto 30px auto;
    display: flex;
    justify-content: center;
    align-items: stretch;
    text-align: left;
}

#footer .bnrBox .bnr {
    width: 320px;
    margin: 0 5px;
}

/*===================sp=*/
@media screen and (max-width: 860px) {

    #footer .bnrBox {
        display: block;
        margin: 0 auto 5vw auto;
        padding: 0 0 0 0;
    }

    #footer .bnrBox .bnr {
        width: 100%;
        margin: 0 auto 10px;
    }

}

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


/*-----------------------------------------------------------
	#share setting
-----------------------------------------------------------*/
#share {
    width: 40px;
    height: 100%;
    margin: 0 auto 0 auto;
    padding: 0 0 0 0;
    position: fixed;
    right: 2%;
    top: 0;
    text-align: right;
    z-index: -1;
}

#share .contentBox {
    width: 100%;
    height: 100%;
    max-width: 1200px;
    margin: 0 auto 0 auto;
    padding: 0 0 0 0;
    position: relative;
    z-index: 1;
}

#share ul {
    width: 40px;
    margin: -75px auto 0 auto;
    z-index: 10;
    position: absolute;
    right: 1%;
    bottom: 15%;

}

#share li {
    margin: 0 0 10px 0;
}

#share li div {
    padding-bottom: 100%;
    background: #000000;

    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    overflow: hidden;
    position: relative;
    z-index: 10;

    box-shadow: 2px 5px 8px rgba(102, 102, 102, 0.30);
}

#share li div a {
    display: block;
    width: 100%;
    height: 100%;
}

#share li div {
    line-height: 0;
    font-size: 0;
}

#share li .btn_tw {
    background: #1ea2f2 url(../img/i_tw.svg) no-repeat center center;
    background-size: auto 40%;
}

#share li .btn_tw:hover {
    opacity: 0.7;
}

#share li .btn_fb {
    background: #3b5999 url(../img/i_fb.svg) no-repeat center center;
    background-size: auto 50%;
}

#share li .btn_fb:hover {
    opacity: 0.7;
}

#share li .btn_li {
    background: #00b800 url(../img/i_li.svg) no-repeat center center;
    background-size: auto 50%;
}

#share li .btn_li:hover {
    opacity: 0.7;
}


/*===================sp=*/
@media screen and (min-width: 1200px) {

    #share ul {
        width: 40px;
        margin: -75px auto 0 auto;
        z-index: 10;
        position: absolute;
        right: 2%;
        bottom: 15%;
    }

}

/*===================sp=*/
@media screen and (max-width: 860px) {

    #share {
        width: 35px;
        height: 100%;
        margin: 0 auto 0 auto;
        padding: 0 0 0 0;
        position: fixed;
        right: 1%;
        bottom: 15%;
        text-align: right;
        z-index: 10;
    }

    #share ul {
        width: 35px;
        margin: -30px auto 0 auto;
        z-index: 10;
        position: absolute;
        right: 0;
        bottom: 15%;
    }

}

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

/*----------------------------------#popup setting----------*/
#popup {
    display: none;
}

#popupBtn {
    width: 15%;
    max-width: 130px;
    position: fixed;
    right: 0;
    bottom: 10px;
    z-index: 100;
    cursor: pointer;
}

#popupBtn img {
    width: 100%;
    border-style: none;
}


/*===================sp=*/
@media screen and (max-width: 860px) {

    #popupBtn {
        width: 30%;
        position: fixed;
        right: 0;
        bottom: 8px;
        z-index: 100;
        cursor: pointer;
    }

    #popupBtn img {
        width: 100%;
        border-style: none;
    }

}

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



.closebtn {
    width: 6%;
    padding: 0;
    margin: 0 0 0 0;
    display: block;
    z-index: 1000;
    line-height: 0;
    position: absolute;
    right: 20px;
    top: 20px;
}

.closebtn:hover {
    opacity: 0.7;
}

.closebtn p,
.closebtn p span {
    display: inline-block;
    transition: all .4s;
    box-sizing: border-box;
}

.closebtn p {
    position: relative;
    width: 100%;
    height: 100%;
    padding-top: 100%;
}

.closebtn p span {
    position: absolute;
    left: 7%;
    width: 86%;
    height: 6px;
    background-color: #a9153b;
}

.closebtn p span:nth-of-type(1) {
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    top: 45%;
}

.closebtn p span:nth-of-type(2) {
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    bottom: 45%;
}

/*===================sp=*/
@media screen and (max-width: 860px) {

    .closebtn {
        width: 10%;
        padding: 0;
        margin: 0 0 0 0;
        display: block;
        z-index: 1000;
        line-height: 0;
        position: absolute;
        right: 5px;
        top: 5px;
    }

    .closebtn p span {
        position: absolute;
        left: 2%;
        width: 96%;
        height: 3px;
        background-color: #a9153b;
    }

    .closebtn p span:nth-of-type(1) {
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg);
        top: 44%;
    }

    .closebtn p span:nth-of-type(2) {
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
        bottom: 44%;
    }

}

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

.scrapnote {
    border: 1px solid #000;
    padding: 10px;
    margin-top:20px ;
}

.scrapnote a {
    font-size: 90%;
}
