@charset "utf-8";
/*
Theme Name:テンプレート__01
Version: 1.1
Author:エイジェック広報部
Author URI:https://www.agekke.co.jp/

/*============================
トップページ
============================*/
/* ----- メインビジュアル -----*/
.bl_top_txt svg {
	max-width: 100%;
}
.bl_top_txt span.hp_ttl {
	color:#ffffff00;
}
.bl_top_mv_img {
	width: 100%;
}
.bl_top_mv_img.mo,
.bl_top_mv_img.pad {
	display: none;
}
svg .svg-elem-1 {
	stroke-dashoffset: 354.05352783203125px;
	stroke-dasharray: 354.05352783203125px;
	fill: transparent;
	-webkit-transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 0.6s;
	transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 0.6s;
}

svg.active .svg-elem-1 {
	stroke-dashoffset: 0;
	fill: rgb(0, 0, 0);
}

svg .svg-elem-2 {
	stroke-dashoffset: 242.30059814453125px;
	stroke-dasharray: 242.30059814453125px;
	fill: transparent;
	-webkit-transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.08s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 0.7s;
	transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.08s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 0.7s;
}

svg.active .svg-elem-2 {
	stroke-dashoffset: 0;
	fill: rgb(0, 0, 0);
}

svg .svg-elem-3 {
	stroke-dashoffset: 337.49591064453125px;
	stroke-dasharray: 337.49591064453125px;
	fill: transparent;
	-webkit-transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.16s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 0.8s;
	transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.16s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 0.8s;
}

svg.active .svg-elem-3 {
	stroke-dashoffset: 0;
	fill: rgb(0, 0, 0);
}

svg .svg-elem-4 {
	stroke-dashoffset: 301.01336669921875px;
	stroke-dasharray: 301.01336669921875px;
	fill: transparent;
	-webkit-transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.24s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 0.9s;
	transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.24s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 0.9s;
}

svg.active .svg-elem-4 {
	stroke-dashoffset: 0;
	fill: rgb(0, 0, 0);
}

svg .svg-elem-5 {
	stroke-dashoffset: 236.73068237304688px;
	stroke-dasharray: 236.73068237304688px;
	fill: transparent;
	-webkit-transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.32s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 1s;
	transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.32s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 1s;
}

svg.active .svg-elem-5 {
	stroke-dashoffset: 0;
	fill: rgb(0, 0, 0);
}

svg .svg-elem-6 {
	stroke-dashoffset: 300.01544189453125px;
	stroke-dasharray: 300.01544189453125px;
	fill: transparent;
	-webkit-transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.4s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 1.1s;
	transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.4s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 1.1s;
}

svg.active .svg-elem-6 {
	stroke-dashoffset: 0;
	fill: rgb(0, 0, 0);
}

svg .svg-elem-7 {
	stroke-dashoffset: 244.60325622558594px;
	stroke-dasharray: 244.60325622558594px;
	fill: transparent;
	-webkit-transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.48s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 1.2000000000000002s;
	transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.48s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 1.2000000000000002s;
}

svg.active .svg-elem-7 {
	stroke-dashoffset: 0;
	fill: rgb(0, 164, 151);
}

svg .svg-elem-8 {
	stroke-dashoffset: 296.5000305175781px;
	stroke-dasharray: 296.5000305175781px;
	fill: transparent;
	-webkit-transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.56s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 1.3s;
	transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.56s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 1.3s;
}

svg.active .svg-elem-8 {
	stroke-dashoffset: 0;
	fill: rgb(0, 164, 151);
}

svg .svg-elem-9 {
	stroke-dashoffset: 333.2870788574219px;
	stroke-dasharray: 333.2870788574219px;
	fill: transparent;
	-webkit-transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.64s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 1.4s;
	transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.64s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 1.4s;
}

svg.active .svg-elem-9 {
	stroke-dashoffset: 0;
	fill: rgb(0, 164, 151);
}

svg .svg-elem-10 {
	stroke-dashoffset: 312.8204345703125px;
	stroke-dasharray: 312.8204345703125px;
	fill: transparent;
	-webkit-transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.72s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 1.5s;
	transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.72s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 1.5s;
}

