@charset "UTF-8";

* {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
	line-height:1.5;
}

html{
	/* font-size: 62.5%; */
	 font-size: 53%; 
}
body{
	font-family: "メイリオ",Meiryo,"Hiragino Kaku Gothic Pro","ヒラギノ角ゴ Pro W3","ＭＳ Ｐゴシック","Lucida Grande","Lucida Sans Unicode",Arial,Verdana,sans-serif;
	font-size: 16px;
	color: #333;
	position: relative;
/*	letter-spacing: .1em; */
	line-height: 1;
	font-weight: 400;
	overflow-x:hidden;
	background-color:#fafafa
}
main{
	display: block;
}

main h1.midashi{
	color:dodgerblue;
	font-size:28px;
	text-align:center;
}

img{
	border:none;
	-webkit-backface-visibility: hidden;
}
ul,ol{
	list-style: none;
}
li{
	list-style-type: none;
}

a{
	text-decoration: none;
	color: #333;
	transition: .3s all ease;
}
a:hover{
	opacity: .7;
	filter: alpha(opacity=70);
}

.sp{
	display: none !important;
}

.pic img,
.pic picture,
.pic source,
.pic a{
	display: block;
	width: 100%;
}
.pic img{
	height: 100%;
	object-fit: cover;
	font-family: "object-fit: cover;";	
}
#works .pic img{ aspect-ratio: 16/10; }
table{
	border-collapse: collapse;
	table-layout: fixed;
	width: 100%;
}
.bold{
	font-weight: 600;
}
.medium{
	font-weight: 500;
}
.parag{
	line-height: 1.5;
}
.inner{
	/*
	width: 120rem;
	
	width:140rem; */
	padding-left: 5rem;
	padding-right: 5rem;
	margin: 0 auto;
	position: relative;
}
.outer{
	width: 100%;
	/* min-width: 120rem; */
	position: relative;
}
.max1500{
	max-width: 150rem;
	min-width: 110rem;
	margin: 0 auto;
}
.bg-gray{
	background: #fafafa;
}
.sec{
	padding: 20px;
	position: relative;
}
.en{
	letter-spacing: .05em;
}
.d-inline-block{
	display:inline-block;
}
.justify-space-between{
	justify-content:space-between;
}
.flex-column{
	flex-direction:column;
}
.back-transparent{ background:transparent!important; }
.red{ color:red; }
.d-flex{
	display:flex;
}
.align-items-center{
	align-items:center;
}

.fuchidori {
	text-shadow:2px 2px 2px #FFF, -2px -2px 2px #FFF,
				-2px 2px 2px #FFF, 2px -2px 2px #FFF,
				0px 2px 2px #FFF,  0 2px 2px #FFF,
				2px 0 2px #FFF, 2px 0 2px #FFF;
  }
