@charset "utf-8";


/* all
-------------------------------------------------------------------*/
html {
	background:#FFFFFF;
	color:#282828;
	font-family: 'Noto Sans JP',  "游ゴシック Medium", "Yu Gothic Medium" ,"游ゴシック体", "Yu Gothic", YuGothic , 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	font-size:16px;
	line-height:1.4;
}
html .goti,
html form *{
	font-family:  'Noto Sans JP', "游ゴシック Medium", "Yu Gothic Medium" ,"游ゴシック体", "Yu Gothic", YuGothic , 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
}
html .mincho,
html .mincho form *{
	font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "Times New Roman", "HG明朝B", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

body {
	width: 100%;
	font-size: 100%;
	text-align: center;
	min-width:1200px;
}

main{
	overflow:hidden;
	width:100%;
}
.sitewrap {
	width: 1200px;
	min-width:1200px;
	overflow:hidden;
	margin: 0 auto;
	text-align: left;
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
}
body:not(.home) main .sitewrap{
	padding-left:100px;
	padding-right:100px;
	overflow:visible;
}
.edit_wrap .sitewrap{
	overflow:visible;
}
.edit_wrap .sitewrap img{
	max-width:100%;
	height:auto;
}
@media screen and (max-width:1600px) {
	body:not(.home) main .sitewrap{
		padding-left:0;
		padding-right:0;
		max-width:1000px;
		min-width:0;
	}
}
@media screen and (max-width:1200px) {
	body,
	.sitewrap {
		width: 100%;
		min-width:0;
	}	
	.sitewrap > *{
		padding-left:2%;
		padding-right:2%;
	}
	body:not(.home) main .sitewrap{
		padding-left:0;
		padding-right:0;		
	}
}
@media screen and (max-width:767px) {
	html {
		font-size:14px;
	}
	.sitewrap > *{
		padding-left:15px;
		padding-right:15px;
	}
}


/* header
-------------------------------------------------------------------*/
.sub_head{
	padding: 0.3125em 2em;
	display:flex;
	justify-content:flex-end;
	align-items:flex-start;
	gap:1em;
	background:#f0f0f0;
}
.sub_head img{
	height:52px;
	width:auto;
}

header {
}
header#fix_menu{
	position: absolute;
	top: 62px;
	left:0;
	right:0;
	z-index:999;
	height:122px;
	transition:top 0s;
	background:rgba(255,255,255,0.8);
	display:flex;
	justify-content:space-between;
	align-items:center;
}
header#fix_menu.fixedMenu{
	top:0;
	position:fixed;
	
}
header + main{
	padding-top:122px;
}
.menu_top #site_ttl {
	padding:0 20px;
}
.menu_top #site_ttl img{
	max-width:100%;
	height:auto;
}
.menu_top #site_ttl a,
.menu_top #site_ttl p{
	display:inline-block;
	vertical-align:middle;
}
.menu_bottom {
	padding:15px 30px;
}
.menu_bottom .contacts{
	display:flex;
	justify-content:flex-end;
	margin-bottom:5px;
}
.menu_bottom .contacts .tel a{
	font-size:1.5rem;
	display:block;
	text-decoration:none;
	margin-right:25px;
}
.menu_bottom .contacts .tel a *{
	display:inline-block;
	vertical-align:baseline;
}
.menu_bottom .contacts .tel a span{
	margin-left:5px;
}
.menu_bottom .contacts .tel small{
	display:block;
	font-size:0.75rem;
	text-align:left;
}
.menu_bottom #NavWrap .contacts ul {
	width:auto;
	margin-right:40px;
}
.menu_bottom #NavWrap .contacts ul li + li{
	margin-left:30px;
}

