* {
	margin: 0;
	padding: 0;
}
*::after,
* {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

body {
  font-family: 'Open Sans', sans-serif;
  font-weight: 300;
	font-size: 16px;
	line-height: 150%;
	color: #000000;
	position: relative;
	background-color: #FFFFFF;
}

a {

}

a:hover, a:active, a:focus {
  text-decoration: none;
}

h1, h2, h3, h4, h5, h6 {
  color: #484c50;
}



/*# section設定 */

#logobox {
	background-color: #fff;
	width: 100%;
	margin-right: auto;
	margin-left: auto;
}

#topimgbox {
	background-color: #fff;
	width: 100%;
	margin-right: auto;
	margin-left: auto;
}



#endimgbox {
	background-color: #fff;
	padding-top: 50px;
	width: 100%;
	margin-right: auto;
	margin-left: auto;
}

#header {
	background-color: #fff;
	padding-top: 1.5em;
	padding-right: 0;
	padding-bottom: 0;
	padding-left: 0;
}

#top-box1 {
	background-color: #fff;
	padding: 2em 0;
	width: 100%;
	text-align: left;
}

#foo-box {
	padding: 1em 0;
	background-color: #94D015;
	text-align: center;
	font-size: 14px;
	line-height: 40px;
}

.logoimg {
	background-color: #fff;
	height: 100px;
}

#topimg {
	position: relative;
	overflow: hidden;
	height: 680px;
	background-size: cover;
	background-color: #FFFBC7;
	background-image: url(../images/topimg_01.jpg);
	background-repeat: repeat-x;
	background-position: 50% 0;
}

#topimg a {
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
}



@media screen and (max-width:1000px) {

#logobox {
	background-color: #fff;
	width: 100%;
	margin-right: auto;
	margin-left: auto;
	height: 80px;
}

.logoimg {
	background-color: #fff;
	height: 80px;
}

#topimg {
	position: relative;
	overflow: hidden;
	height: 530px;
	background-size: cover;
	background-color: #FFFBC7;
	background-image: url(../images/topimg_03.jpg);
	background-repeat: repeat-x;
	background-position: 50% 0;
}

}

@media screen and (max-width: 768px) {
#logobox {
	background-color: #fff;
	width: 100%;
	margin-right: auto;
	margin-left: auto;
	height: 50px;
}
.logoimg {
	background-color: #fff;
	height: 50px;
}

#topimg {
width: 100%;
height: 0;
padding-top: calc(1350 / 1280 * 100%); /* calc(画像高さ ÷ 画像横幅 × 100%) */
background: url(../images/topimg_03sp.jpg) center center / cover no-repeat;
}

#header {
	background-color: #fff;
	padding-top: 0;
	padding-right: 0;
	padding-bottom: 20px;
	padding-left: 0;
}

#top-box1 {
    padding: 3em 0;
  }
  
#endimgbox {
	background-color: #fff;
	padding-top: 20px;
	width: 100%;
	margin-right: auto;
	margin-left: auto;
}

}



/* パーツ類 */

.top-news {
	font-size: 16px;
	line-height: 220%;
}

.top-news-kiji ul {
	font-size: 16px;
	line-height: 220%;
	list-style: none;
}

.top-news-kiji ul li {
	font-size: 16px;
	line-height: 220%;
	list-style: none;
}



/*トップボタン */


.menuh {
	width:auto;
	line-height: 34px;
	font-size: 15px;
	float: left;
	border-left-width: 1px;
	border-left-style: solid;
	border-left-color: #94D015;
	margin-top: 33px;
	margin-bottom: 33px;
	position: relative;
	padding-right: 15px;
	padding-left: 15px;
}

.menuh a {
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    text-indent:-999px;
}

.menuh a:hover{
    background-color:#FFF;
    filter:alpha(opacity=50);
    -moz-opacity: 0.5;
    opacity: 0.5;
}


.menuhtop {
	width:200px;
	font-size: 16px;
	height:50px;
	line-height: 50px;
	background-image: url(../images/top_b_kage2.png);
	font-weight: bold;
	color: #FFFFFF;
	float: right;
	position: relative;
	text-align: right;
	padding-right: 50px;
}

.menuhtop a {
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
	text-indent:-999px;
	font-weight: bold;
	color: #FFFFFF;
}

.menuhtop a:hover{
    background-color:#FFF;
    filter:alpha(opacity=20);
    -moz-opacity: 0.2;
    opacity: 0.2;
}