svg.active .svg-elem-10 {
	stroke-dashoffset: 0;
	fill: rgb(0, 0, 0);
}

svg .svg-elem-11 {
	stroke-dashoffset: 396.8132019042969px;
	stroke-dasharray: 396.8132019042969px;
	fill: transparent;
	-webkit-transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.8s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 1.6s;
	transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.8s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 1.6s;
}

svg.active .svg-elem-11 {
	stroke-dashoffset: 0;
	fill: rgb(0, 0, 0);
}

svg .svg-elem-12 {
	stroke-dashoffset: 300.0059509277344px;
	stroke-dasharray: 300.0059509277344px;
	fill: transparent;
	-webkit-transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.88s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 1.7000000000000002s;
	transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.88s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 1.7000000000000002s;
}

svg.active .svg-elem-12 {
	stroke-dashoffset: 0;
	fill: rgb(0, 0, 0);
}

svg .svg-elem-13 {
	stroke-dashoffset: 222.48806762695312px;
	stroke-dasharray: 222.48806762695312px;
	fill: transparent;
	-webkit-transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.96s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 1.8000000000000003s;
	transition: stroke-dashoffset 0.8s cubic-bezier(0.47, 0, 0.745, 0.715) 0.96s,
	fill 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 1.8000000000000003s;
}

svg.active .svg-elem-13 {
	stroke-dashoffset: 0;
	fill: rgb(0, 0, 0);
}

.bl_top_mv {
	position: relative;
	z-index: 0;
}

.bl_top_cc {
	position: absolute;
	top: 50%;
	left: 0;
	width: 100%;
	transform: translateY(-50%);
}

.bl_top_txt {
    max-width: 800px;
}

.bl_top_cc h2 {
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.9;
	margin: -10px 30px 0 10px;
}

.bl_top_cc h2 span {
	display: block;
}

.bl_top_cc_box {
	overflow: hidden;
	display: flex;
	align-items: center;
}

.bl_top_cc_item.hp_left {
	width: 58%;
	padding: 0 120px 0 5%;
}

.bl_top_cc_item.hp_right {
	width: 42%;
	padding: 60px 0 0 0;
}

.sphere_01{
	position: absolute;
	top: 11%;
	left: 10%;
	max-width:200px;
}

.sphere_02{
	position: absolute;
	top: 30%;
	left: 25%;
	max-width:300px;
}

.sphere_03{
	position: absolute;
	bottom: 12%;
	right: 10%;
	max-width:360px;
}

.sphere_04{
	position: absolute;
	bottom: -120px;
	left: 3%;
	max-width:320px;
	opacity: .6;
}

.bl_top_slider {
	display:none;
}

/* ページ読み込み時に、一瞬縦並びになるのを防止 */
/* slick-initializedが付与されたら表示 */
.bl_top_slider.slick-initialized {
  display: block;
}

.slick-track {
  display: flex;
}

.bl_top_slider .slick-slide {
    background: #fff;
    border-radius: 20px;
    margin: 0 20px;
}

.bl_top_cc_recruiting {
	margin: 0 0 20px 10px;
	font-weight: bold;
	font-size: 1.5rem;
	letter-spacing: .08em;
}

.bl_top_cc_recruiting .hp_en {
	color: #00a497;
	padding: 0 3px 0 1px;
	font-size: 1.375rem;
}

.bl_top_slider_item img {
	border-radius: 20px 20px 0 0;
}

.bl_top_slider_inner {
	padding: 24px 15px;
}

.bl_top_slider_ttl {
	font-weight: 600;
	font-size: .9375rem;
	margin: 0 0 15px;
}

.bl_top_slider_corp {
	font-size: .875rem;
}

.bl_top_slider .slick-dots li {
	width: 60px !important;
    height: 3px !important;
    display: inline-block;
    margin: 0 !important;
  }

.bl_top_slider .slick-dots li button {
    padding: 0 !important;
    color: transparent !important;
    outline: none !important;
    width: 60px !important;
    border: unset !important;
    height: 3px !important;
    display: block !important;
    background: #e2e2e2 !important;
    cursor: pointer !important;
  }

.bl_top_slider .slick-dots li.slick-active button {
   background: #ee7800 !important;
 }

