@charset "UTF-8";
/*  
Theme Name:Original Style - 1column
Version:1.2
*/


.home #contents > .inner {/* トップページ幅 100% */
	width:100%;
	max-width:100%;
}
.topinner {/* コンテンツは1000pxに */
	width:1000px;
	margin:0 auto;
	max-width:96%;
}

/* tinyMCE用に見出しをリセット */
.toppage h3,
.toppage h4,
.toppage h5 {
	background:none;
	border:none;
	color:inherit;
	font-size:inherit;
	line-height:inherit;
	margin:0;
	padding:0;
}
.toppage h3::before,
.toppage h3::after ,
.toppage h4::before,
.toppage h4::after,
.toppage h5::before,
.toppage h5::after {
	display:none;
}


/*==========================
	　mainimage
==========================*/

/*-- スライダーの時 ------------*/

.slider { }
.slick-slide img { margin:0 auto;}

button.slick-arrow {/* 矢印ボタン */
	background:none;
	border:none;
	position:absolute;
	top:50%;
	margin-top:-20px;
	height:40px;
	width:16px;
	text-indent:-9px;
	z-index:1;
}
button.slick-arrow:hover {
 	cursor:pointer;
	opacity:0.7;
}
button.slick-prev {/* 矢印（前へ）ボタン */
	background:url(img/btn_prev.png) no-repeat;
	left:18%;
	margin-left:-16px;
}
button.slick-next {/* 矢印（次へ）ボタン */
	background:url(img/btn_next.png) no-repeat;
	right:18%;
	margin-right:-16px;
}
@media screen and (max-width: 1650px) {
button.slick-prev {	left:13.7%;}
button.slick-next {	right:13.7%;}
}
@media screen and (max-width: 1400px) {
button.slick-prev {	left:8%;}
button.slick-next {	right:8%;}
}
@media screen and (min-width: 1200px) {
.slick-track {}
.mainimage .slick-slide:not(.slick-center) {/* 前と次の画像を半透明に */
	opacity: 0.4;
	-moz-opacity: 0.4;
	filter: alpha(opacity=40);
}
}


/*==========================
	汎用に使えるボタン
==========================*/
.link_btn ,.btn-style { text-align:center; }
.link_btn a,
.btn-style a {
	background:url(img/btn_bg.png);
	width:280px;
	max-width:100%;
	padding:0.9em 1.2em;
	text-align:center;
	color:#fff;
	display:inline-block;
	text-decoration:none;
	line-height:1.2;
	box-sizing:border-box;
	font-size:16px;
	border-radius:0;
    letter-spacing: 0.1em;
	position:relative;
}
.link_btn a span,
.btn-style a span{
	display:block;
	font-size:12px;
}
.link_btn a::after,
.btn-style a::after {
content: "";
    bottom: 8px;
    right: 8px;
    border-top: 7px solid transparent;
    border-right: 7px solid #fff;
    position: absolute;
    transition: .3s;
}
.link_btn a:hover:after,
.btn-style a:hover:after{
	right:6px;
    bottom:6px;
}
.link_btn a:hover,
.btn-style a:hover {
	opacity: 0.7;
	-moz-opacity: 0.7;
	filter: alpha(opacity=70);
 	cursor:pointer;
}
.under .link_btn a,
.under .btn-style a {
	width:auto;
	min-width:280px;
}
/*==========================
	loopSlider　無限ループスライダー
==========================*/
#slide-div2 ul li .img{
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    display: block;
    width:2001px;
    height: 200px;
    background-image: url("img/slide1.jpg");
}
#slide-div2 ul li .img.img02{
    width:1144px;
    background-image: url("img/slide2.jpg");
}
/*==========================
	　TOP コンテンツ
==========================*/

.top .mainblock a {
	text-decoration:none;
}
.top .mainblock a:hover {
}
/*-- 新着情報 --------------*/
.sec_news {
    padding: 4em 0;
}
.sec_news .news {
    position: relative;
    box-sizing: border-box;
}
.sec_news ul {
    max-height: 300px;
    overflow-y: scroll;
/*    -webkit-overflow-scrolling: touch;*/
}
.sec_news ul::-webkit-scrollbar{ 
    width: 10px;
}
.sec_news ul::-webkit-scrollbar-thumb{ 
    background: #93c528;
    border-radius: 10px;
}
.sec_news ul::-webkit-scrollbar-track-piece:start{
    background:#faffef;
}
.sec_news ul::-webkit-scrollbar-track-piece:end{
    background: #fff;
}
.sec_news ul li{
    border-bottom: 1px solid #cecece;
}
.sec_news p{
    margin-bottom:15px;
}
.sec_news .news dl{
	line-height:1.3;
}
.sec_news .news dt {
    float: left;
    color: #333;
    padding:10px 0 4px;
    width: 120px;
}
.sec_news .news dd {
    padding: 10px 0 4px;

    color: #8fc31f;
    font-weight: bold;
}
.news dd a {
    text-decoration: none;
    color: #8fc31f;
}
.sec_news .news dd a:hover {
    text-decoration: underline;
}
.sec_news .news .btn a:hover {
    opacity: 0.7;
    -moz-opacity: 0.7;
    -webkit-opacity: 0.7;
}
.sec_news .news h3 {
    font-size: 26px;
    color: #473d2c;
    line-height: 1.5;
    letter-spacing: 0.1em;
    position: relative;
    font-weight: bold;
    padding: 18px 10px 15px 80px;
    border-bottom: 1px solid #93c528;
    border-top: 1px solid #93c528;
    margin: 0 auto 10px;
    box-sizing: border-box;
	background:none;
	text-align:left;
	border-radius:0;
    background: url(img/h2_icon.png) no-repeat left center;
}
.sec_news .news .btn a {
    position: absolute;
    top: 21px;
    right: 0;
    color: #fff;
    font-size: 16px;
    background: #93c528;
    display: table;
    padding: 1px 15px;
    text-decoration: none;
    letter-spacing: 0.1em;
}
.sec_news .news .btn a:after {
content: "";
    bottom: 3px;
    right: 3px;
    border-top: 7px solid transparent;
    border-right: 7px solid #fff;
    position: absolute;
}


