@charset "UTF-8";


/* 横スクロールに関するCSS --------------------------------------------------------------- */
body {
	height: 100vh;
	overflow-x: scroll;
  overflow-y: hidden;

	/* ページの枚数分 */
	width: 800%;
	}

#wrapper {
	width: 100%;
	height: 100%;
	overflow: hidden;
	position: relative;
	}

	.page {
		float: left;
		width: 100%;
		height: 100%;
		position: relative;
		}

@media(max-width: 990px){
	body {
		width: 100%;
		height: auto;
		overflow: auto;
		position: static;
		}

	#wrapper {
		width: 100%;
		height: auto;
		overflow: auto;
		}

		.page {
			float: none;
			width: 100%;
			height: auto;
			margin: 0 auto;
			}
	}



/* header --------------------------------------------------------------- */
#header {
	display: none;

	width: 100%;
	padding: 0 30px;

	z-index: 100;
	overflow: hidden;

	box-sizing: border-box;
	position: fixed;
	left: 0;
	top: 20px;
	}

	#header #logo {
		float: left;
		width: 200px;
		background-image: none;
		background-size: 100% 100%;
		position: relative;
		}

		#header #logo img {
			width: 100%;
			transition: all 0.3s ease-out;
			}
		
			#header #logo img.bk {
				position: absolute;
				left: 0;
				top: 0;
				opacity: 0;
				}

			#header #logo img.wh {
				opacity: 1;
				}
			
			#header.hanten #logo img.bk {
				opacity: 1;
				}

			#header.hanten #logo img.wh {
				opacity: 0;
				}

	#header #sns {
		float: right;
		width: 22px;
		}

		#header #sns a {
			width: 100%;
			line-height: 1;
			position: relative;
			}

			#header #sns a img {
				width: 100%;
				transition: all 0.3s ease-out;
				}
		
				#header #sns a img.bk {
					position: absolute;
					left: 0;
					top: 0;
					opacity: 0;
					}

				#header #sns a img.wh {
					opacity: 1;
					}
				
				#header.hanten #sns a img.bk {
					opacity: 1;
					}

				#header.hanten #sns a img.wh {
					opacity: 0;
					}

@media(max-width: 990px){
	}

@media(min-width: 1px) and (max-width: 660px){
	}



/* home --------------------------------------------------------------- */
#home {
	}

	#home video {
		width: 100%;
		height: 100%;
		object-fit: cover;
		position: absolute;
		left: 0;
		top: 0;
		}

	#home h1 {
		width: 90%;
		text-align: center;
		transition: all 0.5s ease-out;
		transform: translate(-50%, -50%);
		position: absolute;
		left: 50%;
		top: 50%;
		}

		#home h1 span {
			color: #ffffff;
			font-size: 90px;
			line-height: 1.5;
			text-align: center;
			letter-spacing: 4px;
			}

@media(max-width: 990px){
	}



/* message --------------------------------------------------------------- */
#message {
	background-color: #eeeeee;
	background-image: url("../../img/message/bg.png");
	background-position: center top;
	background-size: 100% auto;
	}

	#message .content {
		display: inline-block;
		height: 50vh;
		margin: 0 auto;

		transform: translate(-50%,-50%);
		position: absolute;
		left: 50%;
		top: 50%;
		}
    
		#message .content p {
			color: #000000;
			font-size: 18px;
			writing-mode: vertical-rl;
			text-orientation: upright;
			}

			#message .content p span {
				display: inline;
				background-color: #eeeeee;
				}

@media(max-width: 990px){
	}



