@charset "UTF-8";
/* CSS Document */



/* -------------------------------- mainvisual */
/*
.mainvisual {
	background-image:url("../images/index/mainvisual_01.jpg");
	background-position: center;
	background-size:cover;
	width:100%;
	height:450px;
	position:relative;

} */
/* ---------- */
.mainvisual {
	width:100%;
	height:450px;
	position:relative;
}
.slider-area {
    position: relative;
    width: 100%;
    height: 450px;
}

.slider-item {
    position: absolute;
    inset: 0;
    opacity: 0;
    z-index: 0;
    animation: slideShow 15s linear infinite 0s;
}

.slider-item:nth-child(2) {
    animation-delay: 5s;
}

.slider-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

@keyframes slideShow {
    0% {
        opacity: 0;
        animation-timing-function: ease-in;
    }

    18% {
        opacity: 1;
        animation-timing-function: ease-out;
    }

    60% {
        opacity: 1;
    }

    80%,
    100% {
        opacity: 0;
    }
}
/* ---------- */









.mainvisual_text {
	writing-mode: vertical-rl;
	position:absolute;
	right:10vw;
	top:50px;
	font-size:24px;
	font-weight:bold;
	line-height:1.7em;
	opacity: 0;
	text-shadow: 1px 1px 5px #fff;
}

.mainvisual_text2 {
	writing-mode: vertical-rl;
	position:absolute;
	right:22vw;
	top:50px;
	font-size:24px;
	font-weight:bold;
	line-height:1.7em;
	opacity: 0;
	text-shadow: 1px 1px 5px #fff;
}

/*---TOPメインテキスト---*/

h2.mainvisual_text {
    animation: fadeIn_txt 4s ease 0.2s 1 forwards;
}

@keyframes fadeIn_txt {
    0% {opacity: 0}
    100% {opacity: 1}
}

h2.mainvisual_text2 {
    animation: fadeIn_txt 4s ease 1.2s 1 forwards;
}

@keyframes fadeIn_txt {
    0% {opacity: 0}
    100% {opacity: 1}
}

/* -------------------------------- survices1 */

.survice_link {
	display:flex;
	max-width:1020px;
}



.leftbox {
	background:#D0F7EC;
	padding:50px;
	width: 100%;
}

.leftbox .images {
	display: flex;
    justify-content: space-around;
    margin-top: 30px;
}

.rightbox {
	background:#FCF7ED;
	padding:50px;
	width: 100%;
	display: none;
}

.images01 {
	margin-top:8px;
}

.images02 {
	margin-top:30px;
}

.images01,.images02 {
	transition:all 0.5s;
}

.images01 img ,.images02 img{
	width:100%;
}

.images01:hover,.images02:hover {
	opacity:0.7;
}

.leftbox_text {
	padding-top:15px;
}

/* =====blog===== */

.blog_section {
	width: 100%;
	padding: 0 20px;
	box-sizing: border-box;
}

.blog_section .list {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	width: 1000px;
	max-width: 100%;
	margin: 0 auto 60px;
  }

  .blog_section .item {
	width: 200px;
	margin: 0 66.6px 0 0;
  }

  .blog_section .item:hover {
	opacity: .7;
	transition: .4s;
	}

  .blog_section .item_image {
	height: 150px;
	margin: 0 0 20px;
	background: #ccc;
  }

  .blog_section .item_image img {
	height: 100%;
	width: 100%;
	-o-object-fit: cover;
	   object-fit: cover;
  }

  .blog_section .date {
	padding: 0 0 0 12px;
	border-left: 12px solid #25b090;
	margin: 0 0 8px;
	color: #333;
  }

  .blog_section .title {
	color: #333;
  }

  .blog_section .btn {
	display: block;
	width: 300px;
	height: 44px;
	margin: 0 auto;
	background: #fff;
  }

  .blog_section .btn a {
	display: block;
	width: 100%;
	height: 100%;
	background: #25b090;
	font-size: 17px;
	color: #fff;
	text-align: center;
	line-height: 44px;
  }

  .blog_section .btn a:hover {
	  opacity: .7;
	  transition: .4s;
  }



/* -------------------------------- survices */

