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


/* ////////////////////////////////////////////////////////////////////////////////

	Common

//////////////////////////////////////////////////////////////////////////////// */
@font-face {
	font-family: 'sns_icon';
	src: url('../font/sns_icon.eot?hf355k');
	src: url('../font/sns_icon.eot?hf355k#iefix') format('embedded-opentype'),
	url('../font/sns_icon.ttf?hf355k') format('truetype'),
	url('../font/sns_icon.woff?hf355k') format('woff'),
	url('../font/sns_icon.svg?hf355k#sns_icon') format('svg');
	font-weight: normal;
	font-style: normal;
}

i.snsIcon {
	font-family: 'sns_icon' !important;
	speak: never;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	line-height: 1;

	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;

	color: #000;
}
.icon-ap:before { content: "\e900";}
.icon-blo:before { content: "\e901";}
.icon-fb:before { content: "\e902";}
.icon-hp:before { content: "\e903";}
.icon-in:before { content: "\e904";}
.icon-line:before { content: "\e905";}
.icon-spo:before { content: "\e906";}
.icon-tt:before { content: "\e907";}
.icon-tw:before { content: "\e908";}
.icon-yt:before { content: "\e909";}



body {
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
	font-size: 12px;
	line-height: 1.8;
	-webkit-text-size-adjust: 100%;
	background-color: #fff;
}

.contentWrap {
	max-width: 980px;
	margin: 0 auto;
	padding: 80px 60px;
	box-sizing: content-box;
}
.contentWrap h2 {
    font-family: 'Poppins', sans-serif;
	font-size: 64px;
	font-weight: 100;
	text-align: center;
	margin-bottom: 60px;
	-webkit-font-smoothing: antialiased;
    letter-spacing: .1em;
	line-height: 1;
}

img {
	max-width: 100%;
	height: auto;
}
ul { list-style: none;}

.anim {
	opacity: 0;
	transition: all .8s ease-out;
}
.anim.on {
	opacity: 1;
}
#streaming .btnStreaming,
#ticket .btnConfirm,
#trade .btnTrade,
#trade .btnRegist,
#goods .btnGoods,
#special .btnSpecial {
	margin-top: 40px;
}
#streaming .btnStreaming a,
#ticket .btnConfirm a,
#trade .btnTrade a,
#trade .btnRegist a,
#goods .btnGoods a,
#special .btnSpecial a {
	display: block;
	background: #EE6860;
	color: #fff;
	text-decoration: none;
	text-align: center;
	font-size: 16px;
	max-width: 400px;
	border-radius: 80px;
	padding: 18px 25px;
	margin: 0 auto;
}
.logoup #ticket .btnConfirm a{
	background: #E60012;
}
#ticket .btnConfirm.close a {
	background: #aaa;
}
#ticket .btnConfirm.close a:hover {
	opacity: 1;
}

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

	.sp { display: none;}

	a { transition: all 0.3s ease-out;}
	a:hover { opacity: 0.5;}

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

	.pc { display: none;}

	#streaming .btnStreaming,
	#ticket .btnConfirm,
	#trade .btnTrade,
	#trade .btnRegist,
	#goods .btnGoods,
	#special .btnSpecial {
		margin-top: 8vw;
	}
	#streaming .btnStreaming a,
	#ticket .btnConfirm a,
	#trade .btnTrade a,
	#trade .btnRegist a,
	#goods .btnGoods a,
	#special .btnSpecial a {
		font-size: 3.8vw;
		width: 68vw;
		min-width: fit-content;
		padding: 3vw;
		margin: 0 auto;
	}
}

#menuButton {
	display: block;
	width: 42px;
	height: 42px;
	position: fixed;
	top: 40px;
	right: 40px;
	z-index: 9999;
}
#menuButton span {
	display: block;
	background: #000;
	width: 42px;
	height: 2px;
	position: absolute;
	left: 0;
	transition: all 0.4s;
}

#menuButton span:nth-child(1) { top: 12px;}
#menuButton span:nth-child(2) { bottom: 12px;}
#menuButton.active span {
	background: #fff;
}
#menuButton.active span:nth-child(1) {
	transform: translateY(8px) rotate(45deg);
}
#menuButton.active span:nth-child(2) {
	transform: translateY(-8px) rotate(-45deg);
}


#globalNav {
	display: none;
	position: fixed;
	top: 0;
	right: 0;
	width: 50vw;
	height: 100%;
	background-color: #222222;
	z-index: 1000;
}
#globalNav .navWrap {
	width: 50vw;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
    padding: 60px;
}

