@charset "UTF-8";


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

	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;
}
.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";}


html {
	font-family: 'Noto Sans JP', sans-serif;
	background-color: #000;
	color: #fff;
	line-height: 2;
	letter-spacing: 0.05em;
	font-size: 18px;
	font-weight: 500;
}

body {
	z-index: -999;
}

main {
	overflow: hidden;
}

img {
	width: 100%;
	vertical-align: middle;
}
a {
	color: #fff;
	text-decoration: none;
}
li {
	list-style: none;
}

h2 {
	font-family: 'Roboto', sans-serif;
	font-size: 3.333rem;
	line-height: 1.2;
	margin-bottom: 0.7em;
}
h2 span {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 0.75rem;
	color: #13c1ea;
	display: block;
	margin-top: 0.8em;
}
h3 {
	font-size: 2rem;
	display: inline-block;
	font-family: 'Roboto', sans-serif;
	background: -webkit-linear-gradient(-52deg, #34eeff 40%, #0061b9 60%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
h4 {
	font-family: 'Roboto', sans-serif;
	font-size: 1.4rem;
	color: #13c1ea;
	line-height: 1.2;
	margin-bottom: 0.6em;
}
h4 span {
	font-size: 0.6em;
	color: #fff;
}
.outer {
	margin: auto;
	max-width: 1240px;
	padding: 0 60px;
}
.anim {
	opacity: 0;
	transition: all .6s ease-out;
}
.anim.on {
	opacity: 1;
}

.plot {
	display: flex;
}
.plot > li {
	font-family: 'Roboto', sans-serif;
	font-size: 0.8vh;
	border: 1px solid #fff;
	border-radius: 20px;
	padding: 0 8px;
	margin-left: 2em;
}
.plot > li:first-child {
	margin-left: 0;
}
@media screen and (min-width: 821px) {
	.sp {
		display: none;
	}
	a:hover {
		opacity: 0.6;
	}
}
@media screen and (max-width: 820px) {
	.pc {
		display: none;
	}
	html {
		font-size: min(3.2vw, 18px);
	}
	.outer {
		padding: 5vw;
	}

	h2 {
		font-size: 2.8rem;
	}
	h2 span {
		font-size: 1rem;
	}
	.plot > li {
		font-size: 2.6vw;
		margin-left: 1em;
	}
}
/* ////////////////////////////////////////////////////////////////////////////////

	Opening

//////////////////////////////////////////////////////////////////////////////// */
#op {
	position: fixed;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	background-color: #000;
	background-image: linear-gradient(-14deg, rgba(18,46,110,1) 0%, rgba(18,46,110,0) 50%);
	display: flex;
	justify-content: center;
	align-items: center;
	z-index: 9999;
}
#op .opImg {
	/* width: 320px;*/
	width: min(150px, 20%);
	line-height: 0;
	animation: op 1s ease-out .6s forwards;
	opacity: 0;
}

@keyframes op {
	0% { opacity: 0; transform: scale(1.1);}
	100% { opacity: 1; transform: scale(1);}
}
@keyframes pu {
	0% { transform: translateX(0);}
	100% { transform: translateX(-50%);}
}
@keyframes pu2 {
	0% { transform: translateX(-50%);}
	100% { transform: translateX(0);}
}

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

	#op .opImg {
		width: min(56vw, 320px);
	}
}
/* ////////////////////////////////////////////////////////////////////////////////

	Header

//////////////////////////////////////////////////////////////////////////////// */
header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 40px;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1000;
	width: 100%;
}
.mvLogo {
	width: min(150px, 20%);
}
#menuButton {
	width: 40px;
	height: 40px;
	position: relative;
	z-index: 3000;
}
#menuButton span {
	position: absolute;
	right: 5px;
	background-color: #fff;
	height: 1px;
	width: 30px;
	transition: all .3s ease-out;
}
#menuButton span:nth-child(1) {
	top: 12px;
}
#menuButton span:nth-child(2) {
	bottom: 12px;
}

#menuButton.active span:nth-child(1) {
	transform: rotate(45deg);
	top: 19px;
}
#menuButton.active span:nth-child(2) {
	transform: rotate(-45deg);
	bottom: 19px;
}

#globalNav ul {
	display: flex;
	justify-content: right;
	align-items: center;
	font-family: 'Roboto', sans-serif;
	font-size: 0.75rem;
	font-weight: 700;
}
#globalNav ul li {
	margin-left: 1.5em;
}
#globalNav ul li:first-child {
	margin-left: 0;
}
#globalNav ul li.hdrTw {
	transform: translateY(12%);
}
#globalNav ul li.hdrTw a i {
	font-size: 1.2rem;
}
#globalNav ul li.btnFooterEntry a {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 0.7rem;
	display: block;
	text-align: center;
	background: linear-gradient(45deg, #25d8f5 20%, #0061b9 80%);
  color: white;
	padding: 6px 24px;
  border-radius: 6px;
	margin-left: 1em;
}


