@charset "utf-8";

/* ////////////////////////////////////////////
 *				 base & layout
 * //////////////////////////////////////////// */

/* Typography
------------------------------------------*/
body{
	font-size: 13px;
	line-height: 1.6;
	font-family: "メイリオ" ,"Meiryo", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	/* font-family: "Avenir", "Open Sans", "Helvetica Neue", "Helvetica", "Arial", "Verdana", "Roboto", "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Meiryo UI", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif; */
	color: #444;
}
a{
	color: #255185;
	text-decoration: none;
}
a:hover,
a:focus{
	color: #255185;
	text-decoration: underline;
}
/* use hover animation */
/*
a, a:hover{
	-webkit-transition: 0.3s ease-in-out;
	   -moz-transition: 0.3s ease-in-out;
		 -o-transition: 0.3s ease-in-out;
			transition: 0.3s ease-in-out;
}
*/


/* Layout
------------------------------------------*/
body{
	padding-bottom: 60px;
	min-width: 980px;
	text-align: center;
	background: #eee;
}
body.home{
}
#container{
	overflow: hidden;
}
#content-inner{
	margin: 0 auto;
	padding: 0 0 100px 0;
	width: 980px;
}
body.home #content-inner{
	width: auto;
}
#main{
	text-align: left;
}
#main article{
	margin: 0 0 20px 0;
}
#main .entry-content{
	padding: 0 10px 20px 10px;
	line-height: 1.8;
}



/* header
------------------------------------------*/
#header{
	background: url(/images/default/header-bg.png) repeat-x center 0;
}
#header-inner{
	position: relative;
	margin: 0 auto;
	width: 980px;
	height: 178px;
	z-index: 1000;
}
.site-description{
	position: absolute;
	top: 12px;
	left: 0;
	color: #666;
	font-size: 10px;
}
.header-logo{
	position: absolute;
	top: 54px;
	left: 0;
}
.header-sns{
	position: absolute;
	top: 0;
	right: 0;
	line-height: 1;
	background: #032445;
	border-radius: 0 0 3px 3px;
	box-shadow: 0 1px 3px rgba(0,0,0,.3);
}
.header-sns li{
	float: left;
}
.header-txt{
	position: absolute;
	top: 45px;
	right: 209px;
}
.header-txt li{
	float: left;
	padding-left: 2px;
}
.header-tel{
	position: absolute;
	top: 50px;
	right: 0;
}
.gnav{
	position: absolute;
	bottom: 9px;
	left: 0;
	border-radius: 3px;
	box-shadow: 0 1px 3px rgba(0,0,0,.2);
}

/* droppy */
.gnav-list { position: relative; text-align: left; zoom: 1; }
.gnav-list li { float: left; display: block; position: relative; z-index: 1000; }
.gnav-list ul {
	display: none;
	position: absolute;
	top: 48px;
	left: -7.5%;
	width: 115%;
	background: #284460;
	/*border-width: 0 1px 1px;*/
	/*border-style: solid;*/
	/*border-color: #284460;*/
}
.gnav-list ul li { float: none; }
.gnav-list ul li a { display: block; padding: 5px 10px; color: #fff; font-size: 11px; zoom: 1; }
.gnav-list ul li a:hover { text-decoration: none; background: rgba(2,35,68,0.95); }
.gnav-list ul ul { top: 0; left: 100%; width: 100%; }
.gnav-list a, .gnav-ul img{ display: block; }



/* mainimage
------------------------------------------*/
#mainimage{
	background: #0c111f;
}
#mainimage-inner{
	margin: 0 auto;
	width: 980px;
}

/* slideshow */
.slideshow{
	overflow: hidden;
	margin: 0 -185px;
	height: 370px;
}
.slideshow .slick-slide{
	overflow: hidden;
	width: 1350px;
	height: 370px;
}
.slideshow .slick-slide img{
	display: inline;
}



/* main
------------------------------------------*/
.main-feature{
	position: relative;
	text-align: center;
	background: #e4e4e4 url(/images/default/main-feature-bg01.png) repeat center 0;
	box-shadow: 0 0 8px rgba(0,0,0,.2);
	z-index: 100;
}
.main-feature-inner{
	margin: 0 auto;
	padding: 35px 0 50px;
	width: 980px;
}
.main-feature h2{
	margin-bottom: 10px;
}
.main-feature-text{
	margin-bottom: 15px;
	line-height: 1.5;
}
.main-feature-list{
	padding: 18px 0 17px 15px;
	background: #ccc url(/images/default/main-feature-bg02.png) repeat center 0;
	border-radius: 3px;
	box-shadow: inset 0 0 8px rgba(0,0,0,.3);
}
.main-feature-list ul li{
	float: left;
	margin: 0 2px 4px 0;
}