#globalNav .mainNav {
	padding-bottom: 4vh;
	margin-bottom: 4vh;
	border-bottom: #fff solid 1px;
}
#globalNav .mainNav li a {
	color: #fff;
	text-decoration: none;
	font-size: 4vh;
	font-weight: bold;
	letter-spacing: .05em;
    font-family: 'Poppins', sans-serif;
}
#globalNav p {
	color: #fff;
	font-size: 2.2vh;
	font-weight: bold;
	letter-spacing: .05em;
	margin-bottom: 2vh;
}
#globalNav p a {
	color: #fff;
	text-decoration: none;
}
#globalNav .menuSns {
	display: flex;
    align-items: center;
}
#globalNav .menuSns li {
	margin-right: 3vh;
}
#globalNav .menuSns a {
	text-decoration: none;
	font-size: 3.2vh;
}
#globalNav .menuSns a i {
	color: #fff;
}
#globalNav .menuSns li.share {
	font-size: 1.6vh;
	color: #fff;
}



.fixBtn {
	position: fixed;
	bottom: 40px;
	right: 40px;
	z-index: 10;
}
.fixBtn a {
	display: block;
    background: #EE6860;
	color: #fff;
	text-decoration: none;
	font-size: 18px;
	font-weight: bold;
	padding: 15px 45px;
	border-radius: 80px;
	text-align: center;
	line-height: 1.6;
	letter-spacing: 0.1em;
}
.logoup .fixBtn a {
    background: #E60012;
}
.fixBtn a span {
	display: block;
	font-size: 0.7em;
	font-weight: normal;
}

/*===================================================
  OP:LOADER
====================================================*/
.loader{
	position: fixed;
    height: 100%;
    width: 100%;
    background: #FFF;
    z-index: 99999;
}


.bg{
    position: fixed;
    width: 100%;
    height: 100%;
    background-image: url(/static/sbr/fanclub/feature/babukai_vol3/images/bg_babukai_vol3_Fm47vMXg.jpg);
    background-size: cover;
    background-position: center;
    z-index: -1;
    opacity: 0.7;
}
#mainvisual {
	width: 100%;
	height: 100vh;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	position: relative;
	opacity: 0;
	animation: op 1s ease-out .5s forwards;
}
@keyframes op {
	0% { opacity: 0;}
	100% { opacity: 1;}
}

#mainvisual h1 {
	max-width: 60%;
	width: 86vh;
}
#mainvisual .mainvisualInner{
    display: flex;
    width: 80%;
    max-width: 1000px;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
}
#mainvisual .mainvisualInner .mainVisualTxt{
    width: 35%;
    padding: 0 100px 0 0;
    line-height: 0;
    box-sizing: border-box;
	transition: 0.5s cubic-bezier(1, 2, 0.1, 1) 0.8s;
	transform: scale(2);
	opacity:0;
}
.loaded #mainvisual .mainvisualInner .mainVisualTxt{
	transform: scale(1);
	opacity:1;
}
#mainvisual .mainvisualInner h1{
    width: 65%;
    line-height: 0;
	transition: 0.5s cubic-bezier(1, 2, 0.1, 1) 1.1s;
	transform: scale(2);
	opacity:0;
}
.loaded #mainvisual .mainvisualInner h1{
	transform: scale(1);
	opacity:1;
}
#mainvisual .scroll {
	display: block;
	position: absolute;
	bottom: 2vh;
	left: 50%;
	width: 1px;
	height: 7vh;
	overflow: hidden;
}
#mainvisual .mainvisualInner + .scroll {
    left: 20px;
    width: 1px;
}
#mainvisual .scroll::before {
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	background-color: #000;
	animation: scrl 2s linear 0s infinite;
}
@keyframes scrl {
	0% { transform: translateY(-100%);}
	100% { transform: translateY(100%);}
}

/* ----------- news ----------- */
.newsList li {
	display: flex;
	padding: 16px 0;
	border-bottom: #000 solid 1px;
}
.newsList .date {
	font-size: 16px;
	width: 180px;
}
.newsList a {
	color: #000;
	text-decoration: none;
	font-size: 16px;
	width: calc(100% - 180px);
	display: block;
}

.newsArchivesBtn {
	text-align: center;
	margin: 32px 0 24px;
}
.newsArchivesBtn a {
	color: #000;
	font-size: 14px;
	text-decoration: none;
	position: relative;
}
.newsArchivesBtn a span {
	position: absolute;
	top: 50%;
	right: -2em;
	display: inline-block;
	width: 0.6em;
	height: 0.6em;
	border-right: #000 solid 2px;
	border-bottom: #000 solid 2px;
	transform: translateY(-75%) rotate(45deg);
}
.newsArchivesBtn.more a::before {
	content: "VIEW MORE";
}
.newsArchivesBtn.close a::before {
	content: "CLOSE";
}
.newsArchivesBtn.close a span {
	transform: translateY(-30%) rotate(-135deg);
}