@media screen and (min-width: 821px) {
	#menuButton {
		display: none;
	}
	a {
		transition: all .4s ease-out;
	}
	a:hover {
		opacity: 0.5;
	}
}
@media screen and (max-width: 820px) {
	header {
    	padding: min(6vw, 40px);
	}
	.mvLogo {
		width: 42%;
	}

	#globalNav {
		display: none;
		position: fixed;
		top: 0;
		left: 0;
		width: 100vw;
		height: 100vh;
		background-color: #000;
		z-index: 2000;
	}
	#globalNav ul {
		width: 100%;
		height: 100%;
		display: flex;
		flex-direction: column;
		justify-content: center;
		padding-bottom: min(8vw, 40px);
	}
	#globalNav ul li {
		margin: 0;
    	font-size: min(6vw, 24px);
	}
	#globalNav ul li.hdrTw {
	}
	#globalNav ul li.hdrTw a i {
		font-size: min(6.2vw, 26px);
	}
	#globalNav ul li.btnFooterEntry a {
		margin: min(10vw, 60px) 0 0;
    padding: 0.2em 2.4em;
		font-size: min(4vw, 17px);
	}
	#menuButton {
		position: absolute;
		right: min(6vw, 40px);
		top: 12px;
	}
}

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

	Main Visual

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

.mainVisual {
	background: url(../images/mvbg01.png) no-repeat top left;
	background-size: 60%;
	position: relative;
	height: 100vh;
	margin: 0;
	padding-top: 140px;
	padding-bottom: 4vh;
	display: flex;
	align-items: center;
	background-color: #000;
}
.mvCatch {
	position: absolute;
	top: calc(4vh + 140px);
	left: 80px;
	font-size: min(2.33rem, 4vh);
	font-weight: 700;
	line-height: 1.5;
	z-index: 1;
}

.mvCount {
	position: absolute;
	right: 60px;
	bottom: 10vh;
	width: 6vh;
	height: 6vh;
	z-index: 1;
}
.mvCount p {
	font-family: 'Roboto', sans-serif;
	position: absolute;
	font-size: 4vh;
	line-height: 1;
}
.mvCount p:nth-of-type(1) {
	top: -0.4em;
	left: 0;
}
.mvCount .fractionLine {
	position: absolute;
	top: 50%;
	right: 50%;
	transform: translate(-50%, -50%) rotate(45deg);
	background-color: #fff;
	width: 1px;
	height: 141.4%;
}
.mvCount p:nth-of-type(2) {
	bottom: -0.5em;
	right: 0;
}

.mainVisual .artistWrap {
	width: 100%;
	padding: 0 80px;
}
.mainVisual .artistWrap > li {
	position: relative;
}

.artistImg {
	width: 60%;
	height: 70vh;
	margin-left: 40%;
	padding-bottom: 4.5vh;
	position: relative;
}
.artistImg img {
	object-fit: cover;
	width: 100%;
	height: 100%;
	border-radius: 6px;
}
.artistImg .loadingBar {
	position: absolute;
	bottom: 0;
	left: 0;
	background-color: #666;
	height: 1px;
	width: 17.8%;
}
.artistImg .loadingBar::before {
	content: "";
	display: block;
	width: 0;
	height: 100%;
	background-color: #fff;
	transition: all 4s linear .5s;
}
.slick-current .artistImg .loadingBar::before {
	width: 100%;
}