.main-message{
	margin: 0 auto;
	padding: 40px 0 60px;
	width: 980px;
}
.main-message-inner{
	padding: 30px 30px 30px 25px;
	background: #fff;
	border-radius: 7px;
	box-shadow: inset 0 0 8px rgba(0,0,0,.3);
}
.main-message-text{
	float: right;
	width: 560px;
	font-size: 14px;
	line-height: 1.7;
}
.main-message-text h2{
	margin-bottom: 15px;
}
.main-message-img{
	float: left;
}

.main-point{
	text-align: center;
	background: #052647 url(/images/default/main-point-bg.png) repeat center 0;
}
.main-point-inner{
	margin: 0 auto;
	padding: 35px 0 25px;
	width: 980px;
}
.main-point h2{
	margin-bottom: 14px;
}
.main-point ol{
	margin: 0 -10px 25px 0;
}
.main-point ol li{
	float: left;
	margin-right: 10px;
	box-shadow: 0 1px 3px rgba(0,0,0,.2);
}
.main-point p{
	margin-bottom: 20px;
}

.main-proposal{
	margin: 0 auto 10px;
	padding: 25px 0 0;
	width: 980px;
}
.main-proposal h2{
	margin-bottom: 16px;
	text-align: center;
}
.main-proposal ul{
	margin-right: -10px;
}
.main-proposal ul li{
	float: left;
	margin: 0 10px 19px 0;
	width: 240px;
	line-height: 1.4;
}
.main-proposal ul li.large{
	margin-right: 20px;
	width: 470px;
}
.main-proposal ul li h3{
	margin-bottom: 5px;
	box-shadow: 0 1px 3px rgba(0,0,0,.3);
}
.main-proposal ul li .image{
	margin: 10px 0 5px;
}

.main-contents{
	margin: 0 auto 35px;
	width: 980px;
}
.main-contents ul{
	margin: 0 -12px;
}
.main-contents ul li{
	float: left;
	padding: 18px 27px;
	width: 334px;
	height: 229px;
	line-height: 1.4;
	background: url(/images/default/main-contents-bg.png) no-repeat center 0;
}
.main-contents ul li h3{
	margin-bottom: 7px;
}

.main-blog{
	margin: 0 auto 35px;
	width: 980px;
}
.main-blog-title{
	position: relative;
	margin-bottom: 20px;
}
.main-blog-title a{
	position: absolute;
	top: 13px;
	right: 15px;
	line-height: 1;
}
.main-blog-inner{
}
.main-blog-list{
	margin-right: -20px;
}
.main-blog-list-item{
	float: left;
	margin: 0 20px 18px 0;
	width: 230px;
	line-height: 1.4;
}
.main-blog-list-img{
	margin-bottom: 10px;
}
.main-blog-list-title{
	margin-bottom: 5px;
}
.main-blog-list-title span{
	font-size: 12px;
	display: block;
}
.main-blog-list-title a{
	font-weight: bold;
}
.main-blog-list-text{
	font-size: 12px;
}

.main-comment{
	overflow: hidden;
	margin: 0 auto;
	padding: 31px 20px 0 320px;
	width: 980px;
	height: 220px;
	line-height: 2;
	background: url(/images/default/main-comment-bg.png) no-repeat 0 0;
}
.main-comment p{
	margin-bottom: 12px;
}
.main-comment p img{
	vertical-align: top;
}
.main-comment :last-child{
	margin-bottom: 0;
}



/* sidebar
------------------------------------------*/
#sidebar{
	float: left;
	width: 220px;
	text-align: left;
}
.side-nav{
	margin: 0 0 20px 0;
}
.side-nav li a{
}
.side-nav-inner > ul > li > a{
	display: block;
	padding: 5px 5px 5px 20px;
	font-size: 13px;
	background: url(/images/default/side-nav-btn-bg.png) no-repeat 3px 50%;
	border-bottom: 1px dashed rgba(185,185,185,0.5);
}
.side-nav-inner > ul > li > ul{
	padding: 10px;
}
.side-nav-inner > ul > li > ul > li > a{
	display: block;
	padding: 2px;
	font-size: 12px;
}
.side-about{
	margin: 20px 0;
	padding: 10px;
	color: #fff;
	font-size: 11px;
	background: #222;
}



