:root{
	--color_pink: #ff709f;
	--color_pink_shd: #ff709f40;
	--color_blue: #60b1ff;
	--color_blue_shd: #60b1ff40;
	--color_red: #c40044;
	--color_red_shd: #c4004440;
	--color_yellow: #ffc67c;
	--color_orange: #ffc277;
	--color_black: black;
	--color_gray: #585858;
	--color_twitter: #1DA1F2;
	--color_twitter_shd: #1DA1F240;
	--color_youtube: #FF0000;
	--color_youtube_shd: #FF000040;
}
html{
	font-size: 16px;
}
@media screen and (max-width: 800px){
	html{
		font-size: 14px;
	}
}
body{
	margin: 0;
	padding: 0;
	font-family: source-han-sans-japanese, sans-serif;
	font-weight: 500;
	font-style: normal;

	background-image: url(./img/bg.png);
	background-repeat: repeat;
	background-position: center top;

	overflow-x: hidden;
}

a{
	text-decoration: none;
}
.menu_top{
	position: fixed;
	top: 0;
	z-index: 50;
	width: 100%;
	height: 65px;
	padding: 10px 0;

	background: var(--color_pink);
	box-shadow: 0px 0px 30px var(--color_pink_shd);

	overflow: hidden !important;

	transition: .3s cubic-bezier(0.25, 1, 0.5, 1);
}
.menu_top img.pattern{
	position: absolute;
	z-index: -2;
	top: 50%;
	width: 100%;

	opacity: 1.0;

	transform: translateY(-50%);

	mix-blend-mode: overlay;
	transition: .3s cubic-bezier(0.25, 1, 0.5, 1);

}
.menu_top.min{
	background: none;
	box-shadow: none;
}
.menu_top.min img.pattern{
	opacity: 0;
}
.menu_top .button_list{
	position: relative;
	z-index: -2;
	height: 100%;
	width: 920px;
	margin: 0 auto;

	display: flex;
	justify-content: space-evenly;
	align-items: center;
	flex-direction: row;

	background: white;
	box-shadow: 3px 3px 10px var(--color_pink_shd);

	transform: skewX(-10deg);

	overflow: hidden;
}
.menu_top .button_list .button_outer{
	position: relative;

	cursor: pointer;

	transition: .3s cubic-bezier(0.25, 1, 0.5, 1);
}
.menu_top .button_list .button:before{
	content: '';
	position: absolute;
	z-index: -1;
	top: 0;
	left: 50%;
	width: -100%;
	height: 100%;

	background: var(--color_pink);

	transition: .3s cubic-bezier(0.25, 1, 0.5, 1);
}
.menu_top .button_list .button_outer:nth-child(3n-2), .mobile_menu .mobile_list .button_outer:nth-child(3n-2){
	color: var(--color_pink);
}
.menu_top .button_list .button_outer:nth-child(3n-1), .mobile_menu .mobile_list .button_outer:nth-child(3n-1){
	color: var(--color_blue);
}
.menu_top .button_list .button_outer:nth-child(3n), .mobile_menu .mobile_list .button_outer:nth-child(3n){
	color: var(--color_orange);
}
.menu_top .button_list .button_outer:nth-child(3n-2) .button:before{
	background: var(--color_pink);
}
.menu_top .button_list .button_outer:nth-child(3n-1) .button:before{
	background: var(--color_blue);
}
.menu_top .button_list .button_outer:nth-child(3n) .button:before{
	background: var(--color_orange);
}
.menu_top .button_list .no, .mobile_menu .mobile_list .no{
	cursor: default !important;
}
.menu_top .button_list .no .button:before{
	background: none !important;
}
.menu_top .button_list .button_outer:hover{
	color: white;
}
.menu_top .button_list .button_outer:hover .button:before{
	left: 0%;
	width: 100%;
}
.menu_top .button, .mobile_menu .button{
	padding: 6px 6px;
	text-align: center;
}
.menu_top .button .text, .mobile_menu .button .text{
	font-family: vdl-logog,sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 22px;
	line-height: 22px;
}
.menu_top .button .small, .mobile_menu .button .small{
	font-family: vdl-logog,sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 14px;
	line-height: 14px;
}

.menu_top .button_list.mobile{
	width: 65px;
	margin: 0 15px 0 auto;

	flex-direction: column;

	color: var(--color_pink);

	cursor: pointer;
}