.artistText {
	position: absolute;
	left: 0;
	bottom: 0;
	width: 36%;
}
.artistText .artistTitle {
	margin-bottom: 0.8em;
    font-size: 2.6vh;
}
.artistText > div:first-child {
	margin-left: 16px;
}
.artistText .border-bottom {
	background-color: #fff;
	height: 0.5px;
	width: 130%;
	margin-bottom: 1em;
}
.artistText .artistClubTitle {
	font-size: 2vh;
	color: #13c1ea;
	margin-bottom: 0.6em;
}
.artistText .artistClubAbout {
	font-size: 1.6vh;
	margin-bottom: 2em;
}
.artistText .artistClubLink {
	margin-top: 6vh;
}
.artistText .artistClubLink a {
	background: linear-gradient(135deg, #25d8f5 20%, #0032a1 80%);
	width: 10vh;
	height: 10vh;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: 'Roboto', sans-serif;
	font-weight: 700;
	font-size: 0.666rem;
	line-height: 1.4;
	text-align: center;
}

@media screen and (max-width: 820px) {
	.mainVisual {
		background: #000 url(../images/mvbg01.png) no-repeat top left;
    	background-size: 86%;
    	padding-top: 140px;
		padding-bottom: 5vh;
	}

	.mainVisual .artistWrap {
		padding: 0;
	}
	.mvCatch {
		top: 16vh;
		left: min(6vw, 80px);
		font-size: min(1.6rem, 5.1vw);
		line-height: 1.6;
	}
	.mvCount {
		right: min(6vw, 60px);
		bottom: 33vh;
		width: 10vw;
		height: 10vw;
	}
	.mvCount p {
		font-size: 6.2vw;
	}

	.artistImg {
		width: 85%;
    	height: 64vw;
		margin-left: 15%;
    	padding-bottom: 0;
		margin-bottom: min(6vw, 40px);
	}

	.artistImg .loadingBar {
		position: absolute;
    	left: -9vw;
		bottom: 0;
		height: 20vw;
		width: 1px;
	}
	.artistImg .loadingBar::before {
		width: 100%;
		height: 0;
	}
	.slick-current .artistImg .loadingBar::before {
		width: 100%;
		height: 100%;
	}

	.mainVisual .slick-list {
		overflow: visible;
	}
	.artistText {
		padding-left: min(6vw, 80px);
		width: 72%;
    	position: relative;
	}
	.artistText .border-bottom {
		width: 100%;
	}
	.artistText .artistTitle {
		margin-bottom: 0.8vh;
		font-size: 4.2vw;
	}
	.artistText .artistClubTitle {
		font-size: 3.2vw;
	}
	.artistText .artistClubLink {
		margin-top: 0;
		position: absolute;
		bottom: -2vw;
		right: -22vw;
	}
	.artistText .artistClubAbout {
		font-size: 2.8vw;
		margin-bottom: 1.8em;
	}
}
@media screen and (min-width: 480px) and (max-width: 820px){
	.mvCatch {
   		top: calc(8vw + 80px);
	}
	.mvCount {
		bottom: 28vh;
	}

	.artistText .artistTitle {
		font-size: min(4.2vw, 20px);
	}
	.artistText .artistClubTitle {
		font-size: min(3.2vw, 18px);
	}
	.artistText .artistClubAbout {
		font-size: min(2.8vw, 14px);
		margin-bottom: 1.8em;
	}
}


/* ------- pickup --------- */
#pickup .plot {
	margin-top: 0.6em;
}
#pickup {
	background-color: #000;
    padding-bottom: 120px;
}
#pickup .pickupTitle {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-top: 1.6em;
	margin-bottom: 0.7em;
}
#pickup h2 {
	margin-bottom: 0;
}
#pickup .pickupTitle a {
	display: flex;
	align-items: center;
	font-size: 0.75rem;
	padding-top: 4.6em;
}
#pickup .pickupTitle a::before {
	content: "";
	background-color: #fff;
	width: 3em;
	height: 1px;
	margin-right: 0.5em;
}
#pickup .pickupText {
	margin-bottom: 2.5em;
	font-size: 0.833em;
}


.pickupSlider > div a {
	display: block;
	height: 100%;
	padding-top: 63%;
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	overflow: hidden;
}
.pickupSlider > div .thumb {
	line-height: 0;
	padding-top: 63%;
	position: absolute;
	width: 100%;
	top: 0;
	left: 0;
}
.pickupSlider > div .thumb img {
	object-fit: cover;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}
.pickupSlider > div a .interviewLabel {
	position: absolute;
	top: 0;
	left: 0;
	width: 30%;
	z-index: 1;
}
.pickupSlider > div .tit {
	font-size: 14px;
	margin-top: 20px;
}
.pickupSlider > div .tit span {
	margin-top: 5px;
	display: block;
	font-size: 12px;
	line-height: 1.6;
	color: #13c1ea;
}

#pickup .btnViewMore {
	display: flex;
	justify-content: center;
}
#pickup .btnViewMore a {
	font-family: 'Roboto', sans-serif;
	position: relative;
	font-size: 0.77rem;
	display: block;
	text-align: center;
	background: -webkit-linear-gradient(-52deg, #34eeff 34%, #0061b9 67%);
  color: white;
	max-width: 260px;
	width: 20vw;
	padding: 10px 32px;
  border-radius: 6px;
}
#pickup .btnViewMore a::after {
	position: absolute;
	top: 50%;
	right: 16px;
	content: url(../images/arrow.png);
	transform: translate(40%, -50%) scale(0.2);
}

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

	.sliderArea {
	  margin: 80px auto 60px;
		overflow: hidden;
	}
	.pickupSlider {
		display: flex;
		width: 100%;
	}
	.pickupSlider.pus02 {
		margin-top: 40px;
		flex-direction: row-reverse;
	}

	.pickupSlider > div {
		padding: 10px;
		width: 25%;
		height: auto;
		box-sizing: border-box;
	}
	.pickupSlider > div:nth-child(-n+4){
		margin-bottom: 40px;
	}
	/*.pickupSlider.pus01 > div:nth-child(n+5),
	.pickupSlider.pus02 > div:nth-child(n+5) {
		display: none;
	}*/
}
@media screen and (max-width: 820px) {
	#pickup {
		padding-bottom: min(10vw, 100px);
	}
	#pickup h2 {
		padding-top: 0;
	}
	#pickup h2+p {
		font-size: 1em;
	}

	/* スライダーのwrapper */
	.infinite-slider .swiper-wrapper,
	.infinite-slider2 .swiper-wrapper {
	  transition-timing-function: linear;
	  flex-wrap: nowrap;
	}


	.sliderArea {
		margin: 0 auto min(6vw, 60px);
		padding: 0;
	}
	.pickupSlider {
		/*width: calc(50vw * 4 * 2);*/
		/*animation: pu 48s linear 0s infinite;*/
	}
	.pickupSlider.pus02 {
		margin-top: min(6vw, 40px);
		/*animation: pu2 48s linear 0s infinite;*/
	}
	.pickupSlider > div {
		padding: 5px 0 5px min(6vw, 80px);
		width: 100%;
		height: auto;
		box-sizing: border-box;
	}
	/*.pickupSlider > div .thumb {
		margin-bottom: min(3vw, 20px);
	}*/
	.pickupSlider > div .tit {
		font-size: min(3.2vw, 14px);
    	margin-top: min(3vw, 20px);
	}
	.pickupSlider > div .tit span {
		font-size: min(3vw, 12px);
		line-height: 1.8;
	}
	/*.pickupSlider .slick-slide .thumb {
		margin-bottom: min(3vw, 20px);
	}
	.pickupSlider .slick-slide .tit {
		font-size: min(3.2vw, 14px);
	}
	.pickupSlider .slick-slide .tit span {
		display: block;
		font-size: min(3vw, 12px);
		line-height: 1.8;
	}*/
	.pickupSlider > div .thumb .interviewLabel {
		width: 26%;
	}
	#pickup .btnViewMore a {
	max-width: 200px;
	width: 50vw;
	}
}

