@charset "utf-8";

/* content
---------------------------------------- */
#content{
	padding-bottom: 20px;
	width: calc(100% - 60px);
	max-width: 1000px;
	margin: 0 auto;
}
#content #topic_path {
    margin:10px auto 35px auto;
}
#content #topic_path {
    font-size: 12px;
}
#content #topic_path li{
    font-size: 12px;
}
#topic_path {
width: 95%;
    max-width: 1000px;
    margin: 20px auto 20px auto;
    padding: 0 0px;
}
	#topic_path li{
    font-size: 12px;
	}
#content #main h1{
	width:calc(100% - 60px);
	max-width:400px;
	padding:8px 0 8px 0;
	margin-bottom:30px;
	text-align: center;
	font-size:20px;
	font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
	font-weight: bolder; /* Macは太すぎる */
	font-weight: 500;
	background-color: #0E9E80;
	color:#FFF;
}
#content #main img.mv{
	width:100%;
	max-width:700px;
	margin-bottom:30px;
}
#content #main p.lead1{
	font-size:16px;
	text-align: justify;
	margin-bottom:10px;
}
#content #main p.lead2{
	font-size:16px;
	text-align: justify;
	margin-bottom:0px;
}
#content #main p.lead3{
	font-size:14px;
	text-align: justify;
	margin-bottom:10px;
}
#content #main p.lead4{
	font-size:16px;
	text-align: justify;
	margin-bottom:30px;
}
#content #main section{
	margin-bottom: 35px;
}
#content #main section div.title_wrap{
	background-color: #0E9E80;
	padding:3px 0 3px 0;
	margin-bottom: 20px;
}
#content #main section h2{
	background-color: #0E9E80;
	border-top:1px solid #FFF;
	border-bottom:1px solid #FFF;
	padding:8px 0 7px 15px;
	line-height: 100%;
	color:#FFF;
	position: relative;
	font-size:15px;
}

/* CSSハック（Safariのみ） */
@media screen and (-webkit-min-device-pixel-ratio:0) {
	::i-block-chrome, #content #main section h2{
		padding:70px 0 7px 15px;
	}
}


#content #main section h2 span{
	position: absolute;
	right:15px;
	font-weight: normal;
}
#content #main section ul{
	margin-bottom: 30px;
}
#content #main section ul li{
	margin-bottom: 8px;
	padding-left:16px;
	text-indent:-16px;
}
#content #main section ul li span{
	color:#0E9E80;
	margin-right: 2px;
}
#content #main section img.full{
	width: 100%;
	margin: 15px 0 0px 0;
}
#content #main section h3{
	font-size:14px;
	font-weight:normal;
	margin:20px 0 10px 0;
}
#content #main p.promote{
	font-size:16px;
	line-height:150%;
	margin:0px 0 30px 0;
}
#content #main p.guide{
	clear:both;
	border-top:1px solid #CCC;
	text-align:center;
	font-size:16px;
	line-height:150%;
	padding:20px 0 0 0;
	margin-top:50px;
	margin-bottom:40px;
}





@media screen and (max-width:900px) {
	#content{
		padding-bottom:10px;
		width: calc(100% - 30px);
	}
	#content #topic_path{
		padding-left:0px;
		margin-bottom:20px;
	}
	#content #main h1{
		box-sizing: border-box;
		width:100%;
		max-width:inherit;
		padding:8px 0 8px 0;
		font-size:18px;
		margin-bottom:15px;
	}
	#content #main p.lead1{
		font-size:15px;
		line-height: 150%;
		margin-bottom:10px;
	}
	#content #main p.lead2{
		font-size:15px;
		line-height: 150%;
		margin-bottom:0px;
	}
	#content #main p.lead3{
		font-size:13px;
		line-height: 150%;
		margin-bottom:10px;
	}
	#content #main p.lead4{
		font-size:15px;
		line-height: 150%;
		margin-bottom:30px;
	}
	#content #main img.mv{
		margin-bottom:15px;
	}
	#content #main section{
		margin-bottom:25px;
	}
	#content #main section div.title_wrap{
		padding:2px 0 2px 0;
		margin-bottom: 15px;
	}
	#content #main section h2{
		padding:7px 0 8px 10px;
		color:#FFF;
		font-size:16px;
		position: relative;
		margin: 0;
	}
	#content #main section h2 span{
		position: absolute;
		right:10px;
		font-weight: normal;
		font-size:13px;
	}
	#content #main section ul{
		margin-bottom: 20px;
	}
	#content #main section ul li{
		margin-bottom: 8px;
		padding-left:17px;
		text-indent:-17px;
		font-size:15px;
		text-align: justify;
	}
	#content #main section ul li span{
		margin-right: 2px;
	}
	#content #main p.promote{
		font-size:15px;
		line-height:150%;
	}
	#content #main p.guide{
		text-align: center;
		font-size:13px;
		line-height: 150%;
		padding:20px 0 0 0;
		margin-top: 25px;
		margin-bottom: 25px;
	}
}