@media screen and (max-width:1200px) {
.menuh {
	width:auto;
	line-height: 30px;
	height:30px;
	margin-top: 35px;
	margin-bottom: 35px;
	font-size: 13px;
	float: left;
	border-left-width: 1px;
	border-left-style: solid;
	border-left-color: #94D015;
	padding-right: 10px;
	padding-left: 10px;
}
.menuhtop {
	width:140px;
	font-size: 15px;
	line-height: 50px;
	background-image: url(../images/top_b_kage2.png);
	font-weight: bold;
	color: #FFFFFF;
	float: right;
	text-align: right;
	padding-right: 20px;
}
}

@media screen and (max-width:1000px) {
.menuh {
display:none;
}
.menuhtop {
display:none;
}
.menuhtop {
	font-size: 13px;
}

.menuhac {
	font-size: 13px;
}

.menuh2 {
	font-size: 13px;
}
.menuhac2 {
	font-size: 13px;
}
}

@media screen and (max-width:768px) {
.menuh {
display:none;
}
.menuhtop {
display:none;
}
.menuhac {
display:none;
}

.menuh2 {
display:none;
}
.menuhac2 {
display:none;
}

}

@media print { 
.menuh {
	width:100px;
	line-height: 30px;
	height:30px;
	margin-top: 35px;
	margin-bottom: 35px;
	font-size: 14px;
	float: left;
	border-left-width: 1px;
	border-left-style: solid;
	border-left-color: #94D015;
}
.menuhtop {
	width:150px;
	font-size: 14px;
	line-height: 50px;
	background-image: url(../images/top_b_kage2.png);
	font-weight: bold;
	color: #FFFFFF;
	float: right;
	text-align: right;
	padding-right: 20px;
}
} 



/*# 左右均等配置 */
.justify{
	display:flex;
	display:-moz-flex;
	display:-o-flex;
	display:-webkit-flex;
	display:-ms-flex;
	justify-content:space-between;
	-moz-justify-content:space-between;
	-o-justify-content:space-between;
	-webkit-justify-content:space-between;
	-ms-justify-content:space-between;
}



/*# ロールオーバーでイメージ半透明 */

.alpha a:hover img {
  opacity: 0.7;
  filter: alpha(opacity=70);
  -ms-filter: "alpha(opacity=70)";
}



/*# 繰り返し写真 */
.phbana {
	position: relative;
	overflow: hidden;
	height: 249px;
	background: url(../images/end_img2.jpg) repeat-x 50% 0;
	background-size: cover;
}

@media screen and (max-width:768px) {
	.phbana {
		padding-bottom: 20.4%;
		height: 0;
	}
}


/* テーブル */

.listtitle {
	width: 100%;
	padding-bottom: 3px;
	border-bottom-width: 1px;
	border-bottom-style: dotted;
	border-bottom-color: #000000;
	margin-bottom: 10px;
	font-size: 16px;
	font-weight: bold;
	padding-left: 3px;
}

.listtitle2 {
	margin-bottom: 10px;
	font-size: 16px;
	font-weight: bold;
	padding-left: 5px;
	border-left-width: 5px;
	border-left-style: solid;
	border-left-color: #94D015;
}

table.listStyle {
	width: 100%;
}
table.listStyle tr {
	width: 100%;
}
table.listStyle td.sh00 {
	width: 20%;
	text-align: left;
	vertical-align: top;
	background-color: #EBFBCC;
	padding: 5px;
	border-bottom-width: 3px;
	border-bottom-style: solid;
	border-bottom-color: #FFFFFF;
	font-size: 13px;
}
table.listStyle td.sh01 {
	width: 80%;
	text-align: left;
	vertical-align: top;
	padding: 5px;
	border-bottom-width: 3px;
	border-bottom-style: solid;
	border-bottom-color: #FFFFFF;
	font-size: 13px;
}



table.listStyle2 {
	width: 100%;
}
table.listStyle2 tr {
	width: 100%;
}
table.listStyle2 td.sh00 {
	width: 30%;
	text-align: left;
	vertical-align: top;
	background-color: #EBFBCC;
	padding: 5px;
	border-bottom-width: 3px;
	border-bottom-style: solid;
	border-bottom-color: #FFFFFF;
	font-size: 13px;
}
table.listStyle2 td.sh01 {
	width: 70%;
	text-align: left;
	vertical-align: top;
	padding: 5px;
	border-bottom-width: 3px;
	border-bottom-style: solid;
	border-bottom-color: #FFFFFF;
	font-size: 13px;
}