.bl_top_slider .slick-dots li button:before {
	content: none !important;
}

.bl_top_slider .slide-dots {
	position: relative;
	z-index: 3;
	bottom: -40px !important;
	text-align: center !important;
}
.bl_top_slider figure {
	border-radius: 20px 20px 0 0;	
}
@media screen and (max-width: 1600px){
	.bl_top_cc_recruiting{
		font-size: 1.0625rem;
	}
	.bl_top_cc_item.hp_left {
    	padding: 0 80px 0 5%;
	}
    .bl_top_cc h2,
	.bl_top_cc_recruiting {
        font-size: 1rem;
    }
	.bl_top_cc h2 {
		font-size: 1.125rem;
	}
}
@media screen and (max-width: 1200px){
	.bl_top_cc h2,
	.bl_top_cc_recruiting {
        font-size: .785rem;
    }
}
@media screen and (max-width: 1023px){	
    .bl_top_txt {
        max-width: 600px;
    }	
	.bl_top_cc h2 {
    	font-size: 1rem;
	}
	.bl_top_mv_img.pc {
		display: none;
	}
	.bl_top_mv_img.pad {
		display: block;
	}
	.bl_top_cc_box {
    	display: block;
	}
	.bl_top_cc_item.hp_left {
		width: 100%;
        padding: 0 30px;
    }
	.bl_top_cc_item.hp_right {
    	width: 50%;
    	padding: 0;
		margin: 0 0 0 auto;
	}
	.bl_top_cc h2, .bl_top_cc_recruiting {
        font-size: 1rem;
    }
	.bl_top_cc {
    	margin: 30px 0 0;
	}
	.bl_top_cc h2 {
    	font-size: 1.125rem;
    	line-height: 1.7;
    	margin: -10px 0 0 5px;
	}
}

@media screen and (max-width: 767px){
	.bl_top_mv {
    	margin: 60px 0 0;
	}
	.bl_top_txt {
    	margin: 0;
	}
	.bl_top_mv_img.pad {
		display: none;
	}
	.bl_top_mv_img.mo {
		display: block;
	}
	.bl_top_cc_item.hp_left {
        padding: 0 15px;
    }
	.bl_top_slider_box {
		margin: 0;
	}
	.bl_top_cc_item.hp_right {
        padding: 20px 15px 40px;
    }
	.bl_top_slider .slick-dots li,
	.bl_top_slider .slick-dots li button {
    	width: 30px !important;
	}
    .bl_top_cc h2 {
        font-size: .9375rem;
        line-height: 1.8;
    }
	.bl_top_slider_inner {
    	padding: 16px 15px;
	}
	.bl_top_cc {
        margin: 0;
    }
	.bl_top_cc_item.hp_right {
        width: 70%;
		padding: 0;
        margin: 20px 0 0 auto;
    }
	.sphere_04 {
		display: none;
	}
	.sphere_03 {
    	bottom: 0;
    	right: 30%;
    	max-width: 150px;
	}
	.sphere_02 {
    	top: 30%;
    	left: 60%;
    	max-width: 170px;
	}
}
/* ----- バナー -----*/
.bl_banner {
	padding: 0 0 100px;
	margin: -100px 0 0;
    position: relative;
}
.bl_banner_img {
	max-width: 960px;
	margin: 0 auto;
}

.bl_banner_img img:hover {
	box-shadow: 0px 0px 20px #0000001a;
}
@media screen and (max-width: 1600px) {
	.bl_banner {
    	margin: -70px 0 0;
	    padding: 0 0 60px;
	}
}
@media screen and (max-width: 1400px) {
	.bl_banner_img {
    	max-width: 720px;
	}
}
@media screen and (max-width: 1023px) {
	.bl_banner {
    	padding: 0;
    	margin: -50px 0 0;
	}
}
/* ----- エイジェックPHRコネクトとは -----*/
.bl_about {
	position: relative;
	z-index: 0;
	/*padding: 20px 0 0;*/
    background: url(images/bg2.png) no-repeat;
    background-position: top left;
	-webkit-background-size: cover;
    background-size: cover;
}

/*.bl_about_cont {
	display: grid;
	grid-template-columns: 44% 1fr;
	gap: 60px;
	align-items: center;
}*/