/* ------- artistnews --------- */

#artistnews {
	background-color: #000;
	padding-bottom: 120px;
}

#artistnews .artist--news .name {
	margin-top: 20px;
	font-size: 14px;
	color: #13c1ea;
}

#artistnews .artist--news .date {
	margin-top: 5px;
	font-size: 12px;
	line-height: 1.6;
}

#artistnews .artist--news .tit {
	font-weight: 700;
	line-height: 1;
	margin-bottom: 0;
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
	margin-top: 4% !important;
}

#artistnews .artist--news .pickupSlider a {
	justify-content: start;
	padding-top: 0;
}

#artistnews .btnViewMore {
	display: flex;
	justify-content: center;
}

#artistnews .btnViewMore a {
	font-family: 'Roboto', sans-serif;
	position: relative;
	font-size: 0.77rem;
	display: block;
	text-align: center;
	background: -webkit-linear-gradient(-52deg, #34eeff 34%, #0061b9 67%);
	color: white;
	max-width: 260px;
	width: 20vw;
	padding: 10px 32px;
	border-radius: 6px;
}

#artistnews .btnViewMore a::after {
	position: absolute;
	top: 50%;
	right: 16px;
	content: url(../images/arrow.png);
	transform: translate(40%, -50%) scale(0.2);
}


#artistnews .pickupSlider>div .thumb {
	height: 164px;
	position: relative;
	text-align: center;
	overflow: hidden;
}

#artistnews .pickupSlider>div .thumb img {
	height: 100%;
	width: 100%;
	-o-object-fit: contain;
	object-fit: contain;
	background-size: contain;
	z-index: 2;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

#artistnews .pickupSlider>div .thumb .blur {
	-webkit-filter: blur(40px);
	filter: blur(40px);
	display: block;
	width: 120%;
	max-width: inherit;
	height: auto;
	min-height: 170%;
	position: absolute;
	top: 50%;
	left: -10%;
	z-index: 1;
}
#artistnews .sliderArea .swiper-wrapper{
	flex-wrap: wrap;
}

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

	#artistnews .btnViewMore a {
		max-width: 200px;
		width: 50vw;
	}
	#artistnews {
		padding-bottom: min(10vw, 100px);
	}
	#artistnews .artist--news .tit{
		overflow: auto;
		text-overflow: inherit;
		width: auto;
		white-space: normal;
		line-height: 1.5;
		padding-right: min(6vw, 80px);
	}
	#artistnews h2 {
		padding: 5vw;
	}

	#artistnews h2+p {
		font-size: 1em;
	}

	#artistnews .outer {
		padding: 0;
	}
	#artistnews .sliderArea .swiper-wrapper{
		flex-wrap: wrap;
		transition: none !important;
		transform: none !important;
	}
	#artistnews .sliderArea .swiper-wrapper .swiper-slide:nth-child(n+7){
		display: none;
	}
	#artistnews .artist--news .pickupSlider a{
		display: block;
	}
	#artistnews .pickupSlider>div .thumb{
		float: left;
		width: 45%;
		margin-right: 5%;
		padding-top: 45%;
	}
	#artistnews .artist--news .name{
		margin-top: 0;
	}
}

/* ------- about point --------- */

