@charset "utf-8";

.mainImg {
	height: 1000px;
	align-items: flex-end;
	padding: 50px 20px 64px;
	box-sizing: border-box;
	background-image: url(../images/index/main_img.jpg);
}
.mainImg .content {
	max-width: 1450px;
	padding: 0 0 21px;
	border-bottom: 2px solid #fff;
}
.mainImg h2 {
	margin-bottom: 138px;
	font-weight: 500;
	font-size: 79.91px;
	line-height: 1.75;
}
.mainImg h2 span {
	font-weight: 500;
	margin-top: 40px;
	font-size: 34.75px;
	letter-spacing: 0.05em;
	display: block;
}
.mainImg p {
	font-size: 40.58px;
	font-weight: 500;
	letter-spacing: 0.07em;
}
.mainImg p span {
	display: block;
	margin-top: 42px;
}
#main .news .content {
	max-width: 1415px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#main .news {
	position: relative;
	padding: 84px 0;
}
#main .news:after {
	width: 190px;  
	height: 270px;
	background-image: -webkit-linear-gradient( 90deg, rgb(32,226,215) 0%, rgb(141,240,190) 49%, rgb(249,254,165) 100%);
	border-radius: 50px;
	opacity: 0.4;
	position: absolute;  
	bottom: 26px;
	left: -50px;  
	content: ""; 
}
#main .news .lBox {
	width: 260px;
	margin-right: 40px;
}
#main .news .rBox {
	flex: 1;
	padding-top: 6px;
}
#main .news .linkP {
	text-align: right;
	margin-right: 12px;
}
#main .news .linkP a {
	letter-spacing: 0.05em;
	font-weight: 700;
	color: #368c9b;
}
#main .news .linkP a:hover {
	opacity: 0.7;
}
#main .concept {
	padding: 91px 0 149px;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
}
#main .concept .photoBox {
	margin-right: 138px;
	width: calc(50% - 139px);
}
#main .concept .photoBox img {
	width: 100%;
}
#main .concept .textBox {
	padding: 22px 20px 0 0;
	flex: 1;
}
#main .concept .textBox .sub {
	max-width: 550px;
	position: relative;
}
#main .concept p {
	font-weight: 300;
	margin-bottom: 62px;
	line-height: 1.75;
	text-align: justify;
}
#main .concept h4 {
	font-size: 32px;
	color: #368c9b;
	line-height: 1.75;
	margin-bottom: 43px;
	letter-spacing: 0.05em;
}
#main .concept h3 {
	margin-bottom: 48px;
	position: relative;
}
#main .concept h3:after {
	width: 84px;  
	height: 142px;
	border-radius: 50px;
	background-image: -webkit-linear-gradient( 90deg, rgb(254,225,64) 0%, rgb(252,169,109) 47%, rgb(250,112,154) 100%);
	opacity: 0.4;
	position: absolute;  
	top: -110px;
	right: 68px;  
	content: ""; 
}
#main .concept .comLink {
	margin: 0 0 0 auto;
}
#main .bigPhoto img {
	width: 100%;
}
#main .works {
	padding: 175px 0 138px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	position: relative;
}
#main .works:after {
	width: 84px;  
	height: 284px;
	border-radius: 50px;
	background-image: -webkit-linear-gradient( 90deg, rgb(72,198,239) 0%, rgb(92,166,227) 49%, rgb(111,134,214) 100%);
	opacity: 0.4;
	position: absolute;  
	top: 174px;
	left: -39px;  
	content: ""; 
}
#main .works .photoBox {
	width: calc(50% - 139px);
	order: 2;
	margin-left: 138px;
}
#main .works .photoBox img {
	width: 100%;
}
#main .works .textBox {
	margin-top: -7px;
	flex: 1;
	padding-left: 20px;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
}
#main .works .subBox {
	max-width: 550px;
	width: 100%;
}
#main .works .headLine01 {
	margin-bottom: 57px;
}
#main .worksList {
	margin-bottom: 57px;
}
#main .worksList li {
	margin-bottom: 50px;
}
#main .worksList li:last-child {
	margin-bottom: 0;
}
#main .worksList a {
	padding-bottom: 48px;
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	justify-content: space-between;
	border-bottom: 1px solid #CDE2E6;
}
#main .worksList a:hover {
	opacity: 0.7;
}
#main .worksList li:last-child a {
	padding-bottom: 0;
	border: none;
}
#main .worksList .photo {
	width: 192px;
	margin-right: 30px;
	position: relative;
}
#main .worksList .photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#main .worksList .txtBox {
	flex: 1;
}
#main .worksList li h4 {
	margin-bottom: 20px;
	font-size: 20px;
	font-weight: 400;
	color: #368c9b;
}
#main .worksList li p {
	font-weight: 300;
	text-align: justify;
	line-height: 1.75;
}
#main .works .comLink {
	margin: 0 2px 0 auto;
}
#main .flow {
	padding: 108px 0 99px;
	position: relative;
	background-color: rgb(54, 140, 155,0.102);
}
#main .flow:after {
	width: 84px;  
	height: 198px;
	background-image: -webkit-linear-gradient( 90deg, rgb(32,226,215) 0%, rgb(141,240,190) 49%, rgb(249,254,165) 100%);
	opacity: 0.4;
	border-radius: 50px;
	position: absolute;  
	top: -100px;
	right: 451px;  
	content: ""; 
}
#main .flowList {
	padding: 2px 0 38px 1px;
	display: flex;
	flex-wrap: wrap;
}
#main .flowList li {
	margin: 0 37px 20px 0;
	width: 190px;
	border-radius: 10px;
	padding: 10px 20px 27px;
	background-color: #fff;
	position: relative;
	border: 2px solid  rgba(54, 140, 155,1);
}
#main .flowList li:nth-child(5n) {
	margin-right: 0;
}
#main .flowList li .photo {
	min-height: 130px;
	margin-bottom: -10px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
}
#main .flowList li .num {
	font-weight: 700;
	margin: -37px auto 10px;
	width: 50px;
	height: 50px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 5px;
	border-radius: 100%;
	color: #fff;
	font-size: 22px;
	letter-spacing: 0.05em;
	background-color: #368C9B;
}
#main .flowList li p {
	min-height: 50px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	font-size: 18px;
	letter-spacing: 0.05em;
	line-height: 1.388;
	font-weight: 700;
}
#main .flow .txt {
	margin-bottom: 60px;
	text-align: center;
}
#main .flow .txt span {
	display: inline-block;
	text-align: left;
	line-height: 1.75;
	font-weight: 400;
}
#main .info {
	padding: 147px 0 121px;
	position: relative;
}
#main .info::before {
	width: 190px;  
	height: 270px;
	border-radius: 50px;
	background-image: -webkit-linear-gradient( 90deg, rgb(250,112,154) 0%, rgb(252,169,109) 53%, rgb(254,225,64) 100%);
	opacity: 0.4;
	position: absolute;  
	top: 103px;
	right: -132px;  
	content: ""; 
}
#main .info .innerBox {
	margin: -8px 0 120px;
}
#main .info .imgBox {
	margin-bottom: 129px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#main .info .imgBox:last-child {
	margin-bottom: 0;
}
#main .info .imgBox .photoBox {
	width: calc(50% - 140px);
	margin: 0 108px 0 -14px;
}
#main .info .imgBox .photoBox img {
	width: 100%;
	border-radius: 0 160px 0 0;
}
#main .info .imgBox .textBox {
	margin-top: -2px;
	flex: 1;
}
#main .info .imgBox .textBox .sub {
	max-width: 599px;
	display: block;
}
#main .info .imgBox p {
	font-weight: 300;
	line-height: 1.75;
	text-align: justify;
}
#main .info .imgBox02 {
	padding-bottom: 20px;
	position: relative;
}
#main .info .imgBox02 .photoBox {
	order: 2;
	margin-right: -0;
	margin-left: 138px;
}
#main .info .imgBox02 .photoBox img {
	border-radius: 160px 0 0 0;
}
#main .info .imgBox02 .textBox {
	display: flex;
	padding-left: 20px;
	justify-content: flex-end;
}
#main .info .imgBox02 .textBox .sub {
	max-width: 485px;
}
#main .info .imgBox02::before {
	width: 105px;  
	height: 179px;
	border-radius: 50px;
	background-image: -webkit-linear-gradient( 180deg, rgb(196,113,245) 0%, rgb(223,113,225) 49%, rgb(250,113,205) 100%);
	opacity: 0.2;
	position: absolute;  
	top: 0px;
	left: -52px;  
	content: ""; 
}
#main .info .imgBox03 {
	position: relative;
}
#main .info .imgBox03::after {
	width: 215px;  
	height: 71px;
	border-radius: 50px;
	background-image: -webkit-linear-gradient( 180deg, #96fbc4 0%, #f9f586 100%);
	opacity: 0.4;
	position: absolute;  
	bottom: -47px;
	right: -35px;  
	content: ""; 
}
#main .magazine {
	position: relative;
	padding: 115px 0 103px;
	background-color: #EBF3F5;
}
#main .magazine::before {
	width: 85px;  
	height: 222px;
	background-image: -webkit-linear-gradient( 90deg, rgb(254,225,64) 0%, rgb(252,169,109) 47%, rgb(250,112,154) 100%);
	opacity: 0.4;
	position: absolute;  
	bottom: -111px;
	border-radius: 50px;
	left: 78px;  
	content: ""; 
}
#main .magazine .magazineList {
	margin-top: -8px;
}
#main .magazine .content {
	max-width: 1236px;
}
#main .company {
	padding: 150px 0 38px;
}
#main .company .content {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#main .company .rBox {
	width: 482px;
	margin: 6px 0 0 140px;
}
#main .company .lBox {
	flex: 1;
}
#main .company .rBox li {
	margin-bottom: 5px;
}
#main .company .rBox li:last-child {
	margin-bottom: 0;
}
#main .company .rBox a {
	display: block;
	position: relative;
}
#main .company .rBox a:hover {
	opacity: 0.7;
}
#main .company .rBox a > img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#main .company .rBox a .subBox {
	position: absolute;
	top: 50%;
	width: 100%;
	padding: 20px;
	text-align: center;
	z-index: 1;
	transform: translateY(-50%);
}
#main .company .rBox p {
	font-size: 14px;
	color: #368c9b;
	font-weight: 300;
	letter-spacing: 0.05em;
}
#main .company .rBox p .en {
	display: block;
	letter-spacing: 0.05em;
	font-weight: 300;
	font-size: 36px;
	margin-bottom: 6px;
}
#main .company h4 {
	padding-top: 2px;
	margin-bottom: 32px;
	font-weight: 300;
	font-size: 28px;
	letter-spacing: 0.05em;
	line-height: 1.75;
	color: #368c9b;
}
#main .company .lBox p {
	margin-bottom: 79px;
	letter-spacing: 0.05em;
	font-weight: 300;
	line-height: 1.75;
	text-align: justify;
}
#main .company .comLink {
	margin: 0 0 0 auto;
}
#main .bigPhoto img {
	width: 100%;
}