.aowaku{ border:5px solid #7be5ff; /* border-radius:10px; background-color:#effdfe; */ padding:30px; margin-top:16px; }

/* +++++++++++++++++++++++header++++++++++++++++++++++ */
#site-ttl{
	position: absolute;
	left: 5rem;
	top: 2rem;
	font-size: 1.2rem;
	z-index: 9;
	font-weight: 500;
}
#header{
	position: sticky;
	/*left: 5rem;*/
	left: 0;
	right: 0;
	margin-left: auto;
	margin-right: auto;
	top: 5rem;
	background: #fff;
	width: calc(100% - 10rem);
	/*min-width: 110rem;*/
	height: 10rem;
	box-shadow: 0 10px 30px rgba(0,0,0,.1);
	display: flex;
	justify-content: space-between;
	align-items: center;
	z-index: 999;
	transition: .3s all ease;
}
#header.fixed{
	top: 1rem;
	height: 7.5rem;
}
#header .logo{
	width: 20rem;
	margin-left: 5rem;
}
#header .logo img{
	width:250px;
	margin-left:-50px;
}
#global-navi{
	display: flex;
	font-weight: 500;
	/*font-size: 1.5rem;*/
	font-size: 14px;
}
#global-navi>li:not(.head-btn){
	display: flex;
	justify-content: center;
	align-items: center;
	padding-left: 2rem;
	padding-right: 2rem;
	position: relative;
	width:180px; /*240131 追加*/
}
#global-navi li.head-btn{
	padding-left: 0;
	padding-right: 0;
	margin-right: 0;
	width: 20rem;
	border-left: .1rem solid #fff;
}
#global-navi .child{
	position: absolute;
	left: -25%;
	right: 0;
	top: calc(100% - 1.5rem);
	background: #fff;
	width: 150%;
	box-shadow: 0 20px 30px rgb(0 0 0 / 5%);
	transform: translateY(2rem);
	visibility: hidden;
	transition: .4s all ease;
	opacity: 0;
}
@media screen and (min-width: 769px){
	#global-navi>li:hover>.child{
		visibility: visible;
		transform: translateY(0);
		opacity: 1;
	}
}
#global-navi ul.child li{
	padding: 0;
	text-align: center;
	height: 6rem;
}
#global-navi ul.child li a{
	display: flex;
	width: 100%;
	height: 100%;
	align-items: center;
	justify-content: center;
	font-size: 1.6rem;
}
#global-navi ul.child li:not(:last-of-type) a{
	border-bottom: .1rem solid #fafafa;
}
#global-navi ul.child li a:hover{
	background: #fafafa;
}
.head-btn a{
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	/*background: #009d80;*/
	background:	dodgerblue;
	height: 10rem;
}
.fixed .head-btn a{
	height: 7.5rem;
}
.head-btn.tel-btn a{
	font-size: 1.7rem;
	font-weight: 500;
	letter-spacing: .05em;
	background: #333;
}
.head-btn.contact-btn{
	margin-left: 2rem;
}
.head-btn.contact-btn a{
	letter-spacing: .2em;
	flex-direction: column;
}
.head-btn.contact-btn a:before{
	content: "";
	display: block;
	width: 2.4rem;
	height: 1.8rem;
	margin-bottom: 1rem;
	background: url(../images/renewal/header-icon02.svg) no-repeat;
	background-size: 100% auto;
}
.head-btn.tel-btn a:before{
	content: "";
	display: block;
	width: 1.8rem;
	height: 1.8rem;
	margin-right: .25em;
	background: url(../images/renewal/header-icon01.svg) no-repeat;
	background-size: 100% auto;
}


/* +++++++++++++++++++++++contents++++++++++++++++++++++ */
.sec-ttl01{
	font-size: 1.8rem;
	display: flex;
	align-items: flex-end;
	margin-bottom: 5rem;
}
.sec-ttl01 .en{
	font-size: 5rem;
	padding-right: 2rem;
	color:dodgerblue;
}
.sec-ttl01 .ja{
	padding-bottom: .35em;
}
.sec-ttl02{
	display: flex;
	font-size: 100%;
	align-items: flex-end;
	line-height: 1;
}
.sec-ttl02 .en{
	font-size: 20px;
	color:dodgerblue;
	letter-spacing: .05em;
	padding-right: .5em;
}
.sec-ttl02 .ja{
	padding-bottom: .3em;
	font-size: 14px;
}
.sec-ttl03{
	//font-size: 1.2rem;
	font-size:16px;
	font-weight: 500;
}
.sec-ttl03 span{
	//font-size: 2rem;
	font-size:20px;
	margin-right: 1.5rem;
}
.sec-ttl04{
	display: flex;
	font-size: 1.8rem;
	align-items: flex-end;
	line-height: 1;
}
.sec-ttl04 .en{
	font-size: 200%;
	color:dodgerblue;
	letter-spacing: .05em;
	padding-right: .5em;
}
.sec-ttl04 .ja{
	padding-bottom: .3em;
}
.sec-ttl05{
	color:dodgerblue;
	text-align: center;
	margin-bottom: 5rem;
	font-size: 3.6rem;
}
/* .btn01{
	width: 24rem;
	height: 6rem;
	display: flex;
	align-items: center;
	color: #fff;
	padding-left: 3rem;
	background-color: #444;
	background-image: url(../images/renewal/btn01-arrow.png);
	background-repeat: no-repeat;
	background-position: right 1.5rem center;
	transition: .075s all ease;
} */
.btn01{
	width: 280px;
	height: 60px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	background-color: #369;
	transition: .075s all ease;
}
.btn01:hover{
	background-position: right 1rem center;
	opacity: 1;
	filter: alpha(opacity=100);
}