#about {
	padding-top: 100px;
	position: relative;
	background-color: rgba(0,0,0,0.80);
}
#about .aboutPointWrap {
	position: relative;
}
#about .aboutPointWrap::before {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 400px;
	background-image: linear-gradient(-14deg, rgba(18,46,110,1) 0%, rgba(18,46,110,0) 50%);
	z-index: 0;
}
.aboutBg {
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	transition: all 2s ease-out;
	z-index: -1;
}
.aboutBg.on {
	opacity: 0;
}
.aboutBg ul {
	height: 100vh;
}
.aboutBg ul li {
	width: 100vw;
	height: 100vh;
}
.aboutBg ul li img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

#about h2+p {
	font-size: 0.833rem;
}
#about .aboutPoint {
	display: flex;
	justify-content: space-between;
	margin-top: 88px;
}
#about .aboutPoint > div {
	width: 47%;
}
#about .aboutPoint > div:nth-of-type(2) {
	display: flex;
	justify-content: center;
	align-items: flex-start;
}
#about .aboutPoint .aboutPointCatch {
	font-size: 1.666rem;
	line-height: 1.5;
	margin-bottom: 1em;
}
#about .aboutPoint .aboutPointText {
	font-size: 0.75rem;
}
#about .aboutPoint .aboutPintImg1 {
	margin-top: 40px;
	width: 70%;
}
#about .aboutPoint .aboutPintImg2 {
	margin-top: 40px;
	width: 80%;
}

#about .aboutPoint.point3 {
	display: block;
}
#about .aboutPoint.point3 h4 {
	margin-bottom: 0;
}
#about .aboutPoint.point3 .aboutPointText {
	margin-bottom: 2.4em;
}
#about .aboutPoint.point3 > div{
	width: 100%;
}
#about .aboutPoint.point3 li {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 1.6em;
}
#about .aboutPoint.point3 li:first-child {
	margin-top: 1.4em;
}
#about .aboutPoint.point3 li > div {
	width: 24%;
	position: relative;
}
#about .aboutPoint.point3 li > div {
	width: 24%;
	position: relative;
}
#about .aboutPoint.point3 li .point3Text {
	font-size: 1rem;
	width: 72%;
}
@media screen and (max-width: 820px) {
	#about {
		padding-top: min(14vw, 100px);
	}

	#about .aboutPoint {
		margin-top: 14vw;
	}
	#about .aboutPoint {
		display: block;
	}
	#about .aboutPoint > div {
		width: 100%;
	}
	#about .aboutPoint .aboutPintImg1,
	#about .aboutPoint .aboutPintImg2,
	#about .aboutPoint .aboutPintImg3 {
		margin-top: 6vw;
	}

	#about h2+p {
		font-size: 1rem;
	}
	#about .aboutPoint .aboutPointText {
		font-size: 1rem;
	}
	#about .aboutPoint.point3 li > div {
		width: 33%;
	}
	#about .aboutPoint.point3 li .point3Text {
		width: 62%;
	}
}

/* ------- about list --------- */
#about .aboutList {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	grid-template-rows: 1fr 1fr 1fr auto;
	gap: 24px;
	margin-top: 120px;
	padding-bottom: 120px;
}
#about .aboutList > li {
	position: relative;
	background-color: #111;
	border: 1px solid #222222;
	padding: 32px 24px;
}

#about .aboutList > li img {
	display: block;
	width: 64%;
	padding: 10%;
	margin: auto;
}
#about .aboutList .aboutListBadge {
	position: absolute;
	top: 16px;
	left: 0;
	background-color: #183d8f;
	font-size: 0.75rem;
	padding: 0 16px;
}
#about .aboutList .aboutListText1 {
	color: #13c1ea;
	font-size: 0.92rem;
	text-align: center;
	margin-top: 1em;
}
#about .aboutList .aboutListText2 {
	font-size: 0.666rem;
	margin-top: 1em;
}
#about .aboutList .note {
	font-size: 0.583rem;
}

#about .aboutList .item10 {
	padding: 56px;
}
#about .aboutList .item10 > div {
	width: 52%;
}
#about .aboutList .item10 .btnDL {
	display: flex;
	margin-top: 1.8em;
}
#about .aboutList .item10 .btnDL img {
	width: 100%;
	padding: 0;
}
#about .aboutList .item10 .appStoreImg {
	width: 140px;
}
#about .aboutList .item10 .googleImg {
	width: 174px;
	margin-left: 1em;
}
#about .aboutList .item10Img {
	display: block;
	width: 42%;
	padding-bottom: 0;
}
#about .aboutList .item10Img img {
	padding: 0;
	margin: 0;
	width: 100%;
}
#about .aboutList .item10 .aboutListText1 {
	font-size: 1.875rem;
	text-align: left;
	margin-top: 0;
}
#about .aboutList .item10 .aboutListText2 {
	margin-bottom: 1em;
}
@media screen and (min-width: 821px) {
	#about .aboutList .item10 {
		grid-column: 1/4;
		grid-row: 4;
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
}
@media screen and (max-width: 820px) {
	#about .aboutList {
		grid-template-columns: 1fr;
		grid-template-rows: auto;
		gap: 4vw;
		margin-top: 8vw;
	}
	#about .aboutList {
		padding: 10vw 0;
	}
	#about .aboutList li {
		padding: 6vw 8vw;
	}
	#about .aboutList .aboutListBadge {
		top: 4vw;
		padding: 0 4vw;
	}
	#about .aboutList .item10 {
		padding: 12vw 8vw;
	}
	#about .aboutList .item10 > div,
	#about .aboutList .item10Img {
		width: 100%;
	}
	#about .aboutList .item10 .btnDL {
		justify-content: space-between;
	}
	#about .aboutList .item10 .appStoreImg {
		width: 31.9vw;
	}
	#about .aboutList .item10 .googleImg {
		width: 39.3vw;
		margin: 0;
	}
	#about .aboutList .item10Img {
		margin-top: min(10vw, 60px);
	}

	#about .aboutList .aboutListText1 {
    	font-size: 1.2rem;
	}
	#about .aboutList .aboutListText2 {
		font-size: 1rem;
	}
	#about .aboutList .note {
		font-size: 0.8rem;
	}
}