/*
.newsArchivesBtn a.open::before {
	display: none;
}
.newsArchivesBtn a.open::after {
	display: inline;
}
.newsArchivesBtn a::after {
	content: "CLOSE";
	display: none;
}
*/



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

	.fixBtn {
		bottom: 30px;
		right: 40px;
		width: calc(100% - 80px);
		opacity:0;
		pointer-events:none;
		transition:0.3s ease;
	}
	.headerFix .fixBtn {
		opacity:1;
		pointer-events:auto;
	}
	.bottomFix .fixBtn {
		opacity:0;
		pointer-events:none;
	}
	.fixBtn a {
		font-size: 20px;
		padding: 10px 25px;
		line-height: 1.4;
	}
	.fixBtn a span {
		font-size: 0.5em;
	}

	.newsList li {
		display: block;
	}
	.newsList .date {
		font-size: min(3.4vw, 14px);
		width: 100%;
		margin-bottom: min(2vw, 10px);
	}
	.newsList a {
		width: 100%;
		font-size: min(3.6vw, 16px);
	}


}
/* ----------- about ----------- */
#about {
	font-size: 16px;
}
#about .contentWrap {
	padding-bottom: 140px;
}
#about p + p {
	margin-top: 1em;
}
#about .lead {
	font-size: 24px;
	font-weight: bold;
	text-align: center;
	color: #a24f62;
	margin-bottom: 32px;
}
@media screen and (max-width: 812px) {
	#about {
		font-size: min(3.4vw, 16px);
	}
	#about .contentWrap {
		padding-bottom: min(20vw, 140px);
	}
	#about .lead {
		font-size: min(4.2vw, 24px);
		margin-bottom: min(4vw, 32px);
	}
}
/* ----------- schedule ----------- */
#schedule {
	background-color: #000;
	color: #fff;
}
.schedule li {
	border-bottom: #fff solid 1px;
	padding: 10px 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: 14px;
}
.schedule li.scheduleHead {
	margin-bottom: 12px;
}
.schedule li.scheduleHead .date,
.schedule li.scheduleHead .venue,
.schedule li.scheduleHead .time,
.schedule li.scheduleHead .info {
	font-size: 14px;
    font-family: 'Poppins', sans-serif;
	letter-spacing: .08em;
}
.schedule li .date {
    width: 10%;
    font-size: 12px;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    line-height: 1.8em;
}
.schedule li .date span {
    font-size: 24px;
    margin-right: 0.2em;
    display: block;
}
.schedule li .venue {
	width: 40%;
	font-size: 18px;
}
.schedule li .venue span {
    display: inline-block;
    width: 50px;
    margin-right: 10px;
    font-size: 12px;
    font-weight: bold;
    background-color: #ee6860;
    color: #FFF;
    text-align: center;
    vertical-align: 2px;
}
.logoup .schedule li .venue span {
    background-color: #E60012;
}
.schedule li .time {
	width: 15%;
}
.schedule li .info {
	width: 30%;
	font-size: 13px;
}
.schedule li .info a {
	color: #fff;
}


/* ----------- trade ----------- */
#trade h2 + p {
	font-size: 16px;
	margin-bottom: 64px;
}
#trade h3 {
	font-size: 24px;
	text-align: center;
	margin-bottom: 20px;
}
#trade ul {
	margin-bottom: 24px;
}
#trade ul li {
	display: flex;
	border-bottom: #000 solid 1px;
	padding: 16px 0;
	font-size: 18px;
}
#trade ul li p:nth-child(1) {
	font-weight: bold;
	width: 200px;
}
#trade ul li p:nth-child(2) {
	width: calc(100% - 200px);
}
#trade .note {
	font-size: 14px;
	text-align: center;
}
#trade .btnTrade a {
	background: #000;
	color: #fff;
}
#trade .regist {
	background-color: #444444;
	color: #fff;
	padding: 64px 40px;
	text-align: center;
	margin-top: 64px;
}
#trade .regist .shubabuLogo {
	width: 24%;
	margin: 0 auto 24px;
}
#trade .regist p {
	font-size: 18px;
}
#trade .regist .btnTrade a {
	background: #444444;
	border: #fff solid 1px;
}


