@charset "utf-8";

section{
	text-align: center;
}
section h3{
	margin-bottom: 1.25em;
	font-size: clamp(1.75rem, 1.636rem + 0.485vw, 2rem);
	line-height: 1.2;
	letter-spacing: 0.1em;
}
section h3 span{
	display: block;
	font-size: clamp(1rem, 0.858rem + 0.606vw, 1.313rem);
}
@media screen and (max-width: 428px){
	section h3{
		margin-bottom: 0.5em;
	}
}

/* ---------------------------------------------------------
	トップ：slider
--------------------------------------------------------- */
article#main{
	position: relative;
	padding: 0;
}
#main .swiper{
	width: 100%;
	height: auto;
	padding: 50px 0 120px;
}
.swiper .swiper-inner{
	max-width: 820px;
	width: 100%;
	margin: 0 auto;
	overflow: visible;
}
/*
.swiper-cube .swiper-cube-shadow:before{
	background: rgba(0,0,0,0.6);
	filter: blur(80px);
}
*/
section#main_copy{
	max-width: 1200px;
	width: 100%;
	margin: 0 auto;
}
section#main_copy #catch_copy{
	position: absolute;
	bottom: -12vw;
	left: 85vw;
	z-index: 1;
	transform: translate(-50%, -50%);
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	text-orientation: upright;
	text-align: left;
}
section#main_copy #catch_copy h2{
	height: calc(clamp(2.125rem, 1.557rem + 2.424vw, 3.375rem) * 7);
	font-size: clamp(2.125rem, 1.557rem + 2.424vw, 3.375rem);
}
section#main_copy #catch_copy h2 span{
	position: relative;
	display: inline-block;
	background: rgba(255,255,255,0.75);
}
section#main_copy #catch_copy h2 span::after{
	display: block;
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 1px;
	height: 100%;
	background: #333333;
}
section#main_copy #lead_copy{
	position: absolute;
	left: 0;
	height: calc(clamp(1.375rem, 1.063rem + 1.333vw, 2.063rem) * 19);
	font-size: clamp(1.375rem, 1.063rem + 1.333vw, 2.063rem);
	top: 50px;
	left: 15vw;
	z-index: 1;
	transform: translate(-50%, 0);
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	text-orientation: upright;
	text-align: left;
}
section#main_copy #lead_copy span.text-combine{
	-webkit-text-combine: horizontal;
	-ms-text-combine-horizontal: all;
	text-combine-upright: all;
}
section#main_copy #lead_copy span:not(.text-combine){
	display: inline-block;
	background: rgba(255,255,255,0.75);
}

@media screen and (max-width: 1180px){
	section#main_copy #catch_copy{
		bottom: -18vw;
	}
	section#main_copy #lead_copy{
		left: 10vw;
		top: 48%;
		transform: translate(-50%, -50%);
	}
}
@media screen and (max-width: 1024px){
	section#main_copy #lead_copy{
		left: 10vw;
		top: 48%;
		transform: translate(-50%, -50%);
	}
}
@media screen and (max-width: 428px){
	#main .swiper{
		padding: 0px 0 50px;
	}
	.swiper-3d{
		perspective: initial;
	}
	.swiper-pagination{
		bottom: 60px !important;
	}
	section#main_copy{
		display: flex;
		flex-direction: row-reverse;
		justify-content: center;
		margin-bottom: 5em;
	}
	section#main_copy #catch_copy,
	section#main_copy #lead_copy{
		position: relative;
		top: initial;
		bottom: initial;
		right: initial;
		left: initial;
		transform: initial;
		height: fit-content;
	}
	section#main_copy #catch_copy{
		margin-left: 1em;
	}
}

