/* CSS Document */
:root {
	--event-color: #ff14af;
	--event-light-color: #ffc8ff;
	--event-sub-color: #002746;
	--event-sub-light-color: #d6eafa;
}

.lity-content {
	background-color: #FFF!important;
}

.red {
	color: #F00!important;
}
.kv {
	text-align: center;
	background-image: url(../img/bg.jpg);
	background-size: 100%;
	margin-bottom: 30px;
	-webkit-box-shadow: 0px 0px 10px rgba(228,0,127,1.00);
	box-shadow: 0px 0px 10px rgba(228,0,127,1.00);
}
@media screen and (min-width:481px) {
	.kv2 {
		display: flex;
		align-items: center;
	}
	.kv2 > img {
		width: 50%;
		height: auto;
		display: block;
	}
}
@media screen and (max-width:480px) {
	.kv2 {
		text-align: center;
	}
}


.menu,
.menu2,
.menu3 {
	width: 90%;
	max-width: 800px;
	margin: 0 auto 30px;
}
.menu ul,
.menu2 ul,
.menu3 ul {
	width: 100%;
}
.menu ul li a {
	display: block;
	text-align: center;
	background-color:#e4007f;
	border-radius: .3em;
	border-top: 5px solid #e4007f;
	border-bottom: 5px solid #e4007f;
}
.menu ul li a.now {
	border-bottom-color: #ffcc66;
}

@media screen and (min-width:481px) {
	.menu ul {
		display: flex;
		justify-content: space-around;
	}
	.menu ul li {
		width: calc((100% - 20px) / 3);
	}
}
@media screen and (max-width:480px) {
	.menu ul {
	}
	.menu ul li {
		width: 100%;
		margin-bottom: .5em;
	}
}

.menu2 ul,
.menu3 ul {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	width: 100%;
}
.menu2 ul li,
.menu3 ul li {
	width: calc((100% - 30px) / 3);
	margin: 0 5px 10px;
}
@media screen and (max-width:480px) {
	.menu2 ul,
	.menu3 ul {
		display: flex;
		justify-content: center;
		flex-wrap: wrap;
		width: 100%;
	}
	.menu2 ul li,
	.menu3 ul li {
		width: calc((100% - 20px) / 2);
		margin-bottom: 10px;
	}
}
.menu2 ul li a {
	border: 1px solid #e4007f;
	background-color:#FFF;
	border-radius: .3em;
	display: block;
	text-align: center;
	padding: 10px 0;
}
.menu2 ul li a.now {
	background-image: url(../img/menu2_now.png);
	background-position: bottom center;
	background-repeat: no-repeat;
}

.menu3 ul li a {
	border: 1px solid #e4007f;
	background-color:var(--event-light-color);
	border-radius: .3em;
	display: block;
	text-align: center;
	padding: 10px 0;
}
.menu3 ul li a.now {
	background-image: url(../img/menu2_now.png);
	background-position: bottom center;
	background-repeat: no-repeat;
}

.livelogo h1 {
	text-align: center;
	margin-bottom: 60px;
}

.hedding {
	width: 90%;
	max-width: 1200px;
	padding: 5px;
	margin: 0 auto 30px;
	text-align: left;
	border-radius: .3em;
	font-size: 12px;
	line-height: 14px;
	background-color: #ffd5df;
}
.hedding span {
	display: inline-block;
	line-height: 14px;
}





.infomationbox {
	width: 90%;
	max-width: 1200px;
	margin: 0 auto 30px;
}

.infomationbox .index {
	padding: 5px 15px;
	font-size: 110%;
	line-height: 1;
	border-radius: calc(1em + 10px);
	margin-bottom: 15px;
	background-image: -webkit-linear-gradient(0deg,rgba(255,255,255,.800) 0%,rgba(255,255,255,.800) 100%),url(../img/rainbow.png);
	background-image: -moz-linear-gradient(0deg,rgba(255,255,255,.800) 0%,rgba(255,255,255,.800) 100%),url(../img/rainbow.png);
	background-image: -o-linear-gradient(0deg,rgba(255,255,255,.800) 0%,rgba(255,255,255,.800) 100%),url(../img/rainbow.png);
	background-image: linear-gradient(90deg,rgba(255,255,255,.800) 0%,rgba(255,255,255,.800) 100%),url(../img/rainbow.png);
	border: 3px solid #ffd5df;
}
/*
@media screen and (max-width:480px) {
	.infomationbox .index {
		width: calc(100% + 20px);
		margin: 0 -10px 15px;
	}
}
*/