a.inq_btn{
	font-size:0.875rem;
	font-weight:500;
	display:flex;
	align-items:center;
	justify-content:center;
	width:200px;
	height:50px;
	border:solid 1px #9d8a3c;
	background:#9d8a3c;
	color:#fff;
	border-radius:5px;
	text-decoration:none;
	transition:background .4s,color .4s,transform .4s;
}
a.inq_btn:hover{
	background:#b8a456;
}
a.inq_btn img{
	margin-right:0.5em;
}
.drop_menu{
	margin:auto;
}
.drop_menu #NavWrap {
	padding: 0;
}
.drop_menu #NavWrap ul {
	margin: 0;
	padding: 0;
	display:flex;
	width:878px;
	max-width:100%;
	justify-content:space-between;
	align-items:center;
	
}
.drop_menu #NavWrap ul::after{
	display:none;
}
.drop_menu #NavWrap ul > li {
	vertical-align:middle;
	box-sizing:border-box;
}
.drop_menu #NavWrap li a,
.drop_menu #NavWrap li p {
	display: block;
	box-sizing:border-box;
	text-decoration: none;
	font-size: 0.875rem;
	width: auto;
	line-height: 1;
	position:relative;
	text-align:center;
	transition:background 0.5s ,color 0.5s, opacity 0.5s, color 0.5s;
}
.drop_menu #NavWrap li a:hover {
	opacity:1;
	color:#0b5086;
}
.drop_menu #NavWrap li a span{
	padding: 10px 0px 10px;
	display:flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	white-space: normal;
	font-weight: 500;
	position:relative;
}
.drop_menu #NavWrap li a span br{
	display:none;
}
.drop_menu #NavWrap li a span:after{
	content:"";
	width:0;
	height:1px;
	display:block;
	position:absolute;
	bottom:5px;
	left:0;
	transition:width .2s;
	background:#0b5086;
}
.drop_menu #NavWrap li a:hover span{
	opacity:1;
}
.drop_menu #NavWrap li a:hover span:after{
	width:100%;
}
.drop_menu #NavWrap li a:hover {
   opacity:1;
}
.drop_menu #NavWrap li.drop_wrap {
	position:relative;
}
.drop_menu #NavWrap li.drop_wrap i{
	display:none;
}
.drop_menu #NavWrap li ul{
	position:absolute;
	width:225px;
	opacity:0;
	visibility:hidden;
	left:50%;
	transform:translateX(-50%);
	transition:opacity .4s;
	flex-direction:column;
	max-width:inherit;
	align-items:stretch;
}
.drop_menu #NavWrap li:hover ul{
	opacity:1;
	visibility:visible;
	z-index:999;
	padding-top:25px;
}
.drop_menu #NavWrap li:hover ul:before{
	content:"";
	display:block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0 12.5px 20px 12.5px;
	border-color: transparent transparent #0b5186 transparent;
	position:absolute;
	top:5px;
	margin:auto;
	left:0;
	right:0;
	
}
.drop_menu #NavWrap li ul li + li{
	border-top:solid 2px #fff;
}
.drop_menu #NavWrap li ul a{
	padding: 10px 20px;
	background:#0b5086;
	color:#fff;
}
.drop_menu #NavWrap li ul a:hover{
	color:#0b5086;
	background:#fff;
}
.drop_menu #NavWrap li ul a span{
	align-items: flex-start;
}
.drop_menu #NavWrap li ul a span{
}
.drop_menu #switch {
	position: absolute;
	display: none;
	opacity: 0;
}
@media screen and (max-width:1200px) {
	.menu_top #site_ttl{
		padding:0;
	}
	.menu_top{
		padding-left:2%;		
	}
	.menu_bottom{
		padding-left:2%;
		padding-right:2%;
	}
	.drop_menu #NavWrap ul{
		width:740px;
	}
}
@media screen and (max-width:1000px) {
	header#fix_menu{
	}
	.menu_top{
		position:absolute;
		top:15px;
		max-width:190px;
	}
	.menu_bottom{
		width:100%;
	}
	.menu_bottom .contacts{
		margin-bottom:10px;
	}
	.drop_menu #NavWrap ul{
		width:auto;
	}
}
@media screen and (max-width:767px) {
	.sub_head{
		padding-inline:10px;
		height: 45px;
	}
	.sub_head img{
		height:36px;
		width:auto;
	}
	header .menu_top{
		padding:0;
	}
	.drop_menu #switch ~ label {
		display: block;
		cursor: pointer;
		position: fixed;
		top:0;
		right:0;
		z-index:900;
		-webkit-transition: 0.5s transform;
		transition: 0.5s transform, right 0.2s;
		padding: 12px;
		width: 100px;
		height: 100px;
		box-sizing:border-box;
		background:rgba(255,255,255,0);
		text-align:center;
	}
	.drop_menu #switch ~ label b{
		z-index:2;
		width:100%;
		display:block;
		margin-bottom: 0;
	}
	.drop_menu #switch ~ label span{
		cursor: -webkit-grabbing;
		display:block;
		width:60px;
		height:3px;
		background: #0b5086;
		transition: 0.2s transform, 0.5s background;
		position:absolute;
		top: 50%;
		left:0;
		right:0;
		margin:auto;
		margin-top:-5px;
	}
	.drop_menu #switch ~ label span:before,
	.drop_menu #switch ~ label span:after{
		content:"";
		display:block;
		width:60px;
		height:3px;
		background:#0b5086;
		position:absolute;
		margin-top:0;
	}
	.drop_menu #switch ~ label span:before{
		top:-18px;
	}
	.drop_menu #switch ~ label span:after{
		top:18px;
	}
	.drop_menu #switch:checked ~ label span{
		-webkit-transform:rotate(-45deg) ;
		transform:rotate(-45deg) ;
	}
	.drop_menu #switch:checked ~ label span:before{
		top:0;
		background:#fff;
	}
	.drop_menu #switch:checked ~ label span:after{
		-webkit-transform:rotate(270deg);
		transform:rotate(270deg);
		top:0;
		margin-top:0;
		background:#fff;
	}
	.drop_menu #switch:checked ~ label{
		right: 0;
	}
	.drop_menu #NavWrap{
		position: fixed;
		top: 0;
		width:100%;
		z-index: 800;
		height:100%;
		visibility: hidden;
		padding-top: 100px;
		box-sizing: border-box;
		transition:all 0.25s;
	}
	.drop_menu #switch:checked ~ label+#NavWrap{
		visibility:visible;
		max-height: 100vh;
		top: 0;
	}
	.drop_menu #NavWrap > ul {
		width: 100%;
		margin-right: 0;
		margin-left: auto;
	}
	.drop_menu #NavWrap li a {
		padding: 15px 0;
		text-decoration: none;
		text-align: center;
		width: auto;
		background:rgba(255,255,255,0.9);
	}
	.drop_menu #NavWrap li a span{
		padding: 10px 0px;
		border-left:none;
		white-space: normal;
	}
	header#fix_menu{
		top: 45px;
	}
	header#fix_menu,
	header#fix_menu.fixedMenu{
		position: fixed;
		height:59px;
	}
	header .menu_top {
		top:0;
	}
	header .menu_top #site_ttl{
		padding: 11px 10px;
		text-align:left;
	}
	header .menu_top #site_ttl img{
		max-height: 37px;
		width:auto;
	}
	header .menu_top #site_ttl p{
		display:none;
	}
	.menu_top .right_menu {
		padding:5px 60px 5px 5px
	}
	.menu_top .right_menu li{
		display:none;
	}
	.menu_top .right_menu li.inquiry{
		display:block;
		margin: 0;
	}
	.menu_top .right_menu li.inquiry a,
	.menu_top .right_menu li.inquiry a:hover{
		background: #fff;
		color: #337b3b;
		padding: 10px;
		border-radius: 5px;
		font-size: 11px;
	}
	header .menu_top .logo a+a{
		margin-left: 6px;
	}
	header .menu_top .logo a img{
		width: 58px;
		height:auto;
		vertical-align:middle;
	}
	header .menu_top .logo a+a img{
		width:181px;
	}
	header .menu_top .logo span{
		font-size:8px;
		vertical-align:middle;
	}
	header .menu_top .menu_fix{
		position:relative;
	}
	header .menu_top .outwrap{
		padding: 5px 10px 5px;
		height: 50px;
	}
	.type_general header .menu_top .outwrap{
		background:rgba(255,255,255,0.6);
	}
	.drop_menu #NavWrap{
		padding-top: 0;
		position:fixed;
		top: 0;
		left:auto;
		right:-100%;
		padding:0;
		width:100%;
		height:100%;
		background:#0b5086;
		text-align:left;
	}
	.drop_menu #switch:checked ~ label+#NavWrap{
		top: 0;
		left:auto;
		right:0;
	}
	.drop_menu #switch ~ label {
	   padding: 10px;
	   width: 59px;
	   height: 59px;
	   position: absolute;
	}
	.drop_menu #switch ~ label span{
	   width:22px;
	   height:2px;
	   top: 26px;
	   margin:auto;
	}
	.drop_menu #switch ~ label span:before,
	.drop_menu #switch ~ label span:after{
	   width:22px;
	   height:2px;
	   margin-top:0;
	}
	.drop_menu #switch ~ label span:before{
	   top: -9px;
	}
	.drop_menu #switch ~ label span:after{
	   top: 9px;
	}
	.drop_menu #NavWrap .logo{
		width:100%;
		text-align:left;
		padding:11px 10px;
		height:59px;
	}
	.drop_menu #NavWrap .scroll_wrap{
		display:flex;
		flex-direction:column;
		max-height:calc(100% - 69px);
		overflow:auto;
		padding-bottom:10px;
	}
	.drop_menu #NavWrap .scroll_wrap::-webkit-scrollbar {
		height:5px;
		width:5px;
	}
	.drop_menu #NavWrap .scroll_wrap::-webkit-scrollbar-track {
		border-radius: 10px;
		background: #b3b3b3;
	}
	.drop_menu #NavWrap .scroll_wrap::-webkit-scrollbar-thumb {
		border-radius: 10px;
	}
	.drop_menu #NavWrap ul {
	   display: block;
	   border-left:none;
	   width: 100%;
	   padding: 5px 15px 20px;
	}
	.drop_menu #NavWrap ul li {
		display:block;
		padding:0;
	}
	.drop_menu #NavWrap li a,
	.drop_menu #NavWrap li a:hover{
		font-size: 14px;
		text-align: left;
		width: auto;
		padding: 0;
		text-decoration: none;
		background:none;
		color:#fff;
		border:none;
		display:inline-block;
	}
	.drop_menu #NavWrap li a:hover{
		background:none;
	}
	.drop_menu #NavWrap li a span{
		display:block;
		padding: 10px 0;
		font-weight:normal;
		background:none;
		line-height: 1.4;
	}
	.drop_menu #NavWrap li a span br{
		display:block;
	}
	.drop_menu #NavWrap li a span:after{
		display:none;
	}
	.drop_menu #NavWrap ul li.drop_wrap{
	}
	.drop_menu #NavWrap li.drop_wrap ul,
	.drop_menu #NavWrap li.drop_wrap:hover ul{
		opacity:1;
		visibility:visible;
		display:block;
		transform: none;
		width:100%;
		padding:0 ;
		text-align:left;
		position:static;
	}
	.drop_menu #NavWrap li.drop_wrap ul:before{
		display:none;
	}
	.drop_menu #NavWrap li.drop_wrap ul li{
		position:relative;
		padding-left:20px;
	}
	.drop_menu #NavWrap li.drop_wrap ul li:before{
		position:absolute;
		top:0;
		bottom:0;
		margin:auto;
		left:2px;
		content:"";
		display:block;
		width:6px;
		height:1px;
		background:#fff;
	}
	.drop_menu #NavWrap li.drop_wrap ul li + li{
		border:none;
	}
	.drop_menu #NavWrap li.drop_wrap ul li a{
		font-size: 12px;
		text-align: left;
		width: auto;
		padding: 0;
		text-decoration: none;
		border:none;
		display:inline-block;
	}
	.drop_menu #NavWrap li.drop_wrap ul li a span{
		padding:10px 0;
	}
	.drop_menu #NavWrap .other_link{
		color:#b8cddd;
		margin:0 15px 30px;
		padding-bottom:30px;
		border-bottom:solid 1px #b8cddd;
	}
	.drop_menu #NavWrap .other_link a{
		font-size:0.857rem;
		border-bottom:solid 1px #b8cddd;
		text-decoration:none;
	}
	.drop_menu #NavWrap .contacts{
		order:5;
		display:block;
		padding:0 15px;
	}
	.drop_menu #NavWrap .contacts .tel{
		background:#e7eef3;
		text-align:center;
		padding:20px;
		margin-bottom:15px;
	}
	.drop_menu #NavWrap .contacts .tel a{
		display:inline-block;
		margin:0 auto 5px;
		font-size:1.857rem;
	}
	.drop_menu #NavWrap .contacts .tel small{
		font-size:1rem;
		text-align:center;
	}
	.menu_bottom #NavWrap .contacts ul{
		display:none;
	}
	.drop_menu #NavWrap a.inq_btn{
		max-width:100%;
		width:100%;
		border-radius:0;
		height:70px;
		font-size:1rem;
		position:relative;
	}
	.drop_menu #NavWrap a.inq_btn:before{
		content: "";
		width: 36px;
		height: 2px;
		background:#FFF;
		display: inline-block;
		position: absolute;
		margin:auto;
		top:0;
		bottom:0;
		left:0;
		margin:auto;
		transition:background .4s,width .4s;	
	}
}


