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

	林建設工業
	共通CSS

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

@charset "UTF-8";


/*======================================
	base
=======================================*/
* {
	margin: 0;
	padding: 0;
	word-break: normal;
	word-wrap: break-word;
	line-height: 1.6;
	font-family: 'Hiragino Kaku Gothic Pro',Meiryo,'MS PGothic',arial,sans-serif;
	/* font-family: 'Hiragino Kaku Gothic Pro','ヒラギノ角ゴ Pro W3','メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif; */
}
*, *:before, *:after {
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
         -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
}
body {
	margin: 0;
	padding: 0;
	background-color: #fff;
	font-size: 16px;
	color: #000000;
	-webkit-text-size-adjust: 100%;
}
img {
	vertical-align: top;
	max-width:100%;
}
a:link {
	color: #000;
	text-decoration: underline;
}
a:visited {
	color: #000;
	text-decoration: underline;
}
a:hover {
	color: blue;
	text-decoration: underline;
}
a img {
	border: 0;
}
a:hover img {
	opacity: 0.7;
}

/* webフォント */
.ntfont, .ntfont *{
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 900;
}
.page_title .sub_title{
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700 !important;
}


/* iphone スマホ時崩れ調整 */
/* input {
	-webkit-appearance: none;
	border-radius: 0;
}
select {
	-webkit-appearance: none;
	border-radius: 0;
} */
input[type="submit"], input[type="button"]{
	-webkit-appearance: none;
	border-radius: 0;
}


/* 訪問色を変更しないアンカ */
a.colfix:link,
a.colfix:visited {
	color: #04c;
}
a.colfix:hover {
	color: #cd4730;
}

ul,ol,dl {
	list-style-type: none;
}
div,p,form,h1,h2,h3,h4 {
	margin: 0;
	padding: 0;
}

hr {
	/*
	display: none;
	*/
	margin: 0.5em 0 1em;
}
strong * {
	font-weight: bold;
}
strile * {
	text-decoration: line-through;
}
b {
	font-weight: bold;
}

/* テーブル */
tr {
	background-color: #fff;
}

/* リスト系テーブル */
table.list {
	margin-bottom: 0.5em;
	border-collapse: collapse;
}
/*
table.list tr {
	background-color: #fff;
}
*/
table.list th {
	background-color: #eee;
	text-align: center;
	border:	solid 1px #999;
	padding: 0.5em 1em;
	font-weight: normal;
	font-size: 100%;
	font-weight: bold;
}
table.list td {
	border:	solid 1px #999;
	padding: 0.5em 1em;
	text-align: left;
	word-break: break-all;
	font-size: 100%;
}

/* 詳細系テーブル */
table.detail {
	margin-bottom: 1em;
	border-collapse: collapse;
}
table.detail th {
	background-color: #eee;
	text-align: right;
	border:	solid 1px #999;
	padding: 0.5em 1em;
	font-weight: normal;
	font-size: 100%;
	font-weight: bold;
	width: 10em;
}
table.detail td {
	border:	solid 1px #999;
	padding: 0.5em 1em;
	text-align: left;
	word-break: break-all;
	font-size: 100%;
	background-color: #fff;
}

/* 枠なし */
table.noborder {
	margin-bottom: 0;
	border-collapse: collapse;
}
table.noborder td {
	border:	none;
	padding: 1px 3px;
	vertical-align: top;
}


/* 入力 */
table.input p.note {
	color: #999;
	margin-top: 0.2em;
	margin-bottom: 0.5em;
}
table.input span.note {
	color: #999;
}
table.input p.note {
	color: #999;
	margin-top: 0.3em;
	margin-bottom: 0;
}
table.input span.hissu {
	font-size: 80%;
	color: #f63;
	padding-right: 0.5em;
	vertical-align: middle;
}


/* ページトップボタン */
a.pagetop01 {
	position: fixed;
	right: 35px;
	z-index: 1000;
}


/*======================================
	photoswipe 調整
=======================================*/
.pswp__ui--idle .pswp__button--arrow--left, .pswp__ui--idle .pswp__button--arrow--right {
	opacity: 1;
}
.pswp--touch .pswp__button--arrow--left, .pswp--touch .pswp__button--arrow--right {
	visibility: visible;
}
.pswp__caption__center {
	font-size: 16px;
	padding: 50px 20px 50px;
	text-align: center !important;
}


/*======================================
	slide 調整
=======================================*/
.slider{
	width: 575px;
	margin: 0 auto;
}
.slick-dots li {
	width: 18%;
	margin: 0 1%;
}
.slider{
	display: none;
}
.slider.slick-initialized{
	display: block; /*slick-initializedが付与されたら表示*/
}


/*======================================
	clearfix
=======================================*/
.clearfix:after{
  content:".";
  display:block;
  height:0;
  clear:both;
  visibility:hidden;
}
.clearfix{
  zoom:1;
}


/*======================================
	ページ共通
=======================================*/
/* 基本ページ幅 */
.main_wide{
	max-width: 1160px;
	width: 100%;
	padding-left: 30px;
	padding-right: 30px;
	margin: 0 auto;
}

.last_sec{
	margin-bottom: 30px;
}

