/* CSS Document */
@charset "utf-8";

* {
	 -webkit-box-sizing: border-box;
	 -moz-box-sizing: border-box;
	 -o-box-sizing: border-box;
	 -ms-box-sizing: border-box;
	 box-sizing: border-box;
	 text-decoration: none;
	 margin: 0;
	 padding: 0;
	 list-style: none;
	 -webkit-margin-before: 0;
	 -webkit-margin-after: 0;
	 -webkit-padding-start: 0;
}

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

html {
    font-size: 62.5%;
    height: 100%;
    overflow-y: scroll;
    overflow-x: hidden;
}
body {
    font-size: 16px;
    font-size: 1.6rem;
    font-family: 'Droid Serif',"Times New Roman","游明朝",YuMincho,"ヒラギノ明朝 ProN W3","Hiragino Mincho ProN","メイリオ",Meiryo,serif;
    -webkit-text-size-adjust: 100%;
    margin: 0;
    padding: 0;
    perspective: 1px;
    height: 100%;
    z-index: 1;
    position: relative;
    background: #000;
    color: #FFF;
    font-size: 1.4rem;
    line-height: 2.2;
    letter-spacing: 0.1rem;
}
.gothic { font-family: 'Droid Serif', Verdana, "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;}
a, a:visited {color:white;cursor: pointer;}
a:hover {}
img {
    border-style: none;
    max-width: 100%;
    height: auto;
}
.inB {display: inline-block;}
.spBr { display: none;}


#loader-bg {
  display: none;
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0px;
  left: 0px;
  background: #000;
  z-index: 1;
}
#loader {
  display: none;
  position: fixed;
  top: 50%;
  left: 50%;
  width: 200px;
  height: 200px;
  margin-top: -100px;
  margin-left: -100px;
  text-align: center;
  color: #fff;
  z-index: 2;
}

/*oekora*/
.wrapper {
    padding-top: 50px;
    position: relative;
}
/**/
.ticketArea {clear: both;/* margin: 40px 0; */}
.ticketArea a {
    display: block;
    margin: 50px auto 0;
    width: 269px;
    height: 70px;
    overflow: hidden;
    white-space: nowrap;
    text-indent: 120%;
}
.ticketArea a.pc {
    background: url("../images/eplus_img.png") no-repeat top left;
}
.ticketArea a:hover { background: url("../images/eplus_img.png") no-repeat bottom left;}
.ticketArea a.sp { display: none;}

#mainArea {
    text-align: center;
    margin: 0 auto;
    padding: 0 0 80px;
    width: 1280px;
    border-bottom: 1px solid #333333;
}
.stage #mainArea {  border-bottom: none;}

#mainArea h1 {
    margin: 0 0 10px;
    text-align: center;
}
#mainArea h1 img.pc {/* display: block; */}
#mainArea h1 img.sp { display: none;}


/*mainVisual*/
#mainArea #mainVisual {
    position: relative;
    width: 50%;
    height: 100%;
    margin: 0 auto;
    padding: 53% 0 0;
}
#mainArea #mainVisual .mainVisualImg {
    position: absolute;
    height: 100%;
}
#mainArea #mainVisual #main-title {
    z-index: 4;
    width: 350px;
    margin: 0 auto;
    left: 131px;
    top: 150px;
    display: block;
    opacity: 0;
    -webkit-animation: anim_title 3s ease-in-out 1s forwards;
    animation: anim_title 3s ease-in-out 1s forwards;
}
#mainArea #mainVisual #main-rainbow {
    z-index: 3;
    width: 620px;
    display: block;
    opacity: 0;
    top: 0;
    -webkit-animation: anim_rainbow 1s ease-in-out 1.5s forwards;
    animation: anim_rainbow 1s ease-in-out 1.5s forwards;
}
#mainArea #mainVisual #main-moare {
    z-index: 2;
    width: 540px;
    left: 40px;
    top: 40px;
    display: block;
    opacity: 0;
    -webkit-animation: anim_moare 1.5s cubic-bezier(0.18, 0.89, 0.32, 1.28) 0.1s forwards;
    animation: anim_moare 1.5s cubic-bezier(0.18, 0.89, 0.32, 1.28) 0.1s forwards;
}
#mainArea #mainVisual #main-square {
    z-index: 1;
    width: 600px;
    left: 10px;
    top: 10px;
    display: block;
    opacity: 0;
    -webkit-animation: anim_square 1.5s ease 1s forwards;
    animation: anim_square 1.5s ease 1s forwards;
}
@-webkit-keyframes anim_rainbow {
    0% { display: none; opacity: 0;}
    100% { display: block; opacity: 1;}
}
@keyframes anim_rainbow {
    0% { display: none; opacity: 0;}
    100% { display: block; opacity: 1;}
}

