@charset "UTF-8";
/* home */



/* ホーム --------------------------------------------------------------- */
#video {
	width: 100%;
	height: 100vh;
	position: relative;
	}

	#video video {
		width: 100%;
		height: 100%;
		object-fit: cover;
		position: absolute;
		left: 0;
		top: 0;
		}
	
	#video h2 {
		width: auto;
		height: 100vh;
		font-size: 50px;
		font-weight: bold;
		line-height: 2;
		letter-spacing: 5px;
		text-align: center;
		writing-mode: vertical-rl;
		position: absolute;
		left: 20%;
		top: 0;
		}

	/* 新着情報  */
	#video #information {
		width: 100%;
		padding: 0 60px 0 30px;
		box-sizing: border-box;
		background-color: #ffffff;
		z-index: 99;
		position: absolute;
		left: 0;
		bottom: 20px;
		}

		#video #information ul {
			display: flex;
			overflow: hidden;
			white-space: nowrap;
			cursor: ew-resize;
			}

			#video #information ul li {
				margin-right: 30px;
				}

			#video #information ul li:last-of-type {
				margin-right: 60px;
				}

			#video #information ul li,
			#video #information ul li a {
				font-size: 14px;
				line-height: 1;
				}

			#video #information ul li a {
				display: inline-block;
				}

@media(max-width: 1024px){
	#video {
		height: 90vh;
		}

		#video video {
			opacity: 0.2;
			}
		
		#video h2 {
			height: 100vh;
			font-size: 40px;
			left: 50%;
			transform: translate(-50%, 0);
			}

		/* 新着情報  */
		#video #information {
			padding: 0 5%;
			}

			#video #information ul {
				padding: 20px 5%;
				overflow-x: auto;
				}
	}

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


/* 作ったもの --------------------------------------------------------------- */
#works {
	min-height: 100vh;
	margin: 0 auto;
	padding: 50px 10px;
	box-sizing: border-box;
	position: relative;	
	z-index: 10;
	transition: all 0.5s ease-in-out;
	opacity: 0;
	}

#works.visible {
	opacity: 1;
	}
	
	#works ul {
		width: 1240px;
		margin: 0 auto;
		position: relative;
		}

		#works ul li {
			width: 25% !important;
			padding: 0 20px 50px 20px;
			box-sizing: border-box;
			position: absolute;
			}

			#works ul li a {
				width: 100%;
				}

				#works ul li a p {
					margin-bottom: 7px;
					padding: 5px;
					box-sizing: border-box;
					background-color: #f0f0f0;
					overflow: hidden;
					position: relative;
					}

					#works ul li a p span {
						width: 100%;
						position: relative;
						}

						#works ul li a p span img,
						#works ul li a p span video {
							width: 100%;
							height: 100%;
							object-fit: cover;
							}
																	
				#works ul li a h2 {
					font-size: 16px;
					word-break: break-all;
					text-align: center;
					line-height: 1.4;
					}

				/* ランダム動作中用のクラス */
				#works ul li a h2.active {
					/*
					color: #fccf00 !important;
					text-decoration: underline !important;
					*/
					}

	#works #sort {
		padding: 0 20px 30px 20px;
		overflow: hidden;
		}

		#works #sort a {
			width: auto !important;
			padding: 8px 0 8px 20px;
			line-height: 1;
			overflow: hidden;
			transition: all 0.3s ease-in-out;

			background-image: url(../../img/home/sort.png);
			background-position: left center;
			background-size: auto 10px;
			}
		
		#works #sort a.parent {
			}
		
		#works #sort a.child {
			margin-left: 20px;
			}

		#works #sort a.grand {
			margin-left: 40px;
			}

		#works #sort a.active {
			background-color: #fccf00;
			}

@media(max-width: 1024px){
	#works {
		margin: 0 auto;
		padding: 0 2.5% 20px 2.5%;
		}
	
		#works ul {
			width: 100%;
			}
		
			#works ul li {
				width: 50% !important;
				padding: 0 2.5% 30px 2.5%;
				}

			#works #sort {
				padding: 0 10px 20px 10px;
				}

				#works #sort a {
					padding: 7px 0 7px 20px;
					}
	}

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

/* お客さまへ --------------------------------------------------------------- */
#service {
	padding: 100px 0 0 0;
	background-color: #f0f0f0;
	}

