@charset "utf-8";
@import url(cmn.css);
@import url(base.css);
@import url(lineanime.css);
:root {
	--page_color: #F92660;
}
#lv{
	background-image: url("../images/worklifeandhealth/lv.webp");
	background-position: 50% 30%;
}
#lv::before{
	background: linear-gradient(to bottom, rgba(0,0,0,0.25) 0%, rgba(0,0,0,0.1) 100%);
}
#lv h1{
	padding-left: 1.8em;
}
#lv h1::after{
	content: "04";
}
#lv .subttl{
	padding-left: 5.5em;
}
@media screen and (max-width: 768px){
	#lv .subttl {
	  padding-left: 4.0em;
	}
}
@media screen and (max-width: 480px){
	#lv h1{
		padding-left: 1.5em;
	}
	#lv .subttl{
	  padding-left: 2.5em;
	}
}
/*---------------------------------------------*/
@media screen and (min-width: 1401px){
	main .section:last-child::before{
		width: 70%;
	}
}
/*-----------------lead----------------------------*/
#lead .wrapper_full{
	position: relative;
}
#lead .slider{
	width: 55%;
	margin-right: 0;
	margin-left: auto;
	max-width: 1420px;
	display: flex;
	gap: 0 20px;
}
#lead figure{
	border-radius: 10px;
	overflow: hidden;
}
#lead figure:nth-child(2){
	margin-top: 80px;
}
#lead figure.ZoomOut:nth-child(2) img {
	transition: all 2.5s ease-out;
}

#lead h2{
	color: var(--i_txt_color);
	background: none;
	padding: 0 20px;
	width: 100%;
	font-size: 3.5rem;
	letter-spacing: 0.3rem;
	line-height: 1.5;
	position: absolute;
	left: 50%;
	top: 50%;
	max-width: 1280px;
	transform: translateX(-50%) translateY(-50%);
	z-index: 3;
}


#lead .wrapper{
	gap: 40px 5%;
	margin-top: 100px;
}
#lead .wrapper figure{
	width: 50%;
	height: 420px;
	border-radius: 10px;
	overflow: hidden;
}
#lead .wrapper figure img{
	object-fit: cover;
	height: 100%;
}


#lead .wrapper div{
	flex: 1;
}
#lead p.name{
	text-align: right;
}
#lead p.name span{
	font-size: 80%;
	margin-right: 1.5em;
}
#lead p.name span:last-child{
	margin-right: 0;
}
@media screen and (max-width: 1300px){
	#lead .slider{
		width: calc(100% - 480px);
	}
}
@media screen and (max-width: 900px){
	#lead .slider{
		width: 100%;
		gap: 0 10px;
		align-items: flex-start;
	}
	#lead .slider figure{
		max-height: 290px!important;
	}
	#lead .slider figure img{
		object-fit: cover;
		height: 100%;
		object-position: 50% 20%;
	}
	#lead figure:nth-child(1){
		margin-top: 80px;
		border-radius: 0 10px 10px 0;
	}
	#lead figure:nth-child(2){
		margin-top: 0px;
		border-radius: 10px 0px 0px 10px;
	}
	#lead .wrapper{
		display: block;
	}
	#lead .wrapper figure{
		width: 100%;
		max-width: 500px;
		height: auto;
		margin: 0 auto 40px;
		text-align: center;
	}
	#lead .wrapper div{
		max-width: none;
	}
	#lead .outlink{
		text-align: center;
	}
	#lead h2{
		margin-bottom: 30px;
		position: static;
		transform: none;
		font-size: 3.0rem;
	}
	#lead .wrapper{
		margin-top: 60px;
	}
}

@media screen and (max-width: 480px){
	#lead h2{
		font-size: 2.6rem;
	}
}
/*----------------aim-----------------------------*/
#aim .wrapper{
	display: grid;
	grid-template-columns: 55% 40%;
	justify-content: space-between;
	align-items: center;
}
#aim .wrapper h3{
	grid-row: 1;
	grid-column: 1;
}
#aim .wrapper figure{
	grid-row: 1 / 4;
	grid-column: 2;
	border-radius: 10px;
	overflow: hidden;
	text-align: center;
}
#aim .wrapper figure img{
	object-fit: cover;
	height: 100%;
}
#aim .wrapper div{
	grid-row: 2;
	grid-column: 1;
}