/* ---------------------------------------------------------
	トップ：news
--------------------------------------------------------- */
section#news{
	max-width: 850px;
	margin: 0 auto 8.25em !important;
}
#news ul#news_list{
	text-align: left;
	background: rgba(255,255,255,0.75);
}
ul#news_list li{
	justify-content: space-between;
	padding: 1.25em 1em;
	border-bottom: 1px dotted #707070;
}
ul#news_list li:first-of-type{
	border-top: 1px dotted #707070;
}
ul#news_list li .news_lead{
	width: 27%;
}
.news_lead time{
	display: inline-block;
	width: 30%;
	margin-right: 15%;
	font-size: clamp(0.75rem, 0.722rem + 0.121vw, 0.813rem);
}
.news_lead span{
	display: inline-block;
	width: 50%;
	padding: 0.2em 0;
	font-size: clamp(0.75rem, 0.693rem + 0.242vw, 0.875rem);
	color: #FFF;
	text-align: center;
}
.news_lead span.cat_a{
	background: #1C4733;
}
.news_lead span.cat_b{
	background: #81B20A;
}
.news_lead span.cat_c{
	background: #4399C7;
}
ul#news_list li a{
	display: block;
	width: 72%;
	font-size: clamp(0.875rem, 0.818rem + 0.242vw, 1rem);
}
#news p#news_link{
	margin-top: 1.75em;
	text-align: right;
}
p#news_link a{
	position: relative;
	display: inline-block;
	padding: 0.5em 2em 0.5em 0.75em;
	font-size: clamp(0.875rem, 0.818rem + 0.242vw, 1rem);
	color: #FFF;
	background: #81B20A;
}
p#news_link a:hover{
	background: var(--hover_color);
}
p#news_link a::before,
p#news_link a::after{
	content: '';
	position: absolute;
}
p#news_link a::before{
	right: 10px;
	width: 15px;
	height: 1px;
	background: #FFF;
	top: 50%;
	transform: translateY(-50%);
}
p#news_link a::after{
	right: 10px;
	width: 8px;
	height: 8px;
	border-top: 1px solid #FFF;
	border-right: 1px solid #FFF;
	top: 50%;
	transform: translateY(-50%) rotate(45deg);
}
@media screen and (max-width: 820px){
	ul#news_list li a{
		width: 68%;
	}
}
@media screen and (max-width: 428px){
	ul#news_list li{
		padding: 1em 0;
	}
	ul#news_list li .news_lead{
		width: 100%;
	}
	.news_lead time{
		width: auto;
		margin-right: 20px;
	}
	.news_lead span{
		width: auto;
		margin-right: 0;
		padding: 0.2em 2em;
	}
	ul#news_list li > a{
		display: block;
		width: 100%;
		margin: 0.5em 0 0 0;
	}
	#news p#news_link{
		margin-top: 1.5em;
		margin-right: -4%;
	}
}

/* ---------------------------------------------------------
	トップ：service
--------------------------------------------------------- */
section#service{
	width: 100%;
	margin-top: 0 !important;
}
#service #service_list{
	max-width: 1130px;
	margin: 0 auto;
	justify-content: space-between;
	gap: 45px 12%;
}
#service_list a{
	display: block;
	width: 44%;
}
#service_list a dl figure.servics_img{
	border-radius: 2em;
	overflow: hidden;
	transition: .3s all linear;
}
#service_list a:hover dl figure.servics_img img{
	transform: translateY(-0px) scale(1.05);
}
#service_list a dl dt{
	margin-top: 0.5em;
	font-size: clamp(1.25rem, 1.08rem + 0.727vw, 1.625rem);
}
#service_list a dl dd{
	margin-top: 0.25em;
	font-size: clamp(0.875rem, 0.761rem + 0.485vw, 1.125rem);
}
@media screen and (max-width: 428px){
	#service #service_list{
		gap: 40px 0;
	}
	#service_list a{
		width: 100%;
	}
}

/* ---------------------------------------------------------
	トップ：company
--------------------------------------------------------- */
section#company{
	width: 100vw !important;
	margin: 0 calc(50% - 50vw);
	padding-top: 3.25em;
	padding-bottom: 5.5em;
	background: #F7F7EF;
}
section#company ul#company_list{
	margin: 0 auto;
	padding: 0 4%;
	max-width: 1200px;
	justify-content: space-between;
	gap: 0 8.75%;
}
ul#company_list li{
	position: relative;
	width: 27.5%;
}
ul#company_list li a figure.company_img{
	display: block;
	border-radius: 1.25em;
	overflow: hidden;
}
ul#company_list li a:hover figure.company_img img{
	transform: translateY(-0px) scale(1.08);
}
ul#company_list li a span.company_cap{
	position: absolute;
	display: block;
	width: 80%;
	left: 50%;
	bottom: -1em;
	transform: translateX(-50%);
	padding: 5px 50px;
	white-space: nowrap;
	font-size: clamp(1rem, 0.943rem + 0.242vw, 1.125rem);
	color: #000;
	background: #D9D9D9;
	border-radius: 100rem;
	transition: .3s all linear;
}
ul#company_list li a:hover span.company_cap{
	color: #FFF;
	background: var(--hover_color);
}
@media screen and (max-width: 428px){
	ul#company_list li{
		margin: 0 4%;
		width: 100%;
		margin-top: 0;
	}
	section#company ul#company_list{
		gap: 70px 0;
	}
}