/* instructor --------------------------------------------------------------- */
#instructor {
	background-image: url("../../img/instructor/bg.jpg");
	background-position: 92% center;
	background-size: auto 90%;
	}

	#instructor .content {
		width: 1100px;
		transform: translate(-50%,-50%);
		position: absolute;
		left: 50%;
		top: 50%;
		}

		#instructor .content .contentLeft {
			float: left;
			width: 620px;
			}

			#instructor .content .contentLeft h3 {
				display: inline-block;
				margin-bottom: 30px;
				padding: 0 20px;
				font-size: 20px;
				font-weight: bold;
				background-image: url("../../img/instructor/kakoL.png"), url("../../img/instructor/kakoR.png");
				background-position: left center, right center;
				background-size: auto 100%, auto 100%;
				}

			#instructor .content .contentLeft p {
				font-size: 15px;
				line-height: 1.6;
				}

			#instructor #torichan1,
			#instructor #torichan2 {
				width: 120px;
				animation: horizontal 1s ease-in-out infinite alternate;
				animation-duration: 1s;
				position: absolute;
				}
				
			#instructor #torichan1 {
				left: -70px;
				top: 20px;
				}

			#instructor #torichan2 {
				right: -60px;
				bottom: 60px;
				}
					
				#instructor #torichan1 a {
					width: 100%;
					animation: vertical 1s ease-in-out infinite alternate;
					}

				#instructor #torichan2 a {
					width: 100%;
					animation: vertical 2s ease-in-out infinite alternate;
					}
					
					#instructor #torichan1 a img,
					#instructor #torichan2 a img {
						width: 100%;
						}
				
			@keyframes horizontal {
				0% {
					transform:translateX(-3px);
					}
					
				100% {
					transform:translateX(0px);
					}
				}
				
			@keyframes vertical {
				0% {
					transform:translateY(-10px);
					}
					
				100% {
					transform:translateY( 0px);
					}
				}

		
		#instructor .content .contentRight {
			float: left;
			}
			
			#instructor .content .contentRight h2 {
				font-size: 50px;
				line-height: 70px;
				writing-mode: vertical-rl;
				text-orientation: upright;
				}

				#instructor .content .contentRight h2 span {
					text-indent: 2em;
					}

@media(max-width: 990px){
	}



/* vocal --------------------------------------------------------------- */
#vocal {
	background-color: #bbe2e7;

	background-image: url("../../img/vocal/bg.png"), url("../../img/vocal/music.png");
	background-position: 95% bottom, left bottom;
	background-size: auto 95%, 100% auto;
	}

	#vocal .content {
		width: 1100px;		
		overflow: hidden;
		transform: translate(-50%,-50%);
		position: absolute;
		left: 50%;
		top: 50%;
		}

		#vocal .content .contentLeft,
		#vocal .content .contentRight {
			height: 500px;
			}

		#vocal .content .contentLeft {
			float: left;
			width: 500px;
			}

			#vocal .content .contentLeft h2 {
				display: inline-block;
				font-size: 70px;
				line-height: 1;
				margin-bottom: 30px;
				position: relative;
				top: -7px;
				}

				#vocal .content .contentLeft h2 span {
					padding-left: 5px;
					font-size: 50px;
					line-height: 1;
					}

			#vocal .content .contentLeft ul {
				width: 100%;
				height: 380px;
				overflow: hidden;

				background-image: url("../../img/vocal/ulbg.png");
				background-position: left top;
				background-size: 100% auto;

				position: absolute;
				left: 0;
				bottom: 0;
				}

				#vocal .content .contentLeft ul li {
					float: left;
					width: 144px;
					height: 170px;
					margin: 20px 34px 0 0;
					}
				
				#vocal .content .contentLeft ul li:nth-of-type(3n) {
					margin-right: 0;
					}

					#vocal .content .contentLeft ul li a {
						}

						#vocal .content .contentLeft ul li a p {
							width: 144px;
							height: 144px;
							margin-bottom: 3px;
							border-radius: 65px;
							overflow: hidden;
							}

							#vocal .content .contentLeft ul li a p img {
								width: 100%;
								}

						#vocal .content .contentLeft ul li a h3 {
							font-size: 13px;
							text-align: center;
							}

		#vocal .content .contentRight {
			float: right;
			width: 550px;
			}

			#vocal .content .contentRight p {
				width: 100%;
				height: 100%;
				line-height: 32px;
				writing-mode: vertical-rl;
				text-orientation: upright;
				}

				#vocal .content .contentRight p span {
					display: inline;
					background-color: #bbe2e7;
					}