/* 新免新サポートページ 2026/1から*/
#wrapper{
	font-feature-settings: "palt";

}

#KeyV{
width: 100%;
    position: relative;
    height: 590px;
}
#KeyV li.slider{
    width: 100%;
    position: relative;
}

#KeyV li.slider .bg_catch_2{
position: relative;
        width: 100%;
        height: 590px;
        display: block;
        margin: 0 auto;
background: #DBF0EC;
}


#KeyV li.slider .catch_inner{
position: relative;
        width: 90%;
        max-width: 1300px;
        height: 590px;
        display: block;
        margin: 0 auto;

}


#KeyV li.slider .catch1{
top: 34%;
    position: absolute;
    z-index: 3;
    width: 620px;
    margin: 0 auto;
    left: 0;
    right: 0;
}
#KeyV li.slider .catch1 img{
    width: 100%;
}




#KeyV li.slider .catch2_1{
    top: 28%;
    position: absolute;
    z-index: 3;
    max-width: 620px;
    width: 50%;
    margin: 0 auto;
    left: 0%;
    text-align: center;
}
#KeyV li.slider .catch2_1 img{
    width: 100%;

}


#KeyV li.slider .catch2_2{
    top: 5%;
    position: absolute;
    z-index: 3;
    max-width: 634px;
    width: 52%;
    margin: 0 auto;
    right: 0%;
}

#KeyV img.japan{
    width: 100%;

}




#KeyV img.bg{
    inset: 0;
	width: auto;
    pointer-events: none;
    object-fit: contain;
    z-index: 1;
	transform: translateX(-50%);
	left: 50%;
	position: relative;
}




/* スライダー設定 */
#KeyV .slick-prev
{
    left: 10px;
    background-image: url(../js/slick/icon_arrow_white_left.png);
}

#KeyV .slick-next
{
    right: 10px;
    background-image: url(../js/slick/icon_arrow_white_right.png);
}

#KeyV .slick-prev, #KeyV .slick-next {
    border: 0 none;
    background-color: unset;
    padding: 0;
    margin: 0;
    text-shadow: none;
    box-shadow: none;
    position: absolute;
    width: 20px;
    height: 36px;
    text-indent: -9999px;
    top: 47%;
    opacity: 1;
    transition: all 0.3s ease;
    background-size: contain;
    background-repeat: no-repeat;
    cursor: pointer;
    z-index: 1;
}
.slick-dots {
    position: absolute;
    bottom: -20px;
    list-style: none;
    display: none!important;
    text-align: center;
    padding: 0;
    margin: 0;
    width: 100%;
}

.slick-dots li {
    position: relative;
    display: inline-block;
    height: 20px;
    width: 20px;
    margin: 0 5px;
    padding: 0;
    cursor: pointer;
}
.slick-dots li button {
    border: 0;
    background: transparent;
    display: block;
    height: 20px;
    width: 20px;
    outline: none;
    line-height: 0px;
    font-size: 0px;
    color: transparent;
    padding: 2px;
    cursor: pointer;
}
.slick-dots li.slick-active button:before
{
    opacity: 1;
    color: #777777;
}
.slick-dots li button:before {
    position: absolute;
    top: 0;
    left: 0;
    content: "•";
    width: 20px;
    height: 20px;
    font-family: "slick";
    font-size: 30px;
    line-height: 20px;
    text-align: center;
    opacity: 0.8;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: #c7c7c7;
}
@media screen and (max-width:900px) {


#KeyV .slick-prev, #KeyV .slick-next {
    width: 25px;
    height: 25px;
    top: 45%;
}
#KeyV .slick-next {
right: 0;
}

}


nav.menshin_nav{
width: 100%;
height: 50px;
background-color: #0E9E80;
z-index: 5;
}

.nav_fixed{
position: fixed;
    top: 80px;
    z-index: 1;
@media screen and (max-width:900px) {
    top: 50px;

}
}



nav.menshin_nav ul{
display: flex;
    max-width: 1000px;
    margin: 0 auto;
    justify-content: center;
    gap: 24px;
    align-items: center;
    height: 100%;
}

nav.menshin_nav ul li{

}


