@charset "UTF-8";
/* CSS Document */
/* slideArea
================================================== */
#slideArea {
	position: relative;
	max-width: 1800px;
	margin: 0 auto;
}
/* slideTit
================================================== */
#slideTit {
	position: absolute;
	z-index: 2;
	top: 0;
	left: 0;
	width: 100%;
}
#slideTit .title{
	padding: 4% 70% 0;
	width: 12%;
}
@media screen and (max-width: 639px) {
	#slideTit .title{
		padding: 10% 65% 0;
		width: 23%;
	}
}
/* slideBox
================================================== */
#slideBox {
	position: relative;
	z-index: 1;
}
.swiper-container {
	-webkit-border-radius: 4px;
	-moz-border-radius: 4px;
	border-radius: 4px;
}
@media screen and (max-width: 1800px) {
	.swiper-container {
		-webkit-border-radius: 0;
		-moz-border-radius: 0;
		border-radius: 0;
		overflow: inherit;
	}
}
/* ------ スライダー ------ */
@keyframes zoomUp {
	0% {
		transform: scale(1);
	}
	100% {
		transform: scale(1.25);
	}
}
.swiper-slide-active .slide-img,
.swiper-slide-duplicate-active .slide-img,
.swiper-slide-prev .slide-img{
	animation: zoomUp 10s linear 0s 1 normal both;  
}
//imgタグだと下に隙間ができるのでblockに。
.slide-img img{
	display: block;
}
/* siteBg
================================================== */
#siteBg {
	position: absolute;
	z-index: 2;
	top: 78%;
	left: 2%;
	width: 65%;
	mix-blend-mode: multiply;
}
@media screen and (max-width: 639px) {
	#siteBg {
		top: 84%;
		left: -3%;
		width: 100%;
	}
}
/* topArea
================================================== */
#topArea {
	position: relative;
	z-index: 3;
	width: 90%;
	max-width: 1010px;
	margin: 0 auto;
	padding: 9% 5% 40px;
}
@media screen and (max-width: 639px) {
	#topArea {
		padding: 5% 5% 40px;
	}
}
#topLogo {
	width: 70%;
	max-width: 500px;
	margin: 0 auto;
	padding: 0 0 40px;
}
@media screen and (max-width: 639px) {
	#topLogo {
		width: 100%;
		margin: 0 auto;
		padding: 40px 0;
	}
}
#topArea p {
	line-height: 200%;
	padding-bottom: 20px;
	font-size: 120%;
	text-align: justify;
	letter-spacing: 0.05em;
}
@media screen and (max-width: 639px) {
	#topArea p {
		font-size: 100%;
	}
	#topArea p:last-child {
		padding-bottom: 0;
	}
}
/* infoArea
================================================== */
.infoArea {
	position: relative;
	z-index: 3;
	padding: 40px 5%;
}
/* infoBlock */
#infoBlock {
	max-width: 1010px;
	margin: 0 auto 20px;
    padding: 30px 0 10px;
}
@media screen and (max-width: 639px) {
	#infoBlock {
		padding: 2% 0;
		border: none;
		margin: 0;
	}
}
#infoBlock .fLeft {
	width: 25%;
}
#infoBlock .fRight {
	width: 70%;
}
@media screen and (max-width: 639px) {
	#infoBlock .fLeft {
		float: none;
		width: 100%;
	}
	#infoBlock .fRight {
		float: none;
		width: 100%;
	}
}
#infoBlock .fLeft h2 {
	font-size: 130%;
	letter-spacing: 0.12em;
	padding: 0 0 15px;
	margin-bottom: 20px;
	text-align: center;
	width: 100%;
}
#infoBlock .fLeft figure {
	width: 70%;
	margin: 0 auto;
	padding-bottom: 15px;
}
@media screen and (max-width: 639px) {
	#infoBlock .fLeft h2 {
		font-size: 120%;
		letter-spacing: 0.12em;
		text-align: center;
		padding: 10px 0;
		background-color: #32a301;
		color: #fff;
		-webkit-border-radius: 2px;
		-moz-border-radius: 2px;
		border-radius: 2px;
	}
	#infoBlock .fLeft figure {
		width: 30%;
		max-width: 100px;
		margin: 0 auto;
		padding-bottom: 15px;
	}
}
#infoBlock .infoBox {
	padding: 0 0 15px 0;
}
#infoBlock .infoBox:last-child {
	border-bottom: none;
}
#infoBlock .infoBox .infoDay {
	float: left;
	width: 90px;
	font-size: 60%;
	font-weight: 500;
}
@media screen and (max-width: 639px) {
	#infoBlock .infoBox .infoDay {
		float: none;
		width: 100%;
		line-height: 100%;
		padding-bottom: 5px
	}
}
#infoBlock .infoBox p {
    font-size: 90%;
    line-height: 140%;
	font-weight: 500;
}
#infoBlock .infoBox p a {
	color: #222;
	/*線の基点とするためrelativeを指定*/
	position: relative;
	/*リンクの形状*/
	padding: 0 0 15px;
	text-decoration: none;
	outline: none;
	display: block;
	transition: .3s;
}
#infoBlock .infoBox p a:hover {
	color: #32a301;
	transition: .3s;
}
/*線の設定*/
#infoBlock .infoBox p a::before, #infoBlock .infoBox p a::after {
	content: '';
	/*絶対配置で線の位置を決める*/
	position: absolute;
	z-index: 1;
	bottom: 0;
	left: 0;
	/*線の形状*/
	background: #ddd;
	width: 100%;
	height: 1px;
	/*アニメーションの指定*/
	transition: all 0.3s ease-in-out;
}
/*hover時に伸びる線の形状*/
#infoBlock .infoBox p a::after {
	width: 0;
	background: #32a301;
}
/*hover時に100%に伸びる*/
#infoBlock .infoBox p a:hover::after {
	width: 100%;
}
/* #infoArea　centerBtnMore */
.infoArea .forPc {
	display: flex!important;
}
.infoArea .btnMobire {
	display: none!important;
}
@media screen and (max-width: 639px) {
	.infoArea .forPc {
		display: none!important;
	}
	.infoArea .btnMobire {
		display: flex!important;
	}
	.centerBtnMore {
		margin-top: 10px;
	}
}
/* projectArea
================================================== */
#projectArea {
	position: relative;
	background-color: #f2f8f8;
	padding-bottom: 60px;
}
#projectBlcok {
	max-width: 1200px;
	margin: 0 auto;
	position: relative;
	z-index: 1;
	padding: 60px 5% 0;
}
#projectBlcok h2 {
	font-size: 150%;
	letter-spacing: 0.12em;
	text-align: center;
	padding: 10px 0;
	background-color: #32a301;
	color: #fff;
	-webkit-border-radius: 2px;
	-moz-border-radius: 2px;
	border-radius: 2px;
}
@media screen and (max-width: 639px) {
	#projectBlcok {
		padding: 40px 5% 0;
	}
	#projectBlcok h2 {
		font-size: 120%;
	}
}