.bl_about_cont .bl_about_item:nth-of-type(1) {
	max-width: 810px;
	margin: -100px auto 120px;
}

.bl_about_cont .bl_about_item:nth-of-type(2) {
	max-width: 750px;
	margin: 0 auto;
}

.bl_about_cont h2 {
	font-weight: 800;
	font-size: 2.5rem;
	margin: 0 0 24px;
	color: #00a497;
}

.bl_about_graphic {
	display: grid;
	grid-template-columns: 30% 40% 30%;
}

.bl_about_graphic_center {
	position: relative;
	margin: -50px auto 0;
    padding: 15px;
	z-index:-1;
}

.bl_about_graphic_anim {
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
	transform: scale(1.1);
}

.bl_about_graphic_anim img {
	animation: 50s linear infinite rotation;	
}
.bl_about_graphic_desc {
	text-align: center;
	font-size: .75rem;
}

.bl_about_graphic_logo a {
	display: block;
	padding: 5px 0;
}
.bl_about_txt {
    margin: 0 0 20px;
    line-height: 1.9;
    font-size: 1.125rem;
    font-weight: 500;
}
.bl_about_note {
	font-size: .875rem;
	line-height: 1.8;
}
@keyframes rotation{
  0%{ transform:rotate(0);}
  100%{ transform:rotate(360deg); }
}

.bl_about_graphic_box {
	position: relative;
	margin: 100px 0 0;
	box-shadow: 1px 1px 5px #00000033;
	padding: 20px;
	border-radius: 20px;
}

.bl_about_graphic_center .bl_about_graphic_box {
	margin: 80px 15px 0;
	text-align: center;
	padding: 20px 20px 10px;
}

.bl_about_graphic_center .bl_about_graphic_box h3 {
	position: absolute;
	top: -10px;
	left: 50%;
	transform: translateX(-50%);
	background: #09a28f;
	line-height: 1;
	padding: 4px 5px 5px 5px;
	color: #fff;
	border-radius: 10px;
	width: 90%;
    font-size: .875rem;
}

.bl_about_graphic_box:before {
	content:'';
	width: 9px;
	height: 9px;
	border-radius: 50%;
	position: absolute;
	top: -80px;
	left: 50%;
	transform: translateX(-50%);
	background: #ed1c24;
	z-index:0;
}

.bl_about_graphic_box:after {
	content:'';
	width: 1px;
	height: 80px;
	position: absolute;
	top: -80px;
	left: 50%;
	transform: translateX(-50%);
	background: #e5e5e5;
	z-index: -1;
}

.bl_about_graphic_center .bl_about_graphic_box:before,
.bl_about_graphic_center .bl_about_graphic_box:after {
	top: -40px;
}

.bl_about_graphic_center .bl_about_graphic_box:after {
	height: 40px;	
}

.bl_about_graphic_logo img:not(:last-of-type) {
	display: block;
	margin: 0 0 15px;
}
@media screen and (max-width: 1200px) {
	.bl_about_cont h2 {
    	font-size: 2rem;
	}
}

@media screen and (max-width: 1023px) {
	.bl_about {
    	/*padding: 50px 0 0;*/
	}
	.bl_about_cont {
    	display: block;
	}
	.bl_about_graphic {
    	margin: 110px 30px 0;
	}
}

@media screen and (max-width: 767px) {
	.bl_about {
		padding: 50px 0 20px;
		padding: 0 0 20px;
	}
	.bl_about_cont h2 {
    	font-size: 1.375rem;
    	margin: 0 0 12px;
	}
	.bl_about_txt {
    	margin: 0 0 14px;
    	line-height: 1.8;
    	font-size: 1rem;
	}
	.bl_about_graphic {
        margin: 90px 0 0;
    }
	.bl_about_graphic_center .bl_about_graphic_box {
    	margin: 80px 0 0;
	}
	.bl_about_graphic_box h3 {
		font-size: .875rem;
	}
	.bl_about_graphic_box {
		padding: 10px;
		margin: 30px 0 0;
	}
	.bl_about_graphic_desc span.hp_none {
		display: none;
	}
	.bl_about_graphic_box:before {
		top: -40px;
	}
	.bl_about_graphic_box:after {
    	height: 40px;
    	top: -40px;
	}
	.bl_about_graphic_center .bl_about_graphic_box {
    	padding: 36px 10px 10px;
	}
	.bl_about_cont .bl_about_item:nth-of-type(1) {
    	margin: 0 auto 50px;
	    margin: -100px auto 50px;
	}
}
/* ----- サービス -----*/
.bl_service {
	position: relative;
	background: #f7f7f7;
	z-index: 1;
}
.bl_service_bg {
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
}