.btn01.large{
	width: 100rem;
	font-size: 1.6rem;
	justify-content: center;
	background-image: url(../images/renewal/contact-area-arrow01-2.png);
	background-position: right 6rem center;
	height: 10rem;
	z-index: 9;
	position: relative;
	padding: 0;
}
.btn01.large:hover{
	background-position: right 3rem center;
}

.btn02{
	display: flex;
	align-items: center;
}
.btn02:after{
	content: "";
	display: block;
	width: 2.6rem;
	height: 2.6rem;
	margin-left: 1rem;
	background: url(../images/renewal/index-arrow01.png) no-repeat;
	background-size: 100% auto;
	background-position: center center;
}



/* +++++++++++++++++++++++#contact-area++++++++++++++++++++++ */
#contact-area{
	text-align: center;
	padding-left: 0;
	padding-right: 0;
	border-top: .1rem solid #ddd;
	background: #fff;
}
aside .sec-ttl02{
	flex-direction: column;
	align-items: center;
	margin-bottom: 4rem;
}
aside .sec-ttl02 .en{
	padding: 0 0 2rem 0;
	color: #333;
}
#contact-area ul{
	display: flex;
	align-items: center;
	border-left: .1rem solid #ddd;
	padding: 0;
}
#contact-area li:nth-of-type(1){
}
#contact-area li{
	width: 50%;
	display: flex;
	align-items: center;
	padding: 3rem;
}
#contact-area li:nth-of-type(1) a{
	display: flex;
	flex-direction: column;
	justify-content: center;
	text-align: left;
	background-color: dodgerblue;
	background-repeat: no-repeat;
	background-image: url(../images/renewal/contact-arrow.svg);
	background-position: right 25px center;
	background-size: 1.8rem auto;
	padding: 1.5rem 6rem;
	height: 12rem;
	border-radius: 6rem;
	color: #fff;
	width: 100%;
	font-size: 14px;
	//height: 30.9rem;
}
#contact-area a .en{
	font-size: 16px;
	padding-bottom: .5rem;
}
#contact-area li:nth-of-type(2){
	justify-content: center;
	border-left: .1rem solid #ddd;
	border-right: .1rem solid #ddd;
}
#contact-area li:nth-of-type(2) a{
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
}
#contact-area li:nth-of-type(2) a .en{
	font-size: 2.5rem;
}
#contact-area dl{
	display: flex;
	line-height: 2;
}
#contact-area dt{
	padding-right: 1.5em;
}
#contact-area dd{
	text-align: right;
}



/* +++++++++++++++++++++++#link-banners++++++++++++++++++++++ */
#link-banners ul{
	display: flex;
	justify-content: space-between;
	max-width: 120rem;
	width: 100%;
}
#link-banners li{
	width: calc(33% - 2rem);
}
#link-banners img,
#link-banners a{
	display: block;
	width: 100%;
}





/* +++++++++++++++++++++++footer++++++++++++++++++++++ */
#footer{
	padding: 5rem;
	background: #444;
	color: #fff;
}
#footer>.address{
	clear: both;
	padding-top: 3rem;
}
#footer .logo{
	//width: 20rem;
	//float: left;
}
#footer_telln_logo{ width:250px; margin-left:-45px; }
#footer h2{
	/*float: left;
	//font-size: 1.2rem;*/
	font-size:14px;
	/*margin-left: 2rem;*/
	height: 3.8rem;
	display: flex;
	align-items: flex-end;
	font-weight: 400;
}

#footer .back_white{
	background-color:#fff;
	color:#333;
	font-weight;bold;
	font-size:18px;
	padding:16px;
	width:500px;
}

.footer_logo_area{ display:flex; margin-bottom:16px;  }

