@charset "UTF-8";
/* ===================================================================
CSS information

 file name  :base.css
 style info :共通のスタイル指定(ヘッダー、フッターなど)
=================================================================== */

img {
	border: 0;
	max-width: 100%;
	height: auto;
	width /***/:auto;
}
html{
	/*font-family: -apple-system, BlinkMacSystemFont, Roboto, "游ゴシック体", YuGothic, "Yu Gothic Medium", sans-serif;*/
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
    font-feature-settings: "pkna" 1;
    line-height: 1.6em;
    color: #333;
}

body{
	background: url(../img/bg_content.jpg) left top repeat;}
.ten{
	font-family: ten-mincho, serif;
	font-weight: 400;
	font-style: normal;
}

a{
	color: #333;
	text-decoration: none !important;
}
a:hover{
	color: #323e6a;
}



/* ===================================================================


レイアウト


=================================================================== */

.container{
	max-width: 1260px;
	margin: 0 auto;
}
@media (min-width: 769px) {/*PC*/
	#page{
		padding-top: 239px;
		min-width: 1260px;
	}
	#wrapper{
		display: flex;
		justify-content: space-between;
		padding: 20px 0;
	}
	#sidebar{width: 279px;}
	#main{width: 933px;}
	#header{
		min-width: 1260px;
	}
}

@media (max-width: 768px) {/*SP*/
	.container{
		padding: 15px;
	}
}


/* ===================================================================


header


=================================================================== */
#header{
	position: fixed;
	width: 100%;
	top:0;
	left:0;
	z-index:100;
	transition: all 0.8s;
	background: url(../img/bg_content.jpg) left top repeat;
}
#header.smaller{
	background: #fff;
	/*background: rgba(255,255,255,0.6);*/
}


@media (min-width: 769px) {/*PC*/
	#header.smaller{
	/*display: none;
	margin-top: -60px;*/
	top: -50px;
}
	
	
	.header-search{
		background-color: #323e6a;
	}
	.header-search__inner{
		overflow: hidden;
		padding: 10px;
	}
	.header-search__inner .description{
		float: left;
		color: #fff;
		font-size: .8em;
	}
	.header-search__inner .description{
		float: left;
	}
	.header-search__inner .header-search__form{
		float: right;
		
	}
	.header-search__inner .header-search__form form{
		font-size: 0;
		position: relative;
	}
	.header-search__inner .header-search__form form:after{
		content: "\f002";
		font-family: FontAwesome;
		position: absolute;
		top: 3px;
		left: 8px;
		display: block;
		width: 20px;
		height: 20px;
		font-size: 16px;
		color: #ccc;
	}
	.header-search__inner .header-search__form input[type=text],
	.header-search__inner .header-search__form input[type=submit]{
		height: 30px;
		border: none;
		margin: 0;
	}
	.header-search__inner .header-search__form input[type=text]{
		border-top-left-radius: 4px;
		border-bottom-left-radius: 4px;
		position: relative;
		font-family: fontAwesome;
		content: '\f099';
		padding-left: 30px;
	}

	.header-search__inner .header-search__form input[type=submit]{
		border-top-right-radius: 4px;
		border-bottom-right-radius: 4px;
		width: 80px;
		background-color: #000;
		color: #fff;
		font-size: 14px;
	}
	.header-info__inner{
		width: 100%;
		margin: 0 auto;
		padding: 20px 0;
		display: flex;
	}
	.header-info__inner .logo{
		width: 30%;
		vertical-align: middle;
		justify-content: space-between;
		margin-top: 15px;
	}
	.header-info__inner .address{
		text-align: right;
		vertical-align: top;
	}
	.header-info__inner .address{
		display: table;
		margin-left: auto;
		font-size: 14px;
		font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	}
	.header-info__inner .address address{
		display: table-cell;
		vertical-align: top;
	}
	.header-info__inner .address address p span{
		font-size: 1.8em;
	}
	.header-btn{
		display: table-cell;
		padding-left: 20px;
		width: 234px;
	}
	.header-btn a{
		width: 234px;
		line-height: 1.4em;
		position: relative;
		font-size: 16px;
	}
	.header-btn a i{
		position: absolute;
		top: 50%;
		margin-top: -6px;
		left: 24px;
	}
}
@media (max-width: 768px) {/*SP*/
	.header-search,
	.header-info__inner .address{
		display: none;
	}
}
/* ===================================================================
PC NAVI
=================================================================== */