.bl_service_cont {
	display: grid;
	 grid-template-columns: repeat(2, 1fr);
	gap: 30px;
}

.bl_service_item {
	padding: 30px;
	background: #fff;
	border: 1px solid #fff;
	border-radius: 25px;
	box-shadow: 0px 0px 12px #00000008;
}

.bl_service_img img {
	border-radius: 20px;
    height: 180px;
    object-fit: cover;
    width: 100%;
}

.bl_service_ttl {
	font-size: 1.375rem;
	font-weight: 600;
	margin: 0 0 10px;
}

.bl_service_num {
	font-family: "Outfit", sans-serif;
	font-weight: 200;
	font-size: 1rem;
	margin: 20px 0 0;
}

.bl_service_detail {
	margin: 20px 0 0;
}

.bl_service_detail li {
	border-bottom: 1px solid #333;
	font-size: .9375rem;
}

.bl_service_detail li a {
	display: block;
	position: relative;
	padding: 14px 0;
}

.bl_service_detail li a:before {
	content: '→';
	font-size: .9375rem;
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	color: #333;
}

.bl_service_detail li a:hover,
.bl_service_detail li a:hover:before{
	color: #00a497;
}

.bl_service_detail_ctgr {
	display: inline-block;
	background: #00a497;
	color: #fff;
	border-radius: 20px;
	line-height: 1;
    padding: 7px 15px 7px 16px;
    font-size: .875rem;
}

.bl_service_deco1 {
	position: absolute;
	top:30%;
	left:0;
	z-index: -1;
	max-width: 420px;
	animation: rotateAnimation 5s linear infinite;
}

.bl_service_deco2 {
	position: absolute;
	top:1%;
	right: 50px;
	z-index: -1;
	max-width: 390px;
}

.bl_service_deco3 {
	position: absolute;
	bottom: -120px;
	right: 100px;
	z-index: -1;
	max-width: 440px;
	animation: rotateAnimation 5s linear infinite;
}

@keyframes rotateAnimation {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}


@media screen and (max-width: 1023px) {
	.bl_service_cont {
    	display: block;
	}
	
	.bl_service_cont .bl_service_item:not(:last-of-type){
    	margin: 0 0 30px;
	}
	.bl_initiative_cont {
    	gap: 20px;
	}
}

@media screen and (max-width: 767px) {
	.bl_service {
		overflow: hidden;
	}
	.bl_service_detail li a {
    	font-size: .75rem;
	}
	.bl_service_img img {
    	height: 150px;
	}
	.bl_service_item {
    	padding: 15px;
	}
	.bl_service_cont .bl_service_item:not(:last-of-type) {
        margin: 0 0 15px;
    }
}

/* ----- 取り組み紹介 -----*/
.bl_initiative {
	background: #00a497;
	position: relative;
	z-index: 0;
}

.bl_initiative_cont {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 40px;
}

.bl_initiative_item {
	border-radius: 20px;
	position: relative;
}

.bl_initiative_item:after {
	content: '';
    display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: -1;
    background: #fff;
	border-radius: 20px;
	transition: .3s;
}

.bl_initiative_num {
	font-family: "Outfit", sans-serif;
    font-weight: 200;
	color: #00a497;
	margin: 0 0 12px;
	transition: .3s;
}

.bl_initiative_item h3 {
	font-weight: 600;
	margin: 0 0 15px;
	font-size: 1.125rem;
	transition: .3s;
}

.bl_initiative_desc {
	font-size: .9375rem;
	line-height: 1.8;
	transition: .3s;
	letter-spacing: .1em;
}

.bl_initiative_cont .bl_initiative_item:nth-of-type(1) {
	background: url(images/ph01.webp) no-repeat;
    background-position: top left;
    -webkit-background-size: cover;
    background-size: cover;	
	z-index: 0;
}

