@charset "utf-8";

/* ----------------------------------------
- RESET
---------------------------------------- */
*,*::before,*::after{box-sizing:border-box}ul[class],ol[class]{padding:0}body,h1,h2,h3,h4,p,ul[class],ol[class],figure,blockquote,dl,dd{margin:0}body{min-height:100vh;scroll-behavior:smooth;text-rendering:optimizeSpeed;line-height:1.5}ul[class],ol[class]{list-style:none}a:not([class]){text-decoration-skip-ink:auto}img{max-width:100%;display:block}article>*+*{margin-top:1em}input,button,textarea,select{font:inherit}/*img:not([alt]){filter:blur(10px)}*/@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}


/* CLEAR
----------------------------------------------------- */
.clear {clear:both;}


/* CLEAR FIX
----------------------------------------------------- */
.clearfix::after {
	display: block;
	clear: both;
	content: "";
}


/* ----------------------------------------
- FORMAT
---------------------------------------- */
html {font-size:62.5%;}/*デフォルト16px*/

body {color:#636464; font-family:YakuHanJP,"Cormorant","ヒラギノ角ゴ Pro","Hiragino Kaku Gothic Pro","Helvetica Neue",Helvetica,Arial,"Lucida Grande","メイリオ",Meiryo,sans-serif; text-size-adjust:100%; -webkit-text-size-adjust:100%; background:url("../img/backimage.png") center center / cover no-repeat fixed;}

a {text-decoration:none; outline:none; color:#636464; -webkit-tap-highlight-color:rgba(0,0,0,0);}

.spNone {display:none!important;}
.pcNone {display:block!important;}
/*** 960px以上 PCサイズcss適用 ***/
@media screen and (min-width: 960px) {
  .spNone {display:block!important;}
  .pcNone {display:none!important;}
}


/* ヘッダー */
.header {
  width: 100%;
  height: 80px;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 999;
}

/*@media screen and (min-width: 960px) {
  .header {
    height: 100px;
    background: url("../img/backimage.png") center center / cover no-repeat fixed;
  }
}*/

.header_inner {
  padding: 0 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: inherit;
  position: relative;
}

/*.header_title {
  width: 200px;
  visibility: visible;
}

@media screen and (min-width: 960px) {
  .header_title {
    width: 357px;
  }
}

.header_title a {
  display: block;
  width: 100%;
  height: 100%;
  position:relative;
  top: 50px;
  left: 45%;
}

@media screen and (min-width: 960px) {
  .header_title a {
    top:80px;
    left:10px;
    z-index: 10;
  }
  .header_title a {
  	transition-property: opacity;
  	transition-duration: 0.5s;
  }
  .header_title a:hover {
  	opacity: 0.7;
  }
}*/

.header_nav {
  position: absolute;
  right: 0;
  left: 0;
  top: 0;
  width: 100%;
  height: 100vh;
  transform: translateX(100%);
  transition: ease .4s;
}


/*@media screen and (min-width: 960px) {
  .header_nav {
    position: static;
    transform: initial;
    height: inherit;
  }
}*/

.nav-items {
  position: absolute;
  top: 50px;
  left: 50%;
  transform: translateX(-50%);
  padding: 0;
}

.sns-items {
  position: absolute;
  top: 540px;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  border-top: solid 1px #fff;
}


@media screen and (min-width: 960px) {
  /*.nav-items, .sns-items {
    width: 100%;
    height: 100%;
    display: flex;
    position: static;
    top: 0;
    left: 0;
    transform: translate(0, 0);
  }
  .nav-items {
    justify-content: flex-end !important;
    padding: 20px 20px 0 0 !important;
  }*/
  .nav-items img {
    width: 75% !important;
    margin: 0 auto 30px;
  }
  .nav-items img:hover {
    opacity: 0.7 !important;
  }
  .sns-items {
    /*border: none;
    justify-content: end !important;
    position: relative;
    top: -40px;
    left: -825px;*/
    top: 690px;
  }
  /*hr {
  	height: 0; margin: 0; padding: 0; border: 0;
  	border: solid 1px #c184f0;
  	width: 800px;
  	float: right;
  	margin: -130px 0 0;
  }*/
}

.nav-items_item a {
  color: #fff;
  width: 100%;
  display: block;
  text-align: center;
  font-size: 20px;
  margin-bottom: 20px;
  font-family: "Cherry Bomb One", system-ui;
}

.nav-items_item:last-child a {
  margin-bottom: 0;
}

@media screen and (min-width: 960px) {
  .nav-items_item a {
    /*margin-bottom: 0;
    color: #8d5cbc;
    width: fit-content;*/
    transition : all 0.5s ease 0s;
    font-size: 30px;
    margin-bottom: 20px;
  }
  /*.nav-items .nav-items_item a {
    margin-left: 25px;
  }
  .sns_items .nav-items_item a {
    margin-left: 25px;
  }*/
  .nav-items .nav-items_item a:hover {
    color: #8d5cbc !important;
  }
}

.nav-items_item i {
  color: #fff;
  font-size: 20px;
  float: left;
  margin: 30px 0 0 20px;
}

.nav-items_item i.fa-x-twitter {
  margin-left: 0;
}

@media screen and (min-width: 960px) {
  /*.nav-items_item i {
    color: #c184f0;
    margin: 0;
  }*/
  .nav-items_item i:hover {
    color: #8d5cbc !important;
    transition : all 1s ease 0s;
  }
}


/* ハンバーガーメニュー */
.header_hamburger {
  width: 48px;
  height: 100%;
  margin-top: 5px;
  cursor: pointer;
  margin-left: auto;
  margin-right: -5px;
}

.hamburger {
  background-color: transparent;
  border-color: transparent;
  z-index: 9999;
  font-family: "Concert One", sans-serif;
}

.hamburger::after {
	content: "MENU";
	font-size: 13px;
	color: #ce9ef3;
}

/*@media screen and (min-width: 960px) {
  .hamburger {
    display: none;
  }
}*/

.hamburger span {
  width: 100%;
  height: 3px;
  background-color: #ce9ef3;
  position: relative;
  transition: ease .4s;
  display: block;
  border-radius: 10px;
}

.hamburger span:nth-child(1) {
  top: 0;
}

.hamburger span:nth-child(2) {
  margin: 6px 0;
}

.hamburger span:nth-child(3) {
  top: 0;
}


/* ハンバーガーメニュークリック後のスタイル */
.header_nav.active {
  transform: translateX(0);
  background: linear-gradient(to bottom, #f4e2de, #ead9f7, #fed0df, #cfe4f5);
}

.hamburger.active::after {
  content: "CLOSE";
  color: #fff;
}

.hamburger.active span {
  background-color: #fff;
}

.hamburger.active span:nth-child(1) {
  top: 9px;
  transform: rotate(45deg);
}

.hamburger.active span:nth-child(2) {
  opacity: 0;
}

.hamburger.active span:nth-child(3) {
  top: -9px;
  transform: rotate(-45deg);
}


/*=============
main image
=============*/
#mainImage div {
  background-image: url(../img/kyururin_heavenly_logo.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  height: 50vh;
  /*margin: 190px 0 0;*/
}

@media screen and (min-width: 960px) {
  #mainImage div{
    height: 110vh;
	margin: 0;
  }
}

/*=============
content  area
=============*/
#content {
	width: 100%;
	padding: 50px 20px;
}

#content h2 {
	color: #8d5cbc;
	font-size: 30px;
	font-family: "Cherry Bomb One", system-ui;
}

