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



/* common ----------*/
#graduate2025_top .more { width: 225px; overflow: hidden; padding: 17px 0 17px 40px; text-decoration: none; line-height: 1; }
#graduate2025_top .more span { position: relative; z-index: 2; display: block; color: #FFF; font-family: "Josefin Sans", sans-serif; text-align: left; }
#graduate2025_top .more::before { content: ""; position: absolute; z-index: 1; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(217, 3, 60, 0.8); transform: skew(30deg); transform-origin: right bottom; }
#graduate2025_top .more i { position: absolute; z-index: 2; top: 0; bottom: 0; right: 36px; width: 36px; height: 36px; margin: auto; border-radius: 100%; border: solid 1px #FFF; transition: all 0.3s ease-out; }
#graduate2025_top .more:hover i { /*right: 25px;*/ background-color: #04634F; }
#graduate2025_top .more i::before { content: ""; position: absolute; top: 0; bottom: 0; left: 10%; width: 80%; height: 0; margin: auto; border-top: solid 1px #FFF; transition: all 0.3s ease-out; }
#graduate2025_top .more:hover i::before { width: 115%; }
#graduate2025_top .more i::after { content: ""; position: absolute; bottom: 50%; right: 10%; width: 5px; height: 0; border-top: solid 1px #FFF; transition: all 0.3s ease-out; transform: rotate(45deg); transform-origin: right bottom; }
#graduate2025_top .more:hover i::after { right: -25%; }

@media screen and (max-width: 767px) {
	#graduate2025_top .more i { /*right: 25px;*/ background-color: #04634F; }
}