/*見出し*/
.top h2{
	font-size: 32px;
    color: #473d2c;
    text-align: center;
    line-height: 1.4;
    letter-spacing: 0.05em;
    margin-bottom: 0.8em;
    background: url(img/h2_icon.png) no-repeat center top;
    font-weight: bold;
    padding-top:70px;
}
 h2 span{
	 display:block;
	 font-size:12px;
	 color:#985d00;
	 letter-spacing:0.05em;
     margin-top: 5px;
}

/*-- ボックスその他 --------------*/
.sec01 h3{
	color:#473d2c;
	font-size:26px;
	text-align:center;
	font-weight:bold;
	min-height:66px;
	line-height:1.3;
	margin: 10px auto 4px;
}
.sec01 h3.h3_1 {
    padding-top: 8%;
    box-sizing: border-box;
}
.sec01 {
	padding:5.5em 0 4em;
    background:url(img/sec01_bg.jpg) no-repeat center / cover;
}
.sec01 .img_box{
    position: relative;
}
.sec01 .columns .column {
    background: #fff;
    box-sizing: border-box;
    padding: 3% 1% 77px;
	position: relative;
	margin-bottom: 3%;
    box-shadow: 0 0 10px rgba(0,0,0,.1);
}
    .sec01  .column .btn-style{
    position: absolute;
    bottom: 6%;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 75%;
}
.sec01 .column p {
    max-width: 88%;
    margin: 0 auto 1em;
    line-height: 1.6;
}
.sec02 {
	padding:5.5em 0 4em;
	background:url(img/sec02_bg02.png) no-repeat center 124px,url(img/sec02_bg.png);
}
.sec02 p {
    padding: 1em 1em 0;
}
.sec03 {
	padding:5.5em 0 4em;
    background:url(img/sec03_bg.jpg) no-repeat 58% / cover;
}
.sec03 h3{
    font-size:26px;
    color:#8fc31f;
    text-align: center;
    font-weight: bold;
    line-height: 1.4;
    margin-bottom:1em;
}
/********************************
	Responsive
*********************************/

@media screen and (min-width: 768px) {/* タブレットまで */

/*==========================
	mainimage
==========================*/
.mainimage .slick-track {
    height: 980px;
}
.mainimage .slick-slide img {
    margin: 0 auto;
    height: 100%;
    width: auto !important;
    max-width: inherit;
    left: 50%;
}
.mainimage .slider-wrap li:nth-child(1) {
	background:url(img/mainimage01.jpg) no-repeat center / cover;
	}
.mainimage  .slider-wrap li:nth-child(2) {
	background:url(img/mainimage02.jpg) no-repeat center / cover;
	}
.mainimage .slider-wrap  li:nth-child(3) {
	background:url(img/mainimage03.jpg) no-repeat center / cover;
	}

.mainimage {
    background: none;
    margin: 0;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 0;
    z-index: -1;
}
.home .main_wrap {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: -1;
}
.home #contents {
    padding-top: 786px;
    position: relative;
}
.home #contents.scrolled {
    padding-top: 836px;
}
/*    .topinner.tp01{
        position: relative;
    }*/
    ul.main_btn.pc {
    position: absolute;
    top: 655px;
    right: 23%;
    z-index: 1;
    width: 536px;
    height: 90px;
            max-width: 100%;
}