/* contents
-------------------------------------------------------------------*/

main{
	display: block;
}

@media screen and (max-width:767px) {
	header + main{
		padding-top:59px;
	}
}


/* footer
-------------------------------------------------------------------*/
#pageTop {
	position: fixed;
	bottom: 15px;
	right: 5%;
	width: 70px;
	z-index: 500;
}
aside.cta{
	display:block;
	background:url(../img/contact_bg.jpg) no-repeat top center / cover;
	padding:92px 0;
}
aside.cta .ttl_set{
	text-align:center;
	margin-bottom:65px;
	color:#fff;
	text-shadow:0 0 5px #8ecff1;
}
aside.cta .ttl_set h2{
	font-size:2rem;
	margin-bottom:1em;
}
aside.cta .ttl_set p{
	text-align:center;
}
aside.cta .box_flex{
	display:flex;
	justify-content:space-between;
}
aside.cta .box_flex .box{
	background:rgba(255,255,255,0.9);
	width:48%;
	padding:40px;
	text-align:center;
}
aside.cta .box_flex h3{
	font-size:1.25rem;
	margin-bottom:1em;
}
aside.cta .box_flex .mincho {
	display:inline-block;
	margin-bottom:1em;
}
aside.cta .box_flex .mincho *{
	display:inline-block;
	vertical-align:middle;
	font-size:2.5rem;
}
aside.cta .box_flex .mincho span{
	margin-left:5px;
	font-weight:600;
}
aside.cta .box_flex .inq_btn{
	width:100%;
	max-width:332px;
	height:69px;
	border-radius:0;
	margin:auto;
	font-size:1rem;
	position:relative;
}
aside.cta .box_flex .inq_btn:before{
	content:"";
	width:32px;
	height:2px;
	display:block;
	background:#fff;
	position:absolute;
	left:-1px;
	transition:width .4s;
}
aside.cta .box_flex .inq_btn:hover{
	transform:translateY(5px);
}
aside.cta .box_flex .inq_btn:hover:before{
	width:22px;
}
aside.cta .box_flex .inq_btn img{
	margin-right:10px;
}
footer{
	display:block;
	position:relative;
	background:#f8f8f8;
}
footer .liquid_wrap{
	min-height:390px;
}
footer .left_area{
	width:50%;
	position:absolute;
	left:0;
	z-index:10;
}
footer .sitewrap .right_area{
	margin-left:50%;
	padding:50px 0 50px 50px;
}
footer .sitewrap .foot_flex{
	display:flex;
	justify-content:space-between;
	margin-bottom:50px;
	align-items:flex-start;
}
footer .sitewrap .site_sponser{
	position:absolute;
	right:1em;
	display:flex;
	flex-direction:column;
	gap:0.75em;
}
footer .sitewrap .site_sponser p{
	margin:auto;
	font-size:0.875rem;
	font-weight: 600;
}
footer .sitewrap .site_sponser .sponser_logo{
	display:flex;
	gap:1em;
	align-items:flex-start;
}