nav.menshin_nav ul li a{
color: #fff;
font-size: clamp(13px, 1.3vw, 14px);
font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;

}

nav.menshin_nav ul li::after{
    content: "|";
    color: #fff;
    margin: 0px 0px 0 24px;
    display: inline-block;

}

@media screen and (max-width: 640px) {
nav.menshin_nav ul li::after{
    margin: 0px 0px 0 16px;
}
}


nav.menshin_nav ul li:last-child::after{
    display: none;
}



h2.menshin_title{
    background-color: #0E9E80;
    color: #fff;
    padding: 6px 0 5px;
    text-align: center;
    width: 100%;
    position: relative;
    font-size: 18px;
}

h2.menshin_title::before{
background-color: #0E9E80;
content: "";
position: absolute;
height: 4px;
width: 100%;
display: block;
top: -5px;
}

h2.menshin_title::after{
background-color: #0E9E80;
content: "";
position: absolute;
height: 4px;
width: 100%;
display: block;
bottom: -5px;
}




#menshin_menu_btn{
	display: none;
}

@media screen and (max-width:900px) {

nav.menshin_nav ul li a{
font-size: clamp(8px, 1.1vw, 16px);
}



}





@media screen and (max-width:1200px) {
#KeyV li.slider .catch2_1 {
    max-width: 620px;
    width: 50%;

}
#KeyV li.slider .catch2_2 {
        bottom: 6%;
        top: auto;
        position: absolute;
        z-index: 3;
        max-width: 634px;
        width: 60%;
        margin: 0 auto;
        right: 0%;
}


}


@media screen and (max-width: 640px) {

#KeyV{
width: 100%;
    position: relative;
    height: auto;
}
#KeyV img.bg{
        width: 1000px;
        position: relative;
        transform: translateX(-50%);
        height: 360px;
        object-fit: cover;
}

#KeyV li.slider .bg_catch_2{
position: relative;
        width: 100%;
        height: 360px;
        display: block;
        margin: 0 auto;
background: #DBF0EC;
}


#KeyV li.slider .catch_inner{
position: relative;
        width: 90%;
        max-width: 1300px;
        height: 360px;
        display: block;
        margin: 0 auto;
}


#KeyV li.slider .catch1{
    top: 34%;
        position: absolute;
        z-index: 3;
        width: 80%;
        max-width: 340px;
        margin: 0 auto;
        left: 0;
        right: 0;
}
#KeyV li.slider .catch1 img{
    width: 100%;
}




#KeyV li.slider .catch2_1{
        width: 100%;
        max-width: 320px;
        top: 3%;
        left: 0;
        right: 0;
}
#KeyV li.slider .catch2_1 img{
    width: 100%;

}


#KeyV li.slider .catch2_2{
        bottom: 5%;
        top: auto;
        position: absolute;
        z-index: 3;
        max-width: 240px;
        width: 100%;
        margin: 0 auto;
        left: 0%;
}

#KeyV img.japan{
    width: 100%;

}

}


@media screen and (max-width: 640px) {

#menshin_menu_btn{
	display: block;
}


.menshin_menu_btn {
position: fixed;
        top: 0;
        right: 50px;
        z-index: 1000;
        background: #0E9E80;
        color: white;
        border: none;
        padding: 15px 20px 14px;
        font-size: 14px;
        font-weight: bold;
        cursor: pointer;
		        height: 50px;
  }


#menshin_mobile_nav {
    position: fixed;
    top: -210px;
    left: 0;
    right: 0;
    width: 100%;
    background: #0E9E80;
    z-index: 999;
	transition: all 0.5s;
	height: auto;
}
#menshin_mobile_nav.show {
top: 50px;
}

nav.menshin_nav ul {
	display: flex;
    margin: 0 auto;
    gap: 0px;
    flex-wrap: wrap;
    justify-content: left;
}

nav.menshin_nav ul li{
width: calc(50% - 8px);
}
nav.menshin_nav ul li a {
        color: #fff;
        font-size: 12px;
        display: block;
        padding: 16px 16px;
}

nav.menshin_nav ul li::after {
   display: none;
}


}











/* 下層ページ用 */

#sub_menshin_mobile_nav {
    position: fixed;
    top: -200px;
    left: 0;
    right: 0;
    width: 100%;
    background: #0E9E80;
    z-index: 999;
	transition: all 0.5s;
	height: auto;
}
#sub_menshin_mobile_nav.show {
top: 50px;
}













p.lead{
    width: 95%;
    max-width: 1000px;
    margin: 32px auto 20px auto;
	font-size: 20px;
	text-align: center;
	line-height: 170%;
	  @media (max-width: 640px) {
		font-size: 16px;
		text-align: left;
		width: 90%;
	  }

}