@media(max-width: 1024px){
	#service {
		padding: 60px 0 0 0;
		}
	}

	/* philosophy --------------------------------------------------------------- */
	#philosophy {
		width: 1200px;
		margin: 0 auto;
		overflow: hidden;
		}

		#philosophy .philosophyTop {
			width: 100%;
			height: 450px;
			margin-bottom: 70px;
			}

			#philosophy .philosophyTop h2 {
				margin: 0 auto;
				font-size: 20px;
				line-height: 2.5;
				letter-spacing: 4px;
				writing-mode: vertical-rl;
				text-align: justify;
				position: relative;
				}
				
				#philosophy .philosophyTop h2 span:first-of-type {
					text-align: right;
					}
				
				#philosophy .philosophyTop h2 span:last-of-type {
					width: 90px;
					height: 90px;
					
					background-image: url(../../img/home/philosophy_face.webp);
					background-position: center center;
					background-size: 100% 100%;

					position: absolute;
					left: -75px;
					bottom: 90px;
					}

		#philosophy .philosophyBottom {
			}

			#philosophy .philosophyBottom dl {
				overflow: hidden;
				}

			#philosophy .philosophyBottom dl:nth-of-type(2) {
				margin-top: -35px;
				}

				#philosophy .philosophyBottom dl dt {
					float: left;
					width: 230px;
					position: relative;
					}

				#philosophy .philosophyBottom dl:nth-of-type(2) dt {
					margin-left: 135px;
					}

					#philosophy .philosophyBottom dl dt img {
						width: 100%;
						}

					#philosophy .philosophyBottom dl dt span {
						width: 100%;
						font-size: 20px;
						line-height: 1.3;
						text-align: center;
						transform: translate(-50%, 0);
						position: absolute;
						left: 50%;
						top: 35px;
						}
					
					#philosophy .philosophyBottom dl:nth-of-type(2) dt span {
						top: 30px;
						}

				#philosophy .philosophyBottom dl dd {
					float: right;
					width: 940px;
					box-sizing: border-box;
					font-size: 16px;
					line-height: 1.8;
					text-align: justify;
					}
				
				#philosophy .philosophyBottom dl:first-of-type dd {
					padding-top: 25px;
					}

				#philosophy .philosophyBottom dl:nth-of-type(2) dd {
					width: 805px;
					padding-top: 15px;
					}
				
				#philosophy .philosophyBottom dl:last-of-type dd {
					padding-top: 30px;
					}

	@media(max-width: 1024px){
		/* philosophy --------------------------------------------------------------- */
		#philosophy {
			width: 90%;
			}

			#philosophy .philosophyTop {
				height: 440px;
				margin-bottom: 30px;
				padding-bottom: 30px;				
				overflow-x: scroll;
				}

				#philosophy .philosophyTop h2 {
					padding-left: 90px;
					font-size: 20px;
					line-height: 48px;
					}
				
					#philosophy .philosophyTop h2 span:last-of-type {
						left: 10px;
						}

				#philosophy .philosophyBottom dl {
					margin-bottom: 40px;
					}

				#philosophy .philosophyBottom dl:nth-of-type(2) {
					margin-top: 0;
					}

					#philosophy .philosophyBottom dl dt {
						float: none;
						margin: 0 auto 20px auto;
						}

					#philosophy .philosophyBottom dl:nth-of-type(2) dt {
						margin: 0 auto 20px auto;
						}

						#philosophy .philosophyBottom dl dt span {
							top: 30px;
							}
						
						#philosophy .philosophyBottom dl:nth-of-type(2) dt span {
							top: 25px;
							}

					#philosophy .philosophyBottom dl dd {
						float: none;
						width: 100%;
						font-size: 16px;
						}
					
					#philosophy .philosophyBottom dl:first-of-type dd {
						padding-top: 0;
						}

					#philosophy .philosophyBottom dl:nth-of-type(2) dd {
						width: 100%;
						padding-top: 0;
						}
					
					#philosophy .philosophyBottom dl:last-of-type dd {
						padding-top: 0;
						}
		}

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



	/* 制作の流れ --------------------------------------------------------------- */
	#flow {
		padding: 50px 0 0 0;
		overflow: hidden;
		}

		#flow #slickWrapper {
			width: 1190px;
			max-width: 100%;
			margin: 0 auto;
			}

		/* Slickの表示エリアを右側だけはみ出させる */
		#flow #slickWrapper .slick-list {
			overflow: visible;
			}

			#flow #slickWrapper .prev,
			#flow #slickWrapper .next {
				width: 16px;
				cursor: pointer;
				z-index: 10;
				position: absolute;
				top: 50%;
				transform: translate(0,-50%);
				}
			
			#flow #slickWrapper .prev {
				left: -10px;
				}
			
			#flow #slickWrapper .next {
				left: 390px;
				}

				#flow #slickWrapper .prev img,
				#flow #slickWrapper .next img {			
					width: 100%;
					}

			#flow #slickWrapper ul {
				width: 100%;
				}

				#flow #slickWrapper ul li {
					float: left;
					width: calc(100% / 3);
					height: 240px;
					padding: 10px 30px 0 30px;
					box-sizing: border-box;
					position: relative;
					text-align: left;
					direction: ltr;
					}

					#flow #slickWrapper ul li h2 {
						width: 100%;
						font-size: 30px;
						font-weight: bold;
						letter-spacing: 5px;
						text-align: center;
						position: absolute;
						left: 0;
						top: 50%;
						transform: translate(0,-50%);
						}

					#flow #slickWrapper ul li p:first-of-type {
						width: 70px;
						z-index: 1;
						position: absolute;
						left: 15px;
						top: -5px;
						}

						#flow #slickWrapper ul li p:first-of-type img {
							width: 100%;
							}

					#flow #slickWrapper ul li p:last-of-type {
						height: 100%;
						padding: 25px 20px 20px 20px;
						line-height: 1.4;
						border-radius: 20px;
						box-sizing: border-box;
						background-color: #ffffff;
						overflow: hidden;
						}

						#flow #slickWrapper ul li p:last-of-type span {
							width: 100%;
							font-size: 18px;
							text-align: center;
							margin-bottom: 15px;
							}

	@media(max-width: 1024px){
		#flow {
			padding: 0 0 50px 0;
			}

			#flow #slickWrapper {
				width: 100%;
				}

				#flow #slickWrapper .prev,
				#flow #slickWrapper .next {
					display: none;
					}

				#flow #slickWrapper ul {
					}

					#flow #slickWrapper ul li {
						float: none;
						width: 100%;
						height: auto;
						padding: 10px 20px 0 20px;
						margin-bottom: 20px;
						}

						#flow #slickWrapper ul li h2 {
							position: static;
							transform: none;
							}
						
						#flow #slickWrapper ul li p:last-of-type {
							padding: 25px 20px 30px 20px;
							}
		}

	@media(max-width: 400px){
						#flow #slickWrapper ul li p:first-of-type {
							width: 45px;
							}
							
							#flow #slickWrapper ul li p:last-of-type span {
								font-size: 16px;
								}
		}



	/* よくあるご質問 --------------------------------------------------------------- */
	#qanda {
		padding: 100px 0 0 0;
		overflow: hidden;
		}

			#qanda .qanda {
				width: 1200px;
				margin: 0 auto;
				}

				#qanda .qanda h2 {
					display: none;
					}

				#qanda .qanda .qandaLeft,
				#qanda .qanda .qandaRight {
					width: 575px;
					}

				#qanda .qanda .qandaLeft {
					float: left;
					}
				
				#qanda .qanda .qandaRight {
					float: right;
					}

					#qanda .qanda dl {
						line-height: 1.7;
						border-bottom: #ddd solid 1px;
						}
					
					#qanda .qanda dl:first-of-type {
						border-top: #ddd solid 1px;
						}

						#qanda .qanda dl dt {
							cursor: pointer;
							padding: 15px 0 15px 40px;
							text-align: justify;
							background-image: url(../../img/home/qanda_question.png);
							background-position: left center;
							background-size: auto 30px;
							transition: all 0.5s ease-in-out;
							}
						
						#qanda .qanda dl dt:hover {
							opacity: 0.5;
							}
						
						#qanda .qanda dl dt.active {
							background-image: url(../../img/home/qanda_answer.png);
							}
						
						#qanda .qanda dl dd {
							display: none;
							padding: 10px 0 15px 2px;
							border-top: #ddd solid 1px;
							text-align: justify;
							}

							#qanda .qanda dl dd a {
								display: inline-block;
								text-decoration: underline;
								}

	@media(max-width: 1024px){
		#qanda {
			padding: 0;
			}

				#qanda .qanda {
					width: 90%;
					}

					#qanda .qanda h2 {
						display: block;
						width: 100%;
						font-size: 30px;
						font-weight: bold;
						text-align: center;
						margin-bottom: 20px;
						}

					#qanda .qanda .qandaLeft,
					#qanda .qanda .qandaRight {
						width: 100%;
						}

					#qanda .qanda .qandaLeft,
					#qanda .qanda .qandaRight {
						float: none;
						}

							#qanda .qanda dl dt {
								line-height: 1.5;
								}

							#qanda .qanda dl dd {
								padding: 10px 0 15px 0;
								}
		}

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



	/* お問い合わせのボタン --------------------------------------------------------------- */
	#contact {
		margin: 0 auto;
		padding: 100px 0;
		}

		#contact a {
			width: 420px;
			height: 100px;
			margin: 0 auto;
			position: relative;
			}

			#contact a .main {
				width: 100%;
				height: 70px;
				margin: 0 auto;
				border-radius: 12px;
				overflow: hidden;
				background-color: #fccf00;
				transition: all 0.5s ease-in-out;
				position: relative;
				}
			
			#contact a:hover .main {
				border-radius: 0;
				}

				#contact a .main p {
					width: 100%;
					font-size: 20px;
					font-weight: bold;
					text-align: center;
					position: absolute;
					left: 50%;
					top: 50%;
					transform: translate(-50%,-50%);
					}
			
			#contact a .border {
				width: 100%;
				height: 70px;
				border: #fccf00 solid 2px !important;
				box-sizing: border-box;
				border-radius: 12px;
				transition: all 0.3s ease-in-out;
				overflow: hidden;
				position: absolute;
				left: 10px;
				top: 10px;
				}
			
			#contact a:hover .border {
				border-radius: 0;
				left: 0;
				top: 0;
				}
			
			#contact a span {
				width: 100%;
				font-size: 12px;
				text-align: center;
				opacity: 0.5;
				position: absolute;
				left: 50%;
				bottom: 0;
				transform: translate(-50%, 0);
				}

				#contact a span br {
					display: none;
					}

	@media(max-width: 1024px){
		#contact {
			padding: 70px 0;
			}

			#contact a {
				width: 90%;
				}

				#contact a span {
					font-size: 10px;
					}
		}

	@media(max-width: 400px){
			#contact a {
				height: 110px;
				}

					#contact a span br {
						display: block;
						}
		}