.info {
	background-color: #ffd5df;
	border-radius: .3em;
	padding: 15px;
	margin-bottom: 30px;
}
@media screen and (max-width:480px) {
	.info {
		padding: 15px 10px;
	}
}
#live .info {
	background-color: transparent;
	border-radius: 0;
	padding: 0 1em;;
	margin-bottom: 30px;
}
@media screen and (max-width:480px) {
	#live .info {
		padding: 0 .5em;;
	}
}

#main h2 {
	border-radius: .2em;
	background-color: #FFF;
	padding: .5em 1.5em;
	font-size: 140%;
	font-weight: 300;
	box-shadow: none;
	line-height: 1.2;}
#main h2 span {
	display: inline-block;
}
#main h2 span.font80 {
	font-size: 80%!important;

}
@media screen and (max-width:480px) {
	#main h2 {
		padding: .5em .5em;
	}
}


.info p {
	padding: .5em 0em;
}
@media screen and (max-width:480px) {
	.info p {
		padding: .5em .5em;
	}
}
.info .catch {
	font-size: 120%;
	color: #e4007f;
	font-weight: bold;
}
#live .info .catch {
	color: #4e4e4e;
	font-weight: normal;
}
.info .catch span {
	display: inline-block;
}

.info ul.catch {
	margin-left: 1.5em;
}
@media screen and (max-width:480px) {
	.info ul.catch {
		margin-left: .5em;
	}
}
.info  ul.catch li {
	padding-left: 1.2em;
}
.info  ul.catch li::before {
	content: '●';
	display: inline-block;
	width: 1.2em;
	text-align: left;
	margin-left: -1.2em;
}
.info table {
	margin: 1em 0;
	font-size: 120%;
}
#live .info table.listbox {
	margin: .5em 1.5em 1em;
	font-size: 100%;
}
#radio .info table.listbox {
	margin: .5em 1.5em;
	font-size: 100%;
}
.info table td {
	padding-right: 1.5em;
	vertical-align: top;
	min-height: 1em;
}
.info table th {
	padding-right: 1.5em;
	vertical-align: top;
	font-weight: normal;
	white-space: nowrap;
}
#radio .info table th {
	padding-left: 1em;
}
@media screen and (max-width:480px) {
	table.listbox,
	table.listbox tbody,
	table.listbox tbody tr {
		display: inline;
	}
	table.listbox tbody tr th {
		display: block;
		font-weight: bold;
		border-bottom: 1px solid #e4007f;
		color: #e4007f;
	}
	table.listbox tbody tr td {
		display: block;
		padding: .3em 1em 1em 1.5em;
	}
}

.radio_logo {
	text-align: center;
	margin-bottom: .5em;
}
.radio_logo img {
	width: 400px;
	max-width: 40%;
}
@media screen and (max-width:480px) {
	.radio_logo img {
		max-width: 50%;
	}
}



.info .list {
	margin-left: 1.5em;
}
@media screen and (max-width:480px) {
	.info .list {
		margin-left: .5em;
	}
}
.info .list li {
	padding-left: 1em;
}
.info .list li::before {
	content: '★';
	display: inline-block;
	width: 1em;
	text-align: left;
	margin-left: -1em;
}
@media screen and (max-width:480px) {
}
.attention li {
	font-size: 80%;
	padding-left: 1em;
}
.attention li::before {
	content: '※';
	display: inline-block;
	width: 1em;
	text-align: left;
	margin-left: -1em;
}
#overseas .attention li::before {
	content: '*';
}
.cautions .attention li {
	font-size: 100%;
	padding-left: 1em;
}

.infolist {
}
@media screen and (max-width:480px) {
	.infolist {
	}
}
.infolist li {
	padding-left: 1em;
}
.infolist li::before {
	content: '・';
	display: inline-block;
	width: 1em;
	text-align: left;
	margin-left: -1em;
}

.info p.attention_cap {
	display: block;
	padding: .5em 1em .5em 1em;
	color: red;
}
.attention_cap::before {
	content: '※';
	display: inline-block;
	width: 1em;
	text-align: left;
	margin-left: -1em;
}
#overseas .attention_cap::before {
	content: '*';
}
.attention_cap span {
	display: inline-block;
}
span.attention {
	font-size: 90%;
	padding-left: 1em;
	display: inline-block;
}
span.attention::before {
	content: '※';
	display: inline-block;
	width: 1em;
	text-align: left;
	margin-left: -1em;
}


