@charset "utf-8";
/* CSS Document */
.section{
	position: relative;
	margin-bottom: 100px;
}
.section::after{
	content: "";
	position: absolute;
	top: 140px;
	left: 0;
	width: 50%;
	height: 480px;
	background-color: #f3e6d6;
}
.section .contents-wrap{
	position: relative;
	z-index: 2;
}
.contents-title{
	font-size: 150px;
	font-weight: 700;
	padding-left: 50px;
	margin-bottom: 100px;
}
.contents{
	padding: 0 100px;
}
/* ---------- section1 ---------- */
.main-img{width:100%;overflow:hidden;}
.swiper-container{
	height: 80vh;
	min-height: 800px;
}
.swiper-container{
	margin-left: 0px;
}
.swiper-container .box{
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	padding: 0 100px;
}
.swiper-container .box1{
	background-image: url("https://8gen-kouta.com/system_panel/uploads/images/main2.jpg");
}
.swiper-container .box2{
	background-image: url("https://8gen-kouta.com/system_panel/uploads/images/main1.jpg");
}
.swiper-container .box3{
	background-image: url("https://8gen-kouta.com/system_panel/uploads/images/main3.jpg");
}
.swiper-container .box4 {
	background-image: url("https://8gen-kouta.com/system_panel/uploads/images/20250829102503654512.jpg");
}
.swiper-container .box5 {
	background-image: url("https://8gen-kouta.com/system_panel/uploads/images/20250829102514943936.JPG");
}
.swiper-container .box::after{
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.3);
	z-index: 1;
}
.swiper-container .box .box-item{
	position: relative;
	width: 50%;
	z-index: 2;
	order: 1;
}
.swiper-container .box .box-item .box-title{
	font-size: 60px;
}
.swiper-container .box .box-item .box-link a{
	background-color: #638e9c;
	display: inline-block;
	padding: 10px 50px;
}
.swiper-container .box .sowhat{
	position: relative;
	width: 50%;
	z-index: 2;
	text-align: center;
	order: 2;
}
.swiper-container .box .sowhat img{
	width: 50%;
}
.swiper-container .swiper-pagination{
	text-align: left;
	padding: 20px 50px;
	z-index: 4;
}
.swiper-container .swiper-pagination .swiper-pagination-bullet{
	width: 12px;
	height: 12px;
	margin: 0 12px;
	background-color: rgba(255,255,255,1);
	border: 1px solid #ffffff;
	opacity: 1;
	position: relative;
}
.swiper-pagination-bullet-active{
	background-color: rgba(255,255,255,0)!important;
}
.swiper-pagination-bullet-active::after{
	content: "";
	width: 20px;
	height: 20px;
	border: 1px solid #ffffff;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	border-radius: 50%;
}
.swiper-button-next, .swiper-button-prev{
	position: relative;
	width: 60px;
	height: 60px;
	background-color: rgba(255,255,255,1);
	transition: ease 0.3s;
	margin-top: 0;
	cursor: pointer;
}
.swiper-button-next{
	margin-left: 30px;
}
.swiper-button-wrap{
	position: absolute;
	bottom: 20px;
	right: 20px;
	z-index: 5;
}
.swiper-button-next:hover, .swiper-button-prev:hover{background-color: rgba(255,255,255,0.50);}
.swiper-button-next img, .swiper-button-prev img{
	font-size: 40px;
}


/* ---------- section1 ---------- */
.section01 .webgene-blog{
	display:-webkit-box;
    display:-moz-box;
    display:-ms-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:-ms-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap;
    justify-content: space-between;
    align-items: flex-start;
	flex-direction: row;
}
.section01 .webgene-blog .webgene-item{
	width: calc(33.33333% - 20px);
}
.section01 .webgene-blog .webgene-item a{
	position: relative;
}
.section01 .webgene-blog .webgene-item a .cate{
	position: absolute;
	top: 20px;
	right: 10px;
	z-index: 3;
	white-space: nowrap;
}
.section01 .webgene-blog .webgene-item a .cate_02 {
	position: absolute;
	top: 0;
	left: 10px;
	z-index: 3;
	white-space: wrap;
	line-height: 1.4;
}
.section01 .webgene-blog .webgene-item a .img-box{
	z-index: 1;
}
.section01 .webgene-blog .webgene-item a .box-item{
	z-index: 2;
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background-color: rgba(0,0,0,0.5);
	transition: ease 0.3s;
	opacity: 0;
}
.section01 .webgene-blog .webgene-item a:hover .box-item{
	opacity: 1;
}