/* ------- about contents --------- */
#about .aboutContents {
	display: flex;
	justify-content: space-between;
}
#about .aboutContents > li {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	position: relative;
	width: 30%;
	margin-bottom: 36%;
	border-bottom: 1px solid #222222;
}
#about .aboutContents .aboutContentsText > p {
	margin-bottom: 2em;
	z-index: 1;
}
#about .aboutContents > li > a > img {
	position: absolute;
	right: 0;
	bottom: 20px;
	filter: brightness(50%);
	transform: translateY(100%);;
	z-index: 0;
}
#about .aboutContents > li .artistWrap {
	display: flex;
	justify-content: space-between;
	align-items: center;
	position: relative;
	z-index: 1;
}
#about .aboutContents > li .artistWrap > img {
	width: 15%;
	border-radius: 50%;
}
#about .aboutContents > li .artistWrap > div {
	width: 80%;
	margin-left: 24px;
	font-feature-settings: "palt";
}
#about .aboutContents > li .artistWrap .artistClubTitle {
	font-size: 0.75rem;
	color: #13c1ea;
	line-height: 1.6;
}
@media screen and (min-width: 821px) {
	#about .aboutContents > li {
		font-size: 0.833rem;
	}
}
@media screen and (max-width: 820px) {
	#about .aboutContents {
		display: block;
	}
	#about .aboutContents > li {
		display: block;
		width: 100%;
		margin-bottom: 8vw;
		border-bottom: none;
		padding-bottom: 50%;
	}
	#about .aboutContents > li > a > img {
		width: 90%;
		transform: translate(-50%, 0);
		bottom: 0;
		left: 50%;
	}
	#about .aboutContents > li .artistWrap > img {
		width: 18%;
	}
	#about .aboutContents > li .artistWrap > div {
    	margin-left: min(4vw, 24px);
	}
	#about .aboutContents > li .artistWrap .artistClubTitle {
		font-size: 0.75rem;
	}

	#about .aboutContents > li .artistWrap > div .artistTitle {
    	font-size: 1.2rem;
	}
	#about .aboutContents > li .artistWrap > div .artistClubTitle {
    	font-size: 1rem;
	}
}