#content ul li {
	list-style: none;
}

#content .list_item {
	margin: 20px 0;
	width: fit-content;
}

#content .date {
	color: #767676;
	font-family: "Cherry Bomb One", system-ui;
	margin: 0 0 5px;
	font-size: 10px;
}

#content .category {
	color: #adadad;
	font-family: "Cherry Bomb One", system-ui;
	font-size: 10px;
}

#content .title {
	font-size: 13px;
}

#pageTop {position:fixed; bottom:10px; right:10px; z-index:9;}
#pageTop a {background:url(../img/page_top_icon.png) center no-repeat; width:60px; height:0; padding:64px 0 0; display:block; overflow:hidden;}

@media screen and (min-width: 960px) {
  #content {
    width: 960px;
    padding: 0;
    margin: 60px auto;
  }
  #content h2 {
	font-size: 40px;
}
  .information a, .schedule a, .discography a, .blog a {
  	transition-property: opacity;
  	transition-duration: 0.5s;
  }
  .information a:hover, .schedule a:hover, .discography a:hover, .blog a:hover {
  	opacity: 0.5;
  }
  #content .date, #content .category {
  	font-size: 13px;
  }
  #content .title {
  	font-size: 15px;
  }
  #pageTop {bottom:20px; right:20px;}
  #pageTop a {transition-property: opacity; transition-duration: 0.5s;}
  #pageTop a:hover {opacity: 0.7;}
}