footer .sitewrap address{
	display:block;
	margin-top:25px;
}
footer .sitewrap .foot_menu > ul{
	display:grid;
	grid-auto-flow: column dense;
	grid-template-columns:1.25fr 1fr 1fr;
	grid-template-rows:1fr 1fr 1fr 1fr;
	grid-auto-rows: 4fr;
	font-size:0.875rem;
	gap:20px;
}
footer .sitewrap .foot_menu > ul li.drop_wrap{
    grid-row: 1 / 4;
}
footer .sitewrap .foot_menu > ul li.drop_wrap ul{
	font-size:0.875em;
	margin-top:1em;
}
footer .sitewrap .foot_menu > ul li.drop_wrap ul li{
	position:relative;
	padding-left:1em;
	margin-top:0.5em;
}
footer .sitewrap .foot_menu > ul li.drop_wrap ul li:before{
	content:"";
	display:block;
	background:#8d8d8d;
	width:0.75em;
	height:1px;
	position:absolute;
	left:0;
	top:0;
	bottom:0;
	margin:auto;
}
footer .sitewrap .foot_menu > ul li.drop_wrap ul li a{
	color:#8d8d8d;
}
footer .sitewrap .foot_menu > ul a{
	display:inline-block;
	transition:transform .4s, color .4s;
	position:relative;
	text-decoration:none;
}
footer .sitewrap .foot_menu > ul a:hover{
	color:#0b5086;
	text-decoration:none;
}
footer .sitewrap .foot_menu > ul a:before{
	content:"";
	display:block;
	width:0;
	height:1px;
	background:#0b5086;
	position:absolute;
	transition:width .2s;
	bottom:0;
	left:0;
}
footer .sitewrap .foot_menu > ul li.drop_wrap ul li a:before{
	background:#8d8d8d;
}
footer .sitewrap .foot_menu > ul a:hover:before{
	width:100%;
}
footer small{
	display:block;
	background:#fff;
	padding:25px 0 30px;
	font-size:0.75rem;
}
main a.page_link {
	margin-top: -60px;
	padding-top: 60px;
	display: block;
	position:relative;
	z-index:-10;
}
@media screen and (max-width:1350px) {
	footer .sitewrap .foot_flex{
		gap: 1em 2em;
		align-items: flex-start;
		flex-wrap:wrap;
	}
	footer .sitewrap .site_sponser{
		position:static;		
	}
	footer .sitewrap .site_sponser .sponser_logo {
		flex-wrap:wrap;
		gap: 0 1em;
	}
	footer .sitewrap .site_sponser img{
		max-height:70px;
		width:auto;
	}
}
@media screen and (max-width:1200px) {
	footer .sitewrap .foot_menu > ul{
		grid-template-columns:1fr 1fr ;
		grid-template-rows:1fr 1fr 1fr 1fr 1fr 1fr;
		font-size:0.875rem;
		gap:20px;
	}
	footer .sitewrap .foot_menu > ul li.drop_wrap{
	    grid-row: 1 / 4;
	}
}
@media screen and (max-width:767px) {
	#pageTop {
	    width: 49px;
		right:10px;
		bottom:10px;
	}
	aside.cta{
		padding:55px 0;
	}
	aside.cta .ttl_set{
		margin-bottom:3em;
	}
	aside.cta .ttl_set h2{
		margin-bottom:0.75em;
	}
	aside.cta .box_flex{
		display:block;
	}
	aside.cta .box_flex .box{
		width:100%;
		padding:30px;
		text-align:center;
	}
	aside.cta .box_flex .box + .box{
		margin-top:35px;
	}
	aside.cta .box_flex .mincho{
		margin-bottom:0.5em;
	}
	aside.cta .box_flex .mincho img{
		width:18px;
		height:auto;
	}
	aside.cta .box_flex .mincho *{
		font-size:1.857rem;
	}
	aside.cta .box_flex .mincho span{
		margin-left:5px;
		font-weight:600;
	}
	aside.cta .box_flex .inq_btn{
		max-width:100%;
	}
	aside.cta .box_flex .inq_btn img{
		width:22px;
	}
	footer{
		flex-direction:column;
		display:flex;
	}
	footer .left_area{
		width:100%;
		position:static;
	}
	footer .sitewrap .right_area{
		width:100%;
		padding:35px 15px 25px;
		margin:0;
		text-align:center;
	}
	footer .sitewrap .foot_flex{
		margin-bottom:0;
		justify-content:center;
	}
	footer .sitewrap .right_area .site_status img{
		width:149px;
		height:auto;
	}
	footer .sitewrap .site_sponser p{
		font-size:min(3.25vw,0.875rem)
	}
	footer .sitewrap .site_sponser{
		flex-direction:column-reverse;
		margin-top:2em;
		align-items:center;
	}
	footer .sitewrap .site_sponser img{
		max-height:50px;
	}
	footer .sitewrap address{
		margin:15px 0 0;
	}
	footer .sitewrap .right_area .foot_menu{
		display:none;
	}
	footer small{
		padding: 15px 0 20px;
	}
}