@media screen and (max-width:1000px) {

table.listStyle td.sh00 {
	width: 20%;
}
table.listStyle td.sh01 {
	width: 80%;
}

table.listStyle2 td.sh00 {
	width: 20%;
}
table.listStyle2 td.sh01 {
	width: 80%;
}

}

@media screen and (max-width: 768px) { /* ▼768：iPad縦・iPhone6+横 */ 

/* テーブル 複数セル リスト化 */
table.listStyle {
	width: 100%;
}
table.listStyle tr { 
display:block;
width: 100%;
padding-bottom: 20px;
}
table.listStyle th { 
display:block;
width: 100%;
}

table.listStyle td.sh00 {
display:block;
width: 100%;
padding-bottom: 0px;
}
	
table.listStyle td.sh01 {
display:block;
width: 100%;
padding-bottom: 0px;
}
table.listStyle td.sh02 {
display:list-item;
width: 100%;
padding-bottom: 0px;
}


table.listStyle2 {
	width: 100%;
}
table.listStyle2 tr { 
display:block;
width: 100%;
padding-bottom: 20px;
}
table.listStyle2 th { 
display:block;
width: 100%;
}

table.listStyle2 td.sh00 {
display:block;
width: 100%;
padding-bottom: 0px;
}
	
table.listStyle2 td.sh01 {
display:block;
width: 100%;
padding-bottom: 0px;
}
table.listStyle2 td.sh02 {
display:list-item;
width: 100%;
padding-bottom: 0px;
}




}





/*# 汎用設定 */

.clearfix:after {
	clear: both;
	content:".";
	display:block;
	height:0;
	visibility:hidden;
}
.clearfix { display:inline-block; }
* html .clearfix { height:1%; }
.clearfix { display:block; }


.f_sp1 {
	letter-spacing: 1px;
}
.f_sp3 {
	letter-spacing: 3px;
}
.f_sp5 {
	letter-spacing: 5px;
}

.f13 {
	font-size: 13px;
}

.f15 {
	font-size: 15px;
}

.f16 {
	font-size: 16px;
}

.f18 {
	font-size: 18px;
}

.f20 {
	font-size: 20px;
}

.f28 {
	font-size: 28px;
}

.f36 {
	font-size: 36px;
}

.f44 {
	font-size: 44px;
}

.f47 {
	font-size: 47px;
}

.f53 {
	font-size: 53px;
}

.f60 {
	font-size: 60px;
}

.f66 {
	font-size: 66px;
}

.f-red {
	color: #D0121B;
}

.f-white {
	color: #ffffff;
}

.f-green {
	color: #94D015;
}

.lh120 {
	line-height: 120%;
}

.lh130 {
	line-height: 130%;
}

.lh140 {
	line-height: 140%;
}

.lh150 {
	line-height: 150%;
}
.lh170 {
	line-height: 170%;
}

.t-cen {
	text-align: center;
}

.t-lef {
	text-align: left;
}

.t-rig {
	text-align: right;
}

.back-w-50 {
	background-color: rgba( 255, 255, 255, 0.5 );
	padding: 30px;
}

.mgt10 {
	margin-top: 10px !important;
}

.mgt20 {
	margin-top: 20px !important;
}

.mgt30 {
	margin-top: 30px !important;
}

.mgt50 {
	margin-top: 50px !important;
}

.mgt70 {
	margin-top: 70px !important;
}

.mgt90 {
	margin-top: 90px !important;
}

.mgt100 {
	margin-top: 100px !important;
}

.mgt150 {
	margin-top: 150px !important;
}

.mgb10 {
	margin-bottom: 10px !important;
}

.mgb20 {
	margin-bottom: 20px !important;
}

.mgb30 {
	margin-bottom: 30px !important;
}

/*# PCで改行しない */

.br-sp { display:none; }


/*# スマホで空きを非表示に */
.mgt50pc {
	margin-top: 15px !important;
}





/*# Bootstrap追加スタイル */

/* .row の左右のネガティブマージンを0にする */

.row--nopadding {
  margin-left: 0;
  margin-right: 0;
}

/* .row--nopadding の中にあるカラムの左右のパディングを0にする */