/*=============
footer  area
=============*/
footer {
	width: 100%;
	background: #e7d2f7;
	/*margin: 30px 0 0;*/
	margin: -30px 0 0;
	padding: 0 0 50px;
	text-align: center;
}

.footer-logo {
	width: 50%;
	display: block;
	position: relative;
	top: -50px;
	left: 50%;
	transform: translateX(-50%);
}

footer ul li {
	display: inline-block;
	width: fit-content;
}

.footer-sns {
	position: relative;
	top: -10px;
}

.footer-menu {
	position: relative;
	top: 15px;
}

.footer-sns li.fc a {
    font-size: 20px;
    font-family: "Cherry Bomb One", system-ui;
}

.footer-sns i {
	font-size: 25px;
	margin: 0 0 0 20px;
}

/*.footer-sns i.fa-x-twitter {
	margin-left: 0;
}*/

.footer-menu li {
	font-size: 10px;
	margin: 0 0 0 15px;
}

.footer-menu li:first-child {
	margin-left: 0;
}

.copyright {
	font-size: 10px;
	position: relative;
	top: 30px;
	font-family: "Cherry Bomb One", system-ui;
}

@media screen and (min-width: 960px) {
	footer {
		margin: 100px 0 0;
	}
	footer a {
  		transition : all 0.5s ease 0s;
  	}
	footer a:hover {
		color: #8d5cbc;
	}
	.footer-logo {
		width: 300px !important;
		top: -85px;
	}
	.footer-sns {
		top: -25px;
	}
	.footer-menu {
		top: 12px;
	}
	.footer-sns li.fc a {
	    font-size: 35px;
	}
	.footer-sns i {
		font-size: 35px;
		margin: 0 0 0 30px;
	}
	.footer-menu li {
		font-size: 12px;
		margin: 0 0 0 40px;
	}
	.copyright {
		top: 35px;
	}
}



/*===================================================
  anim
====================================================*/
.anim.fadeX,
.anim.fadeY {
    opacity: 0;
    transition: all .5s ease-out;
}
.anim.fadeX {
    transform: translateX(20px);
}
.anim.fadeY {
    transform: translateY(20px);
}
.anim.fadeX.on,
.anim.fadeY.on {
    opacity: 1;
}
.anim.fadeX.on {
    transform: translateX(0px);
}
.anim.fadeY.on {
    transform: translateY(0px);
}

@media screen and (max-width: 960px){}



/*===================================================
	all
====================================================*/
.mainWrap {
    position: relative;
    z-index: 1;
	font-size: 16px;
    line-height: 1.5;
	letter-spacing: 0.03em;
    word-break: break-all;
}
.mainWrap img {
	display: block;
}

.container {
    position: relative;
}

section {
	margin: 0 auto 160px;
    /*width: 90%;
    max-width: 1200px;*/
}

section .inBox {
    position: relative;
    margin-bottom: 40px;
    padding: 20px 40px 60px;
    background: rgba(255, 255, 255, 0.5);
    border-radius: 10px;
    box-shadow: 0 0px 20px rgba(0, 0, 0, 0.1);
}
section .inBox:last-child {
    margin-bottom: 0;
}
section .inBox .inBoxBorder {
    padding: 40px;
    border: 1px solid #8d5cbc;
    border-radius: 10px;
    margin-top: 20px;
    margin-bottom: 20px;
}
section .inBox .inBoxBorder:last-child {
    margin-bottom: 0;
}