.bl_initiative_cont .bl_initiative_item:nth-of-type(2) {
	background: url(images/ph02.webp) no-repeat;
    background-position: top left;
    -webkit-background-size: cover;
    background-size: cover;	
	z-index: 0;
}

.bl_initiative_cont .bl_initiative_item:nth-of-type(3) {
	background: url(images/force-plate.webp) no-repeat;
    background-position: top left;
    -webkit-background-size: cover;
    background-size: cover;	
	z-index: 0;
}

.bl_initiative_item a {
	position: relative;
	z-index: 3;
	display: block;
	padding: 30px 30px 40px;
}

.bl_initiative_item:hover:after {
	background: #000000ab;
}


.bl_initiative_item:hover .bl_initiative_num,
.bl_initiative_item:hover h3,
.bl_initiative_item:hover .bl_initiative_desc {
	color: #fff;
}

.bl_initiative_item a:after {
	content: '';
	width: 30px;
	height: 30px;
	background: #00a497;
	border-radius: 50%;
	position: absolute;
	bottom: 10px;
	right: 10px;
}

.bl_initiative_item:hover a:after {
	background: #fff;	
}

.bl_initiative_item a:before {
	content: '→';
	font-size: 14px;
	color: #fff;
	position: absolute;
	bottom: 14px;
    right: 17px;
    z-index: 2;
}

.bl_initiative_item:hover a:before {
	color: #00a497;	
}

.bl_initiative_box {
	padding: 0 0 50px;
}
@media screen and (max-width: 1023px) {
	.bl_initiative_cont {
    	gap: 20px;
	}
}
@media screen and (max-width: 767px) {
	.bl_initiative_cont {
    	display: block;
	}
	.bl_initiative_item a {
    	padding: 30px 20px;
	}
	.bl_initiative_cont .bl_initiative_item:not(:last-of-type) {
		margin: 0 0 15px;
	}
	.bl_initiative_item a:after {
    	width: 20px;
    	height: 20px;
	}
	.bl_initiative_item a:before {
    	font-size: 12px;
    	bottom: 12px;
    	right: 13px;
	}
	.bl_initiative_item h3 {
    	margin: 0 0 10px;
    	font-size: 1.125rem;
	}
	.bl_initiative_num {
    	margin: 0 0 8px;
	}
	.bl_initiative_desc {
    	line-height: 1.6;
	}
}

/* ----- パートナ募集 -----*/
.bl_partner {
	position: relative;
	padding: 150px 0 0;
}

.bl_partner_cont {
	margin-right :  calc( calc(100% - 1200px) /2 );
	display: grid;
	grid-template-columns: 45% 1fr;
	gap: 60px;
}

.bl_partner_img {
	animation: fade-up3 ease forwards;
	animation-timeline: view();
	animation-range: cover 0% cover 100%;	
	margin: 150px 0 0;
    z-index: 3;
}

.bl_partner_img img {
	border-radius: 0 20px 20px 0;
}

.bl_partner_desc {
	margin-right: 100px;
	font-size: 1.0625rem;
	line-height: 1.8;
}

.bl_partner_desc span {
	display: block;
	margin: 16px 0 0;
}

.bl_partner_link {
	margin: 50px 100px 0 0;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 20px;
}

.bl_partner_rightImg1 {
	width: calc(calc( calc(100% - 1200px) /2 ) + 40px);
	position: absolute;
	top: 200px;
	right: 0;
	animation: fade-up1 ease forwards;
   animation-timeline: view();
   animation-range: cover 0% cover 100%;
    z-index: 3;
}

.bl_partner_rightImg2 {
	width: 180px;
	position: absolute;
	bottom: 0;
	right: 100px;
	animation: fade-up2 ease forwards;
   animation-timeline: view();
   animation-range: cover 0% cover 100%;
    z-index: 3;
}

 @keyframes fade-up1{
   0%{transform: translateY(0);}
 100%{transform: translateY(-200px);}
 }

 @keyframes fade-up2{
   0%{transform: translateY(0);}
 100%{transform: translateY(-240px);}
 }

 @keyframes fade-up3{
   0%{transform: translateY(0);}
 100%{transform: translateY(-300px);}
 }