@media screen and (max-width: 812px) {
	#trade h2 + p {
		font-size: min(3.4vw, 16px);
		margin-bottom: 10vw;
	}
	#trade h3 {
		font-size: 4.2vw;
		margin-bottom: 3vw;
	}
	#trade ul {
		margin-bottom: 24px;
	}
	#trade ul li {
		display: block;
		padding: 3vw 0;
		font-size: min(3.8vw, 18px);
	}
	#trade ul li p:nth-child(1) {
		margin-bottom: 1vw;
		width: 100%;
	}
	#trade ul li p:nth-child(2) {
		width: 100%;
	}
	#trade .note {
		font-size: 3vw;
	}
	#trade .regist {
		padding: min(10vw, 64px) min(8vw, 40px);
		margin-top: min(12vw, 64px);
	}
	#trade .regist .shubabuLogo {
		width: 46%;
		margin: 0 auto min(3vw, 24px);
	}
	#trade .regist p {
		font-size: min(3.8vw, 18px);
	}
	#trade .regist .btnTrade a {
		width: 100%;
    box-sizing: border-box;
	}
}


/* ----------- ticket ----------- */
#ticket {
	background-color: #333;
	color: #fff;
}
#ticket p {
	font-size: 16px;
}
.ticketList li {
	font-size: 18px;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	padding: 20px 0;
	border-bottom: #fff solid 1px;
}
.ticketList li h3 {
	width: 20%;
	line-height: 1.6;
	font-size: 18px;
	font-weight: normal;
}
.ticketList.top li:first-child h3 {
	padding-top: 0.32em;
}
.ticketList li a {
	color: #fff;
}
.ticketList li div {
	width: 80%;
}
.ticketList li div p + p {
	margin-top: 10px;
}

#ticket .ticketList li p {
	font-size: 18px;
}
#ticket .ticketList li p span {
	font-size: 1.3em;
}
#ticket .ticketList li .note {
	font-size: 14px;
}
#ticket .ticketList li .note a {
	text-decoration: underline;
	color: #ee6860;
}

.entryAcc > div {
	background-color: #fff;
	color: #000;
	border-radius: 8px;
	margin-top: 24px;
	padding: 0 24px;
}
.entryAcc > div:first-child {
	margin-top: 64px;
}
.entryAcc dt {
	font-size: 20px;
	font-weight: bold;
	padding: 20px 0;
	position: relative;
	cursor: pointer;
}
.entryAcc dt::before,
.entryAcc dt::after {
	content: "";
	display: block;
	width: 20px;
	height: 2px;
	background-color: #000;
	position: absolute;
	top: 50%;
	right: 0;
	transition: all .3s ease-out;
}
.entryAcc dt::after {
	transform: rotate(-90deg);
}
.entryAcc dt.open::after {
	transform: rotate(0deg);
}
.entryAcc dd {
	display: none;
	padding-bottom: 40px;
}
.entryAcc dd > p {
	text-align: center;
	font-size: 14px;
	margin-top: 24px;
}
.entryAcc .ticketList {
	background-color: #eeeeee;
	padding: 24px 32px;
}
.entryAcc .ticketList li {
	border-bottom: #000 solid 1px;
}
.entryAcc .ticketList li:last-child {
	border-bottom: none;
}
.entryAcc .ticketList li h3 {
	font-weight: bold;
}


#ticket .entryForm {
	background-color: #444444;
	text-align: center;
	padding: 64px 32px;
	margin-top: 56px;
}
#ticket .entryForm > p {
	font-size: 16px;
	margin-top: 2em;
}
#ticket .entryForm .shubabuLogo {
	width: 24%;
	margin: auto;
}
#ticket .entryForm .btnConfirm a {
    background: transparent;
    border: #EE6860 solid 2px;
    color: #EE6860;
}
.logoup #ticket .entryForm .btnConfirm a {
	border: none;
    color: #ffffff;
    font-size: 18px;
    background: #E60012;
    max-width: 260px;
}

@media screen and (max-width: 812px) {
.logoup #ticket .entryForm .btnConfirm a {
    font-size: 16px;
    width: 70%;
    max-width: 260px;
    padding: 10px;
}
}