/* モッケについて --------------------------------------------------------------- */
#company {
	position: relative;
	}

	#company .company {
		width: 1200px;
		height: 100vh;
		margin: 0 auto;
		overflow: hidden;
		position: relative;
		}

		#company .company .companyInfo {
			width: 450px;
			position: absolute;
			left: 0;
			top: 50%;
			transform: translate(0, -50%);
			}
	
			#company .company .companyInfo dl {
				width: 100%;
				display: table;
				border-bottom: solid 1px #eeeeee;
				}

			#company .company .companyInfo dl:first-of-type {
				border-top: solid 1px #eeeeee;
				}
				
				#company .company .companyInfo dl dt,
				#company .company .companyInfo dl dd {
					display: table-cell;
					vertical-align: top;
					padding: 15px 0 15px 10px;
					font-size: 15px;
					line-height: 1.5;
					}

				#company .company .companyInfo dl dt {
					width: 5em;
					}

				#company .company .companyInfo dl dd {
					}

					#company .company .companyInfo dl dd span {
						display: inline;
						font-size: 85%;
						}

					#company .company .companyInfo dl dd a {
						display: inline;
						text-decoration: underline;
						}
			
		#company #map {
			width: 50%;
			height: 100vh;
			position: absolute;
			right: 0;
			bottom: 0;
			}

@media(max-width: 1024px){
	#company {
		height: auto;
		z-index: auto;
		position: static;
		}

		#company .company {
			width: 90%;
			height: auto;
			}

			#company .company .companyInfo {
				width: 100%;
				position: static;
				transform: none;
				}

				#company .company .companyInfo dl:first-of-type {
					border-top: 0;
					}
	
				#company .company .companyInfo dl:last-of-type {
					border-bottom: 0;
					}
	
					#company .company .companyInfo dl dt,
					#company .company .companyInfo dl dd {
						padding: 15px 0;
						font-size: 16px;
						text-align: left;
						}
	
				#company #map {
					width: 100%;
					height: 50vh;
					position: static;
					}
	}

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