@media(max-width: 990px){
	}



/* guitar --------------------------------------------------------------- */
#guitar {
	background-color: #f5ece6;

	background-image: url("../../img/guitar/bg.png"), url("../../img/vocal/music.png");
	background-position: right bottom, left bottom;
	background-size: auto 95%, 100% auto;
	}

	#guitar .content {
		width: 1100px;		
		overflow: hidden;
		transform: translate(-50%,-50%);
		position: absolute;
		left: 50%;
		top: 50%;
		}

		#guitar .content .contentLeft,
		#guitar .content .contentRight {
			height: 500px;
			}

		#guitar .content .contentLeft {
			float: left;
			width: 500px;
			}

			#guitar .content .contentLeft h2 {
				display: inline-block;
				font-size: 60px;
				line-height: 1;
				margin-bottom: 30px;
				position: relative;
				top: -7px;
				}

				#guitar .content .contentLeft h2 span:first-of-type {
					display: inline-block;
					font-size: 45px;
					line-height: 1;
					}

				#guitar .content .contentLeft h2 span:last-of-type {
					padding-left: 5px;
					font-size: 45px;
					line-height: 1;
					}

			#guitar .content .contentLeft ul {
				width: 100%;
				height: 380px;
				overflow: hidden;

				background-image: url("../../img/vocal/ulbg.png");
				background-position: left top;
				background-size: 100% auto;

				position: absolute;
				left: 0;
				bottom: 0;
				}

				#guitar .content .contentLeft ul li {
					float: left;
					width: 144px;
					height: 170px;
					margin: 20px 34px 0 0;
					}

				#guitar .content .contentLeft ul li:nth-of-type(3n) {
					margin-right: 0;
					}

					#guitar .content .contentLeft ul li a {
						}

						#guitar .content .contentLeft ul li a p {
							width: 144px;
							height: 144px;
							margin-bottom: 3px;
							border-radius: 65px;
							overflow: hidden;
							}

							#guitar .content .contentLeft ul li a p img {
								width: 100%;
								}

						#guitar .content .contentLeft ul li a h3 {
							font-size: 13px;
							text-align: center;
							}

		#guitar .content .contentRight {
			float: right;
			width: 550px;
			}

			#guitar .content .contentRight p {
				width: 100%;
				height: 100%;
				font-size: 15px;
				line-height: 32px;
				writing-mode: vertical-rl;
				text-orientation: upright;
				}

				#guitar .content .contentRight p span {
					display: inline;
					background-color: #f5ece6;
					}

@media(max-width: 990px){
	}



/* online --------------------------------------------------------------- */
#online {
	background-color: #dadaf8;

	background-image: url("../../img/online/bg.png"), url("../../img/vocal/music.png");
	background-position: 100% center, left bottom;
	background-size: auto 80%, 100% auto;
	}

	#online .content {
		width: 1100px;		
		overflow: hidden;
		transform: translate(-50%,-50%);
		position: absolute;
		left: 50%;
		top: 50%;
		}

		#online .content .contentLeft,
		#online .content .contentRight {
			height: 500px;
			}

		#online .content .contentLeft {
			float: left;
			width: 550px;
			}

			#online .content .contentLeft h2 {
				display: inline-block;
				font-size: 70px;
				line-height: 1;
				margin-bottom: 30px;
				position: relative;
				top: -7px;
				}

				#online .content .contentLeft h2 span {
					padding-left: 5px;
					font-size: 50px;
					line-height: 1;
					}

			#online .content .contentLeft dl {
				width: 100%;
				display: table;
				padding: 10px 0;
				border-bottom: dotted 1px #bbb;
				}

		#online .content .contentLeft dl:first-of-type {
			border-top: dotted 1px #bbb;
			}

			#online .content .contentLeft dl dt,
			#online .content .contentLeft dl dd {
				display: table-cell;
				vertical-align: top;
				}

			#online .content .contentLeft dl dt {
				width: 7em;
				text-align-last: justify;
				}

			#online .content .contentLeft dl dd {
				padding-left: 1em;
				}

				#online .content .contentLeft dl dd a {
					display: inline-block;
					font-size: inherit;
					background-color: #f3d922;
					}

				#online .content .contentLeft dl dd span {
					margin-top: 5px;
					font-size: 14px;
					line-height: 1.3;
					}

				#online .content .contentLeft dl dd span a {
					font-size: 14px;
					line-height: 1.3;
					}

		#online .content .contentRight {
			float: right;
			width: 550px;
			}

			#online .content .contentRight p {
				width: 100%;
				height: 100%;
				line-height: 32px;
				writing-mode: vertical-rl;
				text-orientation: upright;
				}

				#online .content .contentRight p span {
					display: inline;
					background-color: #dadaf8;
					}