p.lead2{
    width: 95%;
    max-width: 1000px;
    margin: 32px auto 20px auto;
	font-size: 16px;
	text-align: center;
	line-height: 170%;
	  @media (max-width: 640px) {
		font-size: 16px;
		text-align: left;
		width: 100%;
	  }

}




section.user_segmentation{
    width: 100%;
    background: #F0EDE5;
}

section.user_segmentation .inner{
	width: 95%;
	max-width: 1000px;
    margin: 56px auto 56px auto;
    padding: 48px 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
	@media (max-width: 640px) {
		margin: 32px auto 56px auto;
		padding: 48px 0 24px;
	}
}

section.user_segmentation .inner h2{
width: 100%;
text-align: center;
margin: 0 0 48px 0;
	@media (max-width: 640px) {
		font-size: 18px;
	}
}


section.user_segmentation .inner dl::before{
	content: "";
    display: block;
    width: 100%;
    height: 6px;
    background: linear-gradient(90deg, rgba(32, 145, 217, 1) 0%, rgba(43, 190, 143, 1) 100%);
    padding: 0;
    position: absolute;
    top: 0;
    left: 0;
}


section.user_segmentation .inner dl{
    display: flex;
    width: calc(50% - 20px);
    background: #fff;
    border: 1px #ccc solid;
    justify-content: space-between;
    position: relative;
    align-items: center;
	overflow: hidden;
	@media (max-width: 640px) {
	width: 90%;
    margin: 0 auto 20px;
	padding: 0px;
	}
}

section.user_segmentation .inner dl a{
display: flex;
align-items: center;
transition: all 0.3s;
padding: 0px 32px 0px;
justify-content: center;
gap:20px;
	@media (max-width: 640px) {
	padding: 0px 16px 0px;
	}
}

section.user_segmentation .inner dl a:hover{
text-decoration: none;
transition: all 0.3s;
opacity: 0.6;
}


section.user_segmentation .inner dl:nth-of-type(1) figure{
width: 31.5%;
    position: relative;
    top: 12px;
    @media (max-width: 640px) {
width: 31%;
	}
}
section.user_segmentation .inner dl:nth-of-type(2) figure{
width: 31.5%;
    position: relative;
    top: 12px;
    @media (max-width: 640px) {
width: 31%;
	}
}


section.user_segmentation .inner dl figure img{
display: block;
width: 100%;
}
section.user_segmentation .inner dl .text{
width: 62%;
margin: 16px 0 0 0px;
		@media (max-width: 640px) {
        width: 68%;
margin: 16px 0 16px 24px;
		}
}
section.user_segmentation .inner dl dt{
    margin: 0px auto 0px auto;
    padding: 0px 0px 0px;
    font-size: 16px;
    cursor: pointer;
    display: flex;
    width: 100%;
    justify-content: space-between;
	@media (max-width: 640px) {
		font-size: 14px;
	}
}

section.user_segmentation .inner dl dt div{
margin: 0;
    padding: 0px;
    font-size: 20px;
    cursor: pointer;
    color: #0e9e80;
    font-weight: bold;
    display: flex;
    width: 100%;
    justify-content: space-between;
		@media (max-width: 640px) {
		 font-size: 14px;
             align-items: center;
		}
}

section.user_segmentation .inner dl dt span{
    margin: 0;
    padding: 0px;
    font-size: 16px;
    cursor: pointer;
    color: #0e9e80;
    font-weight: bold;
    transform: scaleY(1.5);
    line-height: 130%;
	@media (max-width: 640px) {
	margin: 0px 0 0px 0;
    font-size: 12px;
    transform: scaleY(1.3);
	}
}

section.user_segmentation .inner dl dd{
margin: 18px auto 0px auto;
    padding: 0 0 0 0px;
    font-size: 16px;
    line-height: 160%;
        color: #333;
@media (max-width: 640px) {
    font-size: 12px;
    margin: 8px auto 0px auto;

	}
}



.maintenance_features{
    max-width: 1000px;
	margin: 20px auto 20px auto;
    width: 90%;
}

.maintenance_features h2{

	
}

.maintenance_features .inner{
    display: flex;
    width: 100%;
	max-width: 997px;
    justify-content: space-between;
		@media (max-width: 640px) {
			width: 90%;
			margin: 0 auto;
			display: block;
		}
}