section .inBox .btn a {
	display: block;
    width: 100%;
    max-width: 300px;
    /*margin: 0 auto;*/
    margin: 30px auto 0;
    padding: 20px;
    color: #fff;
    background: #f75b99;
    border: 1px solid #f75b99;
    text-align: center;
    font-weight: bold;
    text-decoration: none;
    border-radius: 100px;
}
section .inBox .btn.fin a {
	background: var(--gray);
    pointer-events: none;
}

.note {
    font-size: 14px;
    text-indent: -1em;
    padding: 0 0 0 1em;
}

.soon {
    text-align: center;
    padding: 20px 0;
    font-weight: bold;
    font-size: 20px;
}

@media screen and (min-width: 961px){

	a,img,i {
		-webkit-transition: all 0.3s ease-out;
		transition: all 0.3s ease-out;
	}

	section .inBox .btn a:hover {
		color: #f75b99;
	    background: #fff;
	}
	
}

@media screen and (max-width: 960px){

    .mainWrap {
        font-size: 14px;
    }

	section {
	    margin: 0 auto 90px;
	    /*width: calc(100% - 50px);*/
	}

	section .inBox {
	    padding: 15px 20px 30px;
        margin-bottom: 20px;
        box-shadow: 0 0px 10px rgba(0, 0, 0, 0.05);
	}
    section .inBox .inBoxBorder {
        padding: 20px;
        border-radius: 5px;
        margin-bottom: 10px;
    }

    section .inBox .btn a {
        padding: 15px;
        /*margin: 0 auto;*/
        margin: 15px auto;
}
    }

    .note {
        font-size: 12px;
    }

    .soon {
        padding: 10px 0;
        font-size: 16px;
    }

}



/*===================================================
	schedule
====================================================*/
#schedule {}
#schedule .inBox {}

#schedule .tourDateBox {}
#schedule .tourDateList {
    position: relative;
}
#schedule .tourDateList:before {
    display: block;
    position: absolute;
    top: -15px;
    left: -20px;
    width: 90px;
    line-height: 25px;
    font-weight: bold;
    text-align: center;
    transform: rotate(-15deg);
    font-size: 14px;
}
#schedule .tourDateList.fin:before  {
    content: "公演終了";
    background: var(--main);
    color: var(--white);
}
#schedule .tourDateList.sold:before {
  content: "完売!";
  background: var(--accent);
  color: var(--white);
}
#schedule .tourDateList.listHead {
    padding: 0 0 10px;
}
#schedule .tourDateList.listHead li {
    justify-content: center;
    font-size: 70%;
    font-weight: 600;
    color: #8d5cbc;
	font-family: "Cherry Bomb One", system-ui;
}
#schedule .tourDateList.listHead li:after {
    display: none;
}

#schedule .tourDateList {
    display: flex;
    align-items: stretch;
    border-bottom: 1px solid #8d5cbc;
    padding: 0 0 15px;
    margin: 0 0 15px;
    position: relative;
}
#schedule .tourDateList:last-of-type {
    margin-bottom: 20px;
}
#schedule .tourDateList li {
    padding: 0 15px;
    box-sizing: border-box;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
}
#schedule .tourDateList li:after {
    content: "";
    position: absolute;
    background: var(--main);
    top: 5%;
    right: 0;
    width: 1px;
    height: 90%;
} 
#schedule .tourDateList li.scheduleTime:after {
    display: none;
}
#schedule .tourDateList .scheduleDate {
    width: 40%;
    font-size: 18px;
    font-weight: bold;
}
#schedule .tourDateList .scheduleDate .day {
    font-size: 14px;
    padding: 0 3px;
}
#schedule .tourDateList .scheduleDate .day.week {
    padding: 0 0 0 3px;
}
#schedule .tourDateList .scheduleTitle {
    width: 17%;
    text-align: center;
}
#schedule .tourDateList .scheduleVenue {
    width: 35%;
    text-align: center;
}
#schedule .tourDateList .scheduleTime {
    width: 28%;
}
#schedule .tourDateList .scheduleTime span {
    display: inline-block;
    font-size: 12px;
    background: var(--accent);
    font-weight: bold;
    padding: 0 10px;
    margin: 0 10px 0 0;
}
#schedule .more {
    text-align: center;
}