#footer .sec-ttl03{
	width: 100%;
	clear: both;
	padding: 7.5rem 0 2rem;
	font-size: 14px;
}
#base-list{
	display: flex;
	//font-size: 1.3rem;
	font-size:16px;
	line-height: 1.8;
	flex-wrap: wrap;
}
#base-list .base:nth-of-type(2n+1){
	border-left: .1rem solid #696969;
}
#base-list .base:nth-of-type(3),
#base-list .base:nth-of-type(4){
	margin-top: 2rem;
}
#base-list .base{
	width: 100%;
	padding: 1rem;
	border-right: .1rem solid #696969;
}
#base-list h4{
	//font-size: 1.5rem;
	font-size:16px;
	font-weight: 600;
	line-height: 1;
	margin-bottom: 2rem;
}
.address{
	display: flex;
	align-items: flex-end;
	font-size: 14px;
}
.tel-access{
	padding-bottom: 1.5rem;
	font-size: 14px;
}
.base dt{
	font-weight: 500;
	font-size: 1.4rem;
}

#footer a{
	color: #fff;
}

.map-link{
	text-decoration: underline;
	display: flex;
	align-items: center;
	margin-left: 1.5em;
}
.map-link:after{
	content: "";
	display: block;
	width: 1rem;
	height: 1.4rem;
	background: url(../images/renewal/footer-icon01.svg) no-repeat;
	background-size: 100% auto;
	margin-left: .5em;
}
#footer .sitemap{
	display: flex;
	//font-size: 1.5rem;
	font-size:12px;
	border-left: .1rem solid #696969;
}
#footer .sitemap li{
/*	width: 14.285%; */
	padding: 1.5rem;
	border-right: .1rem solid #696969;
	display: flex;
	justify-content: center;
}
#gifu-joseikin{
	//font-size: 1.2rem;
	font-size:12px;
	padding-top: 7.5rem;
}
#copyrights{
	//font-size: 1.2rem;
	font-size:12px;
	padding-top: 1.5rem;
}
#chat-banner{
	width: 35rem;
	height: auto;
	border-radius: 1rem 1rem 0 0;
	color:dodgerblue;
	background: #fff;
	font-weight: 600 !important;
	position: fixed;
	right: 5rem;
	bottom: 0;
	box-shadow: 0 6px 30px rgb(0 0 0 / 30%);
	z-index: 99;
	display: flex;
	flex-wrap: wrap;

}
#chat-banner h2{
	font-size: 1.8rem !important;
	padding: 0 1.5rem 0 7rem;
	height: 6.8rem;
	display: flex;
	width: 100%;
	align-items: center;
	background: url(../images/renewal/chat-banner-pic01.png) no-repeat;
	background-position: left 1.5rem center;
	background-size: 4rem auto;
	position: relative;
	margin: 0;
	cursor: pointer;
	font-weight: 600 !important;
}
#chat-banner h2:after{
	content: "";
	display: block;
	width: 3rem;
	height: 100%;
	position: absolute;
	right: 1.5rem;
	top: 0;
	bottom: 0;
	margin: auto;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: 100% auto;
	background-image: url(../images/renewal/chat-banner-arrow01.svg);
}
#chat-banner.active h2:after{
	background-image: url(../images/renewal/chat-banner-arrow02.svg);
}
#chat-banner .chat-btn{
	width: 100%;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	text-align: center;
	padding: 2.5rem 0;
	border-top: 1px solid #ddd;
	border-bottom: 1px solid #ddd;
}
#chat-banner .pic{
	width: 33%;
	padding: 0 1rem;
	font-size: 1.3rem;
	letter-spacing: 0;
}
#chat-banner .pic img{
	/*width: 2.5rem;*/
	width:10rem;
	margin: 0 auto 1rem;
	display: block;
	height: auto;
}
#chat-banner figcaption{
	color:dodgerblue;
}
.chat-btn p{
	font-size: 1.6rem;
	display: flex;
	justify-content: center;
	padding-bottom: 1.5rem;
	width: 100%;
	text-align: center;
}
#chat-banner .tel-btn02{
	padding: 0 1.5rem;
	color:dodgerblue;
	font-size: 2rem;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 7rem;
}
#chat-banner .tel-btn02:before{
	content: "";
	display: block;
	/*width: 1.5rem;*/
	width:6rem;
	height: 100%;
	margin-right: 1rem;
	background: url(../images/renewal/chat-banner-icon01.svg) no-repeat;
	background-position: center center;
	background-size: 100% auto;
}
#chat-banner a{
	color: #333;
}
#chat-banner a:hover{
	opacity: 1;
	filter: alpha(opacity=100);
	background: rgb(0 157 128 / 10%);
}
#chat-banner ul{
	display: none;
}
/* ++++++++++++++++++++++++key-visual++++++++++++++++++++++++ */
#key-visual{
	display: flex;
	//justify-content: flex-end;
}
#page-ttl{
	height: 30rem;
	/*width: 90%;  240109 oshima */
	width:100%;
	/*background: #f6f6f6;*/
	display: flex;
	align-items: flex-end;
	font-size: 4rem;
	padding: 5rem;
}
#page-ttl .ja{
	font-size: 1.8rem;
	display: flex;
	padding-bottom: .25em;
}
#page-ttl .ja:before{
	content: "";
	display: block;
	margin: 0 3rem;
	width: .1rem;
	height: 1em;
	background: #333;
}
/* ++++++++++++++++++++++++bread-crumbs++++++++++++++++++++++++ */
#bread-crumbs{
	padding: 5rem;
	display: flex;
	flex-wrap: wrap;
}
#bread-crumbs li{
	display: flex;
}
#bread-crumbs li:not(:last-of-type):after{
	content: "";
	display: block;
	width: 2rem;
	height: .1rem;
	background: #333;
	margin: .5em 1em 0;

}
#bread-crumbs a{
	color:dodgerblue;
}