/* ------- about label --------- */
.aboutLabel1,
.aboutLabel2 {
	max-width: 1240px;
	margin: auto;
}
.aboutLabel1 .labelText1 {
	font-size: 1.333rem;
	margin-bottom: 1em;
}
.aboutLabel1 .labelText2,
.aboutLabel2 .labelText2 {
	font-size: 0.833rem;
	margin-bottom: 1em;
}
.aboutLabel1 .note,
.aboutLabel2 .note {
	font-size: 0.666rem;
}
.aboutLabel1Wrap {
	background: linear-gradient(135deg, #339bc6 20%, #0032a1 80%);
}
.aboutLabel1 {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 104px 80px;
}
.aboutLabel1 > div {
	width: 65%;
}
.aboutLabel1 > div:nth-child(2) {
	width: 30%;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
}
.aboutLabel1 > div:nth-child(2) > p {
	line-height: 1;
}
.aboutLabel1 > div:nth-child(2) > p span {
	font-size: 5.166rem;
}
.aboutLabel1 .balloon {
	margin: auto;
	position: relative;
	width: 180px;
}
.aboutLabel1 .balloonCmt {
	position: absolute;
	transform: translateX(50%);
	width: 100%;
	text-align: center;
	top: 10%;
	right: 50%;
}

.aboutLabel2Wrap {
	background-color: #1a1a1a;
}
.aboutLabel2 {
	position: relative;
	display: flex;
	justify-content: space-between;
	padding: 80px;
}
.aboutLabel2 .btnEntry {
	position: absolute;
	max-width: 267px;
	width: 25%;
	left: 80px;
	bottom: -64px;
}
.aboutLabel2 .btnEntry::before {
	content: "";
	display: block;
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	border: #13c1ea solid 5px;
	border-radius: 50%;
	animation: eBtn 1s ease-out 0s infinite;
}
@keyframes eBtn {
	0% { transform: scale(1);}
	100% { transform: scale(1.2); opacity: 0;}
}

.aboutLabel2 .aboutLabel2_left {
	width: 35%;
}
.aboutLabel2 .aboutLabel2_right {
	width: 60%;
}
.aboutLabel2_right .stepWrap {
	display: flex;
	align-items: center;
}
.aboutLabel2_right .stepNumber {
	text-align: center;
	line-height: 1.2;
	font-family: 'Roboto', sans-serif;
	color: #13c1ea;
	margin-right: 40px;
}
.aboutLabel2_right .stepNumber span {
	font-size: 2.333rem;
}
.aboutLabel2 .stepWrap dd {
	font-size: 0.75rem;
}
.stepLine {
	font-family: 'Roboto', sans-serif;
	display: flex;
  align-items: center;
  justify-content: center;
	color: #13c1ea;
	font-size: 1.3rem;
}
.stepLine:before, .stepLine:after {
  border-top: 1px solid #333;
  content: "";
  width: 100%;
}
.stepLine:before {
  margin-right: 1em;
}
.stepLine:after {
  margin-left: 1em;
}
@media screen and (max-width: 820px) {
	.aboutLabel1 {
		display: block;
		padding: 14vw 6vw;
	}
	.aboutLabel1 > div {
		width: 100%;
    	margin-bottom: min(10vw, 40px);
	}
	.aboutLabel1 > div:nth-child(2) {
		width: 100%;
    	margin-bottom: 0;
	}
	.aboutLabel1 .balloon {
		width: 40vw;
	}
	.aboutLabel1 .balloonCmt {
		top: 14%;
	}
	.aboutLabel1 > img {
		margin: 6vw 0 0;
	}
	.aboutLabel1 > div:nth-child(2) > p {
    	font-size: 1.8rem;
	}
	.aboutLabel1 > div:nth-child(2) > p span {
		font-size: 8.2rem;
	}

	.aboutLabel2 {
		display: block;
    	padding: 6vw 6vw 20vw;
	}
	.aboutLabel2 .btnEntry {
		width: 34%;
		left: auto;
		right: 6vw;
		bottom: 15vw;
		transform: translateY(100%);
	}
	.aboutLabel2 .btnEntry::before {
		border: #13c1ea solid 2px;
	}
	.aboutLabel2 .aboutLabel2_left {
		width: 100%;
		margin-bottom: 8vw;
	}
	.aboutLabel2 .aboutLabel2_right {
		width: 100%;
	}
	.aboutLabel2_right .stepWrap {
		display: flex;
		align-items: center;
	}

	.aboutLabel2_right .stepWrap dl dt {
    	font-size: 1.4rem;
	}
	.aboutLabel2_right .stepWrap dl dd {
    	font-size: 1rem;
	}

	.aboutLabel2_right .stepNumber {
		text-align: center;
		line-height: 1.2;
		font-family: 'Roboto', sans-serif;
		color: #13c1ea;
		margin-right: 40px;
	}
	.aboutLabel2_right .stepNumber span {
		font-size: 3rem;
	}
	.aboutLabel2 .stepWrap dd {
		font-size: 0.75rem;
	}

	.aboutLabel1 .labelText1 {
		font-size: 1.5rem;
		margin-bottom: 1.5em;
	}
	.aboutLabel1 .labelText2,
	.aboutLabel2 .labelText2 {
		font-size: 1.1rem;
	}
	.aboutLabel1 .note, .aboutLabel2 .note {
		font-size: .9rem;
	}

	.stepLine {
		font-family: 'Roboto', sans-serif;
		display: flex;
		align-items: center;
		justify-content: center;
		color: #13c1ea;
		font-size: 1.3rem;
	}
	.stepLine:before, .stepLine:after {
		border-top: 1px solid #333;
		content: "";
		width: 100%;
	}
	.stepLine:before {
		margin-right: 1em;
	}
	.stepLine:after {
		margin-left: 1em;
	}
}
/* ------- media --------- */

#media {
	padding: 180px 0;
	background-color: #000;
}