/* projectList
================================================== */
#projectList {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 5%;
}
#projectListArea {
	padding: 3.5% 0 0;
	border-bottom: solid 1px #ddd;
	margin-bottom: 20px;
}
@media screen and (max-width: 800px) {
	#projectListArea {
		padding: 6% 0 0;
		margin-bottom: 25px;
	}
}
@media screen and (max-width: 639px) {
	#projectListArea {
		padding: 10% 0 0;
	}
}
/* projectBox */
.projectBox {
	display: inline-block;
	vertical-align: top;
	margin: 0 2.5% 3.5%;
	width: 28%;
}
@media screen and (max-width: 800px) {
	.projectBox {
		margin: 0 3.5% 6%;
		width: 42%;
	}
}
@media screen and (max-width: 639px) {
	.projectBox {
		display: inherit;
		margin: 0 1.5% 10%;
		width: 100%;
	}
}
/* projectBox linkBox */
.projectBox .linkBox {
    position: relative;
    z-index: 1;
}
.projectBox .linkBox a {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    text-indent:-999px;
    z-index: 11;
}
.projectBox .zoomBox {
	display: block;
	transition-duration: 0.3s;	/*変化に掛かる時間*/
}
.projectBox .zoomBox:hover {
	transform: scale(1.1);	/*画像の拡大率*/
	transition-duration: 0.3s;	/*変化に掛かる時間*/
}
.projectBox h3 {
	font-size: 100%;
}
@media screen and (max-width: 639px) {
	.projectBox h3 {
		margin: 2% 0;
		font-size: 90%;
	}
}
/* projectPhoto */
@media screen and (max-width: 639px) {
	.projectPhoto {
		float: left;
		width: 35%;
		padding-right: 5%;
	}
}
.projectPhoto img{
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
    border-radius: 3px;
}
/* projectTxt */
@media screen and (max-width: 639px) {
	.projectTxt {
		float: right;
		width: 60%;
		padding-top: 15px;
	}
}
.projectTxt .projectDay{
	font-size: 60%;
	font-weight: 500;
	line-height: 100%;
    padding-top: 15px;
}
@media screen and (max-width: 639px) {
	.projectTxt .projectDay{
		padding: 0;
	}
}
.projectTxt h3{
	font-weight: 500;
	margin: 0;
    padding-top: 5px;
	line-height: 130%;
}
/* movieArea
================================================== */
#movieArea {
	padding: 0 5%;
}
.movieBox {
	width: 70%;
	max-width: 700px;
    margin: 0 auto;
}
@media screen and (max-width: 639px) {
	.movieBox {
		width: 100%;
	}
}
.movie {
	position: relative;
	padding-bottom: 56.25%; /*アスペクト比 16:9の場合の縦幅*/
	height: 0;
	overflow: hidden;
    box-shadow: 0 0 0 0 #fff, 0.3em 0.3em 1em rgba(0, 0, 0, .2);
}
.movie iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}