/* footer
------------------------------------------*/
#footer{
	text-align: left;
	background: url(/images/default/footer-bg.png) repeat-x center 0;
}
#footer-inner{
	position: relative;
	margin: 0 auto;
	width: 980px;
	height: 270px;
}

.pagetop-btn{
	display: none;
	position: fixed;
	bottom: 84px;
	right: 30px;
	z-index: 1000;
}

.footer-about{
	position: absolute;
	top: 43px;
	left: 0;
}
.footer-about dt{
	margin-bottom: 17px;
}

.footer-nav{
	position: absolute;
	top: 44px;
	left: 320px;
}
.footer-nav ul{
	float: left;
	margin-right: 25px;
}
.footer-nav ul.last{
	margin: 0;
}
.footer-nav ul li{
	margin-bottom: 10px;
	padding-left: 14px;
	background: url(/images/default/footer-nav-btn-bg.png) no-repeat 0 center;
}
.footer-nav ul li a{
	color: inherit;
}

.footer-copyright{
	position: absolute;
	bottom: 34px;
	left: 0;
	width: 100%;
	font-size: 11px;
	text-align: center;
}



/* site-ad
------------------------------------------*/
.site-ad{
	position: fixed;
	bottom: -68px;
	left: 0;
	width: 100%;
	background: #052647;
	box-shadow: 0 -3px 6px rgba(0,0,0,.15);
	z-index: 1000;
}
.site-ad-inner{
	position: relative;
	margin: 0 auto;
	padding-top: 10px;
	width: 980px;
	height: 60px;
}
.site-ad li{
	float: left;
	margin-right: 15px;
}
.site-ad ul li.item03{
	margin-right: 5px;
}
.site-ad ul li.item04{
	margin: 0;
}



/* Lower
------------------------------------------*/
/* link color */
.breadcrumb a,
.entry-content a{
}

/* heading */
.page-title-area{
	margin-bottom: 30px;
	color: #fff;
	text-align: left;
	background: #0c111f;
}
.page-title-area-inner{
	margin: 0 auto;
	padding-top: 40px;
	width: 980px;
	height: 150px;
	background: url(/images/default/page-title-area-bg.png) no-repeat right 0;
}
.page-title{
	font-size: 28px;
	font-weight: bold;
	line-height: 1.5;
	display: none;
}
.entry-content h2, .entry-title{
	margin: 0 0 20px;
	padding: 0 0 0 30px;
	height: 86px;
	color: #000;
	font-size: 24px;
	font-weight: bold;
	line-height: 86px;
	background: url(/images/default/entry-title-bg.png) no-repeat 0 0;
	border-radius: 3px;
	box-shadow: 0 1px 6px rgba(0,0,0,.15);
}
.entry-content h2{
	margin: 0 -10px 20px;
}
.entry-content h2 a,
.entry-title a{
	color: inherit;
}
.entry-content h3, .h3{
	color: #204675;
	padding: 8px 5px 5px 26px;
	font-size: 20px;
	font-weight: bold;
	background: #eff2f3 url(/images/default/entry-h3-bg.png) no-repeat 8px 19px;
	border: 2px solid #abbbc2;
	border-radius: 3px;
}
.entry-content h4, .h4{
	padding: 0 0 0 10px;
	font-size: 17px;
	font-weight: bold;
	background: url(/images/default/entry-h4-bg.png) no-repeat 0 center;
}
.entry-content h5, .h5{
	padding: 0 0 2px 0;
	font-size: 14px;
	font-weight: bold;
	background: url(/images/default/entry-h5-bg.png) repeat-x 0 bottom;
}



/* Breadcrumb
------------------------------------------*/
.breadcrumb{
	padding: 0;
	margin: 0 !important;
	background: none;
	font-size: 11px;
}
.breadcrumb-item a{
	color: inherit;
}
.breadcrumb-item + .breadcrumb-item:before{
	content: '>';
	color: inherit;
}
/*.breadcrumb-item.home:before{
	padding: 0 2px 0 4px;
	content: '\f015';
	font-weight: normal;
	font-size: 11px;
	font-family: 'FontAwesome';
	line-height: 1;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}*/



/* Nav
------------------------------------------*/
.blog-nav-group{
	padding-top: 20px;
}
.common-nav{
	margin: 0 0 20px 0;
	text-align: left;
}
.common-nav h2{
	padding-bottom: 5px;
	border-bottom: 1px solid rgba(186,186,186,0.7);
	font-size: 15px;
	font-weight: bold;
}
.common-nav li{
	display: block;
	padding: 5px;
	border-bottom: 1px dashed rgba(186,186,186,0.7);
}
.common-nav li a{
	color: inherit;
	font-size: 12px;
}