.maintenance_features .inner ul.features_list{
margin: 40px 0 40px;
padding-left: 2px;
	@media (max-width: 640px) {
		padding-left: 16px;
	}
}
.maintenance_features .inner ul.features_list li{
font-size: 18px;
    margin: 0 0 8px;
	@media (max-width: 640px) {
		margin: 0 0px 12px 8px;
        font-size: 16px;
        line-height: 140%;
        font-weight: 500;
	}
}
.maintenance_features .inner ul.features_list li::before{
	font-size: 16px;
  color: #0e9e80;
  font-weight: bold;
  content: "●";
   margin: 0 8px 0 0px;
   @media (max-width: 640px) {
    margin: 0 0px 0 0px;
    left: 38px;
	position: absolute;
    font-size: 10px;
   }
}

.maintenance_features .inner .jssi_membership{
background: #EEE;
    padding: 18px 30px 23px 30px;
    /*width: 33%;*/
    border-radius: 8px;
    margin: 32px 0 32px;
	@media (max-width: 640px) {
padding: 20px 4% 14px;
        width: 92%;
        margin: 32px auto 32px;
	}
}

.maintenance_features .inner .jssi_membership h3.jssi_membership__title{
font-size: 16px;
margin: 0 0 16px 0;
text-align: center;
}

.maintenance_features .inner .jssi_membership .jssi_membership__list{
max-width: 260px;
margin: 0 auto;
}
.maintenance_features .inner .jssi_membership .jssi_membership__list li{
   list-style: disc;
    list-style-position: inside;
    margin: 0 0px 0 0px;
	font-size: 15px;
   @media (max-width: 640px) {
    font-size: 14px;
    letter-spacing: -0.5px;
   }
}
.maintenance_features .inner .jssi_membership .jssi_membership__list li strong{
margin: 0 0 0 -4px;
    width: 100px;
    display: inline-block;
}


.flow_block{
    max-width: 1000px;
    width: 90%;
	margin: 20px auto 64px auto;
	@media (max-width: 640px) {
		margin: 20px auto 32px auto;
        width: 100%;
        overflow-x: scroll;
	}

}

.flow_block h3{
margin: 36px 0 28px;
    text-align: center;
    font-size: 18px;
		@media (max-width: 640px) {
			width: 95%;
			margin: 36px auto 28px;
			line-height: 140%;
		}

}



.flow_block .inner{

		}


.flow_block ul.tenken_flow{
    display: flex;
    width: 100%;
	justify-content: space-between;

		}

.flow_block ul.tenken_flow li{
	font-size: 16px;
    width: 138px;
    height: 140px;
    position: relative;
    clip-path: polygon(0% 0%, 85% 0%, 100% 50%, 85% 100%, 0% 100%);
}



@media (max-width: 1000px) {

.flow_block .inner{
        display: flex;
        justify-content: space-between;
        width: 100%;
        flex-wrap: nowrap;
        margin: 0 auto 0;
        overflow-x: scroll
}

.flow_block .inner ul.tenken_flow {
        flex-wrap: nowrap;
justify-content: left;
        padding: 0px 0px;
}
    .flow_block ul.tenken_flow li{
        width: calc(24% - 5px);
        margin: 0 1.5% 16px 0;
    }

}
	@media (max-width: 640px) {

.flow_block .inner{
        display: flex;
        justify-content: space-between;
        width: 90%;
        flex-wrap: nowrap;
        margin: 0 auto 0;
        overflow-x: scroll;
}

.flow_block ul.tenken_flow{
        justify-content: left;
        width: 2854px;
        display: flex;
        flex-wrap: nowrap;
		}

    .flow_block ul.tenken_flow li{
        width: 110px;
        margin: 0 1.2% 16px 0;
    }


	}


.flow_block ul.tenken_flow li:nth-of-type(1){
	background: #1f8ac0;
/*background: #447fc0;*/
}
.flow_block ul.tenken_flow li:nth-of-type(1)::after{
  background: #1f8ac0;
	/*background: #447fc0;*/
}
.flow_block ul.tenken_flow li:nth-of-type(2){
	 background: #2b9ccc;
	/*background: #3986b3;*/
}
.flow_block ul.tenken_flow li:nth-of-type(2)::after{
   /* background: #3986b3;*/
	 background: #2b9ccc;
}

.flow_block ul.tenken_flow li:nth-of-type(3){
/*background: #318aa9;*/
	background: #2fa8c8; 
}
.flow_block ul.tenken_flow li:nth-of-type(3)::after{
   /* background: #318aa9; */
	background: #2fa8c8; 
}

.flow_block ul.tenken_flow li:nth-of-type(4){
/*background: #2d8da5;*/
background: #35b2c3;	
}
.flow_block ul.tenken_flow li:nth-of-type(4)::after{
/*background: #2d8da5;*/
background: #35b2c3;
}