/* ボタン類 */
.btn_wrap{
	position: relative;
	margin: 0 auto;
	text-align: center;
}
a.btn_01{
	max-width: 275px;
	width: 100%;
	display: inline-block;
	font-size: 112.5%;
	color: #fff;
	text-decoration: none;
	text-align: center;
	line-height: 1;
	padding: 15px 0;
	background-image: url(../img/common/arrow_w.png);
	background-color: #0a8d00;
	background-repeat: no-repeat;
	background-position: top 12px right 10px;
}
a.btn_01:hover{
	opacity: .7;
}


/* パンクズ */
#pankuzu{
	margin-top: 25px;
	margin-bottom: 70px;
}
#pankuzu li{
	font-size: 87%;
	float: left;
	margin-right: 10px;
}
#pankuzu li:last-child{
	margin-right: 0;
}
#pankuzu li:not(:last-child)::after{
	content: url('../img/common/mk_pankuzu.png');
	margin-left: 10px;
}
#pankuzu li a{
	color: #8a8a8a;
}
#pankuzu li a:hover{
	color: blue;
}


/* ページタイトル */
h2.page_title{
	font-size: 237.5%;
	color: #0a8d00;
	letter-spacing: 6px;
	line-height: 1.2;
	text-align: center;
	margin-bottom: 60px;
}
h2.page_title > .sub_title{
	display: block;
	font-size: 55%;
	letter-spacing: 3px;
}
.sub_title .delimter{
	margin-left: 0.3em;
	margin-right: 0.3em;
}

.line_title{
	position: relative;
	font-size: 145%;
	font-weight: bold;
	vertical-align: middle;
	padding-left: 45px;
	margin-bottom: 15px;
	line-height: 1.3;
}
.line_title::before{
	position: absolute;
	top: 12px;
	left: 0;
	content: "";
	display: block;
	width: 37px;
	height: 8px;
	background: #0a8d00;
}


/* サイドナビ */
#side_nav_sp{
	display: none;
}
.nav_wrap{
	position: absolute;
	max-width: 215px;
	width: 100%;
	top: 0;
	right: 0;
}
.nav_detail{
	padding: 15px 5px 15px 15px;
	background-color: #ebf5e7;
}
.nav_detail > ul > li{
	margin-bottom: 4px;
}
.nav_detail > ul > li.archit{
	margin-bottom: 30px;
}
.nav_title{
	font-size: 125%;
	font-weight: bold;
	margin-bottom: 8px;
}
.nav_title a,
.nav_s_title a{
	text-decoration: none;
}

.nav_wrap .title{
	font-size: 105%;
}
.nav_wrap .nav_list{
	background: url(../img/common/bk_nav.png);
	background-repeat: repeat-y;
	background-position: top 0 left 5px;
	padding-left: 16px;
}
.nav_wrap .nav_list li{
	position: relative;
	font-size: 95%;
	padding-left: 11px;
	margin-bottom: 10px;
}
.nav_wrap .nav_list li:first-child{
	margin-top: 10px;
}
.nav_wrap .nav_list li:last-child{
	margin-bottom: 0;
}
.nav_wrap .nav_list a{
	text-decoration: none;
}
.nav_s_title a:hover,
.nav_wrap .nav_list a:hover{
	color: #0a8d00;
}
.nav_wrap .nav_list > li::before{
	content: url(../img/common/mk_nav.png);
	position: absolute;
	top: 1px;
	left: -3px;
}
.nav_wrap .nav_list > li.open::before{
	content: url(../img/common/mk_nav_open.png);
	top: 0px;
	left: -6px;
}
.nav_wrap .nav_list > li.close::before{
	content: url(../img/common/mk_nav.png);
	position: absolute;
	top: 1px;
	left: -3px;
}

.nav_btn{
	cursor: pointer;
}
.nav_btn:hover{
	color: #0a8d00;
}

.active > a{
	color: #0a8d00;
	font-weight: bold;
}

.nav_wrap .nav_list li .lower_list li{
	padding-left: 0;
}
.lower_list{
	display: none;
}


/* 下層トップイメージ */
.fit_img{
	object-fit: cover;
	font-family: 'object-fit: cover;';
	width: 100%;
	max-height: 295px;
}





@media screen and (max-width:960px) {
	.main_wide{
		padding-left: 20px;
		padding-right: 20px;
	}
}

@media screen and (max-width:650px) {
	.main_wide{
		padding-left: 15px;
		padding-right: 15px;
	}
}

@media screen and (max-width:800px) {
	#side_nav{
		max-width: 450px;
		margin: 0 auto;
	}
	
	#nav_content .archit{
		margin-bottom: 0;
	}
	
	.nav_wrap{
		position: relative;
		max-width: 100%;
	}
	.nav_detail{
		padding: 20px;
	}
	.nav_title{
		padding-bottom: 12px;
		padding-left: 0;
		border-bottom: solid 1px #231815;
	}
	.nav_detail > ul > li{
		padding-left: 0;
		padding-bottom: 10px;
		margin-top: 10px;
		margin-bottom: 0;
	}
	#ship .nav_detail > ul > li{
		padding-bottom: 10px;
		margin-top: 10px;
	}
	.nav_detail > ul > li:not(:last-child){
		border-bottom: solid 1px #231815;
	}
	.nav_wrap .nav_list{
		background: none;
	}
	
	.nav_wrap .nav_list > li{
		font-size: 100%;
		padding-right: 10px;
		margin-bottom: 5px;
	}
	.nav_wrap .nav_list > li:first-child{
		margin-top: 5px;
	}
	.lower_list {
		padding-left: 0;
	}
}