.mobile_menu{
	display: none;
	position: fixed;
	z-index: 30;
	top: 0; right: 0; left: 0; bottom: 0;
	width: 100%;
	height: 100%;

	display: flex;
	justify-content: space-evenly;
	align-items: center;
	flex-direction: column;

	background: rgba(255,255,255,0.85);
	-webkit-backdrop-filter: blur(10px);
	        backdrop-filter: blur(10px);
}
.mobile_menu .mobile_list{
	width: 100%;
	height: 50%;

	display: flex;
	justify-content: space-evenly;
	align-items: center;
	flex-direction: column;
}
.mobile_menu .button_outer{
	transform: skewX(-10deg);

	cursor: pointer;
}

.top_first{
	position: relative;
	z-index: 10;
	width: 100%;
	height: 100vh;
}
.top_first img.animation{
	width: 100%;
	height: 100vh;
	object-fit: cover;
}
@media screen and (max-width: 800px){
	.top_first{
		height: 40vh;
	}
	.top_first img.animation{
		height: 40vh;
	}
}

.top_first .banner{
	position: absolute;
	bottom: 50px;
	left: 50%;
	transform: translateX(-50%);
}


.keyvisual{
	z-index: -100;
	position: fixed;
	top: 0;
	width: 100vw;
	height: 100vh;
}
.keyvisual .bg{
	height: 100%;
	width: 100%;
}
.keyvisual .bg img{
	height: 100%;
	width: 100%;

	object-fit: cover;
}
.keyvisual .character{
	position: absolute;
	top: 0;
	height: 100%;
	width: 100%;

	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: row;
}
.keyvisual .character img.char{
}
.mainbox{
	position: relative;
	z-index: 20;
	margin-top: 100vh;
	padding-top: 30px;

	background: white;
	background-image: url(./img/bg.png);
	background-repeat: repeat;
	background-position: center top;
}

.char_stand_list{
	box-sizing: border-box;
	width: 100%;
	max-width: 1000px;
	height: 50vw;
	max-height: 510px;
	padding: 0 0px;
	margin: 0 auto;
	margin-top: 40px;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: row;
}
.char_stand{
	width: 30%;
	height: 100%;
	margin: 1px;

	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: row;

	overflow: hidden;
	cursor: pointer;
}
.char_stand:hover img{
	width: 186%;
}
.char_stand img{
	width: 200%;

	transition: .3s cubic-bezier(0.25, 1, 0.5, 1);
}
.linkset_list{
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}
.linkset{
	margin: 0 20px;
	margin-top: 40px;

	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
}
.linkset2{
	margin: 0 20px;
	margin-top: 40px;

	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}
.linkset img{
	height: 5rem;
	margin-right: 15px;
	border-radius: 50%;
}
.linkset2 img{
	height: 3.5rem;
	margin-top: 10px;
}
.linkset2.sm img{
	height: 2.4rem;
	margin-top: 10px;
}
.linkset2.sm2 img{
	height: 4.0rem;
	margin-top: 10px;
}
.heading{
	position: relative;
	width: 320px;
	margin: 0 auto;
	margin-top: calc(85px + 50px);
	padding: 0 10px;

	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;

	font-family: vdl-logog,sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 2.5rem;
	line-height: 2.5rem;

	border-bottom: 3px solid black;

	overflow: hidden;
}
.heading .text{
	transform: skewX(-10deg);
}
.heading .small{
	font-size: 1.2rem;

	transform: skewX(-10deg);
}
.heading2{
	position: relative;
	width: 300px;
	margin: 0 auto;
	margin-top: calc(85px + 50px);

	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;

	font-family: vdl-logog,sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 2.0rem;
	line-height: 3.0rem;

	border-bottom: 3px solid black;

	overflow: hidden;
}
.heading2 .text{
	transform: skewX(-10deg);
}
.heading2 .small{
	font-size: 1.0rem;

	transform: skewX(-10deg);
}
.heading2 i{
	margin-right: 10px;

	transform: skewX(10deg);
}
.heading2.tume{
	margin-top: calc(85px - 30px);
}


.middle_text{
	margin: 0 auto;
	margin-top: 40px;
	max-width: 750px;

	text-align: center;
}


.left_info, .right_info{
	z-index: 50;
	position: fixed;
	top: 50%;
	box-sizing: border-box;
	height: 170px;
	width: 80px;

	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;

	text-align: center;
	line-height: 50px;
	text-decoration: none;
	-ms-writing-mode: tb-rl;
	    writing-mode: vertical-rl;

	color: white;
	background: var(--color_pink);
	box-shadow: 3px 3px 30px var(--color_pink_shd);

	transform: translateY(-50%) skewX(-10deg);

	cursor: pointer;

	transition: .3s cubic-bezier(0.25, 1, 0.5, 1);
}
.left_info{
	left: -25px;
	padding-left: 7px;
}
.right_info{
	right: -25px;
	padding-right: 7px;
	background: var(--color_twitter);
	box-shadow: 3px 3px 30px var(--color_twitter_shd);
}
.left_info_inner, .right_info_inner{
	transform: skewX(10deg);
}
.left_info:hover, .right_info:hover{
	color: var(--color_pink);
	background: white;
	border: 1px solid var(--color_pink);
}
.left_info:hover{
	left: -15px;
}
.right_info:hover{
	right: -15px;
	color: var(--color_twitter);
	border: 1px solid var(--color_twitter);
}

