@charset "utf-8";
/* CSS Document */
.contents{
	overflow: hidden;
}
.main-bg{
	position: relative;
	background: url("../images/csr/main.jpg") no-repeat center center;
	background-size: cover;
	height: calc(100vh - 100px);
	margin-bottom: 0px;
}
.main-bg .tex-box{
	width: 100%;
	text-align: center;
	position: absolute;
    top: 50%;
    left: 0%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}
.main-bg .tex-box .tex-img{
	width: 58%;
	max-width: 558px;
	margin-left: auto;
	margin-right: auto;
}
.main-bg .tex-box .tex-img img{
	display: block;
}
.main-bg .tex-box .ttl-tex{
	font-size: 42px;
	color: #fff;
}
.text_csr{
	color: #fff;
	font-weight: bold;
	margin-top: 20px;
}


.scroll{
	position: absolute;
	bottom: 30px;
	width: 10%;
	max-width: 10px;
	right:5%;
	opacity: 1;
	height: 50px;
		transition: 1.0s;
	-webkit-transition: 1.0s; /* Chrome、Safari用 */
	-moz-transition: 1.0s; /* Firefox用 */
	-o-transition: 1.0s; /* Opera用 */
		-moz-transition-delay:0s;
-webkit-transition-delay:0s;
-o-transition-delay:0s;
-ms-transition-delay:0s;
	/*display: flex;
	justify-content: space-between;
	align-items: flex-end;*/
}
.scroll .sc-img{
	position: absolute;
	left: 0;
	right: 0;
	margin-left: auto;
	margin-right: auto;
	top:-78%;
}
.scroll::after{
  content: "";
    /*描画位置*/
  position: absolute;
  top: 0;
    /*線の形状*/
  width: 1px;
  height: 30px;
	left: 0;
	right: 0;
	margin-left: 32%;
	margin-right: auto;
  background: #fff;
    /*線の動き1.4秒かけて動く。永遠にループ*/
  animation: pathmove 2.0s ease-in-out infinite;
  opacity:0;
}
@keyframes pathmove{
  0%{
    height:0;
    top:0;
    opacity: 0;
  }
  30%{
    height:30px;
    opacity: 1;
  }
  100%{
    height:0;
    top:50px;
    opacity: 0;
  }
}


@media screen and (min-width: 769px) and (max-width: 1200px) {
.copy-tex{
		white-space: normal;
	}
.ttl-tex1{
	white-space: normal;
	font-size: 26px;
}
	.copy-tex{
		font-size: 19px;
	} 
	.main-bg .tex-box .ttl-tex{
		font-size: 36px;
	}
}
@media only screen and (max-width: 768px) {
.main-bg{
	position: relative;
	background: url("../images/csr/main.jpg") no-repeat 30% center;
	background-size: cover;
	height: 80vh;
	margin-bottom: 0px;
}
.main-bg .tex-box .ttl-tex{
	font-size: 8.0vw;
	color: #fff;
	line-height: 1.59;
}

.scroll{
	/*position: absolute;*/
	bottom: 3vw;
	/*width: 14%;
	max-width: 65px;*/
	right:10%;
}
.first-tex{
	margin-bottom: 70px;
}
}
@media print, screen and (min-width: 1201px) {

}


@media only screen and (max-device-width: 1024px) and (orientation: landscape){
	.main-bg{
		height: 250vh;
	}
}


/*20241001追記*/
.bg_01{
	position: relative;
	background: url("../images/csr/bg01.jpg") no-repeat center top / cover;
	background-size: cover;
	padding-top: 84px;
	padding-bottom: 130px;
}
.bg_01 .logo{
	margin-bottom: 26px;
	max-width: 188px;
	margin-left: auto;
	margin-right: auto;
}