@media only screen and (min-width: 769px) {
	/* #main .concept .comLink a {
		padding-left: 30px;
	} */
	#main .info .imgBox03 .photoBox {
		width: calc(50% - 140px);
		margin: 0 95px 0 0;
	}
}

/* ----------------------------- mobile ------------------------------- */
@media only screen and (max-width: 768px) {
	.mainImg {
		margin-bottom: 0;
		padding: 50px 20px 32px;
		height: 723px;
	}
	.mainImg .content {
		padding-bottom: 19px;
	}
	.mainImg h2 {
		margin: 0 -10px 87px 0;
		font-size: 34px;
		line-height: 1.53;
		letter-spacing: 0.05em;
	}
	.mainImg h2 span {
		font-size: 14px;
		margin-top: 9px;
	}
	.mainImg p {
		font-size: 20px;
	}
	.mainImg p span {
		margin-top: 24px;
	}
	#main .news {
		padding: 64px 0;
	}
	#main .news .content {
		display: block;
	}
	#main .news .lBox {
		width: auto;
		margin: 0;
	}
	#main .news .rBox {
		padding: 0;
	}
	#main .news::after {
		width: 40px;
		height: 99px;
		bottom: auto;
		top: 48px;
		left: auto;
		right: 20px;
	}
	#main .news .linkP {
		font-size: 16px;
		text-align: center;
	}
	#main .concept {
		padding: 63px 19px 108px;
		display: block;
	}
	#main .concept .photoBox {
		margin: 0 -19px 26px 0;
		width: auto;
	}
	#main .concept h3 {
		margin: 0 0 39px;
	}
	#main .concept h3::after {
		width: 40px;
		height: 111px;
		top: -47px;
		right: 1px;
	}
	#main .concept h4 {
		margin-bottom: 23px;
		font-size: 30px;
		line-height: 1.733;
	}
	#main .concept p {
		margin-bottom: 40px;
		line-height: 2;
	}
	#main .concept .textBox .sub {
		max-width: inherit;
	}
	#main .concept .textBox {
		padding: 0;
	}
	#main .concept .comLink {
		margin: 0 auto;
	}
	#main .bigPhoto {
		margin: 0 -400px 0 -309px;
	}
	#main .works {
		padding: 75px 19px 70px;
		display: block;
	}
	#main .works .photoBox {
		width: auto;
		margin: -24px -19px 45px 0;
	}
	#main .works .textBox {
		margin: 0;
		padding: 0;
		display: block;
	}
	#main .works .subBox {
		max-width: inherit;
	}
	#main .worksList .photo {
		width: 34.6%;
		margin-right: 20px;
	}
	#main .worksList .photo img {
		width: 100%;
	}
	#main .worksList li h4 {
		font-size: 16px;
		margin-bottom: 8px;
	}
	#main .worksList li p {
		line-height: 1.785;
		text-align: left;
	}
	#main .worksList .txtBox {
		margin-top: -2px;
	}
	#main .worksList a {
		padding-bottom: 26px;
	}
	#main .worksList li {
		margin-bottom: 32px;
	}
	#main .works .comLink {
		margin: 0 auto;
	}
	#main .works::after { 
		width: 39px;
		height: 106px;
		left: auto;
		right: 20px;
		top: 43px;
	}
	#main .flow {
		padding: 52px 0 75px;
	}
	#main .flow::after {
		right: 65px;
		top: -38px;
		width: 30px;
		height: 70px;
	}
	#main .flowList {
		padding: 15px 0 30px;
		display: block;
	}
	#main .flowList li {
		min-height: 140px;
		padding: 5px 20px 10px;
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		justify-content: space-between;
		width: auto;
		margin: 0 0 13px 24px;
	}
	#main .flowList li:last-child {
		margin-bottom: 0;
	}
	#main .flowList li .num {
		margin: 0 10px 0 -45px;
	}
	#main .flowList li .spBpx {
		flex: 1;
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		justify-content: space-between;
	}
	#main .flowList li .photo {
		display: block;
		width: 140px;
		min-height: inherit;
	}
	#main .flowList li .photo img {
		max-height: 95px;
		height: auto;
		width: auto;
	}
	#main .flowList li p {
		min-height: inherit;
		display: block;
		flex: 1;
		text-align: center;
	}
	#main .flow .txt span {
		line-height: 2;
	}
	#main .flow .txt {
		margin-bottom: 53px;
	}
	#main .info {
		padding: 78px 0 86px;
	}
	#main .info::before {
		display: none;
	}
	#main .info .headLine01 {
		text-align: center;
	}
	#main .info .imgBox {
		margin-bottom: 62px;
		display: block;
	}
	#main .info .imgBox .photoBox {
		width: auto;
		margin: 0 20px 41px 0;
	}
	#main .info .imgBox .textBox {
		padding: 0 !important; 
		margin: 0 19px;
	}
	#main .info .imgBox .textBox .sub {
		max-width: inherit;
	}
	#main .info .innerBox {
		margin: 0 0 45px;
	}
	#main .info .imgBox p {
		text-align: left;
		line-height: 2;
	}
	#main .info .imgBox02::before {
		display: none;
	}
	#main .info .imgBox02 .photoBox {
		margin-right: 0;
		margin-left: 20px;
	}
	#main .info .imgBox02 {
		padding-bottom: 23px;
	}
	#main .info .imgBox03::after {
		display: none;
	}
	#main .magazine {
		padding: 68px 2px 71px;
		background-color: #E9F2F4;
	}
	#main .magazine .magazineList {
		margin-top: -2px;
	}
	#main .magazine::before {
		display: none;
	}
	#main .company {
		padding: 68px 0 0;
	}
	#main .company .content {
		display: block;
	}
	#main .company .headLine01 {
		text-align: center;
	}
	#main .company .rBox {
		width: auto;
		margin: 50px -19px 0;
	}
	#main .company h4 {
		padding-top: 0;
		margin: -2px 0 24px;
		font-size: 24px;
		line-height: 1.666;
	}
	#main .company .lBox p {
		margin-bottom: 31px;
		line-height: 2;
	}
	#main .company .comLink {
		margin: 0 auto;
	}
	#main .company .rBox p {
		font-size: 10px;
	}
	#main .company .rBox p .en {
		margin-bottom: 8px;
		font-size: 27px;
	}
	#main {
		margin-bottom: 0;
	}
}

@media only screen and (max-width: 375px) {
	#main .company h4 {
		font-size: 21px;
	}
	.mainImg h2 {
		font-size: 30px;
	}
}

@media only screen and (max-width: 374px) {
	.mainImg h2 {
		font-size: 26px;
	}
	.mainImg h2 span {
		font-size: 13px;
	}
	#main .concept h4 {
		font-size: 25px;
	}
	#main .flowList li .photo {
		width: 100px;
	}
	#main .flowList li p {
		font-size: 14px;
	}
	#main .magazineList li:not(.liStyle) a .photo {
		width: 46%;
	}
}