.langage{
	position: fixed;
	bottom: 0;
	left: 0;
	z-index: 25;
	width: 75px;
	height: 70px;

	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;

	color: white;
	background: var(--color_pink);
	box-shadow: 3px 3px 30px var(--color_pink_shd);

	transition: .3s cubic-bezier(0.25, 1, 0.5, 1);
}
.langage:hover{
	color: var(--color_pink);
	background: white;
	border: 1px solid var(--color_pink);
}
.langage i{
	font-size: 1.4rem;
}

.pop{
	display: flex;
	justify-content: center;
	align-items: center;
	z-index: 200;
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	-webkit-backdrop-filter: blur(5px);
	backdrop-filter: blur(5px);
}
.pop .tab{
	opacity: 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	max-width: 100%;
	max-height: 100%;

	background: white;
	box-shadow: 3px 3px 30px var(--color_pink_shd);
}
.pop .tab.open{
	opacity: 1.0;
}


.select{
	margin-top: 40px;

	display: flex;
	justify-content: center;
	align-items: flex-start;
	flex-direction: row;
}
.select_tab{
	width: 110px;
	margin: 0 5px;

	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;

	cursor: pointer;
}
.select_tab:hover{
}
.select_tab img{
	height: 5rem;
	margin-bottom: 3px;
	border-radius: 50%;

	transition: .3s cubic-bezier(0.25, 1, 0.5, 1);
}
.select_tab.p_0 img{
	box-shadow: 3px 3px 30px var(--color_pink_shd);
}
.select_tab.p_1 img{
	box-shadow: 3px 3px 30px var(--color_blue_shd);
}
.select_tab.p_2 img{
	box-shadow: 3px 3px 30px var(--color_red_shd);
}
.select_tab.p_0:hover img{
	transform: scale(1.08);
}
.select_tab.p_1:hover img{
	transform: scale(1.08);
}
.select_tab.p_2:hover img{
	transform: scale(1.08);
}


.profile{
	margin-top: 40px;
	max-width: 100%;

	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: row;
}
.profile .right{
	box-sizing: border-box;
	width: 420px;
	max-width: 100%;
	padding-top: 40px;
}
.profile .left{
	box-sizing: border-box;
	max-width: 100%;
}
.profile .tachie{
	position: relative;
	width: 440px;
	max-width: 100%;
	height: 640px;

	text-align: center;

	overflow: hidden;
}
.profile .tachie img{
	position: relative;
	max-width: 100%;
	height: 100%;
}
.profile .tachie img.t_0{
	opacity: 0;
}
.profile .tachie img.t_1, .profile .tachie img.t_2{
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;

	display: none;
}
.profile .tachie img.t_1{
	display: inline;
}
.design{
	position: absolute;
	bottom: 0;
	left: 20px;

	background: white;
	font-size: 1rem;
}
.profile .name{
	display: inline-block;

	font-family: vdl-logog,sans-serif;
	font-size: 5rem;
	line-height: 5rem;
}
.profile .name .color{
	color: var(--color_pink);
}
.p_1.profile .name .color{
	color: var(--color_blue);
}
.p_2.profile .name .color{
	color: var(--color_red);
}
.profile .rubi{
	font-size: 1.1rem;
	line-height: 1.1rem;
}
.profile .text{
	margin-top: 12px;
}
.profile .data{
	margin-top: 18px;
}
.profile .data_column{
	margin: 6px 0;
	height: 1.8rem;

	display: flex;
	justify-content: flex-start;
	align-items: center;
	flex-direction: row;
}
.profile .data .title{
	position: relative;
	display: inline-block;
	width: 5rem;
	height: 100%;

	font-size: 1rem;
	text-align: center;
	line-height: 1.8rem;

	color: white;
}
.profile .data .title:before{
	content: '';
	position: absolute;
	z-index: -1;
	top: 0; left: 0; right: 0; bottom: 0;

	background: var(--color_pink);

	transform: skewX(-10deg);
}
.p_1.profile .data .title:before{
	background: var(--color_blue);
}
.p_2.profile .data .title:before{
	background: var(--color_red);
}
.profile .data .content{
	display: inline-block;
	margin-left: 10px;
	height: 100%;

	font-size: 1.1rem;
}
.profile .data .content img{
	height: 100%;
}