/* ++++++++++++++++++++++++pagenation++++++++++++++++++++++++ */
.pagenation{
	display: flex;
	justify-content: center;
	margin: 5rem 0 0;
	font-weight: 600;
}
.pagenation li a{
	display: flex;
	justify-content: center;
	align-items: center;
	border: .2rem solid dodgerblue;
	border-radius: 100%;
	width: 4rem;
	height: 4rem;
	margin: 0 1rem;
	color:dodgerblue;
}/*
.pagenation li a:hover,
.pagenation li.current a{
	color: #fff;
}*/

/* ++++++++++++++++++++++++各見出しのスタイル++++++++++++++++++++++++ */







/* ++++++++++++++++++++++++セクション内共通++++++++++++++++++++++++ */


/* **********************IE用のスタイル************************* */
@media all and (-ms-high-contrast: none){


}


@media screen and (max-width: 1200px){

}



@media screen and (max-width:768px){
	body{
		font-size: 14px;
	}
	.pc{
		display:none !important;
	}
	.sp{
		display:block !important;
	}
	main{
		padding: 5rem 0;
	}
	.max1500{
		max-width: 100%;
		min-width: 100%;
	}
	.outer{
		width: 100%;
		min-width: 100%;
		position: relative;
	}
	.inner{
		width: 100%;
		padding-left: 0;
		padding-right: 0;
	}
	main,
	#main-visual{
		/*display: none !important;*/
	}