.social li {
	width: 80px;
}

.track {
	margin-bottom: 20px;
}
.track:last-of-type {
	margin-bottom: 0;
}
.track li {
	margin-bottom: .8em;
}
.track li > ins {
	text-decoration: none;
	font-size: 80%;
	letter-spacing: -.01em;
	display: inline-block;
	padding-left: 2em;
}
.track li > span {
	display: block;
	padding-top: .2em;
	padding-left: 1.8em;
	font-size: 90%;
	letter-spacing: -.01em;
}

.track li > dl {
	font-size: 80%;
	padding: .5em 0 0 2em;
	color: #666;
	line-height: 1;
}
.track li > dl dt {
	float: left;
}
.track li > dl dd {
	letter-spacing: -.01em;
	margin-bottom: .5em;
}
.track li:last-child > dl dd:last-child {
	margin-bottom: 0;
}

.info table table {
	margin: .5em 0 .5em 1em;
	font-size: 100%;
}
.info table table td {
	padding-right: 0;
	vertical-align: top;
	min-height: 1em;
}
.info table table th {
	padding-right: 0;
	vertical-align: top;
	font-weight: normal;
	white-space: nowrap;
}
@media screen and (max-width:480px) {
	.info table table {
		margin-left: 0;
	}
	table.listbox tbody tr td th {
		display: block;
		font-weight: bold;
		border-bottom: 1px solid #e4007f;
		color: #e4007f;
	}
	table.listbox tbody tr td td {
		display: block;
		padding: 0;
	}
}



/* goods:shoplink */

.shoplink {
	text-align: center;
}



/* goods:oversea */

.oversea {
	background-color: #425396;
	width: 100%;
	max-width: 600px;
	margin: 15px auto 30px;
	padding: 3px;
	border-radius: .3em;
	font-size: 12px;
	letter-spacing: -.001em;
}
@media screen and (max-width:480px) {
	.oversea {
		font-size: 10px;
	}
}
.oversea p {
	background-color: #FFF;
	padding: 0 20px 10px;
}
.oversea .title {
	background-color: #425396;
	font-size: 160%;
	line-height: 1;
	font-weight: bold;
	color: #FFF;
	text-align: center;
	padding: 10px 0;
}
.oversea ul {
	background-color: #FFF;
	padding: 10px 20px;
}



/* goods:itembox */

.infomationbox .goodslist li {
	margin-bottom: 30px;
	border-radius: .3em;
}
.infomationbox .goodslist li:nth-child(odd) {
	background-color: var(--event-light-color);
}
.infomationbox .goodslist li:nth-child(even) {
	background-color: var(--event-sub-light-color);
}
.infomationbox .goodslist li ul.attention {
	margin: 5px 0 0;
	padding: 0;
}
.infomationbox .goodslist li ul.attention li {
	margin-bottom: 5px;
	border-radius: 0;
	background: none;
}
.infomationbox .goodslist li ul.attention li:last-child {
	margin-bottom: 0;
}

.infomationbox .goodslist li > a img {
	display: block;
	margin: 0 auto;
}

.infomationbox .itembox {
	background-color: rgba(255,255,255,.8);
	padding: 30px;
	letter-spacing: -.002em;
}
@media screen and (max-width:640px){
	.infomationbox .itembox {
		padding: 15px;
	}
}

.itembox .hdbox {
	position: relative;
}
.itembox .hdbox .livetitle {
	font-size: 80%;
	font-weight: bold;
	color: var(--event-sub-color);
	text-shadow: 0px 0px 5px var(--event-sub-light-color);
	background-color: #FFF;
	padding: .3em 60px .3em 10px;
	line-height: 1;
	border-radius: .2em;
}
.itembox .hdbox .livetitle span {
	display: inline-block;
}
.itembox .hdbox .name {
	font-size: 160%;
	font-weight: 600;
	color: var(--event-color);
	text-shadow: 1px 1px 5px var(--event-light-color);
	padding: .5em 10px 0 10px;
	line-height: 1;
}
.itembox .hdbox .price {
	font-size: 180%;
	font-weight: 600;
	color: #555;
	padding: .3em 10px 0 10px;
	line-height: 1;
}
.itembox .hdbox .price span {
	font-size: 70%;
}
.itembox .hdbox .ico {
	position: absolute;
	right: -5px;
	top: -5px;
}