.bl_partner_rightImg1 img {
	border-radius: 20px 0 0 20px;	
}

.bl_partner_rightImg2 img {
	border-radius: 20px;	
}

@media screen and (max-width: 1500px) {
	.bl_partner {
   		padding: 120px 0 0;
	}
	.bl_partner_rightImg2 {
		display: none;
	}	
	.bl_partner_rightImg1 {
    	width: calc(calc(calc(100% - 1200px) / 2) + 150px);
	}	
	.bl_partner_cont {
    	grid-template-columns: 39% 1fr;
		gap: 40px;
		margin-right: 0;
	}	
	.bl_partner_link {
    	margin: 50px 160px 0 0;
	}
	
	.bl_partner_desc {
		margin-right: 120px;
		font-size: 1rem;
	}
}
@media screen and (max-width: 1279px) {
	.bl_partner_rightImg1 {
		display: none;
	}
	.bl_partner_cont {
        grid-template-columns: 33% 1fr;
		margin: 0 0 50px;
    }
    .bl_partner_link {
        margin: 50px 66px 0 0;
    }
}
@media screen and (max-width: 1023px) {
	.bl_partner_cont {
        grid-template-columns: 30% 1fr;
		margin: 0;
		gap: 30px;
    }
    .bl_partner_desc {
        margin-right: 0;
        padding: 0 30px 0 0;
    }
	.bl_partner {
        padding: 80px 0;
    }
	.bl_partner_img {
		animation: none;
		margin: 0;
	}
	.bl_partner_link {
        margin: 40px 30px 0 0;
    }
}

@media screen and (max-width: 767px) {
	.bl_partner_cont {
		display: block;
	}
	.bl_partner_img {
		width: 70%;
		margin: 0 0 30px;
	}
	.bl_partner {
        padding: 40px 0;
    }
	.bl_partner_link {
        margin: 30px 0 0;
		display: block;
    }
	.bl_partner_desc {
		padding: 0;
	}
	.bl_partner_link .el_more:first-of-type {
		margin: 0 0 15px;
	}
	.bl_partner_txt {
		padding: 0 15px;
	}
}


/* ----- お問い合わせ -----*/
.bl_contact {
	max-width: 90%;
	margin: -60px auto 0;
	border-radius: 30px;
	background: #00a497;
	position: relative;
	z-index:1;
	padding: 50px 0;
}

.bl_contact .el_lv2Heading {
	margin: 0 0 40px;
}

.bl_contact_txt {
	color: #fff;
	margin: 0 0 30px;
	line-height: 1.8;
	font-weight: bold;
}

.bl_contact_cont {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 100px;
	align-items: center;
	padding: 30px;
}

.bl_contact_btn a {
    position: relative;
    display: block;
    padding: 30px 10px;
    font-weight: bold;
    text-align: center;
    transition: .2s;
    color: #00a497;	
    background: #fff;
    border: 1px solid #fff;
	font-size: 1.125rem;
	letter-spacing: .1em;
	border-radius: 50px;
}

.bl_contact_btn a:hover {
	background: transparent;
	color: #fff;
}

.bl_contact_desc {
	color: #fff;
	line-height: 1.8;
	font-size: 1.0625rem;
	font-weight: 500;
}

.bl_contact_item .bl_contact_btn:nth-of-type(2) {
	margin: 30px 0 0;
}
@media screen and (max-width: 1500px) {
.bl_contact {
    margin: 0 auto;
	}
}
@media screen and (max-width: 1023px) {
	.bl_contact_cont {
    	display: block;
		padding: 0;
	}
	.bl_contact_cont .bl_contact_item:nth-child(2) {
		margin: 40px 0 0;
	}
	.bl_contact {
    	padding: 42px 10px 50px;
	}
}
@media screen and (max-width: 767px) {
	.bl_contact {
        padding: 30px 5px 50px;
    }
	.bl_contact .el_lv2Heading {
    	margin: 0 0 30px;
	}
	.bl_contact_desc {
    	line-height: 1.7;
    	font-size: 1rem;
	}
	.bl_contact_btn a {
		font-size: 1rem;
    	padding: 20px 10px;
	}
	.bl_contact_item .bl_contact_btn:nth-of-type(2) {
    	margin: 15px 0 0;
	}
}