@media screen and (min-width: 961px){}

@media screen and (max-width: 960px){

    #schedule .tourDateList {
        padding: 0px 0 15px;
        margin: 0 0 15px;
    }
    #schedule .tourDateList:last-of-type {
        margin-bottom: 15px;
    }
    #schedule .tourDateList:before {
        position: relative;
        transform: rotate(0deg);
        top: 0;
        left: 0;
        margin-bottom: 5px;
    }
    #schedule .tourDateList.fin:before {}
    #schedule .tourDateList.sold:before {}
    
    #schedule .tourDateList.listHead {
        padding: 0;
    }
	#schedule .tourDateList.listHead li {
	    display: none;
	}

	#schedule .tourDateList {
        display: block;
        padding: 0 0 20px;
        margin: 0 0 15px;
        border-bottom: 1px solid #8d5cbc;
	}
	#schedule .tourDateList li {
	    padding: 0;
	    display: block;
	    font-size: 100%;
	}
	#schedule .tourDateList li:after{
		display: none;
	} 
	#schedule .tourDateList .scheduleDate {
	    width: 100%;
        font-size: 16px;
        font-weight: 400;
        margin: 0 0 5px;
    }
    #schedule .tourDateList .scheduleDate .day {
        font-size: 12px;
    }
    #schedule .tourDateList .scheduleDate .area {}
	#schedule .tourDateList .scheduleDate .sp {
		padding: 0 0 0 10px;
        font-size: 90%;
	}
	#schedule .tourDateList .scheduleTitle {
        width: 100%;
        text-align: left;
	}
	#schedule .tourDateList .scheduleVenue {
        width: 100%;
        text-align: left;
        font-size: 18px;
        margin: 0 0 10px;
        font-weight: bold;
	}
	#schedule .tourDateList .scheduleTime {
        width: 100%;
        font-size: 12px;
	}
    #schedule .tourDateList .scheduleTime span {
        margin: 0 5px 5px 0;
    }
    #schedule .tourDateList .scheduleTime p span:last-child {
        margin: 0 5px 0 0;
    }

    #schedule .more {}

}



/*===================================================
	ticket
====================================================*/
#ticket {}
#ticket h3 {}
#ticket .inBox {}

#ticket .ticketBoxTit {
    display: flex;
    font-size: 24px;
    font-weight: bold;
    align-items: center;
    margin: 0 0 20px;
}
#ticket .ticketBoxTit:after {
    content: "";
    flex-grow: 1;
    border-top: 1px solid;
    margin-left: 20px;
}

#ticket .areaBox {
    margin-bottom: 30px;
}
#ticket .areaBox:last-child {
    margin-bottom: 0;
}

#ticket .areaBox .area {
    font-size: 16px;
    /*border-left: 3px solid;
    padding: 0 0 0 10px;*/
    margin: 0 0 15px;
    font-weight: bold;
}

#ticket .caution {
    margin: 30px auto 0;
}

#ticket .caution span {
    color: #8d5cbc;
    font-weight: bold;
    font-size: 20px;
}

/*============ accordion ===========*/
.op_ticket {
    margin: 0 0 2px;
}
.op_ticket:last-child {
    margin: 0;
}
.op_ticket .ticketTit {
    background: #8d5cbc;
    color: #fff;
    padding: 30px 65px 30px 40px;
    font-size: 20px;
    font-weight: bold;
    position: relative;
    cursor: pointer;
    transition: 0.5s ease;
    border-radius: 10px;
}
.op_ticket .ticketTit.open {
    border-radius: 10px 10px 0 0;
}
.op_ticket .ticketTit span {
    position: absolute;
    top: 50%;
    right: 40px;
    width: 20px;
    height: 20px;
    transform: rotate(180deg) translateY(50%);
    transition: 0.3s ease;
}
.op_ticket .ticketTit span:before,
.op_ticket .ticketTit span:after {
    content: "";
    display: block;
    width: 20px;
    height: 0;
    border-bottom: solid 2px;
    position: absolute;
    top: 40%;
    right: 0px;
    transition: all 0.3s ease-out;
    z-index: 1;
}
.op_ticket .ticketTit span:before {
    transform: rotate(90deg);
}
.op_ticket .ticketTit.open span:before {
    -webkit-transform: rotate(0);
    transform: rotate(0);
}