/* +++++++++++++++++++++++header++++++++++++++++++++++ */
	#site-ttl{
		position: static;
		left: auto;
		top: auto;
		font-size: 1rem;
		line-height: 1.5;
		padding: .5rem 1.5rem;
		letter-spacing: -.025em;
	}
	#header{
		left: 1.5rem;
		top: 4rem;
		width: calc(100% - 3rem);
		min-width: calc(100% - 3rem);
		height: 5rem;
	}
	#header.fixed{
		top: 1.5rem;
		height: 5rem;
	}
	#header .logo{
		width: 11.5rem;
		margin-left: 1rem;
	}
	#header .logo img{
		width:150px;
	}
	#header .logo img{
		margin-left:0px;
	}
	nav.opened{
		transform: translateX(0);
		opacity: 1;
		filter: alpha(opacity=100);
	}
	nav{
		position: fixed;
		left: 0;
		top: 0;
		width: 100%;
		height: 100%;
		background: rgba(255,255,255,1);
		overflow-y: auto;
		z-index: 999;
		transform: translateX(100vw);
		opacity: 0;
		filter: alpha(opacity=0);
		transition: .4s all ease;
	}
	#global-navi{
		display: block;
		font-size: 1.5rem;
		padding: 5rem 1.5rem 3rem;
	}
	#global-navi li{
		border-bottom: .1rem solid #dfdfdf;
		padding: 0;
		position: relative;
	}
	.toggle-btn{
		border-radius: 100%;
		width: 3rem;
		height: 3rem;
		border: .2rem solid dodgerblue;
		background:dodgerblue;
		position: absolute;
		right: 1rem;
		top: 2.3rem;
		transition: .5s all ease;
	}
	.toggle-btn:before{
		content: "";
		display: block;
		width: 1rem;
		height: .2rem;
		background: #fff;
		left: 0;
		right: 0;
		top: 0;
		bottom: 0;
		margin: auto;
		position: absolute;
		transition: .5s all ease;
	}
	.toggle-btn:after{
		content: "";
		display: block;
		width: .2rem;
		height: 1rem;
		background: #fff;
		left: 0;
		right: 0;
		top: 0;
		bottom: 0;
		margin: auto;
		position: absolute;
		transition: .5s all ease;
	}

	.active .toggle-btn{
		background: transparent;
		transform: rotate(90deg);
	}
	.active .toggle-btn:after{
		background:dodgerblue;
	}
	.active .toggle-btn:before{
		opacity: 0;
		filter: alpha(opacity=0);
	}

	#global-navi>li:not(.head-btn){
		display: block;
		max-height: 7.6rem;
		transition: .5s all ease;
		overflow: hidden;
		width:100%; /*240131*/
	}
	#global-navi .child{
		position: relative;
		left: auto;
		right: auto;
		top: auto;
		bottom: auto;
		width: 100%;
    	box-shadow: none;
		visibility: visible;
		transition: .3s all ease;
		transform: translateY(0);
		opacity: 1;
		filter: alpha(opacity=100);
		overflow: hidden;
	}
	#global-navi li.active{
		height: 100%;
		max-height: 30rem;
	}
	#global-navi ul.child li {
		padding: 0;
		text-align: left;
		height: auto;
		padding: 0;
		border: none !important;
	}
	#global-navi ul.child li a{
		justify-content: stretch;
		border: none !important;
		padding: 1.5rem 0 2rem 1.5rem !important;
		font-size: 1.3rem;
	}

	#global-navi li:nth-of-type(1) a,
	#global-navi li:nth-of-type(2) a,
	#global-navi li:nth-of-type(3) a,
	#global-navi li:nth-of-type(4) a{
		padding: 3rem 0;
		display: flex;
		align-items: center;
		width: 100%;
	}
	#global-navi li.head-btn{
		width: 100%;
		border-left: none;
		padding-top: 1.5rem;
		padding-bottom: 0;
		border: none;
	}
	.head-btn.contact-btn{
		margin-left: 0;
	}
	.head-btn a{
		display: flex;
		align-items: center;
		justify-content: center;
		color: #fff;
		background:dodgerblue;
		height: 6rem;
	}
	.fixed .head-btn a{
		height: 6rem;
	}

	.head-btn.contact-btn a{
		flex-direction: row;
	}
	.head-btn.contact-btn a:before{
		content: "";
		display: block;
		width: 2rem;
		height: 1.5rem;
		margin-bottom: 0;
		margin-right: .5em;
	}
	.head-btn.tel-btn a:before{
		margin-right: .5em;
	}
	.menu-open-btn,
	.menu-close-btn{
		position: absolute;
		right: 0;
		top: 0;
		width: 5rem;
		height: 5rem;
	}
	.menu-open-btn span,
	.menu-close-btn span{
		display: block;
		width: 1.5rem;
		height: .2rem;
		background: #333;
		position: absolute;
		left: 0;
		right: 0;
		top: 0;
		bottom: 0;
		margin: auto;
		transition: .15s all ease;
	}
	.menu-close-btn{
		background: #333;
	}
	.menu-close-btn span{
		background: #fff;
	}
	.menu-open-btn span:nth-of-type(1){
		transform: translateY(-.4rem);
	}
	.menu-open-btn span:nth-of-type(3){
		transform: translateY(.4rem);
	}
	.menu-close-btn span:nth-of-type(1){
		transform: rotate(45deg);
	}
	.menu-close-btn span:nth-of-type(2){
		transform: rotate(-45deg);
	}
	.sp-contact-btn{
		position: absolute;
		right: 5rem;
		top: 0;
		height: 100%;
		overflow: hidden;
	}
	.sp-contact-btn li a{
		display: flex;
		width: 5rem;
		height: 5rem;
	}
	.sp-contact-btn li{
		float: left;
	}
	.sp-contact-btn li img{
		display: block;
		width: 1.5rem;
		margin: auto;
	}
	.sp-contact-btn li:nth-of-type(1) a{
		background:dodgerblue;
	}
	.sp-contact-btn li:nth-of-type(2) a{

		background: #444;
	}