.survices_cont {
	max-width:1020px;
	margin:0 auto;
}

.title_img {
	text-align: center;
	padding:100px 0 50px 0;
}

.number_flex {
	display:flex;
	padding-top:50px;
}

.number {
	font-family: 'Lato', sans-serif;
	font-size:85px;
}

.bar {
	border-bottom:solid 1px #25b090;
	width:100%;
	margin-bottom:18px;
	margin-left:20px;
}

.survises_inner {
	display:flex;
	padding-top:25px;
}

.text_side {

}

.s_title {
	font-size:24px;
	margin-left:50px;
	font-weight:bold;
	text-align: center;
	background: -webkit-linear-gradient(transparent 40%, #fcf8c3 40%);
	background: -o-linear-gradient(transparent 40%, #fcf8c3 40%);
	background: linear-gradient(transparent 40%, #fcf8c3 40%);
}

.s_text {
	margin:50px 0;
	position: relative;
	padding:0 50px;

}

.s_text:after {
	position: absolute;
	top:14px;
	left:0;
	background:#e4f9f3;
	content:"";
	height:120%;
	width:100%;
	z-index: -1000;
}

.img_side img {
	width:400px;
}

#souji_dou {
	margin-top:100px;
}

.souji_header {
	background-image:url("../images/index/souji_dou_back.png");
	background-repeat: no-repeat;
	background-position:center;
	height:536px;


}

.souji_title_img  {
	text-align: center;
	width:520px;
	margin:0 auto;
}

.souji_title_text {
	writing-mode: vertical-rl;
	margin:40px auto;
	font-size:30px;
	font-family: 'Noto Serif JP', serif;
	line-height:1.8em;
}

.souji_dou_box {
	background-image:url("../images/index/soujidou_box_back.png");
	background-repeat:no-repeat;
	width:557px;
	height:451px;
	padding:40px 0;
	text-align: center;
	box-sizing: border-box;
	font-family: 'Noto Serif JP', serif;

}

.box_number {
	background-image:url("../images/index/soujidou_number_mark.png");
	width:190px;
	height:72px;
	background-repeat:no-repeat;
	margin:0 auto;
	font-size:34px;
	font-weight:bold;
	line-height:72px;
}

.box_title {
	padding:40px 0;
	font-size:24px;
	font-weight:bold;

}

.box_text {
	font-size:20px;
	line-height:2em;
}

.survices_cont {
	max-width:1020px;
	margin:0 auto;
}

.souji_header {
	margin-bottom:200px;
}

.souji_dou_flexbox {
	display:flex;
	max-width:1150px;
	box-sizing: border-box;
	margin:-110px auto;
	justify-content: space-around;
	position:relative;

}

.souji_dou_cont {
	background-image: url("../images/index/souji_dou_back2.jpg");
	padding:100px 0 300px 0;
}


.souji_dou_box:nth-child(even){
  margin-top:350px;
}

.sixth .box_title {
	padding:30px 0 10px 0;

}

#services1 .service_wrap {
	max-width: 1000px;
	margin: 0 auto;
	padding: 50px 20px 20px;
	box-sizing: border-box;
	background: #D0F7EC;

}

#services1 .service_text {
	max-width: 800px;
	margin: 0 auto 50px;
	line-height: 2;
}

#services1 .service_list {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	max-width: 1000px;
	margin: 0 auto;
}

#services1 .service_item {
	margin-bottom: 50px;
	margin-left: 20px;
	margin-right: 20px;
}

#services1 .service_item a:hover {
	cursor: pointer;
	transition: .4s;
	opacity: .7;
}

/* -------------------------------- lisk */

.lisk_cont {
	background-image:url("../images/index/background02.png");
	height:auto;
	background-position: bottom;
	background-repeat:repeat-x;
}

.lisk_box {
	background-image:url("../images/index/circle.png");
	width:181px;
	height:181px;
	font-weight:bold;
	font-size:26px;
	position: relative;
	margin:10px;
	text-align: center;
}

.lisk_text {
	position: absolute;
	top:50%;
	left:50%;
    transform: translateY(-50%) translateX(-50%);
	width:181px;
}