@media screen and (max-width: 900px){
	#aim .wrapper{
		display: block;
	}
	#aim .wrapper figure{
		width: 100%;
		height: auto;
		margin: 0 auto 40px;
	}
	#step .wrapper div{
		max-width: none;
	}
}

/*---------------attempt------------------------------*/

#attempt .inner{
	background: var(--i_sub2_color);
	padding: 30px;
	border-radius: 20px;
}
#attempt .inner + .inner{
	margin-top: 25px;
}
#attempt .inner figure{
	width: 30%;
	text-align: center;
	margin-right: 30px;
}
#attempt .inner div{
	flex: 1;
}
#attempt .inner ul li{
	list-style: disc;
	list-style-position: inside;
	letter-spacing: 0.2rem;
}
#attempt .inner ul li + li{
	margin-top: 5px;
}
@media screen and (max-width: 600px){
	#attempt .inner{
		padding: 25px 20px;
	}
	#attempt .inner figure{
		width: 100%;
		margin-right: 0;
		margin-bottom: 20px;
	}
	#attempt .inner figure img{
		width: 45%;
	}
}
/*------------------communication---------------------------*/
#communication .event{
	gap: 30px 5%;
	margin-top: 40px;
}
#communication .event .slider,
#communication .event .inner{
	width: 47.5%;
}

#communication .event .inner ul li{
	list-style: disc;
	list-style-position: inside;
	letter-spacing: 0.2rem;
}
#communication .event .inner ul li + li{
	margin-top: 5px;
}
#communication figure figcaption{
	color: var(--i_txt_color);
	text-align: center;
	font-size: var(--font-size-base);
}
#communication .slick-slide{
	border-radius: 0;
}
#communication .slick-slide img{
	border-radius: 10px;
}
@media screen and (max-width: 768px){
	#communication .event .slider,
	#communication .event .inner{
		width: 100%;
	}


/*-----------------health----------------------------*/
#health .flex{
	flex-direction: row-reverse;
	gap: 40px 5%;
}
#health figure{
	width: 47.5%;
	text-align: center;
}
#health .flex > div{
	width: 47.5%;
}
@media screen and (max-width: 900px){
	#health .flex{
		flex-direction: column;
	}
	#health figure{
		width: 80%;
		margin: 0 auto;
	}
	#health .flex > div{
		width: 100%;
	}
}
/*-----------------number----------------------------*/
#number ul{
	gap: 40px 4%;
	align-items: stretch;
}
#number ul li{
	width: 48%;
	background: #fff;
	border-radius: 20px;
	padding: 30px 40px;
}
#number ul li h4{
	padding-left: 0;
	border-left: none;
	margin-bottom: 0;
	font-weight: 600;
}
#number ul li.sp{
	display: none;
}
#number ul li.pc{
	width: 100%;
}
#number ul li.pc figure{
	display: flex;
	justify-content: space-around;
	align-items: center;
}
#number ul li.pc figure img{
	width: 50%;
}
@media screen and (max-width: 768px){
	#number ul li{
		padding: 20px;
	}
}
@media screen and (max-width: 480px){
	#number ul{
		gap: 20px 0;
	}
	#number ul li{
		width: 100%;
	}
	#number ul li.pc{
		display: none;
	}
	#number ul li.sp{
		display: block;
	}
}
/*------------------------------------------------------*/
/*------------------lineanime---------------------------*/
/*------------------------------------------------------*/
#lead{
	position: relative;
}
#lead .lineanime{
	width: 95%;
	max-width: 1700px;
	height: 50%;
	top: 0px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 2;
}

#lead .lineanime .left{
	width: 20%;
	height: 100%;
	position: relative;
}

#lead .lineanime .left .round.b{
	left: 100px;
	top: 25px;
}
#lead .lineanime .left .round.b .ani-round{
	animation-delay: 1.2s;
}
#lead .lineanime .left .round.m{
	left: 230px;
	top: 100px;
}
#lead .lineanime .left .round.m .ani-round{
	animation-delay: 1.5s;
}
#lead .lineanime .left .round.s:nth-of-type(3){
	top: 90px;
	left: 0;
}
#lead .lineanime .left .round.s:nth-of-type(3) .ani-round{
	animation-delay: 1.7s;
}
#lead .lineanime .left .round.m2{
	left: 150px;
	top: 190px;
}
#lead .lineanime .left .round.ms .ani-round{
	animation-delay: 1.9s;
}
#lead .lineanime .left .round.b:nth-of-type(5) > div{
	width: 30px;
	height: 30px;
}
#lead .lineanime .left .round.b:nth-of-type(5) > div.ani-round{
	animation-delay: 1.9s;
}
#lead .lineanime .left .round.b:nth-of-type(5){
	left: 30px;
	top: 190px;
}
#lead .lineanime .left .round.b:nth-of-type(5) > div.ani-round{
	animation-delay: 1.7s;
}