/* index ----------*/
.re-about__items { display: flex; justify-content: center; position: relative; z-index: 3; align-items: flex-start; }
.re-about__items a { display: block; position: relative; filter: drop-shadow(8px 8px 20px rgba(0, 0, 0, 0.25)); }
.re-about__items a .pw { position: relative; z-index: 1; }
.re-about__items a .pw img { position: relative; z-index: 1; transition: all 0.3s ease-out; }
.re-about__items a:hover .pw img { transform: scale(1.1,1.1); }
.re-about__items a .pw::before { content: ""; position: absolute; z-index: 2; top: 0; left: 0; width: 100%; height: 100%; background: rgba(5, 21, 16, 0.33); transition: all 0.3s ease-out; }
.re-about__items a:hover .pw::before { opacity: 0; }  
.re-about__items a:nth-child(1) .pw { clip-path: polygon(0% 34%, 33.2% 0%, 96.8% 0%, 90.1% 44.4%, 100% 68%, 64.4% 100%, 17.8% 100%, 0% 34%); }
.re-about__items a:nth-child(2) .pw { clip-path: polygon(0% 50%, 26.9% 7.4%, 64.5% 0%, 100% 29.6%, 94.3% 44.4%, 94.3% 69.4%, 66.7% 100%, 18.8% 86.6%, 0% 50%); }
.re-about__items a:nth-child(3) .pw { clip-path: polygon(83.8% 12.6%, 50% 0%, 42.5% 12.6%, 14.6% 26.9%, 0% 53.3%, 8.1% 66.7%, 24.7% 93.4%, 26.7% 93.4%, 46.1% 97.8%, 54.6% 100%, 100% 68.7%, 83.8% 12.6%); }
.re-about__items a .tw { position: absolute; z-index: 2; top: 50%; left: 50%; display: inline-block; margin: auto; text-align: center; transform: translate(-50%, -50%); }
.re-about__items a .tw .s { display: block; margin-bottom: 2cqw; margin-left: -3cqw; color: #FFF; font-size: 0.9cqw; font-weight: bold; font-family: "Josefin Sans", sans-serif; text-align: left; }
.re-about__items a .tw h3 { margin-bottom: 2cqw; color: #FFF; font-size: 1.45cqw; font-weight: bold; text-align: center; white-space: nowrap; }
.re-about__items a .tw i { position: relative; z-index: 2; display: inline-block; width: 36px; height: 36px; margin: auto; border-radius: 100%; border: solid 1px #FFF; transition: all 0.3s ease-out; }
.re-about__items a:hover .tw i { background-color: #D9033C; /*right: 25px;*/ }
.re-about__items a .tw i::before { content: ""; position: absolute; top: 0; bottom: 0; left: 10%; width: 80%; height: 0; margin: auto; border-top: solid 1px #FFF; transition: all 0.3s ease-out; }
.re-about__items a:hover .tw i::before { width: 115%; }
.re-about__items a .tw i::after { content: ""; position: absolute; bottom: 50%; right: 10%; width: 5px; height: 0; border-top: solid 1px #FFF; transition: all 0.3s ease-out; transform: rotate(45deg); transform-origin: right bottom; }
.re-about__items a:hover .tw i::after { right: -25%; }

.re-about__items a.ptn_message {
	top: -70px;
}
.re-about__items a.ptn_recruit {
	top: -30px;
}
.re-about__items a.ptn_sustainability {
	top: -130px;
}

@media screen and (max-width: 767px) {
	.re-about__items a .pw img { transform: scale(1.1,1.1); }
	.re-about__items a .tw i { background-color: #D9033C; /*right: 25px;*/ }
	.re-about__items a .tw i::before { width: 115%; }
	.re-about__items a .tw i::after { right: -25%; }

	.re-about__items {
		display: block;
		padding: 0 20px;
		margin-top: 40px;
	}
	.re-about__items a {
		margin: 20px auto;
		position: relative;
		top: auto !important;
	}
	.re-about__items a.ptn_message {
		left: -24px;
	}
	.re-about__items a.ptn_recruit {
		right: -36px;
	}
	.re-about__items a.ptn_sustainability {
		left: -40px;
	}
	.re-about__items a .tw .s{
		margin: 10cqw auto 5cqw;
		margin-left: -4cqw;
		font-size: 4cqw;
	}
	.re-about__items a .tw h3{
		margin-bottom: 7cqw;
		font-size: 6cqw;
	}
}


.re-solution__items { max-width: 942px; position: relative; z-index: 3; margin: 0 auto 60px;  }
.re-solution__items::after { content: ""; display: block; clear: both; }
.re-solution__items .list_segment { max-width: 806px; display: grid; margin-top: 60px; grid-template-columns: repeat(2, 1fr); column-gap: 0px; row-gap: 50px; }
.re-solution__items .list_segment.-l {}
.re-solution__items .list_segment.-r { float: right;}
.re-solution__items .list_segment li {}
.re-solution__items .list_segment li a { display: block; filter: drop-shadow(8px 8px 20px rgba(0, 0, 0, 0.25)); }
.re-solution__items .list_segment li h3 { position: relative; width: 90%; margin-bottom: -25px !important; margin-left: 10px; }
.re-solution__items .list_segment li h3 span { position: relative; z-index: 2; display: inline-block; padding: 8px 20px; color: #FFF; font-size: 19px; font-weight: bold; line-height: 1.6; }
.re-solution__items .list_segment li h3::after { content: ""; position: absolute; position: absolute; z-index: 1; top: 0; left: 0; display: block; width: 100%; height: 100%; border: solid 1px #DCDEE7; opacity: 0.9; background-color: #B30A18; transition: all 0.3s ease-out; transform: skew(-12.2deg); }
.re-solution__items .list_segment li .pw { position: relative; }
.re-solution__items .list_segment li .pw::before { content: ""; position: absolute; z-index: 2; top: 0 ; left: 0; display: block; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.3); transition: all 0.3s ease-out; }
.re-solution__items .list_segment li a:hover .pw::before { opacity: 0; }
.re-solution__items .list_segment li .pw img { position: relative; z-index: 1; transition: all 0.3s ease-out; }
.re-solution__items .list_segment li a:hover .pw img { transform: scale(1.1,1.1); }
.re-solution__items .list_segment li .pw i { position: absolute; left: 0; right: 0; margin: auto; bottom: 20px; z-index: 2; display: inline-block; width: 36px; height: 36px; margin: auto; border-radius: 100%; border: solid 1px #FFF; transition: all 0.3s ease-out; }
.re-solution__items .list_segment li a:hover .pw i { background-color: #014637; }
.re-solution__items .list_segment li a .pw i::before { content: ""; position: absolute; top: 0; bottom: 0; left: 10%; width: 80%; height: 0; margin: auto; border-top: solid 1px #FFF; transition: all 0.3s ease-out; }
.re-solution__items .list_segment li a:hover .pw i::before { width: 115%; }
.re-solution__items .list_segment li a .pw i::after { content: ""; position: absolute; bottom: 50%; right: 10%; width: 5px; height: 0; border-top: solid 1px #FFF; transition: all 0.3s ease-out; transform: rotate(45deg); transform-origin: right bottom; }
.re-solution__items .list_segment li a:hover .pw i::after { right: -25%; }
.re-solution__items .list_segment li .tw { margin-top: 15px; padding-right: 50px; }
.re-solution__items .list_segment li .tw h4 { margin-bottom: 10px; padding-bottom: 5px; border-bottom: solid 1px #A0A4BA; font-size: 15px; font-weight: bold; }
.re-solution__items .list_segment li .tw p {}
.re-solution__items .list_segment li .tw .btw { margin-top: 10px; }
@media screen and (max-width: 767px) {
	.re-solution__items .list_segment li a .pw i { background-color: #014637; }
	.re-solution__items { margin: 0 auto 0; padding: 0 20px;  }
	.re-solution__items .list_segment { display: block; margin-top: 0; }
	.re-solution__items .list_segment li { margin-bottom: 20px; }
}

.more_photo_bt_wrap{
	position: relative;
	z-index: 5;
}
.project .btn01{
	z-index: 5;
	position: relative;
	margin: 40px auto 20px;
}

.more_photo_bt_wrap .h01 {
	transition: all 0.3s ease-out;
	position: absolute;
	width: 40%;
	z-index: 5;
	top: -10px;
	right: -10px;
}
.more_photo_bt_wrap .h02 {
	transition: all 0.3s ease-out;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 5;
	font-size: clamp(18px, 1.5vw, 21px);
	font-weight: 600;
	color: #fff;
	line-height: 1.5;
	letter-spacing: 1.6px;
	text-align: center;
	width: 100%;
}

.more_photo_bt_wrap:hover .h01,.more_photo_bt_wrap:hover .h02 { opacity: .5; }


.more_photo_bt_btw { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 30px; }
.more_photo_bt_btw .more_photo_bt { overflow: hidden; width: 100%; display: block; position: relative; }
.more_photo_bt_btw .more_photo_bt::before { content: ""; position: absolute; z-index: 3; width: 100%; height: 100%; display: block; top: 0; left: 0; background-color: rgba(1, 13, 74, 0.3); transition: all 0.3s ease-out; }
.more_photo_bt_wrap:hover .more_photo_bt:before { opacity: 0; }
.more_photo_bt_btw .more_photo_bt .pw { width: 100%; }
.more_photo_bt_btw .more_photo_bt .pw img { transition: all 0.3s ease-out; }
.more_photo_bt_wrap:hover .pw img { transform: scale(1.1,1.1); }
.more_photo_bt_btw .more_photo_bt i { position: absolute; z-index: 6; bottom: 25px; right: 25px; width: 28px; height: 28px; border-radius: 100%; border: solid 1px #FFF; transition: all 0.3s ease-out; }
.more_photo_bt_wrap:hover i { right: 25px; background-color: #D9033C; }
.more_photo_bt_btw .more_photo_bt i::before { content: ""; position: absolute; top: 0; bottom: 0; left: 10%; width: 80%; height: 0; margin: auto; border-top: solid 1px #FFF; transition: all 0.3s ease-out; }
.more_photo_bt_wrap:hover i::before { width: 115%; }
.more_photo_bt_btw .more_photo_bt i::after { content: ""; position: absolute; bottom: 50%; right: 10%; width: 5px; height: 0; border-top: solid 1px #FFF; transition: all 0.3s ease-out; transform: rotate(45deg); transform-origin: right bottom; }
.more_photo_bt_wrap:hover i::after { right: -25%; }

.job .re-solution__items{
	margin-bottom: 0;
}

.job .re-solution__items .list_segment{
	margin-top: 0;
	margin-left: auto;
	margin-right: auto;
}

.ec .more_photo_bt_btw01{
	grid-template-columns: 1fr 1fr 1fr 1fr;
	max-width: 96%;
	margin: 0 auto;
}
.ec .more_photo_bt_btw01 .h01{
	width: 50%;
}

.more_photo_bt_btw02{ position: relative; z-index: 5; width: 96%; max-width: 1052px;margin: 0 auto; }
.more_photo_bt_btw02 .more_photo_bt_btw { display: flex; justify-content: center; gap: 30px; margin-top: 60px; }
.more_photo_bt_btw02 .more_photo_bt_btw .more_photo_bt { overflow: hidden; width: 100%; max-width: 560px; display: block; position: relative; }
.more_photo_bt_btw02 .more_photo_bt_btw .more_photo_bt::before { content: ""; position: absolute; z-index: 3; width: 100%; height: 100%; display: block; top: 0; left: 0; background-color: rgba(184, 221, 213, 0.4); transition: all 0.3s ease-out; }
.more_photo_bt_btw02 .more_photo_bt_btw .more_photo_bt:hover:before { opacity: 0; }
.more_photo_bt_btw02 .more_photo_bt_btw .more_photo_bt .h {     position: absolute; max-width: 240px; z-index: 5;
    bottom: -20px; left: 0; right: 0; margin: auto; }
.more_photo_bt_btw02 .more_photo_bt_btw .more_photo_bt .pw { width: 100%; }
.more_photo_bt_btw02 .more_photo_bt_btw .more_photo_bt .pw img { transition: all 0.3s ease-out; }
.more_photo_bt_btw02 .more_photo_bt_btw .more_photo_bt:hover .pw img { transform: scale(1.1,1.1); }
.more_photo_bt_btw02 .more_photo_bt_btw .more_photo_bt.-wphoto .pw { position: relative; z-index: 1; width: 55.357%; }
.more_photo_bt_btw02 .more_photo_bt_btw .more_photo_bt.-wphoto .pw2 { position: absolute; z-index: 2; top: 0; right: 0; clip-path: polygon(19% 0%, 100% 0%, 100% 100%, 0% 100%); }
.more_photo_bt_btw02 .more_photo_bt_btw .more_photo_bt i { position: absolute; z-index: 6; bottom: 25px; right: 25px; width: 28px; height: 28px; border-radius: 100%; border: solid 1px #FFF; transition: all 0.3s ease-out; }
.more_photo_bt_btw02 .more_photo_bt_btw .more_photo_bt:hover i { right: 25px; background-color: #E73485; }
.more_photo_bt_btw02 .more_photo_bt_btw .more_photo_bt i::before { content: ""; position: absolute; top: 0; bottom: 0; left: 10%; width: 80%; height: 0; margin: auto; border-top: solid 1px #FFF; transition: all 0.3s ease-out; }
.more_photo_bt_btw02 .more_photo_bt_btw .more_photo_bt:hover i::before { width: 115%; }
.more_photo_bt_btw02 .more_photo_bt_btw .more_photo_bt i::after { content: ""; position: absolute; bottom: 50%; right: 10%; width: 5px; height: 0; border-top: solid 1px #FFF; transition: all 0.3s ease-out; transform: rotate(45deg); transform-origin: right bottom; }
.more_photo_bt_btw02 .more_photo_bt_btw .more_photo_bt:hover i::after { right: -25%; }

@media screen and (max-width: 767px) {
	.more_photo_bt_btw02 .more_photo_bt_btw .more_photo_bt i { background-color: #E73485; }
	.more_photo_bt_wrap{ margin-bottom: 30px !important; display: block !important;}
	.more_photo_bt_btw,.more_photo_bt { display: block !important; margin-bottom: 30px !important; margin-top: 30px !important;max-width: 100% !important; }
}

.more_photo_bt_btw03{
	grid-template-columns: 1fr 1fr;
	gap: 90px;
}

.more_photo_bt_btw03 .more_photo_bt::before,.more_photo_bt_btw04 .more_photo_bt::before{
	display: none !important;
}

.more_photo_bt_btw03 .btn01,.more_photo_bt_btw04 .btn01{
	position: absolute;
	right: -40px;
	bottom: 0;
}

.more_photo_bt_btw03 .h01,.more_photo_bt_btw04 .h01{
	left: -10px;
}

.more_photo_bt_btw04{
	gap: 35px;
	margin-top: 60px;
}

.btn01,.more_photo_bt_btw04 .btn01{
	position: absolute;
	right: 0;
	bottom: -24px;
}

.more_photo_bt_btw04 .h01.t01 {
	width: 50.82%; /* 185 / 364 × 100 */
}
.more_photo_bt_btw04 .h01.t02 {
	width: 44.51%; /* 162 / 364 × 100 */
}
.more_photo_bt_btw04 .h01.t03 {
	width: 40.93%; /* 149 / 364 × 100 */
}

.more_photo_bt_btw04 .more::before { background-color: rgba(35, 215, 178, 0.8) !important; }
.more_photo_bt_btw03 .more_photo_bt_wrap:hover .more i,.more_photo_bt_btw04 .more_photo_bt_wrap:hover .more i { background-color: #02372C !important; }
.more_photo_bt_btw03 .more_photo_bt_wrap:hover .more i::before,.more_photo_bt_btw04 .more_photo_bt_wrap:hover .more i::before { width: 115% !important; }
.more_photo_bt_btw03 .more_photo_bt_wrap:hover .more i::after,.more_photo_bt_btw04 .more_photo_bt_wrap:hover .more i::after { right: -25% !important; }


@media screen and (max-width: 767px) {
	.more_photo_bt_btw03,.more_photo_bt_btw04{
		width: calc(100% - 40px);
		margin: 0 auto;
	}
	.more_photo_bt_btw03 .btn01,.more_photo_bt_btw04 .btn01{
		right: -10px;
		bottom: -24px;
	}
	.more_photo_bt_btw03 .more_photo_bt_wrap,.more_photo_bt_btw04 .more_photo_bt_wrap{
		margin-bottom: 60px !important;
	}
	
}

@media screen and (min-width: 768px) {
	.more_photo_bt_btw_one{
		grid-column: 1 / -1;
		justify-self: center;
	}
}