.risk_list {
	display:flex;
	max-width:1020px;
	flex-wrap: wrap;
	margin:50px auto 0 auto;
	justify-content: center;
	padding-bottom:50px;
}

/* -------------------------------- link botton */

#link_btn {

}

.link_btn_cont {
	background:#aed4e8;
	padding:50px 0;
}

.link_btn_flexbox {
	display:flex;
	max-width: 920px;
	margin:0 auto;
	flex-wrap: wrap;
	justify-content: space-between;
}

.link_btn_01 img {
	height:200px;
	width:100%;
	margin-bottom:20px;
	filter: drop-shadow(10px 10px 10px rgba(0,0,0,0.6));
}

.link_btn_02 img,
.link_btn_03 img,.link_btn_04 img {
	height:135px;
	filter: drop-shadow(10px 10px 10px rgba(0,0,0,0.6));
}

.link_btn_01:hover,.link_btn_02:hover,.link_btn_03:hover,.link_btn_04:hover {
	opacity:0.7;
}

.link_btn_01,.link_btn_02,.link_btn_03,.link_btn_04 {
	transition: opacity 0.5s;
}

/* -------------------------------- facilities */

.facilities_cont {
	background:#ecebe5;
	position: relative;
	background-image:url("../images/index/facilities_back.png");
	background-repeat:no-repeat;
	background-position: 750px -50px;
	padding:50px 0;
}



/* -------------------------------- strength */

.strength_cont {
	padding:50px 0;
}

.strength_box01,.strength_box02,.strength_box03,.strength_box04,
.strength_box05,.strength_box06,.strength_box07,.strength_box08 {
	margin:60px 0;
	width:286px;
	height:286px;
	position:relative;
	background-repeat:no-repeat;
}

.strength_box01 {
	background-image:url("../images/index/strength_01.png");
}

.strength_box02 {
	background-image:url("../images/index/strength_02.png");
}

.strength_box03 {
	background-image:url("../images/index/strength_03.png");
}

.strength_box04 {
	background-image:url("../images/index/strength_04.png");
}

.strength_box05 {
	background-image:url("../images/index/strength_05.png");
}

.strength_box06 {
	background-image:url("../images/index/strength_06.png");
}

.strength_box07 {
	background-image:url("../images/index/strength_07.png");
}

.strength_box08 {
	background-image:url("../images/index/daihyou.png");
}

.number {
	font-size:85px;

}

.strength_list {
	display:flex;
	max-width:1020px;
	flex-wrap: wrap;
	justify-content: space-between;
	margin:0 auto;
}



.strength_text {
	text-align:center;
	position: absolute;
	bottom:0;
    left: 50%;
    transform: translateX(-50%);
	width:286px;
}

/* -------------------------------- example */

#example .sub_title02 {
	color:#fff;
}

#example .bar {
	border-bottom:solid 1px #ccc;
}

.example_cont {
	background:url("../images/index/example_bak.jpg");
	background-size:cover;
	padding:70px 0;
}

.example_list {
	display:flex;
	flex-wrap: wrap;
	justify-content: center;
	margin:0 auto;
	text-align: center;
	color:#fff;
	max-width: 1020px;
}

.example_box {
	margin:50px 20px;
}

/* -------------------------------- result */

#result_list {
	background:#aed4e8;
}

.result_cont {
	padding:70px 0;
	max-width:1020px;
	margin:0 auto;
}

.result_list {
	display:flex;
	flex-wrap: wrap;
	max-width:801px;
	margin:0 auto;
	box-sizing: border-box;
}

.result_box {
	margin:20px;
}

.result_btn_cont {
	background:#004480;
	color:#fff;
	width:200px;
	padding:15px;
	box-sizing: border-box;
	margin: 0 0 0 auto;
	text-align: center;
	transition: background 0.5s;
}

.result_btn_cont a{
	color:#fff;
}

.result_btn_cont:hover {
	background:#4790C8;
}





.mail_img a {
	transition:filter 0.4s;
}

.mail_img a:hover {
	filter: brightness(130%);
}


.area_cont {
	background:#ecebe5;
	padding:40px;
	margin-top:50px;
}

.area_title {
	font-size:25px;
	color:#004480;
	font-weight:bold;
	padding-bottom:10px;
}