/* ----------- goods ----------- */
#goods {
	background-color: #575252;
}
#goods h2 {
	color: #fff;
}
.goods h3 {
	color: #fff;
	text-align: center;
	font-size: 20px;
	margin-bottom: 32px;
}
.goods h3::before,
.goods h3::after {
	display: inline-block;
	content: "";
	background-color: #fff;
	width: 56px;
	height: 1px;
}
.goods h3::before {
	transform: rotate(60deg);
}
.goods h3::after {
	transform: rotate(-60deg);
}
.goods .goodsImg {
	max-width: 720px;
	margin: auto;
}
.goods dl > div {
	background-color: #fff;
	border-radius: 8px;
	padding: 24px;
	margin-top: 32px;
}
.goods dl > div:first-child {
	margin-top: 64px;
}
.goods dt {
	color: #a24f62;
	font-size: 20px;
	font-weight: bold;
	letter-spacing: .1em;
	position: relative;
	cursor: pointer;
	padding: 16px 0;
}
.goods dt::before,
.goods dt::after {
	content: "";
	display: block;
	width: 20px;
	height: 2px;
	background-color: #a24f62;
	position: absolute;
	top: 50%;
	right: 0;
	transition: all .3s ease-out;
}
.goods dt::after {
	transform: rotate(-90deg);
}
.goods dt.open::after {
	transform: rotate(0deg);
}
.goods dd {
	display: none;
	padding: 30px;
}
.goods li {
	font-size: 18px;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	padding: 20px 0;
	border-bottom: #000 solid 1px;
}
.goods li > div {
	width: 80%;
}
.goods li > div p {
	margin-bottom: 10px;
}
.goods li h4 {
	width: 20%;
	line-height: 1.6;
	font-size: 18px;
}
.goods .title {
	font-size: 20px;
	font-weight: bold;
}
.goods p {
	font-size: 18px;
	margin-bottom: 15px;
}
.goods p:last-child {
	margin-bottom: 0;
}
.goods p span {
	color: #e50000;
}
.goods .listHead {
	background-color: #000;
	color: #fff;
	font-weight: bold;
	padding: 12px 16px;
	margin: 48px 0 0;
}
.goods ul + p {
	margin-top: 48px;
}
.goods .note {
	font-size: 14px;
}
#goods .btnGoods a {
	background: #575252;
	border: #fff solid 1px;
}
@media screen and (min-width: 813px) {
	.goos h3::before {
		margin-right: 0.5em;
	}
	.goos h3::after {
		margin-left: 0.5em;
	}
}
@media screen and (max-width: 812px) {
	.goods .titleWrap {
		display: flex;
		justify-content: center;
	}
	.goods h3 {
		position: relative;
		display: inline-block;
		padding: 0 8vw;
		font-size: 4.2vw;
	}
	.goods h3::before,
	.goods h3::after {
		height: 120%;
    width: 1px;
    position: absolute;
    top: 50%;
	}
	.goods h3::before {
    transform: translateY(-50%) rotate(-160deg);
    right: 0;
	}
	.goods h3::after {
		transform: translateY(-50%) rotate(-20deg);
    left: 0;
	}
	.goods dl > div {
		border-radius: 6px;
		padding: 5vw;
		margin-top: 6vw;
	}
	.goods dl > div:first-child {
		margin-top: 8vw;
	}
	.goods dt {
		font-size: 4.2vw;
		padding: 2vw 0;
	}
	.goods dd {
		padding: 3vw 0 0;
	}
	.goods li {
		font-size: 3.8vw;
		display: block;
		padding: 4vw 0;
	}
	.goods li > div {
		width: 100%;
	}
	.goods li h4 {
		width: 100%;
		line-height: 1.6;
		font-size: 3.8vw;
		margin-bottom: 2vw;
	}
	.goods .title {
		font-size: 4vw;
	}
	.goods p {
		font-size: 3.6vw;
	}
	.goods .listHead {
		padding: 2vw 3vw;
		margin: 6vw 0 0;
	}
	.goods ul + p {
		margin-top: 6vw;
	}
	.goods .note {
		font-size: 3vw;
	}
	/* .btnGoods {
		margin-top: 8vw;
	} */
	/* .btnGoods a {
		font-size: 4.2vw;
		border-radius: 8px;
		padding: 4vw;
	} */
}