.ttl-tex1{
	font-size: 32px;
	line-height: 1.51;
	text-align: center;
}
.flex-list{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.flex-list li{
	width: 48%;
	padding: 0 48px 53px;
	border-radius: 5px;
	box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0.16);
	background-color: #fff;
	margin-top: 100px;
}
.flex-list li .line{
	margin-bottom: 64px;
	border-radius: 0 0 10px 10px;
	height: 17px;
	width: 100%;
}
.flex-list li .line.ptn1{
  background-image: linear-gradient(to left, #af2, #0fc2c9 95%);
}
.flex-list li .line.ptn2{
	background-image: linear-gradient(to right, #ffadad, #ffeb00 95%);
}
.flex-list li .ttl{
	margin-bottom: 23px;
	font-size: 32px;
	text-align: center;
	line-height: 1;
	font-weight: 700;
}
.flex-list li .text{
	font-size: 16px;
	line-height: 1.69;
	text-align: center;
	margin-bottom: 37px;
}
.flex-list li .icon{
	width: 73%;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 20px;
}
.bg_02{
	background: url("../images/csr/bg03.jpg") repeat center top / 1290px;
	margin-bottom: 45px;
}
.bg_02 .map{
	padding-top: 100px;
	padding-bottom: 100px;
}
.ttl-tex2{
	text-align: center;
	font-size: 43px;
	line-height: 1.49;
}
.map-wrap{
	position: relative;
}
.map-wrap .text-box{
	position: absolute;
	left: 78px;
	top: 146px;
}

.news{
	padding-top: 75px;
	padding-bottom: 130px;
	background: rgba(227,225,218,0.25);
}
.news .ttl-img{
	margin-bottom: 50px;
	max-width: 144px;
	width: 26.7%;
}
.news-list li{
	display: flex;
	justify-content: space-between;
	border-bottom: 2px dotted #000000;
	margin-bottom: 17px;
	padding-bottom: 20px;
	font-size: 16px;
}
.news-list li:last-child{
	margin-bottom: 0;
}
.news-list li .new{
	width: 120px;
}
.news-list li .new span{
	font-size: 26px;
	font-weight: 700;
	color: #fff;
	background-color: #FF0A00;
	padding: 6px 10px;
	border-radius: 50px;
	line-height: 1;
	display: block;
	width: 100%;
	text-align: center;
	font-family: "Oswald", sans-serif;
}
.news-list li .date{
	width: 84px;
	padding-top: 3px;
}
.news-list li .text{
	width: calc(100% - 240px);
	padding-top: 3px;
}
@media only screen and (max-width: 768px) {
	.bg_01{
		padding-top: 16vw;
		padding-bottom: 21vw;
	}
	.bg_01 .logo{
		margin-bottom: 26px;
		max-width: 188px;
		margin-left: 0;
		margin-right: 0;
	}.ttl-tex1{
		font-size: 5.6vw;
		line-height: 1.47;
		text-align: left;
	}
	.flex-list{
		display:block;
		margin-top: 13vw;
	}
	.flex-list li{
		width: 100%;
		margin-top: 5.8vw;
		padding: 0 10vw 10vw;
		border-radius: 1.3vw;
	}
	.flex-list li .line{
		margin-bottom: 13vw;
		border-radius: 0 0 2vw 2vw;
		height: 17px;
		width: 100%;
	}
	.flex-list li .ttl{
		margin-bottom: 4vw;
		font-size:6vw;
		text-align: center;
	}
	.flex-list li .text{
		font-size: 3.2vw;
		line-height: 1.69;
		text-align: center;
		margin-bottom: 14vw;
	}
	.flex-list li .icon{
		width: 73%;
		margin-left: auto;
		margin-right: auto;
		margin-bottom: 4.8vw;
	}
	.bg_02{
		background: url("../images/csr/bg03.jpg") repeat center top / 120vw;
		margin-bottom: 10.6vw;
	}
	.bg_02 .map{
		padding-top: 21vw;
		padding-bottom: 15vw;
	}
	.ttl-tex2{
		text-align: center;
		font-size: 6.4vw;
		margin-bottom: 4.2vw;
		line-height: 1.49;
	}
	.map-wrap{
		position: relative;
	}
	.map-wrap .text-box{
		position: relative;
		left: auto;
		top: auto;
		margin-bottom: 3.2vw;
	}

	.news{
		padding-top: 18vw;
		padding-bottom: 18vw;
	}
	.news .ttl-img{
		margin-bottom: 50px;
		max-width: 144px;
		width: 26.7%;
	}
	.news-list li{
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
		border-bottom: 2px dotted #000000;
		margin-bottom: 5vw;
		padding-bottom: 2.5vw;
		font-size: 3.5vw;
	}
	.news-list li:last-child{
		margin-bottom: 0;
	}
	.news-list li .new{
		width: 24%;
	}
	.news-list li .new span{
		font-size: 4vw;
		padding: 2vw 2vw;
		border-radius: 13vw;
		line-height: 1;
		display: block;
		width: 100%;
		text-align: center;
		font-family: "Oswald", sans-serif;
	}
	.news-list li .date{
		width: 74%;
		padding-top: 1vw;
	}
	.news-list li .text{
		width: 100%;
		padding-top: 0vw;
	}
}

.ken-1{
	padding-top: 130px;
	background: url("../images/csr/bg02.jpg") no-repeat center top / cover;
}
.ken-ttl img{
	display: inline-block;
	height: 94px;
	margin-bottom: -2px;
}
.ken-ttl span{
	padding-bottom: 22px;
	color: #fff;
	font-size: 43px;
	display: inline-block;
	line-height: 1;
}
.ken-2{
	background-image: linear-gradient(to bottom, #fff, rgba(255,245,118,0.25));
	padding-top: 110px;
	padding-bottom: 136px;
}
.ken-2 .flex-box{
	display: flex;
	justify-content: space-between;
}
.ken-2 .flex-box.right{
	flex-direction: row-reverse;
}
.ken-2 .en-name{
	margin-bottom: 14px;
	text-align: center;
}
.ken-2 .en-name img{
	height: 25px;
	width: auto;
}
.ken-2 .jp-name{
	font-size: 43px;
	line-height: 1;
	color: #000000;
	margin-bottom: 17px;
	text-align: center;
	font-weight: 700;
}
.ken-2 .icon{
	width: 43%;
	max-width: 130px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 36px;
}
.ken-2 .flex-box .text{
	line-height:1.68;
}
.ken-2 .flex-box .text.ptn0{
	width: 63.5%;
}
.ken-2 .flex-box .text.ptn1{
	width: 40%;
}
.ken-2 .flex-box .text.ptn2{
	width: 65%;
}
.ken-2 .flex-box .text.ptn3{
	width: 32%;
}
.ken-2 .flex-box .text.ptn4{
	width: 48%;
}
.ken-2 .flex-box .img.ptn0{
	width: 31.4%;
}
.ken-2 .flex-box .img.ptn1{
	width: 54%;
}
.ken-2 .flex-box .img.ptn2{
	width: 30%;
}
.ken-2 .flex-box .img.ptn3{
	width: 65%;
}
.ken-2 .flex-box .img.ptn4{
	width: 48%;
}
.name-text{
	font-size: 28px;
	font-weight: 700;
	margin-bottom: 15px;
}
.full-img1{
	margin-left: -23%;
	width: 123%;
	max-width: none;
}
.full-img2{
	margin-right: -23%;
	width: 123%;
	max-width: none;
}
.link-btn{
	width: 410px;
	margin-left: auto;
	margin-right: auto;
}
.link-btn a{
	padding-top: 22px;
	padding-bottom: 22px;
	text-align: center;
	display: block;
	width: 100%;
	color: #fff;
	background: #000000;
	font-size: 18px;
	line-height: 1;
	font-weight: 700;
}
.ken-3{
	padding-top: 90px;
	padding-bottom: 150px;
	background: url("../images/csr/bg04.jpg") no-repeat center top / cover;
}
.ken-3 .topic-ttl{
	font-size: 28px;
	font-weight: 700;
	line-height: 1;
	margin-bottom: 20px;
}
.topic-box{
	padding: 48px;
	border-radius: 10px;
	box-shadow: 0 0 6px 0 rgba(0, 109, 177, 0.16);
	background-color: #fff;
	display: flex;
	justify-content: space-between;
	box-sizing: border-box;
	flex-direction: row-reverse;
}
.topic-box .icon{
	width: 8%;
}
.topic-box .text{
	width: 88%;
	display: flex;
	justify-content: space-between;
}
.topic-box .text .pic-box{
	width: 32%;
}
.topic-box .text .txt-box{
	width: 65%;
	line-height:1.68;
}
.topic-box .text .txt-box .ttl{
	font-weight: 700;
	margin-bottom: 16px;
	font-size: 16px;
}
.plus-text{
	line-height:1.68;
	background: #f7f3f3;
	font-size: 16px;
	box-sizing: border-box;
	padding: 45px 70px;
	border-radius: 8px;
}
.plus-text .ttl{
	font-weight: 700;
	line-height: 1;
	margin-bottom: 20px;
}
.mie-img{
	margin-top: -100px;
}
.copy{
	padding-top: 86px;
}
@media only screen and (max-width: 768px) {
	.ken-1{
		padding-top: 14vw;
		background: url("../images/csr/bg02.jpg") no-repeat center top / 178vw;
	}
	.ken-ttl img{
		display: inline-block;
		height: 13vw;
		margin-bottom: -1px;
	}
	.ken-ttl span{
		padding-bottom: 2.6vw;
		font-size: 6vw;
		display: inline-block;
		line-height: 1;
	}
	.ken-2{
		background-image: linear-gradient(to bottom, #fff, rgba(255,245,118,0.25));
		padding-top: 15vw;
		padding-bottom: 18vw;
	}
	.ken-2 .flex-box{
		display: block;
	}
	.ken-2 .en-name{
		margin-bottom: 1.6vw;
		text-align: center;
	}
	.ken-2 .en-name img{
		height: 4.8vw;
		width: auto;
	}
	.ken-2 .jp-name{
		font-size:6.4vw;
		margin-bottom: 3.7vw;
	}
	.ken-2 .icon{
		width: 43%;
		max-width: none;
		margin-left: auto;
		margin-right: auto;
		margin-bottom:9.8vw;
	}
	.ken-2 .flex-box .text{
		line-height:1.68;
	}
	.ken-2 .flex-box .text.ptn0{
		width: 100%;
		margin-left: auto;
		margin-right: auto;
		margin-top: 8.8vw;
	}
	.ken-2 .flex-box .text.ptn1{
		width: 100%;
	}
	.ken-2 .flex-box .text.ptn2{
		width: 100%;
	}
	.ken-2 .flex-box .text.ptn3{
		width: 100%;
	}
	.ken-2 .flex-box .text.ptn4{
		width: 100%;
	}
	.ken-2 .flex-box .img.ptn0{
		width: 72%;
		margin-left: auto;
		margin-right: auto;
		margin-top: 8vw;
	}
	.ken-2 .flex-box .img.ptn1{
		width: 100%;
		margin-bottom: 8.8vw;
	}
	.ken-2 .flex-box .img.ptn2{
		width: 65%;
		margin-bottom: 8.8vw;
		margin-left: auto;
		margin-right: auto;
	}
	.ken-2 .flex-box .img.ptn3{
		width: 100%;
		margin-bottom: 8.8vw;
		margin-left: auto;
		margin-right: auto;
	}
	.ken-2 .flex-box .img.ptn4{
		width: 100%;
		margin-bottom: 8.8vw;
	}
	.name-text{
		font-size: 5.6vw;
		font-weight: 700;
		margin-bottom: 4.8vw;
	}
	.full-img1{
		margin-left: -12.5%;
		margin-right: -12.5%;
		width: 125%;
		max-width: none;
	}
	.full-img2{
		margin-left: -12.5%;
		margin-right: -12.5%;
		width: 125%;
		max-width: none;
	}
	.link-btn{
		width:100%;
		margin-left: auto;
		margin-right: auto;
	}
	.link-btn a{
		padding-top:5vw;
		padding-bottom: 5vw;
		text-align: center;
		display: block;
		width: 100%;
		font-size: 3.5vw;
		line-height: 1;
		font-weight: 700;
	}
	.ken-3{
		padding-top: 14vw;
		padding-bottom: 14vw;
		background: url("../images/csr/bg04.jpg") no-repeat center top / 720vw;
	}
	.ken-3 .topic-ttl{
		font-size: 4.4vw;
		font-weight: 700;
		line-height: 1;
		margin-bottom: 4vw;
	}
	.topic-box{
		padding:10vw 10vw 10vw 10vw;
		border-radius: 2vw;
		display: block;
	}
	.topic-box .icon{
		width: 28%;
		margin-left: auto;
		margin-right: auto;
		margin-bottom: 2.6vw;
	}
	.topic-box .text{
		width: 100%;
		display: block;
	}
	.topic-box .text .pic-box{
		width: 100%;
		margin-bottom: 3vw;
	}
	.topic-box .text .txt-box{
		width: 100%;
		line-height:1.68;
	}
	.topic-box .text .txt-box .ttl{
		font-weight: 700;
		margin-bottom: 2vw;
		font-size:4.2vw;
	}
	.plus-text{
		line-height:1.68;
		font-size:4.2vw;
		box-sizing: border-box;
		padding: 5vw 5vw;
		border-radius: 1vw;
	}
	.plus-text .ttl{
		font-weight: 700;
		line-height: 1;
		margin-bottom: 4vw;
	}
	.mie-img{
		margin-top: -0px;
	}
	.copy{
		padding-top: 2vw;
	}
}

.link-list{
	margin-top: 90px;
}
.link-list li{
	margin-bottom: 15px;
}
.link-list li:last-child{
	margin-bottom: 0;
}
.link-list li a{
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 19px 38px;
	color: #fff;
	background: #00C796;
	box-sizing: border-box;
	border-radius: 50px;
	font-size: 21px;
	font-weight: 700;
	line-height: 1.4;
}
.link-list li .left-text{
	width: 60%;
}
.link-list li .right-text{
	width: 35%;
	text-align: right;
}
@media only screen and (max-width: 768px) {
	.link-list{
		margin-top: 2.4vw;
	}
	.link-list li{
		margin-bottom: 4vw;
	}
	.link-list li:last-child{
		margin-bottom: 0;
	}
	.link-list li a{
		display: block;
		padding: 4.2vw 0;
		font-size: 4.2vw;
		line-height: 1.68;
		font-weight: 700;
		border-radius: 5vw;
	}
	.link-list li .left-text{
		width: 100%;
		text-align: center;
	}
	.link-list li .right-text{
		width: 100%;
		text-align: center;
	}
}

.ken-4{
	padding-top: 100px;
	padding-bottom: 170px;
	background: #fff;
}
.mini-wrap{
	max-width: 610px;
	margin-left: auto;
	margin-right: auto;
}
.new-logo{
	margin-bottom: 35px;
	max-width: 232px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 20px;
}
.new-logo img{
	display: block;
}
.new-ttl{
	text-align: center;
	font-weight: 700;
	margin-bottom: 25px;
	line-height: 1.6;
	font-size: 28px;
}
.new-text{
	line-height: 1.68;
	font-size: 16px;
	margin-bottom: 25px;
	letter-spacing: 0;
}
.mini-box{
	margin-bottom: 130px;
}
.mini-box.last{
	margin-bottom: 115px;
}
.mini-list{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.mini-list li{
	margin-bottom: 7px;
	text-align: center;
	width: 49.5%;
}
.mini-list li .img-box{
	text-align: center;
	margin-bottom: 16px;
}
.mini-list li .img-box img{
	height: 137px;
}
.mini-list li .list-ttl{
	line-height: 1;
	margin-bottom: 6px;
	font-size: 24px;
	color: #391A06;
}
.mini-list li .list-text{
	font-size: 15px;
	line-height: 1.68;
	color: #000000;
}
@media only screen and (max-width: 768px) {
	.ken-4{
		padding-top: 14vw;
		padding-bottom: 14vw;
	}
	.mini-wrap{
		max-width: none;
	}
	.new-logo{
		margin-bottom: 5vw;
		max-width: 50%;
		margin-left: auto;
		margin-right: auto;
		margin-bottom: 5vw;
	}
	.new-ttl{
		text-align: center;
		font-weight: 700;
		margin-bottom: 5vw;
		line-height: 1.6;
		font-size: 5.6vw;
	}
	.new-text{
		line-height: 1.68;
		font-size: 3.6vw;
		margin-bottom: 4.4vw;
	}
	.mini-box{
		margin-bottom: 15vw;
	}
	.mini-box.last{
		margin-bottom: 26vw;
	}
	.mini-list{
		display: block;
	}
	.mini-list li{
		margin-bottom: 1.4vw;
		text-align: center;
		width: 100%;
	}
	.mini-list li .img-box{
		margin-bottom: 2.4vw;
	}
	.mini-list li .img-box img{
		height: 36vw;
	}
	.mini-list li .list-ttl{
		line-height: 1;
		margin-bottom: 6px;
		font-size: 6.4vw;
	}
	.mini-list li .list-text.min{
		font-size: 3.2vw;
	}
	.mini-list li .list-text{
		line-height: 1.68;
	}
}