.profile .link{
	margin-top: 18px;

	display: flex;
	justify-content: flex-start;
	align-items: center;
	flex-direction: row;
}
.link .button, .linkset .button{
	position: relative;
	display: inline-block;
	box-sizing: border-box;
	
	width: 7.5rem;
	height: 3.2rem;
	margin-right: 10px;

	text-align: center;
	line-height: 3.2rem;
	text-decoration: none;

	color: white;

	transform: skewX(-10deg);

	cursor: pointer;

	transition: .3s cubic-bezier(0.25, 1, 0.5, 1);
}
.link .button_inner, .linkset .button_inner{
	transform: skewX(10deg);
}
.link .button i, .linkset .button i{
	margin-right: 6px;
}
.link .button.btn_twitter, .linkset .button.btn_twitter{
	background: var(--color_twitter);
	box-shadow: 3px 3px 20px var(--color_twitter_shd);
}
.link .button.btn_youtube, .linkset .button.btn_youtube{
	background: var(--color_youtube);
	box-shadow: 3px 3px 20px var(--color_youtube_shd);

	transition: .3s cubic-bezier(0.25, 1, 0.5, 1);
}
.link .button.btn_twitter:hover, .linkset .button.btn_twitter:hover{
	color: var(--color_twitter);
	background: white;
	border: 1px solid var(--color_twitter);
}
.link .button.btn_youtube:hover, .linkset .button.btn_youtube:hover{
	color: var(--color_youtube);
	background: white;
	border: 1px solid var(--color_youtube);
}

.biography_text{
	margin: 0 auto;
	margin-top: 40px;
	max-width: 750px;
}
.biography{
	margin-top: 40px;

	display: flex;
	justify-content: center;
	flex-direction: row;
}
.biography .left{
	display: flex;
	justify-content: center;
	align-items: center;
}
.biography .right{
	align-items: center;
}
.biography .biography_line{
	position: relative;
	top: 20px;
	box-sizing: border-box;
	height: 100%;
	width: 4px;
	margin: 0 40px 0 25px;

	border-right: 4px dashed var(--color_pink);
}
.biography .biography_line:after{
	content: '';
	position: absolute;
	top: 0;
	bottom: 80px;
	width: 100%;
	border-right: 4px solid var(--color_pink);
}
.biography .biography_column{
	position: relative;
	margin-bottom: 30px;
}
.biography .biography_column.ex{
	margin-top: 60px;
}
.biography .biography_column .stone{
	position: absolute;
	top: 50%;
	left: calc(-40px - 2px - 25px);
	padding: 5px 0;
	width: 50px;

	color: white;
	background: var(--color_pink);
	box-shadow: 3px 3px 30px var(--color_pink_shd);

	text-align: center;

	transform: translateY(-50%) skewX(-10deg);
}
.biography .year{
	color: var(--color_pink);

	font-family: vdl-logog,sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 2.5rem;
	line-height: 2.5rem;
}
.biography .date{
	margin-bottom: 6px;

	font-family: vdl-logog,sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 1.6rem;
	line-height: 1.6rem;
}
.biography .color_s{
	color: var(--color_blue);
}
.biography .color_a{
	color: var(--color_pink);
}
.biography .color_f{
	color: var(--color_red);
}



.music{
	margin: 0 auto;
	margin-top: 40px;
	padding: 20px;
	max-width: 820px;
}
.music_column{
	box-sizing: border-box;
	position: relative;
	width: 100%;
	padding: 30px;

	display:flex;
	justify-content:space-between;

	background: white;
	box-shadow: 3px 3px 30px var(--color_pink_shd);
}
.music_column .left{
	 margin-right: 20px;
}
.music_column .img{
	width: 300px;
}
.music_column .img img{
	width: 100%;
}
.music_column .date{
	position: relative;
	z-index: 1;
	display: inline-block;
	padding: 5px 8px;
	margin-bottom: 4px;

	color: white;

	font-family: vdl-logog,sans-serif;
	font-weight: 400;
	font-style: normal;
	line-height: 1rem;
}
.music_column .date:before{
	content: '';
	position: absolute;
	z-index: -1;
	top: 0; left: 0; right: 0; bottom: 0;

	background: var(--color_pink);

	transform: skewX(-10deg);
}
.music_column .title{
	color: var(--color_pink);

	font-family: vdl-logog,sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 2.5rem;
	line-height: 2.5rem;
}
.music_column .disc{
	margin-top: 1.5rem;
}