@media(max-width: 990px){
	}



/* flow --------------------------------------------------------------- */
#flow {
	background-color: #eeeeee;
	}

	#flow .content {
		width: 1100px;		
		overflow: hidden;
		transform: translate(-50%,-50%);
		position: absolute;
		left: 50%;
		top: 50%;
		}

		#flow .content h2 {
			font-size: 50px;
			margin-bottom: 30px;
			}

		#flow .content p {
			margin-bottom: 30px;
			}

			#flow .content p span {
				display: inline-block;
				font-size: 85%;
				}

		#flow .content a {
			display: inline-block;
			font-size: inherit;
			background-color: #f3d922;
			}

		#flow .content ul {
			overflow: hidden;
			}

			#flow .content ul li {
				float: left;
				width: 23.5%;
				margin-right: 2%;
				padding: 20px 10px;
				box-sizing: border-box;
				background-color: #ffffff;
				border-radius: 60px;
				}

			#flow .content ul li:last-of-type {
				margin-right: 0;
				}

				#flow .content ul li h3 {
					font-size: 30px;
					height: 75px;
					letter-spacing: 1px;
					line-height: 1.2;
					text-align: center;
					margin-bottom: 10px;
					font-family: 'Hina Mincho', serif;
					}

				#flow .content ul li:last-of-type h3 {
					height: 55px;
					}

				#flow .content ul li p {
					font-size: 15px;
					line-height: 1.5;
					text-align: center;
					}



/* fee --------------------------------------------------------------- */
#fee {
	}

	#fee .content {
		width: 1100px;		
		overflow: hidden;
		transform: translate(-50%,-50%);
		position: absolute;
		left: 50%;
		top: 50%;
		}

		#fee .content h2 {
			font-size: 50px;
			margin-bottom: 30px;
			}

		#fee .content dl {
				width: 100%;
				display: table;
				padding: 10px 0;
				border-bottom: dotted 1px #bbb;
				}

		#fee .content dl:first-of-type {
			border-top: dotted 1px #bbb;
			}

			#fee .content dl dt,
			#fee .content dl dd {
				display: table-cell;
				vertical-align: top;
				}

			#fee .content dl dt {
				width: 4em;
				text-align-last: justify;
				}

			#fee .content dl dd {
				padding-left: 1em;
				}

				#fee .content dl dd a {
					display: inline-block;
					font-size: inherit;
					background-color: #f3d922;
					}

				#fee .content dl dd span {
					margin-top: 5px;
					font-size: 14px;
					line-height: 1.3;
					}

				#fee .content dl dd span a {
					font-size: 14px;
					line-height: 1.3;
					}

		#fee .content .contentLeft {
			float: left;
			width: 530px;
			}

		#fee .content .contentRight {
			float: right;
			width: 530px;
			}

			#fee .content .contentRight dl {
				padding: 9px 0 8px 0;
				font-size: 14px;
				}

				#fee .content .contentRight dl dt {
					width: 7em;
					}