/* ----------- special ----------- */
#special {
	background-image: url(../images/special_bg.jpg);
	background-repeat: no-repeat;
	background-size: cover;
}
#special p + p {
	margin-top: 1em;
}
#special h2 {
	color: #fff;
}
#special h3 {
	position: relative;
	font-size: 20px;
	line-height: 1.6;
	color: #fff;
	text-align: center;
	padding: 32px 0 18px;
	margin-bottom: 32px;
	z-index: 0;
}
#special h3::before {
	display: inline-block;
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 400px;
	height: 120px;
	background-image: url(../images/hippo.png);
	background-size: contain;
	background-position: center;
	z-index: -1;
}
#special h3 span {
	font-size: 24px;
}
#special .requestWrap {
	display: flex;
	justify-content: space-between;
}
#special .request {
	position: relative;
	box-sizing: border-box;
	width: 49%;
	border-radius: 8px;
	background-color: #fff;
	color: #000;
	font-size: 18px;
	padding: 64px 24px 40px;
	margin-top: 32px;
}
#special .request h4 {
	position: absolute;
	top: -32px;
	left: 50%;
	transform: translateX(-50%);
	width: 180px;
	color: #fff;
	font-size: 12px;
	text-align: center;
	line-height: 1.2;
	background-image: url(../images/request.png);
	background-size: contain;
	background-position: center;
	padding: 24px 0 18px;
}
#special .request h4 span {
	font-size: 20px;
}
#special .request .lead {
	font-size: 20px;
	text-align: center;
	font-weight: bold;
	color: #a24f62;
}
#special .request .note {
	font-size: 12px;
}

#special .requestForm {
	background-color: #962854;
	border-radius: 8px;
	color: #fff;
	font-size: 18px;
	text-align: center;
	padding: 56px 32px;
	margin-top: 24px;
	margin-bottom: 80px;
}
#special .requestForm h4 {
	font-size: 20px;
	margin-bottom: 8px;
}
#special .btnWrap {
	margin-top: 24px;
}
#special .btnWrap a {
	display: block;
	color: #fff;
	border: #fff solid 2px;
	text-decoration: none;
	text-align: center;
	font-size: 16px;
	max-width: 400px;
	border-radius: 80px;
	padding: 18px 25px;
	margin: 0 auto;
}
#special .btnWrap.close a {
	background: #aaa;
	border: none;
}

#special .specialPlan2 {
	background-color: #fff;
	border-radius: 8px;
	color: #000;
	font-size: 18px;
	text-align: center;
	padding: 56px 32px;
	margin-bottom: 48px;
}
#special .specialPlan2:last-child {
	margin-bottom: 0;
}
#special .specialPlan2 .lead {
	font-size: 20px;
	font-weight: bold;
	color: #000;
}
#special .specialPlan2 .btnWrap a {
	color: #a24f62;
	border: #a24f62 solid 2px;
}
#special .specialPlan2 .stampImg {
	width: 100%;
	max-width: 520px;
	margin: 24px auto 0;
}
@media screen and (max-width:812px) {
	#special h3 {
		font-size: min(3.6vw, 20px);
    padding: min(4vw, 32px) 0 min(2.8vw, 18px);
    margin-bottom: min(4vw, 32px);
	}
	#special h3::before {
		width: 200vw;
		height: min(22vw, 120px);
	}
	#special h3 span {
		font-size: min(4.2vw, 24px);
	}
	#special .requestWrap {
		flex-direction: column;
	}
	#special .request {
		width: 100%;
		font-size: min(3.6vw, 18px);
		padding: min(14vw, 64px) min(5vw, 24px) min(8vw, 40px);
		margin-top: min(7vw, 32px);
		margin-bottom: min(4vw, 32px);
	}
	#special .request h4 {
		top: max(-7vw, -32px);
		width: min(24vw, 180px);
		font-size: min(2.8vw, 12px);
		padding: min(6vw, 24px) 0 min(3.6vw, 18px);
	}
	#special .request h4 span {
		font-size: min(4.6vw, 20px);
	}
	#special .request .lead {
		font-size: min(4.2vw, 20px);
		line-height: 1.6;
	}
	#special .request .note {
		font-size: min(2.8vw, 12px);
	}

	#special .requestForm {
		font-size: min(3.6vw, 18px);
		padding: min(5vw, 32px);
		margin-top: 0;
		margin-bottom: min(10vw, 80px);
	}
	#special .requestForm h4 {
		font-size: min(4.2vw, 20px);
		margin-bottom: min(1vw, 8px);
	}
	#special .requestForm .btnWrap {
		margin-top: min(4vw, 24px);
	}
	#special .btnWrap a {
		font-size: min(3.8vw, 16px);
    width: 68vw;
    min-width: fit-content;
    padding: 3vw;
	}

	#special .specialPlan2 {
		font-size: min(3.6vw, 18px);
		padding: min(5vw, 32px);
		margin-bottom: min(6vw, 48px);
	}
	#special .specialPlan2 .lead {
		font-size: min(4vw, 20px);
	}
	#special .specialPlan2 .stampImg {
		margin: min(3vw, 24px) auto 0;
	}
}