@-webkit-keyframes anim_square {
    0% { display: none; opacity: 0; transform:scale(1.5); }
    100% { display: block; opacity: 1; transform:scale(1);}
}
@keyframes anim_square {
    0% { display: none; opacity: 0; transform:scale(1.5); }
    100% { display: block; opacity: 1; transform:scale(1);}
}

@-webkit-keyframes anim_moare {
    0% { display: none; opacity: 0; transform:scale(0.8); }
    100% { display: block; opacity: 1; transform:scale(1);}
}
@keyframes anim_moare {
    0% { display: none; opacity: 0; transform:scale(0.8); }
    50% { opacity: 0.4;}
    100% { display: block; opacity: 1; transform:scale(1);}
}

@-webkit-keyframes anim_title {
    0% { display: none; opacity: 0; transform:scale(1.1); }
    100% { display: block; opacity: 1; transform:scale(1);}
}
@keyframes anim_title {
    0% { display: none; opacity: 0; transform:scale(1.1); }
    100% { display: block; opacity: 1; transform:scale(1);}
}


#mainArea img {
}
#mainArea img.image01 {}
#mainArea img.image02 {
    margin: 40px 0;
}

#stageArea {
    position: relative;
    z-index: 2;
}
#stageArea ul {}
#stageArea ul li.pc {
    display: inline-block;
    margin: 0 10px;
    width: 200px;
}
#stageArea ul li.sp { display: none;}
#stageArea ul li img {}

#requestArea {
    background: #3c3c3c;
    padding: 80px 0;
}

#infoArea {
    width: 1080px;
    margin: 0 auto 50px;
    padding: 40px 0 0;
    position: relative;
    border-top: 1;
}
#infoArea .textBlock {
    line-height: 2;
}
#infoArea .textBlock .block {
    display: block;
}
#infoArea .oekora {
    padding: 0 0 10px;
}
#infoArea .oekora h2 {
    text-align: center;
    font-size: 3.8rem;
    letter-spacing: 0.7rem;
}
#infoArea .oekora img.oekora {}
#infoArea .oekora .textBlock {
    column-count: 2;
    -webkit-column-count: 2;
    -moz-column-count: 2;
}
#infoArea .oekora .textBlock .text {
}
#infoArea .oekora .textBlock .award {
    position: relative;
    margin: 10px 0 0;
}
#infoArea .oekora .textBlock .award .awardTitle {
    text-align: center;
    background: #000;
    position: relative;
    margin: 0 auto -22px;
    width: 80px;
}
#infoArea .oekora .textBlock .award img {
}
#infoArea .oekora .textBlock .award img.top {
    vertical-align: bottom;
}
#infoArea .oekora .textBlock .award img.btm {}
#infoArea .oekora .textBlock .award .text {
    background: url(../images/award-mdl.png) repeat-y 0 0;
    background-size: 100%;
    padding: 0 30px;
    margin: -3px 0;
    position: relative;
    z-index: 99;
    line-height: 1.8;
}

#infoArea .profile {
    border-top: 1px solid #444;
    border-bottom: 1px solid #444;
    padding: 20px 0;
}
#infoArea .profile .nobunaga {
    display: table;
    margin: 0 0 20px;
}
#infoArea .profile .nobunaga .imgBox {
    display: table-cell;
    width: 240px;
}
#infoArea .profile .nobunaga .imgBox img {
    width: 100%;
    padding-top: 15px;
}
#infoArea .profile .nobunaga .textBlock {
    display: table-cell;
    vertical-align: top;
    padding: 0 0 0 20px;
}
#infoArea .profile .nobunaga .textBlock h3 {}
#infoArea .profile .nobunaga .textBlock h3 .name { font-size: 2.2rem;}