/* Gallery
------------------------------------------*/
/* archive */
.gallery-list{
}
.gallery-list-row{
	margin: 0;
}
.gallery-list-col{
	padding: 0 15px 15px;
}
.gallery-list-item{
}
.gallery-list-img{
	margin-bottom: 3px;
}
.gallery-list-title{
	font-size: 13px;
}

/* single */
.gallery-detail{
	padding: 0 15px 15px 15px;
	text-align: center;
}
.gallery-detail-row{
}
.gallery-detail-col{
}
.gallery-detail-main{
}
.gallery-detail-sub{
}
.gallery-detail-sub li{
	padding: 0 5px 10px;
}

/* before-after */
.ba-detail{
	padding: 0 10px 20px;
}
.ba-detail-main{
	display: table;
	margin-bottom: 20px;
}
.ba-detail-before,
.ba-detail-after{
	display: table-cell;
	width: 45%;
}
.ba-detail-arrow{
	display: table-cell;
	width: 10%;
	text-align: center;
	vertical-align: middle;
}
.ba-detail-arrow i{
	font-size: 30px;
}
.ba-detail-sub li{
	padding: 0 15px 15px;
}



/* Colors
------------------------------------------*/
/* btns */
.btn-primary.disabled:hover,
.btn-primary:disabled:hover,
.btn-primary.active:focus,
.btn-primary:active:focus,
.btn-primary.active:hover,
.btn-primary:active:hover,
.btn-primary.active,
.btn-primary:active,
.btn-primary:focus,
.btn-primary:hover,
.btn-primary{
	border-color: #202020;
	background-color: #2e2e2e;
	color: #fff;
}

.btn-secondary.disabled:hover,
.btn-secondary:disabled:hover,
.btn-secondary.active:focus,
.btn-secondary:active:focus,
.btn-secondary.active:hover,
.btn-secondary:active:hover,
.btn-secondary.active,
.btn-secondary:active,
.btn-secondary:focus,
.btn-secondary:hover,
.btn-secondary{
	border-color: #ccc;
	background-color: #fff;
}

.btn-outline-primary.disabled:hover,
.btn-outline-primary:disabled:hover,
.btn-outline-primary.active:focus,
.btn-outline-primary:active:focus,
.btn-outline-primary.active:hover,
.btn-outline-primary:active:hover,
.btn-outline-primary.active,
.btn-outline-primary:active,
.btn-outline-primary:focus,
.btn-outline-primary:hover,
.btn-outline-primary{
	border-color: #202020;
	background-color: #fff;
	color: #202020;
}

/* pagination */
.page-link{
	border-color: #9e9e9e;
	color: #444;
}
.page-item.active .page-link,
.page-item.active .page-link:focus,
.page-item.active .page-link:hover,
.page-link:focus,
.page-link:hover{
	border-color: #999999;
	background-color: #9e9e9e;
	color: #fff;
}

/* ハンバーガーメニュー */
.menu-btn {
	position: fixed;
	top: 10px;
	right: 10px;
	display: flex;
	height: 60px;
	width: 60px;
	justify-content: center;
	align-items: center;
	z-index: 99;
	background-color: #3584bb;
}
.menu-btn span,
.menu-btn span:before,
.menu-btn span:after {
	transition: 0.5s;
	content: '';
	display: block;
	height: 3px;
	width: 25px;
	border-radius: 3px;
	background-color: #ffffff;
	position: absolute;
}
.menu-btn span:before {
	bottom: 8px;
}
.menu-btn span:after {
	top: 8px;
}

#menu-btn-check:checked ~ .menu-btn span {
	background-color: rgba(255, 255, 255, 0);/*メニューオープン時は真ん中の線を透明にする*/
}
#menu-btn-check:checked ~ .menu-btn span::before {
	bottom: 0;
	transform: rotate(45deg);
}
#menu-btn-check:checked ~ .menu-btn span::after {
	top: 0;
	transform: rotate(-45deg);
}
#menu-btn-check {
	display: none;
}
.menu-content {
	width: 100%;
	height: 100%;
	position: fixed;
	top: 0;
	left: 100%;/*leftの値を変更してメニューを画面外へ*/
	z-index: 90;
	transition: all 0.5s;/*アニメーション設定*/
}
#menu-btn-check:checked ~ .menu-content {
	left: 0;/*メニューを画面内へ*/
}