.flow_block ul.tenken_flow li:nth-of-type(5){
/*background: #26909d;*/
background: #3bbcbf;

}
.flow_block ul.tenken_flow li:nth-of-type(5)::after{
/*background: #26909d;*/
background: #3bbcbf;
}


.flow_block ul.tenken_flow li:nth-of-type(6){
/*background: #1a978e;*/
	background: #3fc5b3;
}
.flow_block ul.tenken_flow li:nth-of-type(6)::after{
/*background: #1a978e;*/
background: #3fc5b3;

}

.flow_block ul.tenken_flow li:nth-of-type(7){
background: #41c9a5;
/*background: #0e9e80;*/
    clip-path: unset;
}
.flow_block ul.tenken_flow li:nth-of-type(7)::after{
display: none;
}


.flow_block ul.tenken_flow li span.number{
/* opacity: 0.5; */
    color: #fff;
    left: -8px;
    display: block;
    margin: 0 0 20px;
    position: absolute;
    text-align: center;
    width: 100%;
    top: 27%;
}
.flow_block ul.tenken_flow li span.number img{
 height: 42px;
    display: block;
    margin: 0 auto;
}



.flow_block ul.tenken_flow li span.text{
color: #fff;
    position: absolute;
    text-align: center;
    width: 100%;
    top: 65%;
    left: -6px;
    font-weight: bold;
    @media (max-width: 640px) {
        font-size: 14px;
    }
}

.flow_block ul.tenken_flow li:nth-of-type(7) span.number{
left: 0px;
}


.flow_block ul.tenken_flow li:nth-of-type(7) span.text{
left: 0px;
}













.contact_block{
    max-width: 1000px;
	margin: 20px auto 56px auto;
}

.contact_block h3{
    margin: 36px 0 28px;
    text-align: center;
    font-size: 20px;
@media (max-width: 640px) {
	width: 90%;
	margin: 36px auto 28px;
	line-height: 140%;
}
	
}

.contact_block article{
    max-width: 760px;
    width: 90%;
    margin: 20px auto 20px auto;
    background: #eef8f6;
    border: 2px solid #0e9e80;
	border-radius: 5px;
    padding: 25px 30px 35px;
	@media (max-width: 640px) {
		width: 80%;
padding: 30px 5%;

	}
}

.contact_block article .to_form{
border-bottom: 1px #0e9e80 dashed;
    padding: 0 0 28px;
}
.contact_block article .to_form h4{
font-size: 24px;
color:#0e9e80;
text-align: center;
margin: 0 0 20px;
	@media (max-width: 640px) {
		line-height: 140%;
	}

}



.contact_block article .to_form a.btn01{
    font-size: 16px;
	font-weight: 600;
    color: #fff;
    background: #0e9e80;
    border-radius: 30px;
    width: 80%;
    max-width: 270px;
    margin: 0 auto;
    display: block;
    text-align: center;
    padding: 9px 8px 8px;
    transition: all 0.3s;
}

.contact_block article .to_form a.btn01:hover{
opacity: 0.7;
transition: all 0.3s;
text-decoration: none;
}

.contact_block article .to_form{
border-bottom: 1px #0e9e80 dashed;
    padding: 0 0 27px;
}



.contact_block article ul.tel_time{
    padding: 31px 0 0px;
}
.contact_block article ul.tel_time li{
    color: #0e9e80;
	text-align: center;
	font-size: 16px;
}

.contact_block article ul.tel_time li:nth-of-type(1){
font-size: 18px;
    margin: 0 0 7px 0px;
    color: #0e9e80;
	font-weight: bold;
	@media (max-width: 640px) {
		line-height: 140%;
	}
}
.contact_block article ul.tel_time li:nth-of-type(1) a{
	font-size: 24px;
	margin: 0 0 0 8px;
    color: #0e9e80;
	display: inline-block;
	pointer-events: none;
}
.contact_block article ul.tel_time li:nth-of-type(2){

}

@media screen and (max-width: 640px) {
.contact_block article ul.tel_time li:nth-of-type(1) a{
pointer-events: auto;
}


}


/* イーステック免震サポート */
article.eastec_menshin_support{
	/* width: 100%; */
	margin: 20px auto 20px auto;
background: #FFF8D9;
    color: #0e9e80;
	/*padding: 32px;*/
	padding: 40px 20px 20px;
}

article.eastec_menshin_support a{
    color: #0e9e80;
}