#infoArea .profile .coactorBox {
    display: table;
}
#infoArea .profile .coactorBox .coactor {
    display: table-cell;
    width: 180px;
}
#infoArea .profile .coactorBox .coactor img {
    width: 100%;
}
#infoArea .profile .coactorBox .coactor p {
    text-align: center;
}

#infoArea .detail {
    font-size: 1.6rem;
    padding: 20px 0;
}
#infoArea .detail .block {
    float: left;
    width: 50%;
    vertical-align: top;
    padding: 0 10px;
    margin: 5px 0;
}
#infoArea .detail .block dl {}
#infoArea .detail .block dl dt {
    background: #585755;
    margin-bottom: 15px;
    padding: 4px 0;
    text-align: center;
    font-weight: bold;
    border-radius: 6px;
}
#infoArea .detail .block.program dl dd {
    list-style-type: circle;
}
#infoArea .detail .block dl dd {
    margin: 15px 0 15px 20px;
    display: list-item;
    line-height: 1.6;
}
#infoArea .detail .block dl dd ul {
    line-height: 1.6;
    text-indent: -0.2em;
    margin-left: 20px;
}
#infoArea .detail .block dl dd small {
    font-size: 1.1rem;
    margin: 0 9px;
    display: inline-block;
}
#infoArea .detail .block dl dd ul li {
    list-style-type: disc;
    line-height: 1.3;
    margin: 7px 0;
    font-size: 1.6rem;
}
#infoArea .detail .block dl dd ul li span.yori {
    display: block;
    font-size: 1.3rem;
}

#infoArea .detail .block dl dd ul li#jcda {
    background: url(../images/jcda_logo.gif) no-repeat 0px -1px;
    background-size: 10%;
    padding-left: 57px;
}
#infoArea .detail .block dl dd p {
    display: block;
    width: 100%;
}
#infoArea .detail .block dl dd.table {
    display: table;
    margin: 0;
}
#infoArea .detail .block dl dd .imgBox {
    display: table-cell;
    width: 270px;
}
#infoArea .detail .block dl dd .imgBox img {width: 100%;}
#infoArea .detail .block dl dd .place {
    display: table-cell;
    padding-left: 15px;
    vertical-align: top;
}
#infoArea .detail .block dl dd .place h4 {
    font-size: 2rem;
    letter-spacing: 0.4rem;
    margin: 0 0 5px;
}
#infoArea .detail .block dl dd .place address {
    line-height: 1.4;
    letter-spacing: 0.3rem;
    font-style: normal;
}
#infoArea .detail .block dl dd .place a.link {
    border: 2px solid white;
    width: 80%;
    display: block;
    text-align: center;
    padding: 4px 9px 4px 0;
    margin: 20px 0;
    vertical-align: bottom;
    font-weight: bold;
}
#infoArea .detail .block dl dd .place a.link:hover {
    border: 2px solid #E85298;
}
#infoArea .detail .block .attention {
    line-height: 1.5;
    font-size: 1.3rem;
    margin: 10px 0 0;
}

#page-top{
		width:50px;
		height:50px;
		position: absolute;
		right: 40px;
		bottom: 150px;
		z-index: 9999;
		opacity: 0.9;
		background: #FFF;
		border-radius: 56px;
		text-align: center;
		box-shadow: 1px 1px 5px rgba(64, 64, 64, 0.5);
}
#move-page-top {
		opacity: 1;
		color: #232323;
		line-height: 50px;
		display:block;
		cursor:pointer;
		font-size: 2rem;
}

#footer {
    text-align: center;
    background: rgba(255,255,255,0.1);
    padding: 30px 0;
}
#footer #boxArea {
    text-align: center;
    width: 260px;
    margin: 0 auto;
}