.itembox .imgbox {
	text-align: center;
	padding: 15px 0;
}

.itembox .txtbox {
}
.itembox .txtbox .txt {
	font-size: 120%;
	font-weight: 600;
	color: var(--event-color);
	text-shadow: 1px 1px 5px var(--event-light-color);
	line-height: 1.4;
	padding: 0 10px;
	margin-bottom: 15px;
}
.itembox .txtbox .spec {
	font-size: 80%;
	display: flex;
	flex-wrap: wrap;
	padding: 10px;
	background-color: #FFF;
	border-radius: .2em;
}
.itembox .txtbox .spec p {
	margin-right: 10px;
	padding-left: 1em;
	text-indent: -1em;
}
.itembox .txtbox .spec > p:last-child {
	margin-right: 0;
}
.itembox .txtbox .spec p span {
	display: inline-block;
	text-indent: 0;
}
@media screen and (max-width:480px) {
	.infomationbox .itembox {
		padding: 10px 10px;
	}
	.itembox .hdbox .livetitle {
		padding-right: 9vw;
	}
	.itembox .hdbox .name {
		font-size: 140%;
		/*padding: .5em 0 0 0;*/
	}
	.itembox .hdbox .price {
		font-size: 160%;
		/*padding: .3em 0 0 0;*/
	}
	.itembox .hdbox .ico img {
		width: 8vw;
		height: auto;
	}
	.itembox .txtbox .txt {
		font-size: 110%;
		/*padding: 0 0;*/
	}
}

.infomation .info table {
	margin: 1em 0;
}
.infomation .info table,
.infomation .info table tr {
	border-collapse: collapse;
	border-spacing: 0;
}
.infomation .info table tr th {
	white-space: nowrap;
	vertical-align: top;
	padding: 5px 3px;
}
.infomation .info table tr td {
	padding: 5px 3px;
}
.infomation .info table tr td span {
	display: inline-block;
}
@media screen and (min-width:481px) {
	.infomation .info table {
		margin-left: 1em;
	}
	.infomation .info table tr th {
		padding: 5px 1em;
	}
	.infomation .info table tr td {
		padding: 5px 1em;
	}
	.jktbox {
		display: flex;
		flex-wrap: nowrap;
		padding: 15px 0;
		justify-content: center;
	}
	.jktbox li {
		width: calc(100% / 3);
		padding: 0 5px;
		text-align: center;
		font-size: 80%;
	}
	.jktbox li img {
		margin-bottom: .5em;
	}
	.jkt {
		display: block;
		margin: 0 auto;
		padding: 0 5px;
		text-align: center;
	}
	.jkt img {
		width: 100%;
		max-width: 600px;
	}
}
@media screen and (max-width:480px) {
	.infomationbox .info table,
	.infomationbox .info table tbody,
	.infomationbox .info table tr {
		display: block;
		margin: 0;
		padding: 0;
	}
	.infomationbox .info table {
		width: 100%;
	}
	.infomationbox .info table th,
	.infomationbox .info table td {
		display: block;
		width: 100%;
	}
	.infomationbox .info table tr th {
		border-bottom: 1px solid var(--event-light-color);
		padding: 5px .5em 2px;
	}
	.infomationbox .info table tr td {
		padding: 5px 1em;
	}
	.jktbox {
	}
	.jktbox li {
		padding: 10px;
		text-align: center;
		font-size: 80%;
	}
	.jktbox li img {
		margin-bottom: .5em;
	}
	.jkt {
		display: block;
		margin: 0 auto;
		max-width: 300px;
	}
}


.bnrlink {
	display: block;
	background-color: #fff;
	color: #F06;
	border: 1px solid #FF0066;
	margin-top: .5em;
	border-radius: .3em;
	padding: .5em 1.5em .5em 1em;
	position: relative;
	transition: .3s all;
	line-height: 1;
}
.bnrlink::after {
	position: absolute;
	right: .5em;
	content: "〉";
	top: calc(50% - .5em);
}
.bnrlink:hover {
	background-color: #F06;
	color: #FFF;
	text-decoration: none;
}
.bnrlink span {
	display: inline-block;
}


.cautions, .contact {
	margin-bottom: 30px;
}
.cautions p, .contact p {
	margin-left: 1.5em;
}
.cautions dl {
	margin-left: 1em;
}
.cautions dt,
.contact dt {
	font-size: 110%;
	font-weight: bold;
	border-bottom: 1px solid;
}
.cautions dd,
.contact dd {
	padding: 5px 0 15px;
}