article.eastec_menshin_support h2.menshin_title0{
	width: 100%;
    color: #0e9e80;
	text-align: center;
	font-size: 30px;
@media screen and (max-width: 640px) {
	font-size: 24px;
}
}





section.tenken_list{
    max-width: 1000px;
    width: 100%;
    margin: 35px auto 36px auto;

}
section.tenken_list ul{
    width: 100%;
    margin: 40px auto 0px auto;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}

section.tenken_list ul li{
	    margin: 0 0 16px;
	    width: calc(33% - 8px);
	@media (max-width: 640px) {
    width: calc(50% - 8px);
	}

}
section.tenken_list ul li a{
    display: block;
    background: #fff;
    padding: 18px 0px 16px;
    border: 1px #0e9e80 solid;
    border-radius: 6px;
    text-align: center;
    font-size: 20px;
    font-weight: bold;
	position: relative;
	text-decoration: none;
	transition: all 0.3s;
	@media (max-width: 640px) {
		text-align: left;
    padding: 16px 8px 12px;
        font-size: 16px;
	}
}
section.tenken_list ul li a:hover{
	transition: all 0.3s;
	background: #0e9e80;
	color: #fff;
}

section.tenken_list ul li a::after{
	/*content: ">";*/
	content: "";
    position: absolute;
    right: 17px;
	bottom: 18px;
    margin: -1px 0 0px 0;
	background-image: url("../img/arrow.png");
	width: 11px;
	height: 18px;
	background-size: contain;
	@media (max-width: 640px) {
    right: 14px;
    bottom: 14px;
    }
}








section.meshin_buzai_list{
    max-width: 1000px;
    width: 100%;
    margin: 32px auto 48px auto;
	@media (max-width: 640px) {
		margin: 32px auto 32px auto;
	}
}
section.meshin_buzai_list ul{
    width: 100%;
    margin: 40px auto 0px auto;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}

section.meshin_buzai_list ul li{
	width: calc(25% - 12px);
	@media (max-width: 640px) {
    width: calc(50% - 8px);
	    margin: 0 0 16px;
	}
}
section.meshin_buzai_list ul li a{
    display: block;
    background: #fff;
    padding: 18px 0px 16px;
    border: 1px #0e9e80 solid;
    border-radius: 6px;
    text-align: center;
    font-size: 20px;
    font-weight: bold;
	position: relative;
	text-decoration: none;
	transition: all 0.3s;
		@media (max-width: 640px) {
		text-align: left;
    padding: 16px 8px 12px;
            font-size: 16px;
	}
}
section.meshin_buzai_list ul li a:hover{
	transition: all 0.3s;
	background: #0e9e80;
	color: #fff;
}


section.meshin_buzai_list ul li a::after{
	content: "";
    position: absolute;
 	right: 17px;
	bottom: 18px;
    margin: -1px 0 0px 0;
	background-image: url("../img/arrow.png");
	width: 11px;
	height: 18px;
	background-size: contain;
@media screen and (max-width: 640px) {
	right: 14px;
	bottom: 14px;

}
}









section.ordermade_list{
    max-width: 1000px;
    width: 100%;
    margin: 32px auto 16px auto;
	@media (max-width: 640px) {
		margin: 24px auto 0px auto;
	}
}
section.ordermade_list ul{
    width: 100%;
    margin: 40px auto 0px auto;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}

section.ordermade_list ul li{
	width: calc(50% - 12px);
	@media (max-width: 640px) {
	width: calc(50% - 8px);
    margin: 0 0 16px;
	}
}
section.ordermade_list ul li a{
    display: block;
    background: #fff;
    padding: 18px 0px 16px;
    border: 1px #0e9e80 solid;
    border-radius: 6px;
    text-align: center;
    font-size: 20px;
    font-weight: bold;
	position: relative;
	text-decoration: none;
	transition: all 0.3s;
	@media (max-width: 640px) {
	text-align: left;
    padding: 16px 8px 12px;
    font-size: 16px;
	}
}
section.ordermade_list ul li a:hover{
	transition: all 0.3s;
	background: #0e9e80;
	color: #fff;
}

section.ordermade_list ul li a::after{
	content: "";
    position: absolute;
    right: 17px;
	bottom: 18px;
    margin: -1px 0 0px 0;
	background-image: url("../img/arrow.png");
	width: 11px;
	height: 18px;
	background-size: contain;
	@media (max-width: 640px) {
    right: 14px;
	bottom: 14px;
    }
}









p.bottom_lead{
margin: 40px 0 44px;
	text-align: center;
	font-size: 18px;
		@media (max-width: 640px) {
			font-size: 14px;
			width: 90%;
			margin: 40px auto 44px;
			text-align: left;
		}
}