.indent {
    display: inline-block;
    text-indent: -0.25em;
}

.op_ticket .ticketDetail {
    display: none;
    padding: 30px 40px;
    border: 1px solid #8d5cbc;
    border-top: none;
    border-radius: 0 0 10px 10px;
}

.op_ticket .detailList {
    display: flex;
    border-bottom: 1px solid #8d5cbc;
    padding: 0 0 15px;
    margin: 0 0 15px;
    align-items: stretch;
}
.op_ticket .detailList:first-child {
    border-top: 1px solid #8d5cbc;
    padding: 15px 0 15px;
}
.op_ticket .detailList:last-child {
    margin: 0;
}
.op_ticket .detailList dt {
    width: 25%;
    padding: 0 40px 0 0;
    display: flex;
    align-items: center;
    font-weight: 500;
    line-height: 1.6em;
    color: #8d5cbc;
}
.op_ticket .detailList dd {
    width: 75%;
    position: relative;
    padding: 0 0 0 40px;
    display: flex;
    align-items: center;
}
.op_ticket .detailList dd:before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    width: 1px;
    background: #8d5cbc;
}
.op_ticket .detailList dd > * {
    margin-bottom:20px;
}
.op_ticket .detailList dd > *:last-child {
    margin-bottom:0;
}
.op_ticket .detailList dd .detailInner {
    width:100%;
}
.op_ticket .detailList dd .detailInner > *{
    margin-bottom:10px;
}
.op_ticket .detailList dd .detailInner  > *:last-child{
    margin-bottom:0;
}

#faq .op_ticket .ticketTit {
    font-size: 16px;
}

@media screen and (min-width: 961px){

    .op_ticket .ticketTit:hover {
        opacity: 0.7;
    }

}

@media screen and (max-width: 960px){

    #ticket {}
    #ticket h3 {}
    #ticket .inBox {}

	.ticketBoxTit {
        font-size: 16px;
        margin: 0 0 15px;
    }
    .ticketBoxTit:after {
        margin-left: 10px;
    }

    .areaBox {
        margin-bottom: 20px !important;
    }
    .areaBox:last-child {}

    .areaBox .area {
        font-size: 14px !important;
        margin: 0 0 10px !important;
    }
    
    #ticket .caution span {
        font-size: 16px;
    }

    .op_ticket {}
	.op_ticket .ticketTit {
        padding: 15px 35px 15px 15px;
        font-size: 14px;
        border-radius: 5px;
	}
	
    .op_ticket .ticketTit.open {
        border-radius: 5px 5px 0 0;
    }
    .op_ticket .ticketTit span {
        right: 15px;
        width: 15px;
        height: 15px;
    }
    .op_ticket .ticketTit span:before,
    .op_ticket .ticketTit span:after {
        width: 15px;
    }
	.op_ticket .ticketDetail {
        padding: 15px;
        font-size: 14px;
        border-radius: 0 0 5px 5px;
	}
	.op_ticket .detailList {
	    display: block;
	    /*margin: 0 0 15px;*/
	    margin: 0;
	    border-bottom: none;
	}
	.op_ticket .detailList:first-child {
	    border-top: none;
	    /*padding: 0;*/
	    padding: 0 0 15px;
	}
	.op_ticket .detailList dt {
        width: 100%;
        margin: 0 0 10px;
        line-height: 1;
        font-weight: bold;
        border-left: 3px solid;
        padding: 0 0 0 10px;
	}
	.op_ticket .detailList dd {
	    width: 100%;
	    position: relative;
	    padding: 0;
	}
	.op_ticket .detailList dd:before {
	    content: none
	}
	
	#faq .op_ticket .ticketTit {
	    font-size: 14px;
	}
	
}