.fb_iframe_widget span {
    width:100px!important;
    height: 30px!important;
    margin: 0 30px!important;
}

/*==================================
stage
==================================*/
.wrapper.stage {
    background-size: cover!important;
    background-position: 50% 0;
    min-height: 100%;
}
.wrapper.stage_credo { background-image: url(../images/stage_credo.jpg); background-repeat: repeat;}
.wrapper.stage_waka { background-image: url(../images/stage_waka.jpg); background-repeat: repeat;}
.wrapper.stage_niji { background-image: url(../images/stage_niji.jpg); background-repeat: repeat;}
.wrapper.stage_bon { background-image: url(../images/stage_bon.jpg); background-repeat: repeat;}
.wrapper.stage_alacarte { background-image: url(../images/stage_alacarte.jpg); background-repeat: repeat;}
.wrapper.stage h1 {
    margin: 0 auto!important;
    padding: 0 0 10px;
    font-size: 3rem;
    border-bottom: 1px solid;
    width: 80%;
}
.wrapper.stage h1 .stage {
    display: block;
    font-size: 2.5rem;
}
.wrapper.stage .textArea {
    font-size: 3rem;
    padding: 20px;
}
.wrapper.stage .textArea ul {}
.wrapper.stage .textArea ul li {
    margin: 25px 0;
    line-height: 1.7;
}
.wrapper.stage .textArea ul li:first-of-type {
    margin: 15px 0;
}
.wrapper.stage .textArea ul li small {
    display: block;
    font-size: 1.4rem;
}
.wrapper.stage .textArea ul li span.yori {
    display: block;
    line-height: 0.6;
    font-size: 2rem;
}

@media screen and (max-width: 1280px) {
/* desktop - tablet horizon */
.brPc { display: none;}

#mainArea {
    width: 90%;
}
#mainArea #mainVisual {
    width: 60%;
    padding: 60% 0 0;
}
#mainArea #mainVisual #main-title {
    width: 55%;
    left: 22%;
    top: 25%;
}
#mainArea #mainVisual #main-rainbow {
    width: 100%;
    left: 0;
}
#mainArea #mainVisual #main-moare {
    width: 90%;
    left: 5%;
    top: 5%;
}
#mainArea #mainVisual #main-square {
    width: 95%;
    left: 2.5%;
    top: 2.5%;
}
#mainArea img.image02 {
    width: 65%;
}

#stageArea {
    width: 100%;
}
#stageArea ul li {
    width: 16.8%!important;
    margin: 0 1%!important;
}
#stageArea ul li img {
    width: 100%;
}

#requestArea {
    padding: 0 5%;
}

#infoArea {
    width: 90%;
}
#infoArea .oekora h2 {
    font-size: 3rem;
}
#infoArea .detail .block dl dd ul li#jcda {
    padding-left: 12%;
}
#infoArea .detail .block dl dd .imgBox {
    display: block;
    width: 80%;
    margin: 0 auto;
}
#infoArea .detail .block dl dd .place {
    display: block;
    padding: 0;
    margin: 10px auto;
}
#infoArea .detail .block dl dd .place a.link {
    width: 80%;
    margin: 20px auto 10px;
}
}

@media screen and (max-width: 959px) {
/* tablet */
html { font-size: 50%;}

}

@media screen and (max-width: 599px) {
/* smartphone */
html { font-size: 60%;}
body { letter-spacing: 0;}
.wrapper {padding-top: 25px;}

.spBr { display: block;}

.ticketArea a {
    background-size: 70%;
    margin: 30px auto 0;
}
.ticketArea a.pc { display: none;}
.ticketArea a.sp {
    display: block;
    background: url("../images/eplus_img_sp.png") no-repeat 30%;
    background-size: 80%;
}

#mainArea {
    padding: 0 0 40px;
    width: 75%;
}
#mainArea h1 img.pc { display: none;}
#mainArea h1 img.sp { display: block;}

#mainArea #mainVisual {
    width: 80%;
    padding: 77% 0 0;
}
#mainArea img.image02 {
    width: 100%;
    margin: 25px 0 10px;
}