.contact{
	max-width: 600px;
	margin: 0 auto;
	margin-top: 40px;

	display: flex;
	justify-content: flex-start;
	align-items: center;
	flex-direction: column;
}
.contact form{
	width: 100%;
}
.contact .contact_column{
	margin-bottom: 18px;

	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	flex-direction: row;
}
.contact .contact_column .title{
	display:block;
	width: 150px;
}
.contact .contact_column .box{
	display:block;
	width: calc(100% - 150px);
	height: 1.6rem;
}
.contact .contact_column .box_b, .contact .contact_column .category_list{
	display:block;
	width: calc(100% - 150px);
}
.contact .contact_column .category_list{
	display: flex;
	justify-content: flex-start;
	align-items: center;
	flex-direction: row;
	flex-wrap: wrap;
}
.contact .contact_column .category_list label{
	margin-right: 16px;
}
.contact .tyui{
	margin-bottom: 18px;

	font-size: 0.8rem;
}
.contact .submit_outer{
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: row;
}
.contact .submit{
	width: 100px;
	height: 40px;

	background: var(--color_pink);
	color: white;
	border: none;

	cursor: pointer;
}
.contact .submit:hover{
	color: var(--color_pink);
	background: white;
	border: 1px solid var(--color_pink);
}


.utamita_outer{
	margin: 40px 0;
	width: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}
.utamita{
	width: 80%;
}
.utamita .thumbnail{
	width: 100%;
	transition: .25s cubic-bezier(0.075, 0.82, 0.165, 1);
}
.utamita .thumbnail:hover{
	opacity: .65;
}
.utamita .arrow_left, .utamita .arrow_right{
	position: absolute;
	top: 50%;
	width: 40px;
	height: 80px;
	transform: translate(0,-50%) skewX(-10deg);
	background: var(--color_pink);
	box-shadow: 3px 3px 30px var(--color_pink_shd);
	color: white;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	font-size: 1.4rem;
	cursor: pointer;
	transition: .25s cubic-bezier(0.075, 0.82, 0.165, 1);
}
.utamita .arrow_left:hover, .utamita .arrow_right:hover{
	color: var(--color_pink);
	background: white;
	border: 1px solid var(--color_pink);
}
.utamita .arrow_left{
	left: -15px;
}
.utamita .arrow_right{
	right: -15px;
}

a.link{
	text-decoration: underline;
	color: black;
	padding: 10px;
	transition: .25s cubic-bezier(0.075, 0.82, 0.165, 1);
}
a.link:hover{
	opacity: 0.6;
}
.footer{
	box-sizing: border-box;
	width: 100%;
	margin-top: 100px;
	padding: 40px 20px;
	background: var(--color_black);
	color: white;
}
.footer .sitemap{
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
}
.footer .sitemap a.link{
	text-decoration: underline;
	color: white;
	padding: 10px;
	transition: .25s cubic-bezier(0.075, 0.82, 0.165, 1);
}
.footer .sitemap a.link:hover{
	opacity: 0.6;
}
.footer .social{
	margin-top: 20px;

	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
}
.footer .social img{
	height: 2.6rem;
	margin: 10px 20px;

	transition: .25s cubic-bezier(0.075, 0.82, 0.165, 1);
}
.footer .social img.w{
	background: white;
}
.footer .social img:hover{
	opacity: 0.6;
}
.footer .guideline{
	margin: 10px 0;
	margin-top: 30px;

	text-align: center;
}
.footer .guideline a{
	color: white;
	text-decoration: underline;
}
.footer .copyright{
	margin: 10px 0;
	margin-top: 30px;

	text-align: center;
}


.loading{
	position: fixed;
	top: 0;
	width: 100vw;
	height: 100vh;
}


@media screen and (max-width: 950px){
	.left_info, .right_info, .button_list.pc{
		display: none !important;
	}
	.menu_top{
		height: 40px;
	}
	.keyvisual{
		height: 35vh;
	}
	.mainbox{
		margin-top: 35vh;
	}
	.wrapper{
		padding: 0 20px;
	}
	.select_tab{
		width: 90px;
	}
	.char_stand_list{
		height: 70vw;
	}	
	.profile{
		flex-direction: column;
	}
	.profile .right{
		padding-top: 20px;
	}
	.profile .tachie{
		height: auto;
	}
	.profile .tachie img{
		height: auto;
	}
	.music_column{
		padding: 20px;
		flex-direction: column-reverse;
	}
	.music_column .img{
		width: 100%;
		margin-bottom: 6px;
	}
}
@media screen and (min-width: 950px){
	.button_list.mobile{
		display: none !important;
	}
}