@media(max-width: 990px){
	}



/* navigation --------------------------------------------------------------- */
#navigation {
	width: 100%;
	padding: 0 30px;
	box-sizing: border-box;
	overflow: hidden;
	position: fixed;
	right: 0;
	bottom: 0;
	}

	#navigation a {
		float: left;

		background-image: url("../../img/navigation/bgwh.png");
		background-position: right center;
		position: relative;

		height: 45px;
		margin-top: 35px;
		}

	#navigation.hanten a {
		background-image: url("../../img/navigation/bgbk.png");
		}

	#navigation a.active {
		background-image: none;
		}

		#navigation a span {
			width: 100%;
			color: #ffffff;
			font-size: 13px;
			line-height: 1;
			text-align: center;
			transform: translate(0,-50%);
			position: absolute;
			top: 50%;
			}

		#navigation a.active span {
			color: #333333;
			}

	#navigation a.home {
		width: 5%;
		}

		#navigation a.home.active {
			background-color: transparent;
			}

			#navigation a.home.active span {
				color: #ffffff;
				}

	#navigation a.message {
		width: 7%;
		}

		#navigation a.message.active {
			background-color: #eeeeee;
			}

	#navigation a.instructor {
		width: 8%;
		}

		#navigation a.instructor.active {
			background-color: #ffffff;
			}

	#navigation a.vocal {
		width: 10%;
		}

		#navigation a.vocal.active {
			background-color: #bbe2e7;
			}

	#navigation a.guitar {
		width: 13%;
		}

		#navigation a.guitar.active {
			background-color: #f5ece6;
			}

	#navigation a.online {
		width: 11%;
		}

		#navigation a.online.active {
			background-color: #dadaf8;
			}

	#navigation a.flow {
		width: 9%;
		}

		#navigation a.flow.active {
			background-color: #eeeeee;
			}

	#navigation a.fee {
		width: 9%;
		}

		#navigation a.fee.active {
			background-color: #ffffff;
			}

	#navigation a.contact {
		width: 8%;
		}

	#navigation a.booking {
		width: 20%;
		overflow: hidden;
		background-image: none;
		border-radius: 0 0 0 0;
		background-image: url("../../img/navigation/booking.png");
		background-repeat: repeat;
		height: 80px;
		margin-top: 0;
		}

		#navigation a.booking span {
			color: #ffffff;
			font-size: 18px;
			}

		#navigation a.booking span:last-of-type {
			font-size: 12px;
			top: 72%;
			}

			#navigation a.booking #nami {
				width: 100%;
				height: 80px;
				position: relative;
				}

				#navigation a.booking #nami .nami {
					width: 300px;
					height: 300px;
					margin:0 auto;
					overflow: hidden;
					box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
					position: absolute;
					left: 0;
					top: 50%;
					transform: translate(0,-50%);
					}

				#navigation a.booking #nami .nami::before,
				#navigation a.booking #nami .nami::after {
					content: "";
					width: 200%;
					height: 200%;
					background-color: #f3d922;
					background-color: #ff7978;
					animation: wave linear 6s infinite;
					position: absolute;
					left: -50%;
					}

				#navigation a.booking #nami .nami::before {
					border-radius: 50% 50% / 50% 70%;
					top: -150%;
					}

				#navigation a.booking #nami .nami::after {
					border-radius: 30% 70% / 30% 50%;
					opacity: 0.2;
					animation-delay: 0.4s;
					top: -146%;
					}

		@keyframes wave {
			from {
				transform:rotate(0deg);
				}
			to {
				transform:rotate(360deg);
				}
			}

		@keyframes wave {
			from {
				transform:rotate(0deg);
				}
			to {
				transform:rotate(360deg);
				}
			}

@media(max-width: 990px){
	}

@media(min-width: 1px) and (max-width: 660px){
	}