/* ---------- section2 ---------- */
.section02 .webgene-blog{
	display:-webkit-box;
    display:-moz-box;
    display:-ms-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:-ms-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap;
    justify-content: space-between;
    align-items: flex-start;
	flex-direction: row;
}
.section02 .webgene-blog .webgene-item{
	width: calc(33.33333% - 33px);
}
.section02 .webgene-blog .webgene-item a{
	display: block;
}
.section02 .webgene-blog .webgene-item a p{color: #8c8c8c;}
/* ---------- section3 ---------- */
.section03 .contents .contents-box h3{text-shadow: 10px 10px 0 rgba(0,0,0,0.1);}
.section03 .img-box1{
	position: relative;
}
.section03 .img-box1::after{
	content: "";
	position: absolute;
	top: 50px;
	right: -50px;
	width: calc(100% - 100px);
	height: 100%;
	z-index: -1;
	background-image: url("https://8gen-kouta.com/system_panel/uploads/images/top-about1.jpg");
	background-repeat: no-repeat;
	background-size: 100% 100%;
	opacity: 0.2;
}
.section03 .img-box2 img{
	width: calc(50% - 25px);
}
.section03 .img-box2 img:nth-of-type(2){
	transform: translateY(50px);
}
/* ---------- IEのみ ---------- */
@media all and (-ms-high-contrast: none) {
}
/* ---------- 1280px ~ ---------- */
@media screen and (max-width: 1280px){
	.section::after{
		top: 110px;
	}
	.contents-title{
		font-size: 120px;
		padding-left: 50px;
		margin-bottom: 100px;
	}
	
	.swiper-container .box{
		padding: 0 50px;
	}
	.swiper-container .box .box-item .box-title{
		font-size: 40px;
	}
	.swiper-container .box .sowhat img{
		width: 60%;
	}
}
/* ---------- 1000px ~ ---------- */
@media screen and (max-width: 1000px){
}
/* ---------- 768px ~ ---------- */
@media screen and (max-width: 768px){
	.section::after{
		top: 90px;
		height: 380px;
	}
	.contents{
		padding: 0 50px;
	}
	.contents-title{
		font-size: 90px;
		padding-left: 50px;
		margin-bottom: 50px;
	}
	.swiper-container{
	}
	.swiper-container .box{
		display: block;
	}
	.swiper-container .box .box-item{
		width: 100%;
	}
	.swiper-container .box .sowhat{
		width: 100%;
		padding-top: 80px;
		margin-bottom: 80px;
	}
	.swiper-container .box .sowhat img{
		width: 40%;
	}
	
	.section03 .contents-box{
		order: 2;
	}
	.section03 .img-box1{
		order: 1;
		margin-bottom: 80px;
	}
	.section03 .img-box1::after{
		top: 30px;
		right: -30px;
		width: 100%;
	}

	.section01 .webgene-blog .webgene-item a .cate_02 {
		line-height: 1.2;
		font-size: 90%;
		top: 4px;
		letter-spacing: -0.05em;
	}
}
/* ---------- 576px ~ ---------- */
@media screen and (max-width: 576px){
	.section{
		margin-bottom: 80px;
	}
	.section::after{
		top: 50px;
		height: 280px;
	}
	.contents{
		padding: 0 30px;
	}
	.contents-title{
		font-size: 50px;
		padding-left: 10px;
		margin-bottom: 30px;
	}
	.swiper-container{
		height: calc(90vh - 60px);
		min-height: 600px;
	}
	.swiper-container .box{
		display: block;
		padding: 0 30px;
	}
	.swiper-container .box .box-item{
		width: 100%;
	}
	.swiper-container .box .box-item .box-title{
		font-size: 30px;
	}
	.swiper-container .box .sowhat{
		width: 100%;
		padding-top: 50px;
		margin-bottom: 50px;
	}
	.swiper-container .box .sowhat img{
		width: 50%;
	}
	.swiper-container .swiper-pagination{
		text-align: left;
		padding: 20px 20px;
		z-index: 4;
	}
	.swiper-container .swiper-pagination .swiper-pagination-bullet{
		width: 10px;
		height: 10px;
		margin: 0 10px;
	}
	.swiper-pagination-bullet-active::after{
		width: 16px;
		height: 16px;
	}
	.swiper-button-next, .swiper-button-prev{
		width: 40px;
		height: 40px;
	}
	.swiper-button-next{
		margin-left: 20px;
	}
	.swiper-button-wrap{
		position: absolute;
		bottom: 30px;
		right: 20px;
		z-index: 5;
	}
	.swiper-button-next:hover, .swiper-button-prev:hover{background-color: rgba(255,255,255,0.50);}
	.swiper-button-next img, .swiper-button-prev img{
		font-size: 30px;
	}
/* ---------- section1 ---------- */
	.section01 .webgene-blog .webgene-item{
		width: calc(50% - 15px);
		margin: 0 auto;
	}
	.section01 .webgene-blog .webgene-item:nth-of-type(2){
		margin-left: 30px;
	}
	.section01 .webgene-blog .webgene-item:nth-of-type(3){
		margin-top: 30px;
	}
	.section01 .webgene-blog .webgene-item .box .box-item p{
		font-size: 14px;
	}
	/*
	.section01 .webgene-blog .webgene-item .box{
		width: 60%;
		margin: -30px;
		margin-left: 20%;
		transform: rotate(-90deg);
	}
	.section01 .webgene-blog .webgene-item .box .box-item p{
		transform: translate(-50%,-50%) rotate(90deg);
	}
	*/

/* ---------- section2 ---------- */
	.section02 .webgene-blog{
		display: block;
	}
	.section02 .webgene-blog .webgene-item{
		width: 80%;
		margin: 0 auto;
	}
	.section02 .webgene-blog .webgene-item:not(:last-of-type){
		margin-bottom: 50px;
	}
	.section02 .webgene-blog .webgene-item a{
		display: block;
	}
	.section02 .webgene-blog .webgene-item a p{color: #8c8c8c;}
/* ---------- section3 ---------- */
	.section03 .img-box2 img{
		width: 70%;
	}
	.section03 .img-box2 img:nth-of-type(2){
		margin-left: 30%;
		transform: translateY(30px);
	}
}
/* ---------- 350px ~ ---------- */
@media screen and (max-width: 350px){
}