.mediaTitle {
	display: flex;
	justify-content: space-between;
	margin-bottom: 48px;
}
.mediaTitle h3 {
	width: 210px;
}
.mediaTitle > p {
	width: calc(100% - 274px);
	font-size: 0.75rem;
}
.mediaContents {
	background-color: #fff;
	color: #000;
}
.mediaContents > div:nth-of-type(1) {
	display: flex;
	flex-direction: row-reverse;
	justify-content: space-between;
	border-bottom: 1px solid #000;
	padding: 40px 60px;
	align-items: center;
}
.mediaContents > div:nth-of-type(1) > p {
	width: calc(100% - 200px);
}
.mediaContents > div:nth-of-type(1) a {
	width: 180px;
	display: block;
}
.mediaContents > div:nth-of-type(2) {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 32px 40px;
}
.mediaContents > div:nth-of-type(2) > img {
	width: 42%;
}
.mediaContents > div:nth-of-type(2) ul {
	width: 50%;
	line-height: 2.6;
}
.mediaContents > div:nth-of-type(2) li {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-bottom: 1em;
}
.mediaContents > div:nth-of-type(2) li > img {
	width: 60px;
}
.mediaContents > div:nth-of-type(2) li > p {
	width: calc(100% - 80px);
	line-height: 1.6;
}
@media screen and (max-width: 820px) {
	#media {
		padding: min(20vw, 180px) 0 ;
	}
	.mediaTitle {
		display: block;
		margin-bottom: 48px;
	}
	.mediaTitle h3 {
		width: fit-content;
	}
	.mediaTitle > p {
		width: 100%;
		font-size: 1rem;
	}
	.mediaContents {
		background-color: #fff;
		color: #000;
	}
	.mediaContents > div:nth-of-type(1) {
		display: block;
		padding: 6vw;
	}
	.mediaContents > div:nth-of-type(1) > p {
		width: 100%;
		margin-top: 4vw;
	}
	.mediaContents > div:nth-of-type(1) a {
		width: 30%;
	}
	.mediaContents > div:nth-of-type(2) {
		display: block;
		padding: 6vw;
	}
	.mediaContents > div:nth-of-type(2) > img {
		width: 100%;
	}
	.mediaContents > div:nth-of-type(2) ul {
		margin-top: 4vw;
		width: 100%;
	}
}
/* ------- faq --------- */
#faq {
	padding-bottom: 120px;
	background-color: #000;
}
#faq dl {
	border-bottom: 1px solid #333;
	border-left: 1px solid #333;
	border-right: 1px solid #333;
}
#faq dt {
	display: flex;
	align-items: center;
	position: relative;
	border-top: 1px solid #333;
	font-size: 0.833rem;
	padding: 1em 4em 1em 2em;
	cursor: pointer;
}
#faq dt span {
	font-family: 'Roboto', sans-serif;
	font-size: 1.666rem;
	color: #13c1ea;
	margin-right: 0.8em;
}
#faq dt::before,
#faq dt::after {
	position: absolute;
	content: "";
	right: 16px;
	background-color: #fff;
	width: 28px;
	height: 1px;
}
#faq dt::after {
	transform: rotate(90deg);
	transition: all .3s ease-out;
}
#faq dt.on::after {
	transform: rotate(0);
}
#faq dd {
	display: none;
	padding: 20px 60px 40px;
}
#faq dd p {
	font-size: 14px;
	margin-bottom: 1em;
}
#faq dd p:last-child {
	margin-bottom: 0;
}
#faq .btnFaqEntry {
	color: #fff;
	text-decoration: underline;
}
@media screen and (max-width: 820px) {
	#faq {
		padding-bottom: min(12vw, 120px);
	}
	#faq dt {
		font-size: 1.2rem;
		padding: 1em 4em 1em 1.2em;
    	line-height: 1.8;
	}
	#faq dt::before,
	#faq dt::after {
		width: 20px;
	}

	#faq dd {
		padding: min(2vw, 20px) min(6vw, 60px) min(6vw, 40px);
		font-size: min(3vw, 14px);
	}
	#faq dd p {
		font-size: min(3vw, 14px);
	}
}
/* ------- footer --------- */
footer {
	background-color: #fff;
	color: #000;
	padding: 80px 60px;
}
footer > div:nth-of-type(1) {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 60px;
}
footer > div:nth-of-type(1) a {
	width: 200px;
}
footer > div:nth-of-type(1) ul {
	display: flex;
}
footer > div:nth-of-type(1) ul li {
	font-size: 0.666rem;
	margin-left: 2em;
}
footer > div:nth-of-type(1) ul li:first-child {
	margin-left: 0;
}
footer > div:nth-of-type(1) a {
	color: #000;
}

footer > div:nth-of-type(2) {
	display: flex;
	align-items: center;
}
footer > div:nth-of-type(2) a {
	width: 100px;
}
footer > div:nth-of-type(2) > p {
	font-size: 0.5rem;
	margin-left: 3em;
}
@media screen and (max-width: 820px) {
	footer {
		padding: 8vw 6vw;
	}
	footer > div:nth-of-type(1) {
		display: block;
		margin-bottom: 4vw;
	}
	footer > div:nth-of-type(1) a {
		display: block;
		margin: auto;
    	width: 38%;
	}
	footer > div:nth-of-type(1) ul {
		justify-content: center;
		margin-top: 4vw;
    	display: block;
	}
	footer > div:nth-of-type(1) ul li {
		margin-left: 0;
		margin-bottom: min(2vw, 10px);
		text-align: center;
    	font-size: 0.8rem;
	}
	footer > div:nth-of-type(2) {
		display: block;
		margin-top: min(8vw, 60px);
	}
	footer > div:nth-of-type(2) a {
		display: block;
		margin: auto;
		width: 20%;
	}
	footer > div:nth-of-type(2) p {
		text-align: center;
		margin: 4vw 0 0;
		font-size: min(2.6vw, 10px);
	}
}