/* ++++++++++++++++++++++++key-visual++++++++++++++++++++++++ */
	#key-visual{
		margin-top: -2.5rem;
	}
#page-ttl{
	/*height: 15rem; 240131*/
	width: calc(100% - 3rem);
	font-size: 2.7rem;
	padding: 1.8rem;
}
#page-ttl .ja{
	font-size: 1.4rem;
}
#page-ttl .ja:before{
	margin: 0 .75rem;
}


/* +++++++++++++++++++++++contents++++++++++++++++++++++ */
	.sec{
		padding: 5rem 1.5rem;
	}
	.sec-ttl01{
		display: block;
		flex-shrink: 0;
		width: 100%;
		font-size: 1.4rem;
		margin-bottom: 3rem;
	}
	.sec-ttl01 .en{
		font-size: 3.2rem;
		padding-right: 0;
	}
	.sec-ttl01 .ja{
		padding-bottom: 0;
		line-height: 1.5;
		display: block;
		margin-top: 1rem;
	}
.sec-ttl02{
	display: flex;
	font-size: 100%;
	align-items: flex-end;
	line-height: 1;
}
	.sec-ttl02 .en{
		font-size: 2.4rem;
	}
	.sec-ttl02 .ja{
		padding-bottom: .3em;
	}
	.sec-ttl03 span{
		font-size: 1.8rem;
		margin-right: .75rem;
	}
	.sec-ttl04{
			display: block;
			font-size: 1.3rem;
			line-height: 1.5;
		}
	.sec-ttl04 .en{
		font-size: 2.4rem;
		padding-right: 0;
	}
	.sec-ttl04 .ja{
		padding-bottom: 0;
	}
	.sec-ttl05{
		margin-bottom: 1.5rem;
		font-size: 3rem;
	}
	.btn01{
		width: 100%;
		height: 5rem;
		display: flex;
		align-items: center;
		color: #fff;
		padding-left: 3rem;
		background-size: 2.5rem auto;
		background-position: right 1.5rem center;

	}

.btn01.large{
	width: 100%;
	font-size: 1.3rem;
	justify-content: flex-start;
	background-image: url(../images/renewal/contact-area-arrow01-2.png);
	background-position: right 1.5rem center;
	height: 5rem;
	padding: 0 1.5rem;
	background-size: 4rem auto;
}

.btn02{
	display: flex;
	align-items: center;
}
.btn02:after{
	width: 2rem;
	height: 2rem;
	margin-left: .5rem;
}


/* +++++++++++++++++++++++#link-banners++++++++++++++++++++++ */

#link-banners ul{
	display: block;
	justify-content: space-between;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
}
#link-banners li{
	width: 100%;
}

#link-banners li:not(:last-of-type){
	margin-bottom: 1.5rem;
}

/* +++++++++++++++++++++++#contact-area++++++++++++++++++++++ */
	#contact-area{
		padding: 6rem 1.5rem;
	}
	aside  .sec-ttl02{
		margin-bottom: 3rem;
	}
	aside  .sec-ttl02 .en{
		padding: 0 0 1.5rem 0;
	}
	aside  .sec-ttl02 .ja{
		line-height: 1.7;
	}
	#contact-area ul{
		display: block;
		padding: 0;
		border-top: .1rem solid #ddd;
		border-left: none;
	}
	#contact-area li{
		border-left: none !important;
		border-bottom: .1rem solid #ddd;
	}



	#contact-area li{
		width: 100%;
		border-right: none;
		padding: 3rem 0;
	}
	#contact-area li:nth-of-type(1) a{
		padding-left: 0;
		background-size: 1.2rem auto;
		background-position: right 3rem center;
		height: 8rem;
		padding: 1.5rem 3rem;
		border-radius: 4rem;
		font-size: 1.2rem;
	}
	#contact-area a .en{
		font-size: 2rem;
		padding-bottom: .5rem;
	}
	#contact-area li:nth-of-type(2){
		justify-content: center;
		height: 16rem;
		border-right: none;
	}
	#contact-area li:nth-of-type(2) a .en{
		font-size: 3rem;
	}
	#contact-area dl{
		display: flex;
		line-height: 1.7;
		font-size: 1.2rem;
	}