#lead .lineanime .left .round.ss{
	top: 270px;
	left: 77px;
}
@media screen and (max-width: 1200px){
	#lead .lineanime{
		top: -35px;
	}
}
@media screen and (max-width: 900px){
	#lead .lineanime .left{
		height: auto;
		margin-right: 5%;
		margin-left: auto;
	}
}
@media screen and (max-width: 768px){
	#lead .lineanime{
		top: -20px;
	}

}
/*-----------------------*/
#attempt{
	position: relative;
}
#attempt .lineanime {
  width: 95%;
  max-width: 1700px;
  height: 50%;
  top: -50px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
}
#attempt .lineanime .right{
	width: 20%;
	position: absolute;
	right: 0;
	top: 0;
}
#attempt .lineanime .right .line.blue{
	top: 0;
	right: 50px;
}
#attempt .lineanime .right .line.blue.short > div{
	height: 150px;
}
#attempt .lineanime .right .line.lightblue{
	top: 0;
	right: 135px;
}
#attempt .lineanime .right .round.m2{
	top: 155px;
	right: 135px;
}
/*----------*/
#communication{
	position: relative;
}
#communication .lineanime{
	height: 100%;
}
#communication .lineanime .right{
	height: 50%;
}
#communication .lineanime .left{
	width: 100%;
	height: 50%;
	position: relative;
}
#communication .lineanime .left .line.blue{
	top: 0;
	left: 30px;
}
#communication .lineanime .left .line.lightblue{
	top: 106px;
	left: 3px;
}
#communication .lineanime .left .round.m2:nth-of-type(3){
	left: 90px;
	top: 200px;
}
#communication .lineanime .left .round.m2:nth-of-type(3) > div.ani-round{
	animation-delay: 1.0s;
}
#communication .lineanime .left .round.b > div{
	width: 35px;
	height: 35px;
}
#communication .lineanime .left .round.b{
	right: 50px;
	bottom: -53px;
}
#communication .lineanime .left .round.m2:nth-of-type(4){
	right: 0;
	bottom: 0;
}
@media screen and (max-width: 900px){
	#communication .lineanime .left{
		display: none;
	}
	#communication .lineanime .right{
		top: 55px;
	}
}
/*---------------*/
#number{
	position: relative;
	z-index: 1;
}
#number .wrapper{
	position: relative;
	z-index: 3;
}
#number .lineanime {
  width: 95%;
  max-width: 1700px;
  height: 50%;
  top: -50px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
}
#number .lineanime .right{
	width: 20%;
	position: absolute;
	right: 0;
	top: 0;
}
#number .lineanime .right .line.blue{
	top: 0;
	right: 50px;
}
#number .lineanime .right .line.blue.short > div{
	height: 150px;
}
#number .lineanime .right .line.lightblue{
	top: 0;
	right: 135px;
}
#number .lineanime .right .round.s{
	top: 0;
	right: 37px;
}
#number .lineanime .right .round.s .ani-round{
	animation-delay: 0.65s;
}
#number .lineanime .right .round.ss{
	top: -21px;
	right: 18px;
}
#number .lineanime .right .round.ss .ani-round{
	animation-delay: 0.5s;
}
#number .lineanime .left{
	width: 100%;
	height: 55%;
	margin-top: 55%;
	position: relative;
}
#number .lineanime .left .line.blue{
	top: 0;
	left: 30px;
}
#number .lineanime .left .line.lightblue{
	top: 106px;
	left: 3px;
}
#number .lineanime .left .round.m2:nth-of-type(3){
	left: 90px;
	top: 200px;
}
#number .lineanime .left .round.m2:nth-of-type(3) > div.ani-round{
	animation-delay: 1.5s;
}
#number .lineanime .left .round.b > div{
	width: 35px;
	height: 35px;
}
#number .lineanime .left .round.b{
	right: 50px;
	bottom: -53px;
}
#number .lineanime .left .round.m2:nth-of-type(4){
	right: 0;
	bottom: 0;
}
@media screen and (max-width: 900px){
	#number .lineanime .left{
		display: none;
	}
	#number .lineanime .right{
		top: 55px;
	}
}