@media screen and (min-width:481px) {
	.cautions dd,
	.contact dd {
		padding: 15px 0 30px 1em;
	}
}

.info table span {
	display: inline-block;
}

.info .indent {
	display: block;
	padding-left: 2.5em;
	margin-top: -1em;
}
.info .indent span {
	display: inline-block;
	margin-right: .5em;
}


.en-ticket {
	background-color: #FFF;
	border: 1px solid #EEE;
	margin-top: 2em;
	padding: 1em 1em 1em;
	position: relative;
}
.en-ticket p:first-child {
	line-height: 1em;
	margin: 0;
	margin-left: calc(-1em - 1px);
	background-color: #EEE;
	padding: .5em 1em;
	display: inline-block;
	width: calc(100% + 2px);
	position: absolute;
	top: -1em;
}
.en-ticket dt {
	background-color: #EEE;
	font-weight: bold;
}
.en-ticket > dd {
	padding-top: 1em;
}
.en-ticket dl.child dt {
	background-color: var(--event-sub-light-color);
	color: var(--event-sub-color);
	font-weight: bold;
}
.en-ticket dl.child dd {
	border-bottom: 1px dotted #f7f8e6;
}




#merch .subtitle {
	font-size: 120%;
	font-weight: bold;
	background-color: var(--event-sub-color); 
	color: #FFF;
	padding: 0 .5em;
}
#merch .lead {
	font-size: 120%;
	padding: 1em 0;
}
.attentionbox {
	padding: 30px 10px 0;
}
.attentionbox dt {
	background-color: var(--event-light-color); 
	font-weight: bold;
	padding: 0 .5em;
}
.attentionbox dd {
	padding: 15px 5px 30px;
}
.attentionbox dd ul li {
	margin-left: 1em;
}
.attentionbox dd ul li::before {
	content: '・';
	display: inline-block;
	width: 1em;
	text-align: left;
	margin-left: -1em;
}
.attentionbox dd ul li.access::before {
	content: '';
	display: inline-block;
	width: 1em;
	text-align: left;
	margin-left: -1em;
}
.attentionbox dd ul li.circle::before {
	content: '○';
	display: inline-block;
	width: 1em;
	text-align: left;
	margin-left: -1em;
}
.attentionbox dd ul li.asterisk::before {
	content: '※';
	display: inline-block;
	width: 1em;
	text-align: left;
	margin-left: -1em;
}
.attentionbox td {
	vertical-align: top;
}
#attentions .attentionbox dd ul li::before {
	content: '◆';
	display: inline-block;
	width: 1em;
	text-align: left;
	margin-left: -1em;
}



@media screen and (min-width:481px) {
	.sponly {
		display: none;
	}
	.merch_menu {
		display: flex;
		justify-content: space-around;
	}
}
.payment_list th,
.payment_list td {
	border-bottom: 1px dotted #AAA;
	padding: .5em 0;
}
.payment_list tr:first-of-type th,
.payment_list tr:first-of-type td {
	border-top: 1px dotted #AAA;
}

.payment_list th {
	white-space: nowrap;
	font-weight: normal;
}

.payment {
	display: flex;
	flex-wrap: wrap;
	list-style-type: none;
	margin-bottom: -.5em;
}
.payment li {
	padding: .3em 1em;
	border: 1px solid var(--event-sub-color);
	border-radius: 1em;
	line-height: 1;
	margin-right: 1em;
	list-style-type: none;
	margin-bottom: .5em;
}
.attentionbox dd ul.payment li::before {
	content: '';
}

@media screen and (max-width:480px) {
	.payment_list,
	.payment_list tbody,
	.payment_list tr {
		display: inline;
	}
	.payment_list tr:first-of-type th,
	.payment_list tr:first-of-type td {
		border: none;
	}
	.payment_list th {
		display: block;
		background-color: var(--event-light-color);
		margin-bottom: .5em;
		border: none;
		padding: 0 0 0 5px;
	}
	.payment_list td {
		display: block;
		padding-left: 1em;
		padding-bottom: 1em;
		border: none;
	}
}
.tktnimg {
	display: flex;
	flex-wrap: wrap;
}
.tktnimg li {
	width: calc(100% / 4);
	padding: 5px;
}


#attentions .lead {
	font-size: 120%;
	padding: 1em 0;
}