/* トップここまで */




/* 下層ページ ここから*/

#subKeyV{
width: 100%;
    position: relative;
    height: 295px;
}

#subKeyV img{
	position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    pointer-events: none;
    z-index: 1;
}

#subKeyV h1.title01{
 position: absolute;
    z-index: 2;
    margin: 0 auto;
    left: 0;
    right: 0;
    top: 34%;
    width: 377px;
    background: rgb(255 255 255 / 85%);
    padding: 5px 5px;
    text-align: center;
    border: #0ea587 1px solid;
}
#subKeyV h1.title01 .inner{
content: "";
    border: #0ea587 1px solid;
    height: 100%;
    padding: 20px 0 20px;
    color: #0ea587;
    display: block;
}
@media screen and (max-width: 450px) {
#subKeyV h1.title01{
    width: 90%;
}
#subKeyV h1.title01 .inner{
font-size: clamp(20px, 5vw, 40px);
}


}




/* 点検について */
.about_tenken_block{
width: 100%;
    max-width: 1000px;
    margin: 20px auto 100px auto;
}


/* 免震とは */
.about_menshin_block{
width: 100%;
    max-width: 1000px;
    margin: 20px auto 100px auto;
}


/* 実績とは */
.jisseki_block{
width: 100%;
    max-width: 1000px;
    margin: 20px auto 100px auto;
}





/* Q&Aここから */

.qanda_block{
width: 100%;
    max-width: 1000px;
    margin: 20px auto 100px auto;
}

.qanda_block dl{
    margin: 20px auto 20px auto;
	color: #333;
	width: 95%;
	border-bottom: #333 1px dotted;
}
  .qanda_block h3{
        font-size: 20px;
        font-weight: 600;
        color: #0e9e80;
        margin: 8px 0 0;
        border-bottom: #0e9e80 1px solid;
        padding: 0 0 20px;
    }


.qanda_block section:first-of-type{
    margin: 40px auto 20px auto;
}

 .qanda_block section{
        padding-bottom: 15px;
            width: 90%;
            margin: 20px auto 20px auto;
    }


.qanda_block dl dt{
    margin: 12px auto 12px auto;
    font-size: 16px;
    padding: 0px 20px 4px;
    cursor: pointer;
    display: flex;
	position: relative;
        line-height: 150%;
}
.qanda_block dl dd{
    margin: 20px 20px 20px 20px;
	display: none;
    line-height: 180%;
}

.qanda_block dl dt span.q{
display: inline-block;
width: 18px;
font-size: 16px;
margin: 0 28px 0 0;
}
.qanda_block dl dt span.icon{
    color: #333;
    border: #333 solid 1px;
    width: 18px;
    height: 18px;
    display: inline-block;
    vertical-align: middle;
    font-size: 22px;
    position: absolute;
    right: 32px;
    line-height: 20px;
    text-align: center;
}
.qanda_block dl dt span.icon .plus{
    position: absolute;
    right: 0;
    left: 1px;
    top: 1px;
	display: block;
    transition: transform 0.3s ease;
}
.qanda_block dl dt span.icon .minus{
    position: absolute;
    right: 1px;
    left: 2px;
    top: 2px;
	display: block;
    transition: transform 0.3s ease;
}

.qanda_block dl dt div{
    display: block;
    width: calc(100% - 94px);
    font-size: 16px;
    margin: 0 0 0 0px;
}

.qanda_block dl dd span{
display: inline-block;
width: 18px;
font-size: 16px;
margin: 0 28px 0 0;
}
.qanda_block dl dd div.inner{
display: flex;
width: auto;
font-size: 16px;
margin: 0 0 0;
}
.qanda_block dl dd div.text{
display: block;
width: auto;
font-size: 16px;
margin: 0 0 0;
}

.qanda_block dl dd div.text br{
display: none;

}

.qanda_block dl dd div.inner br{
display: none;

}



/* Q&Aここまで */





/* 実績とは */
.jisseki_block{
width: 100%;
    max-width: 1000px;
    margin: 20px auto 100px auto;
}







/* 免責サポートのお問い合わせとは */
.contact_form_block{
width: 100%;
    max-width: 1000px;
    margin: 74px auto 100px auto;
}

.contact_form_block #contact{
    margin: 32px auto 20px auto;
    font-size: 16px;
    line-height: 170%;
}
.contact_form_block #contact p{
    text-align: center;
}
.contact_form_block .topics_link{
    margin: 32px auto 100px auto;
}


button{
    border: none;
}












/* 下層ページ ここまで*/