/* ----------- attention ----------- */
.attentionList > div {
	border-bottom: #000 solid 1px;
}
.attentionList dt {
	font-size: 20px;
	font-weight: bold;
	padding: 25px 0;
	position: relative;
	cursor: pointer;
}
.attentionList dt::before,
.attentionList dt::after {
	content: "";
	display: block;
	width: 20px;
	height: 2px;
	background-color: #000;
	position: absolute;
	top: 50%;
	right: 0;
	transition: all .3s ease-out;
}
.attentionList dt::after {
	transform: rotate(-90deg);
}
.attentionList dt.open::after {
	transform: rotate(0deg);
}
.attentionList dd {
	display: none;
	padding: 32px 40px;
	background-color: #eeeeee;
	font-size: 14px;
	margin-bottom: 32px;
}

/* ----------- attention ----------- */
.contactWrap {
	display: flex;
	justify-content: space-between;
}
.contactWrap > div {
	width: 47%;
	border: #000 1px solid;
	text-align: center;
	font-size: 16px;
	display: flex;
	flex-direction: column;
	padding: 32px 0;

	margin: 0 auto;
}
.contactWrap > div > p {
	/* height: 3em; */
}
.contactWrap .btnWrap {
	margin-top: 32px;
}
.contactWrap .btnWrap a {
	display: block;
	background-color: #000;
	color: #fff;
	text-decoration: none;
	text-align: center;
	font-size: 14px;
	max-width: 280px;
	border-radius: 80px;
	padding: 20px 25px;
	margin: 0 auto;
}
#contact > div > p {
	text-align: center;
	font-size: 14px;
	margin-top: 1em;
}
#contact > div > p a {
	color: #000;
}

/* ----------- footer ----------- */
footer {
	padding: 60px;
}
footer .ftrBtn {
	margin-bottom: 60px;
}
footer .ftrBtn a {
	display: block;
	color: #000;
	border: #000 solid 2px;
	text-decoration: none;
	text-align: center;
	font-size: 14px;
	max-width: 280px;
	border-radius: 80px;
	padding: 20px 25px;
	margin: 0 auto;
}

footer .ftrSns {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	margin-bottom: 60px;
}
footer .ftrSns li.share {
	width: 100%;
    text-align: center;
    font-size: 14px;
    margin-bottom: 12px;
}
footer .ftrSns li {
	margin: 0 15px;
}
footer .ftrSns li a {
	text-decoration: none;
	font-size: 24px;
	color: #000;
}
footer .copyright {
	text-align: center;
	font-size: 10px;
}