@media (min-width: 769px) {/*PC*/
	#gnavi{
		border-top: solid 1px #ccc;
		border-bottom: solid 1px #ccc;
	}
	#gnavi .list-level1{
		padding: 15px 0;
		text-align: center;
	}
	#gnavi .list-level1 > li{
		display: inline-block;
	}
	
	
	#gnavi .list-level1 > li > a{
		display: block;
		padding:0 2em;
		position: relative;
		font-family: ten-mincho, serif;
		font-weight: 400;
		font-style: normal;
		font-size: 18px;
	}

	#gnavi .list-level1 > li:last-child a:after{
		display: none;
	}
	#gnavi .list-level1 > li > a:after{
		content: "";
		display: block;
		width: 5px;
		height: 5px;
		background-color: #323e6a;
		transform: rotate(45deg);
		position: absolute;
		right: 0;
		top: 50%;
		margin-top: -3px;
	}
	#gnavi .list-level1 > li > a{
		color: #323e6a;
	}
	/*プルダウン*/
	#gnavi ul.list-level1 > li{
		position: relative;
	}
	#gnavi ul.list-level1 li ul.list-level2{
		visibility: hidden;
		opacity: 0;
		z-index: 1;
	}
	#gnavi ul.list-level1 li ul.list-level2{
		position: absolute;
	    top: 30px;
	    width: 180px;
	    background: #fff;
	    -webkit-transition: all .2s ease;
	    transition: all .2s ease;
	    text-align: left;
	}
	#gnavi ul.list-level1 li.pulldown:hover ul.list-level2{
		top: 40px;
		visibility: visible;
		opacity: 1;
		
	}
	#gnavi ul.list-level1 li ul.list-level2 li a{
		display: block;
		width: 100%;
		padding: .6em .6em .6em 3em;
		position: relative;
		font-size: 14px;
	}
	#gnavi ul.list-level1 li ul.list-level2 li a:before{
		content: "";
		display: block;
		width: 0;
		height: 0;
		border-right: 4px solid transparent;
		border-top: 4px solid transparent;
		border-bottom: 4px solid transparent;
		border-left: 4px solid #333;
		position: absolute;
		left: 20px;
		top: 50%;
		margin-top: -5px;
	}
	#gnavi ul.list-level1 li ul.list-level2 li a:hover{
		background-color: #f3f3f3;
	}
	.nav-sp{
		display: none;
	}
	
	
}
/* ===================================================================
SP NAVI
=================================================================== */

/*ハンバーガーメニュー*/
.menu-btn{
    height: 40px;
    width: 40px;
    position: absolute;
    right: 10px;
    top: 10px;
    z-index: 99;
    background-color: #323e6a;
}
.menu{
	width: 30px;
	height: 20px;
	position: absolute;
	left: 5px;
	top: 10px;
}
.menu__line{
    background: #fff;
    display: block;
    height: 2px;
    position: absolute;
    transition:transform .3s;
    width: 100%;
}
.menu__line--center{
    top: 9px;
}
.menu__line--bottom{
    bottom: 0;
}
.menu__line--top.active{
    top: 8px;
    transform: rotate(45deg);
    background: #fff;
}
.menu__line--center.active{
    transform:scaleX(0);
    background: #fff;
}
.menu__line--bottom.active{
    bottom: 10px;
    transform: rotate(135deg);
    background: #fff;
}
/*SPナビ*/
@media (max-width: 768px) {/*SP*/
	#page{
		padding-top: 60px;
	}
	#gnavi{
		display: none;
	}
	#header .header-info .logo{
		width: 180px;
	}
}
.gnavi-sp{
    background: #323e6a;
    display: none;
    height: 100%;
    position: fixed;
    width: 100%;
    z-index: 98;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    overflow-y: auto;
}
.gnavi-sp__wrap{
	padding: 20px;
}
.gnavi-sp__wrap .gnav__menu li{
	border-bottom: solid 1px rgba(255,255,255,.2);
}
.gnavi-sp__wrap .gnav__menu li a{
	display: block;
	color: #fff;
	padding: .5em;
	position: relative;
}
.gnavi-sp__wrap .gnav__menu li.accordion > a:after{
	font-family: fontAwesome;
	content: '\f067';
	display: block;
	position: absolute;
	right: 5%;
	top: 50%;
	margin-top: -12px;
}
.gnavi-sp__wrap .gnav__menu li.accordion > a.active:after{
	content: '\f068';
}
.gnavi-sp__wrap .gnav__menu li ul{
	display: none;
	margin-left: 1em;
}
.gnavi-sp__wrap .gnav__menu li ul li:last-child{
	border-bottom: none;
}
.gnavi-sp__wrap dl{
	color: #fff;
	text-align: center;
	margin-top: 2em;
	font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.gnavi-sp__wrap dl a{color: #fff;}
.gnavi-sp__wrap dl dt{
	font-size: 18px;
}
.gnavi-sp__wrap dl dt span{
	font-size: 1.8em;
}
.gnavi-sp__wrap dl dd{
	font-size: 14px;
}


/* ===================================================================


footer


=================================================================== */


#footer{
	background-color: rgba(240,240,245,.8);
}
#footer a{
	color: #333;
	text-decoration: none;
}
#footer a:hover{
	color: #323e6a;
}
#footer h4{
	border-bottom: solid 1px #333;
	padding-bottom: .5em;
	margin-bottom: 1em;
	color: #323e6a;
}
#footer h4:before{
	content: "";
	display: inline-block;
	width: 8px;
	height: 8px;
	background-color: #323e6a;
	transform: rotate(45deg);
	margin-right: .5em;
	margin-left: .5em;
}
.footer__navi ul.list-level1{
	font-weight: bold;
}
	.footer__navi ul li ul li{
	width: 50%;
	float: left;
	font-weight: normal;
}
.footer__navi ul.list-level2 li:before{
	content: "- ";
}
@media (min-width: 769px) {/*PC*/
	#footer .container{
		padding: 70px 0;
	}
	.footer-inner{
		display: flex;
	}
	.footer-inner .footer__info{
		width: 26%;
		font-size: 14px;
		line-height: 1.4em;
	}
	.footer-inner .footer__info .logo-footer{
		margin-bottom: 1em;
	}
	.footer-inner .footer__info .address-tel{
		margin-bottom: 1em;
	}
	.footer-inner .footer__navi{
		overflow: hidden;
		width: 74%;
	}
	.footer__navi--left{
		float: left;
		width: 74%;
	}
	.footer__navi--right{
		float: right;
		width: 23%;
	}

	.footer__navi .unit-list{
		display: table;
		width: 100%;
	}
	.footer__navi ul{
		font-size: 14px;
	}
	.footer__navi .unit-list ul{
		display: table-cell;
		vertical-align: top;
		width: 50%;
	}

	.footer__navi ul.list-level2{
		padding-top: .5em;
	}
	.footer__navi ul li ul li:before{
		content: "-";
		margin-right: .5em;
	}

	.footer__navi ul.list-style2 li{
		width: 50%;
		float: left;
	}
	#footer .copyright{
		font-size: 12px;
		text-align: right;
		color: #666;
	}
}
@media (max-width: 768px) {/*SP*/
	#footer{
		font-size: 14px;
	}
	.logo-footer{
		width: 180px;
	}
	.logo-footer{
		margin-bottom: 2em;
	}
	.footer__info{
		margin-top: 30px;
		margin-bottom: 2em;
		line-height: 1.4em;
	}
	.address-tel{
		margin-bottom: 1em;
	}
	.footer__navi ul li{
		line-height: 2em;
		font-size: 14px;
	}
	.footer__navi .list-style1{
		margin-bottom: 2em;
	}
	.footer__navi .list-style1 ul:first-child > li:first-of-type{
		width: 100%;
	}
	.footer__navi ul.list-level1{
		overflow: hidden;
	}
	.footer__navi ul.list-level1 li{
		width: 50%;
		float: left;
	}
	.footer__navi ul.list-level1 ul{
		margin: .5em 0;
		overflow: hidden;
	}
	.footer__navi--right{
		margin-bottom: 2em;
	}
	#footer .copyright{
		font-size: 10px;
		text-align: center;
		color: #666;
	}
	
}