#stageArea ul li {
}
#stageArea ul li.sp {
    display: inline-block;
    width: 16.8%;
    margin: 0 1%;
}
#stageArea ul li.pc { display: none;}

#infoArea .oekora h2 {
    font-size: 2rem;
    letter-spacing: 0.2rem;
}
#infoArea .oekora .textBlock {
    -webkit-column-count: 1;
    -moz-column-count: 1;
    column-count: 1;
}
#infoArea .textBlock .block {
    margin: 10px 0 0;
}
#infoArea .oekora .textBlock .award .text {
    padding: 10px 20px;
}
#infoArea .oekora .textBlock .award .awardTitle {
    margin: 0 auto -29px;
}

#infoArea .profile .nobunaga {
    display: block;
}
#infoArea .profile .nobunaga .imgBox {
    display: block;
    width: 100%;
    margin: 0 auto;
}
#infoArea .profile .nobunaga .textBlock {
    display: block;
    padding: 0;
}

#infoArea .profile .coactorBox {
    display: flex;
    display: -webkit-flex;
    flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    justify-content: space-between;
    -webkit-justify-content: space-between;
}
#infoArea .profile .coactorBox .coactor {
    display: block;
    width: 32%;
    margin: 0 0 10px;
}
#infoArea .profile .coactorBox .coactor p {
    font-size: 1rem;
}

#infoArea .detail .block {
    float: none;
    width: 100%;
    padding: 0;
}
#infoArea .detail .block dl dd {
    margin: 15px 0 15px 15px;
}
#infoArea .detail .block dl dd ul {
    margin-left: 10px;
}
#infoArea .detail .block dl dd .imgBox {
    width: 100%;
}
#infoArea .detail .block dl dd .place a.link {
    width: 100%;
    padding: 8px 0;
}

#page-top {
    right: 3%;
    bottom: 2.3%;
}

.wrapper.stage {
    background-repeat: repeat-y;
    background-size: inherit!important;
    /* height: auto; */
}
.wrapper.stage h1 {
    font-size: 2rem;
    margin: 10px auto!important;
    width: 100%;
    line-height: 1.6;
    padding: 0 0 10px;
    border-bottom: 1px dashed;
}
.wrapper.stage .textArea {
    font-size: 1.8rem;
    padding: 0;
}
.wrapper.stage .textArea ul li {
    margin: 20px 0!important;
    line-height: 1.3;
    font-size: 2.1rem;    
}
.wrapper.stage .textArea ul li span.yori,
.wrapper.stage .textArea ul li small {
    font-size: 1.3rem;
    margin: 5px 0;
    line-height: 1.3;
}

.wrapper.stage #mainArea p {
    text-align: left;
}
.wrapper.stage #mainArea a.back {
    text-align: left;
    text-decoration: underline;
    margin-bottom: 30px;
}

#page-prev{
		width: 25px;
		height: 25px;
		position: absolute;
		left: 20px;
		bottom: 50%;
		z-index: 9999;
		opacity: 0.9;
		background: rgba(255, 255, 255, 0.8);
		border-radius: 56px;
		text-align: center;
		box-shadow: 1px 1px 5px rgba(64, 64, 64, 0.3);
}
#move-page-prev {
		opacity: 1;
		color: #000000;
		line-height: 26px;
		display:block;
		cursor:pointer;
		font-size: 1.5rem;
		font-weight: bold;
}
#page-next{
		width: 25px;
		height: 25px;
		position: absolute;
		right: 20px;
		bottom: 50%;
		z-index: 9999;
		opacity: 0.9;
		background: rgba(255, 255, 255, 0.8);
		border-radius: 56px;
		text-align: center;
		box-shadow: 1px 1px 5px rgba(64, 64, 64, 0.3);
}
#move-page-next {
		opacity: 1;
		color: #000000;
		line-height: 26px;
		display:block;
		cursor:pointer;
		font-size: 1.5rem;
		font-weight: bold;
}

}
@media screen and (min-width: 600px) {
#page-prev, #move-page-prev, #page-next, #move-page-next,
.wrapper.stage #mainArea a.back {
    display: none;
}
}