ul.main_btn li {
    float: left;
    width: 279px;
}
        ul.main_btn li + li {
    width: 255px;
    margin-left: 2px;
}
/*==========================
	　TOP コンテンツ
==========================*/
/*-- FLEX設定 --------------*/
.columns {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-justify-content: space-between;
    -moz-justify-content: space-between;
    justify-content: space-between;
}
.col_wrap{ /*改行して組む場合*/
	flex-wrap: wrap;
	-ms-flex-wrap: wrap; /*IE10*/
	-webkit-flex-wrap: wrap; /* Safari6.1以降 */
}
.columns.reverse{ /*左右反転*/
-webkit-box-direction:reverse;
    -moz-box-direction:reverse;
    -webkit-box-orient:horizontal;
    -moz-box-orient:horizontal;
    -webkit-flex-direction:row-reverse;
    -moz-flex-direction:row-reverse;
    flex-direction:row-reverse;
}
.columns .column {
    max-width: 48%;
    -webkit-box-flex-basis: 48%;
    -webkit-flex-basis: 48%;
    flex-basis: 48%;
}

/*-- ボックスその他 --------------*/
.sec01 .p01{
    position: absolute;
    top:16%;
    left:0;
    z-index: 1;
}
.sec01 .p02{
    float:right;
    width: 80%;
    margin: 0 0 5%;
}
.sec01 .columns .column {
    max-width: 23.5%;
    -webkit-box-flex-basis: 23.5%;
    -webkit-flex-basis: 23.5%;
    flex-basis: 23.5%;
}

    .sec02 .columns .column {
    max-width:33.3333%;
    -webkit-box-flex-basis: 33.3333%;
    -webkit-flex-basis:33.3333%;
    flex-basis: 33.3333%;
}
}

@media screen and (min-width: 768px)  and (max-width: 1280px) {/* 程よいブラウザサイズでメインイメージを縮小 */
.mainimage .slick-track {
    height: 650px;
}
    .home #contents {
    padding-top: 456px;
}
    .home #contents.scrolled {
    padding-top: 506px;
}
        .sec02 .columns .column {
    max-width:50%;
    -webkit-box-flex-basis:50%;
    -webkit-flex-basis:50%;
    flex-basis:50%;
}
    ul.main_btn.pc {
    position: absolute;
        top: 340px;
    right: 3%;
    }
}
@media screen and (min-width: 768px)  and (max-width: 1041px) {
.sec01 .columns .column {
    max-width: 32%;
    -webkit-box-flex-basis: 32%;
    -webkit-flex-basis: 32%;
    flex-basis: 32%;
}
   .sec03 p {
    background: rgba(255,255,255,.3);
    padding: 1em;
}
}

@media screen and (max-width: 1041px) {/*コンテンツが横幅いっぱいになったら*/

}

@media screen and (max-width: 767px) {/* スマホ */

.topinner {
	width:420px;
	margin:0 auto;
	box-sizing:border-box;
}
.top #contents,
.top #aside{
	margin-bottom:0;
}
/*==========================
	　mainimage
==========================*/
.mainimage, .slider {
    margin-bottom: 0;
}
.mainimage img {
    height: auto;
    max-width: none;
    max-height: none;
    width: 100%;
}
/*==========================
	ボタン
==========================*/


/*==========================
	loop
==========================*/
.loopSlider {    height: 100px;}
.loopSlider ul {    height: 100px;}
.loopSlider ul li {
    width: 150px;
    height: 100px;
}

/*==========================
	　TOP コンテンツ
==========================*/
.sec_news .news dt {
    width: 100%;
    padding: 10px 0 5px;
}
.sec_news .news + .news{
	margin-top:1.5em;
}
.sec_news .news dd {
    padding: 0 0 10px;
}
/*-- 余白・背景 --------------*/
.sec_news {
    padding: 2em 0;
}
.sec01,
    .sec02,
    .sec03{
	padding:2em 0;
}
.sec03 {
    background-position: 18%;
}
/*-- 見出し --------------*/
    .top h2 {
    font-size: 26px;
        margin-bottom:5%;
    }
.sec_news .news h3 {
    font-size: 18px;
}
.sec_news .news .btn a {
    top: 29px;
    }
/*-- ボックスその他 --------------*/
.sec01 h3 {
    font-size: 22px;
    min-height: 56px;
	}
.sec01 .columns {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-justify-content: space-between;
    -moz-justify-content: space-between;
    justify-content: space-between;
    	flex-wrap: wrap;
	-ms-flex-wrap: wrap; /*IE10*/
	-webkit-flex-wrap: wrap; /* Safari6.1以降 */
}
    .sec01 .columns .column {
    max-width:48%;
    -webkit-box-flex-basis: 48%;
    -webkit-flex-basis: 48%;
    flex-basis: 48%;
}
    .sec01 .btn-style a {
    font-size: 12px;
    }
    .sec01 .column .btn-style {
    bottom: 3%;
    }
    .sec01 .columns .column {
    padding: 3% 1.5% 49px;
    }
	.sec02 {
    background-size: 150% auto,auto;
}
    .sec03 h3 {
    font-size: 22px;
    }
}

@media screen and (max-width: 480px) {/* スマホ480px */
.sec01 .btn-style a {
    font-size: 10px;
}
	.sec01 h3 {
    font-size: 17px;
    min-height: 44px;
}
}

@media screen and (max-width: 320px) {/* スマホ320px */
}