/* ===================================================================


sidebar--PC


=================================================================== */

.sidebar__navi{
	border: solid 1px #ccc;
	border-top: solid 4px #323e6a;
	padding: 18px;
	margin-bottom: 2em;
}
.sidebar__navi__ttl{
	font-weight: bold;
	font-family: ten-mincho, serif;
	font-weight: 400;
	text-align: center;
	font-size: 24px;
	margin-bottom: 1em;
	padding-bottom: .5em;
	letter-spacing: .5em;
	border-bottom: solid 1px #ccc;
	position: relative;
	color: #323e6a;
}

.sidebar__navi dl{
	border-bottom: solid 1px #ccc;
	margin-bottom: 1em;
	padding-bottom: 1em;
}
.sidebar__navi dl:last-child{
	border-bottom: none;
	margin-bottom: 0;
	padding-bottom: 0;
}

.sidebar__navi dl dt{
	font-weight: bold;
	margin-bottom: .5em;
	padding-left: 20px;
	position: relative;
}
.sidebar__navi dl dt:before{
	content: "";
	width: 8px;
	height: 8px;
	display: block;
	background-color: #323e6a;
	transform: rotate(45deg);
	position: absolute;
	left: 3px;
	top: 50%;
	margin-top: -5px;
}
.sidebar__navi dl dd{
	font-size: .9em;
}
.sidebar__navi dl dd:before{
	content: "・";
}
.sidebar__navi dl dd a:hover{
	text-decoration: underline;
}
#sidebar .sidebar__bnr li{
	margin-bottom: 1em;
}
@media (max-width: 768px) {/*SP*/
	#sidebar{
		display: none;
	}
}


/* ===================================================================


sp-tabbar


=================================================================== */

@media (min-width: 769px) {/*PC*/
	.sp-tabbar{
		display: none;
	}
}
@media (max-width: 768px) {/*SP*/
	.sp-tabbar{
		position: fixed;
		width: 100%;
		bottom: 0;
		left: 0;
		background-color: rgba(255,255,255,.8);
		z-index: 2;
		transition: ease-out .5s;
	}
	.sp-tabbar ul{
		display: flex;
		justify-content: space-between;
	}
	.sp-tabbar ul li{
		width: 25%;
	}
	.sp-tabbar ul li a{
		display: block;
		text-align: center;
		padding: 15px 0;
		font-size: 12px;
		color: #323e6a;
	}
	.sp-tabbar ul li a i{
		display: block;
		margin-bottom: .2em;
		font-size: 16px;
		
	}
	.sp-tabbar.hide{
		margin-bottom: -80px;
	}
}