/* +++++++++++++++++++++++footer++++++++++++++++++++++ */
	.footer_logo_area{ flex-direction:column; }
	#footer{
		padding: 3rem 1.5rem;
		font-size: 1.2rem;
	}
	#footer>.address{
		clear: both;
		padding-top: 2rem;
		text-align: center;
	}
	#footer .logo{/*
		width: 12rem;
		float: none;
		margin: 0 auto;
		display: block;*/
	}
	#footer_telln_logo{ width:150px; margin:0 auto; }
	#footer h2{
		float: none;
		font-size: 1rem;
		margin: 1rem auto 0;
		height: auto;
		display: block;
		text-align: center;
		line-height: 1.7;
	}
	#footer .sec-ttl03{
		padding: 4rem 0 1.5rem;
		font-size:12px; 
	}
	#footer .back_white{
		width:90%;
		font-size:1.5rem;
		text-align:center;
		margin:0 auto;
	}
	#base-list{
		display: block;
		font-size: 1.2rem;
		border: none;
	}
	#base-list .base{
		width: 100%;
		padding: 2rem 0;
		border-right: none;
		border-bottom: .1rem solid #696969;
	}
	#base-list h4{
		font-size: 1.4rem;
		margin-bottom: 1.5rem;
	}
	.address{
		padding-bottom: 1rem;
		display: block;
	}
	.tel-access{
		padding-bottom: 1rem;
	}
	.base dt{
		font-size: 1.3rem;
	}
	#footer .sitemap{
		flex-wrap: wrap;
		font-size: 1.3rem;
		border: none;
	}
	#footer .sitemap li{
		width: 50%;
		padding: 1rem 0;
		border-right: none;

		display: flex;
		justify-content: center;
	}
	#copyrights{
		font-size: 1rem;
		text-align: center;
		padding-top: 4rem;
		padding-bottom: 6rem;
		line-height: 1.5;
	}

	#base-list .base:nth-of-type(2n+1){
		border-left: none;
	}
	.map-link{
		margin: 0;
	}


	#chat-banner{
		max-width: 35rem;
		width: calc(100% - 3rem);
		margin: auto;
		border-radius: .5rem .5rem 0 0;
		right: 0;
		left: 0
	}
	#chat-banner h2{
		font-size: 1.6rem !important;
		padding: 0 1.5rem 0 7rem;
		height: 6rem;
		background: url(../images/renewal/chat-banner-pic01.png) no-repeat;
		background-position: left 1.5rem center;
		background-size: 4rem auto;
		display: flex;
		margin: 0;
	}
	#chat-banner .pic{
		padding: 0 .5rem;
		font-size: 1.2rem;
	}

	#chat-banner .tel-btn02{
		font-size: 2rem;
		height: 6rem;
	}

/* ++++++++++++++++++++++++bread-crumbs++++++++++++++++++++++++ */
	#bread-crumbs{
		padding: 1.5rem;
		line-height: 1.5;
	}
	#bread-crumbs li:not(:last-of-type):after{
		content: "";
		display: block;
		width: 1rem;

	}

/* ++++++++++++++++++++++++pagenation++++++++++++++++++++++++ */
	.pagenation li a{
		border: .1rem solid dodgerblue;
		width: 3rem;
		height: 3rem;
		margin: 0 .5rem;
	}
}

/*  叶えるボタン　*/
.kanaeru_btn{ 
	display:block;
	text-align:center; 
	background-color:#0c5399;
	width:600px;
	margin: 0 auto;
	font-size:20px;
	color:#fff;
	padding:20px;
	line-height:2;
/*	box-shadow: 0 10px 20px 0 rgba(0,0,0, .5); */
}
.kanaeru_btn a{
	color:#fff;
}
.kanaeru_btn .small{
	 font-size:16px; display:inline-block;
}
@media screen and (max-width:600px){
.kanaeru_btn{
	width:90%;
	font-size:18px;
}
}
@media screen and (max-width:400px){
.kanaeru_btn{
	font-size:16px;
}
.kanaeru_btn .small{
	 font-size:14px;
}
}