.row--nopadding > [class*="col-"] {
  padding-left: 0;
  padding-right: 0;
}



/* 追加スタイル */

.s-line0 {
	border-bottom-width: 5px;
	border-bottom-style: solid;
	border-bottom-color: #94D015;
	width: 100%;
	margin-right: auto;
	margin-left: auto;
}

.s-line1 {
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #94D015;
	width: 400px;
	margin-right: auto;
	margin-left: auto;
	padding-bottom: 20px;
	margin-bottom: 10px;
}

.s-line2 {
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #94D015;
	width: 100%;
	margin-right: auto;
	margin-left: auto;
	padding-bottom: 10px;
	margin-bottom: 30px;
	text-align: left;
}


@media screen and (max-width: 640px) {
/*# スマホで改行しない */
.br-pc { display:none; }
/*# PCで改行しない */
.br-sp { display:inline; }


.f_sp1 {
	letter-spacing: 1px;
}
.f_sp3 {
	letter-spacing: 1px;
}
.f_sp5 {
	letter-spacing: 1px;
}


.mgt50pc {
	margin-top: 0px !important;
}

.mgt50 {
	margin-top: 20px !important;
}

.mgt70 {
	margin-top: 20px !important;
}

.mgt90 {
	margin-top: 20px !important;
}

.mgt100 {
	margin-top: 20px !important;
}

.mgt150 {
	margin-top: 20px !important;
}

.f47 {
	font-size: 32px;
}
.f36 {
	font-size: 20px;
}
.f16 {
	font-size: 14px;
}
.s-line1 {
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #94D015;
	width: 100%;
	margin-right: auto;
	margin-left: auto;
	padding-bottom: 20px;
	margin-bottom: 10px;
}

}

/* Topへ戻るボタン */
#page-top {
  position: fixed;
  bottom: 50px;
  right: 50px;
  width: 42px;
  height: 42px;
}

.arrow{
  position: relative;
  display: inline-block;
  color: #000;
  vertical-align: middle;
  text-decoration: none;
  width: 42px;
  height: 42px;
}

.arrow::before{
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  content: "";
  vertical-align: middle;
  box-sizing: border-box;
  width: 42px;
  height: 42px;
  border: 1px solid #999999;
  background: #ffffff;
}

.arrow::after{
  content: '';
  width: 26px;
  height: 26px;
  border: 0px;
  border-top: solid 1px #999999;
  border-left: solid 1px #999999;
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  left: 8px;
  margin-top: -4px;
}

.arrow a{
    position:absolute;
    top:0;
    left:0;
    width: 100%;
    height: 100%;
    text-indent:-999px;
}

.arrow:hover::after{
  border-top: solid 1px #B4B4B4;
  border-left: solid 1px #B4B4B4;
}

.arrow a:hover{
	border: 1px solid #B4B4B4;
}

@media screen and (max-width: 640px) {
#page-top {
  right: 10px;
}
}





		


/* トップページのスライダーの設定 */
.sp-buttons { padding-top: 10px; }
.sp-button { width: 80px; height: 10px; border: none; border-radius: 0; margin: 3px; background: #ccc; }
.sp-selected-button { background: #000; }
@media only screen and (min-width: 768px) and (max-width: 1024px) { .sp-button { width: 25px; height: 8px; } }
@media only screen and (min-width: 568px) and (max-width: 768px) { .sp-button { width: 25px; height: 8px; } }
@media only screen and (min-width: 320px) and (max-width: 568px) { .sp-button { width: 25px; height: 8px; } }

/* 左右の矢印の設定 */
.sp-arrow { width: 48px; height: 48px; }
.sp-vertical .sp-arrow { -webkit-transform: none; -ms-transform: none; transform: none; }
.sp-horizontal .sp-previous-arrow { background: url(img/prev.png) no-repeat; }
.sp-horizontal .sp-next-arrow { background: url(img/next.png) no-repeat; }
.sp-previous-arrow:before, .sp-previous-arrow:after, .sp-next-arrow:before, .sp-next-arrow:after { content: inherit;}



.sp-slides {
	background-color: #000000;
	width: 100%;
	height: auto;
}

@media screen and (max-width:1000px) {

}

@media screen and (max-width: 768px) {

}

.subbana-w{
	display: block;
	font-size: 0;
}

.subbana{
	display: inline-block;
	width: 49%;
}

.subbana + .subbana{
	margin-left: 2%;
}