@media screen and (max-width: 812px) {
	#menuButton {
		width: 40px;
		height: 40px;
		top: 20px;
		right: 20px;
	}
	#menuButton span {
		width: 40px;
		left: 0;
	}
	#menuButton.active span:nth-child(1) {
		transform: translateY(7px) rotate(45deg);
	}
	#menuButton.active span:nth-child(2) {
		transform: translateY(-7px) rotate(-45deg);
	}

	#globalNav {
		width: 100vw;
		height: 100%;
	}
	#globalNav .navWrap {
		width: 100vw;
		height: 100%;
		padding: 8vw;
	}
	#globalNav .mainNav {
		padding-bottom: 8vw;
		margin-bottom: 8vw;
	}
	#globalNav .mainNav li a {
		font-size: 7.2vw;
	}
	#globalNav p {
		font-size: 3.8vw;
		margin-bottom: 4vw;
	}
	#globalNav .menuSns li {
		margin-right: 6vw;
	}
	#globalNav .menuSns a {
		font-size: 6vw;
	}
	#globalNav .menuSns li.share {
		font-size: 3vw;
	}

	.bg{
    background-image: url(/static/sbr/fanclub/feature/babukai_vol3/images/bg_babukai_vol3_sp_Fm47vMXg.jpg);
	}
	#mainvisual h1 {
		max-width: inherit;
		width: 86%;
	}
	#mainvisual p {
		padding: 4vw 5vw;
		font-size: 2.8vw;
		margin: 10vw 6vw 16vw;
	}
	#mainvisual .mainvisualInner {
		display: block;
	}
	#mainvisual .mainvisualInner .mainVisualTxt {
		width: 80%;
		max-width: 400px;
		margin: 0 auto 40px;
		padding: 0;
	}
	#mainvisual .mainvisualInner h1 {
		width: 100%;
		max-width: 500px;
		margin: 0 auto;
	}
	#mainvisual .scroll {
		height: 10vw;
	}

	#mainvisual.ttl_v2 h1 {
		width: 78%;
	}
	#mainvisual.ttl_v2 p {
		margin: 10vw 6vw 16vw;
	}
	#mainvisual.ttl_v2 .scroll {
		height: 10vw;
	}

	.contentWrap {
		padding: 12vw 6vw;
	}
	.contentWrap h2 {
		font-size: 8.6vw;
		margin-bottom: 8vw;
	}

	.schedule li.scheduleHead {
		display: none;
	}
	.schedule li {
		padding: 3vw 0;
		display: block;
		font-size: 3.4vw;
	}

	.schedule li .date,
	.schedule li .venue,
	.schedule li .time,
	.schedule li .info {
		width: 100%;
		padding-left: 20vw;
		position: relative;
		box-sizing: border-box;
		margin-bottom: min(2vw, 10px);
	}

	.schedule li .date::before,
	.schedule li .venue::before,
	.schedule li .time::before,
	.schedule li .info::before {
		display: inline-block;
		width: 20vw;
    	font-size: min(3vw, 12px);
		font-weight: normal;
		position: absolute;
		top: 0;
		left: 0;
    	font-family: 'Poppins', sans-serif;
	}
	.schedule li .date::before {content: "Date"; line-height: 2.7;}
	.schedule li .venue::before {content: "Venue";}
	.schedule li .time::before {content: "Open/Start";}
	.schedule li .info::before {content: "Information";}

	.schedule li .date {
		font-size: 4.2vw;
    	line-height: 1.6;
	}
	.schedule li .venue {
    	font-size: min(4vw, 20px);
	}
	.schedule li .venue span:nth-child(1) {
		width: 12vw;
		font-size: min(3.2vw, 14px);
		margin-right: 1.2em;
	}

	.schedule li a {
		color: #ee6860;
		text-decoration: underline;
	}

	.ticketList li {
		font-size: 3.4vw;
		padding: 3vw 0;
	}
	.ticketList li h3 {
		width: 30%;
    	font-size: min(3.2vw, 14px);
	}
	.ticketList li div {
		width: 70%;
	}
	.ticketList li div p {
		font-size: 3.4vw;
	}
	.ticketList li div p + p {
		margin-top: 3vw;
	}
	#ticket .ticketList li p {
		font-size: 3.4vw;
	}
	#ticket .ticketList li .note {
		font-size: 3vw;
	}
	#ticket p {
		font-size: 3.4vw;
	}

	.entryAcc dt {
		font-size: 3.8vw;
		padding: 3vw 0;
	}
/*
	.entryAcc dt::after {
		width: 10px;
		height: 10px;
		right: 5vw;
	}
*/
	.entryAcc .ticketList {
		padding: min(2vw, 24px) min(4vw, 32px);
	}
	#ticket .entryForm {
		padding: min(8vw, 64px) min(6vw, 32px);
		margin-top: min(12vw, 56px);
	}
	#ticket .entryForm .shubabuLogo {
		width: 46%;
	}
	#ticket .entryForm > p {
		font-size: min(3.4vw, 16px);
		margin-top: 1.6em;
	}

	.attentionList dt {
		font-size: min(3.8vw, 20px);
		padding: min(4vw, 20px) 0;
	}
	.attentionList dd {
		padding: min(5vw, 20px);
		font-size: min(3.2vw, 14px);
	}

	.contactWrap {
		display: block;
	}
	.contactWrap > div {
		width: 100%;
		font-size: min(3.4vw, 16px);
		padding: min(6vw, 30px);
		box-sizing: border-box;
	}
	.contactWrap > div + div {
		margin-top: min(6vw, 30px);
	}
	.contactWrap .btnWrap {
		margin-top: min(6vw, 32px);
	}
	.contactWrap .btnWrap a {
		font-size: min(3.4vw, 14px);
		padding: min(4vw, 20px) min(3vw, 25px);
		max-width: 240px;
	}
	.contactWrap > div > p {
		height: auto;
	}
	#contact > div > p {
		text-align: left;
		font-size: min(3.4vw, 14px);
	}


	footer {
		padding: 10vw 6vw;
	}
	footer .ftrBtn {
		margin-bottom: 12vw;
	}
	footer .ftrBtn a {
		font-size: 3.2vw;
		max-width: 60vw;
		padding: 4vw;
	}

	footer .ftrSns {
		margin-bottom: 12vw;
	}
	footer .ftrSns li {
		margin: 0 4vw;
	}
	footer .ftrSns li.share {
		font-size: 3vw;
		margin-bottom: 3vw;
	}
	footer .ftrSns li a {
		font-size: 6vw;
	}
	footer .copyright {
		font-size: 2.6vw;
	}

}