@charset "UTF-8";
/* ------------------------------
　　ベース
------------------------------ */

/*	width animation	*/
body {
/* 	transition: width 1s ease-in-out 0.01s; */
}


/*	admin.css	*/
.acms-grid {
    max-width: 970px;
    margin: 0 auto;
}
#adminBox, .acms-admin-box {
	padding: 10px;
	border: 1px solid #d8d8de;
	background-color: #e4e5ea;
	margin-bottom: 0;
	font-size: 14px;
}

.acms-list-group {
	border-top: none;
}

.acms-list-group li {
	border-bottom: 1px dashed #ccc;
}

.acms-list-group-item:hover {
    background: none;
}

.acms-icon {
    padding-right: 3px;
    margin-top: -3px;
}

.headerLink li a {
    color: #333;
}

.entry-column h2,
.entry-column h3,
.entry-column h4 {
	clear: both;
}


/*	site parts	*/
hr.hasenline {
	margin: 50px 0;
	border: none;
	border-top: dashed 1px #ccc;
	height: 1px;
	color: #FFFFFF;
}

.acms-unit-clear {
	clear: both;
}

.columnImage1 {
	border: 1px solid #cdcdcd;
	box-sizing: content-box !important;
	height: auto;
}

.textLeft {
	text-align: left;
}

.textCenter {
	text-align: center;
}

.textRight {
	text-align: right;
}


/*	header	*/
.header {
	width: 100%;
	overflow: hidden;
}

.header-stack .site-name {
	/* 	text-align: center; */
	width: 300px;
	display: inline-block;
	margin: 15px 0 10px;
}

.site-logo {
	display: inline-block;
	width: auto;
	max-width: 300px;
	height: auto;
	margin: 0 0 0 0;
	vertical-align: middle;
}

.headerText {
	text-align: right;
}

.header-stack .header-nav {
    display: block;
    max-width: 970px;
    margin: 0 auto;
}
.header-stack .navbar li a {
    font-size: 14px;
}

.headerLink {
    margin: 20px 0 10px;
}
.sitedes{
	margin: 0;
	margin-block-start: 0em;
    margin-block-end: 0em;
    line-height: 1;
}
/*	nav btn	*/
.nav-menu-btn {
	position: absolute;
	top: 5px;
	right: -5px;
	display: inline-block;
	width: 45px;
	height: 45px;
	margin: 8px 0 8px 3px;
	padding: 0;
	font-size: 22px;
	text-align: center;
	line-height: 1;
	box-sizing: border-box;
	border-radius: 5px;

}

a.nav-menu-btn:link,
a.nav-menu-btn:visited,
a.nav-menu-btn:hover,
a.nav-menu-btn:active {
	color: #333;
}

.nav-menu-btn-text {
	margin: 0;
	padding: 0;
	font-size: 10px;
	font-weight: 700;
	color: #333;
	text-align: center;
	vertical-align: top;
}

.nav-menu-action-item {
	display: table-cell;
	width: 50px;
	height: 50px;
	vertical-align: middle;
	text-align: center;
}

.nav-menu-action-item a:link,
.nav-menu-action-item a:visited,
.nav-menu-action-item a:hover,
.nav-menu-action-item a:active {
	display: block;
	margin: 6px 0 0 0;
	font-size: 30px;

}
.header-stack .navbar > ul {
    table-layout: auto;
}
.nav_nowrap{
	white-space: nowrap;
}

/* part内各SNSアカウントのリンク集 */
.sns-list {
	list-style: none;
	margin: 20px 0 10px;
	padding: 0;
}

.sns-list-item {
	float: left;
	margin: 0 5px;
}
.sns-list-item a:hover,
.sns-list-item a:visited,
.sns-list-item a:active,
.sns-list-item a:focus {
	text-decoration: none;
}

/* 各種SNSボタン */
.sns-list-item .sns-list-facebook,
.sns-list-item .sns-list-twitter,
.sns-list-item .sns-list-instagram,
.sns-list-item .sns-list-youtube  {
	display: block;
	width: 50px;
	height: 50px;
	text-align: center;
	line-height: 1;
	font-size: 20px;
	color: #FFF;
	border-radius: none;
	background:  none;
}
.sns-list-item .sns-list-facebook img,
.sns-list-item .sns-list-twitter img,
.sns-list-item .sns-list-instagram img,
.sns-list-item .sns-list-youtube img {
	width :100%;
	height:auto;
}
.sns-list-item .sns-list-facebook:before,
.sns-list-item .sns-list-twitter:before,
.sns-list-item .sns-list-instagram:before,
.sns-list-item .sns-list-youtube:before{
	vertical-align: middle;
}


/*	sitemap	*/
.sitemap .moduleSection {
	margin-bottom: 20px;
}
.sitemap .moduleHeading {
	margin-bottom: 10px;
	border-bottom: 1px solid #ccc;
}

.sitemap ul li a {
	font-size: 16px;
	line-height: 1.5;
	display: block;
	padding-top: 10px;
	padding-bottom: 10px;
}

.footer-bnr-wrapper {
	padding: 0 !important;
}



/*	slick全体	*/
.slick-slide:hover {
	cursor: default;
}


/*	トップメイン　slick	*/
.js-slider_top .slick-slide{
	width: 970px;
	height: auto;
}
.js-slider_top .slick-slide img{
	width: 100%;
	height: auto;
}

/*	リスト装飾	*/
.acms-list-group-item {
    border-bottom: 1px dashed #e5e5e5;
}

/*トップヘッドライン	*/
.headline_top {
	margin: 50px 0;
}

.headline_top h2 {
/*     font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; */
    letter-spacing: 0.2em;
    font-size: calc(16px + 0.5vw);
}

.headline_top time.headline-dat {
	color: #1b4216;
}

.entry-footer {
    background: none;
}

/*フッター　slick*/
.footer-bnr-wrapper .slider {
  margin: 0 24px;
  overflow: hidden;
}
.footer-bnr-wrapper .slick-slider {
	padding: 15px 60px 10px 60px;
}
.footer-bnr-wrapper .slick-list {
  margin-right: -12px;  /* ガター分ネガティブマージン */
}
.footer-bnr-wrapper .slider-arrow {
  position: absolute;
  top: 50%;
  height: 36px;
  margin-top: -18px;  /* 高さの半分だけネガティブマージン */
  color: #bd77f2;
  line-height: 36px;
  font-size: 28px;
  cursor: pointer;
  z-index: 10;  /* 重要 */
}
.footer-bnr-wrapper .slick-dots {
    margin: 10px 0 0 0;
}
.footer-bnr-wrapper .slick-slide {
  margin-right: 12px;  /* ガター */
}
.footer-bnr-wrapper .slick-slide {
/*   background-color: #bd77f2; */
}
.footer-bnr-wrapper .slick-prev {
	left: 15px;
	background: url(../../images/marker/icon_white_arrow_left.png) no-repeat;
}

.footer-bnr-wrapper .slick-next {
	right: 15px;
	background: url(../../images/marker/icon_white_arrow_right.png) no-repeat;
}


/*footer ナビ		*/
.footerNavi .offcanvas-nav {
	margin: 0;
	padding: 0;
}

.footerNavi ul li,
.footerNavi ul li:first-child,
.footerNavi ul li:last-child  {
	float: none;
	text-align: center;
	border-top: none;
    border-bottom: 1px solid #ccc;
}


.footerNavi ul li a {
	display: block;
	text-align: center;
	background: none;
	padding: 20px 0;
}

.footerNavi .headerLink {
	margin: 0;
	padding: 0;
}

.footerNavi ul li a span {
	display: none;
}

.footerNavi .headerLink li,
.footerNavi .headerLink li:first-child,
.footerNavi .headerLink li:last-child {
	border-top: none;
    border-bottom: 1px solid #ccc;
}

.footerNavi .headerLink li a {
	text-align: center;
}

/*	footer form	*/
.foot-wrapper .contact-form_wrapper {
    width: calc(100% - 40px);
    margin: 0 0 20px 0;
    padding: 30px 20px 20px 20px;
    list-style: none;
    background: #fff;
    border-radius: 5px;
    text-align: center;
}

.foot-wrapper .contact-form_title_wrapper {
	text-align: center;
}

.foot-wrapper h2.contact-form_title {
	color: #333333;
    background-color: transparent !important;
    margin: 30px auto 20px !important;
    padding: 5px 3.0em !important;
/*     font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; */
    font-size: calc(13px + 1.5vw);
    line-height: 1.5;
    display: inline-block;
    text-align: center;
    position: relative;
    margin-left: auto;
    margin-right: auto;
}


.foot-wrapper .contact-form_wrapper .contact-form-label,
.foot-wrapper .contact-form_wrapper .contact-form-control {
	background: #fff;
}

.share-wrapper-top{
	margin: 0 auto 15px;
	text-align: center;
}
.share-wrapper-top .share-list {
    display: inline;
    list-style: none;
    float: none;
    margin: 0;
    padding: 0;
}

/*	form btn	*/
.contactBtn_wrapper {
	margin: 30px auto;
    text-align: center;
}

.contactBtn_wrapper span {
    display: inline-block;
    margin: 0;
    padding: 5px;
    border-radius: 5px;
    text-align: center;
    box-sizing: border-box;
    transition: background-color .25s linear;
    background: #FF9A00;
}

.contactBtn {
    display: inline-block;
    border: 1px solid #FFF;
    border-radius: 3px;
    padding: 15px 20px;
    background: none;
/*     font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; */
    font-size: calc(14px + 0.5vw);
    font-weight: bold;
    line-height: 1.2;
    letter-spacing: 0.1em;
}

.contactBtn:hover,
.contactBtn:focus,
.contactBtn:active {
	opacity: 0.5;
	background: none;
}


/*	offcanvas	*/
.js-acms-offcanvas-body-left .close-btn {
    position: fixed;
    display: block;
    top: 15px;
    right: 5px;
    width: 45px;
    height: 45px;
    margin: 0;
    padding: 0;
    font-size: 30px;
    text-align: center;
    line-height: 1;
    box-sizing: border-box;
    border-radius: 5px;
    opacity: 1;
    color: #fff;
    text-decoration: none;
    z-index: 9999;
}



/*	ユニット	*/
.textLeft {
	margin-right: 10px;
    margin-left: 10px;
	text-align: left;
}
.textCenter {
	margin-right: 10px;
    margin-left: 10px;
	text-align: center;
}

.textRight {
	margin-right: 10px;
    margin-left: 10px;
	text-align: right;
}



/*	テーブルユニットの追加設定　固定テーブル	*/
.entry-column table.acms-table-100fix {
	width: 100%;
}
.entry-column table.acms-table-100fix th,
.entry-column table.acms-table-100fix td {
	float: none;
	display: table-cell;
	padding: 15px 20px;
	text-align: left;
	font-size: 13px;
	border: 1px solid #DFDFDF;
	border-collapse: collapse;
}
.entry-column table.acms-table-100fix th {
	background: #efefef;
}

@media screen and (max-width: 767px) {
	.entry-column table.acms-table-100fix th,
	.entry-column table.acms-table-100fix td {
		float: none;
		display: table-cell;
		padding: 5px 10px;
		text-align: left;
		font-size: 12px;
		border: 1px solid #DFDFDF;
		border-collapse: collapse;
	}
	.entry-column table.acms-table-100fix th {
		background: #efefef;
	}
}

@media screen and (max-width: 600px) {
	.entry-column table.acms-table-100fix th,
	.entry-column table.acms-table-100fix td {
		float: none;
		display: table-cell;
		padding: 2px 1px;
		text-align: left;
		font-size: 11px;
		border: 1px solid #DFDFDF;
		border-collapse: collapse;
	}
	.entry-column table.acms-table-100fix th {
		background: #efefef;
	}
}

@media screen and (max-width: 360px) {
	.entry-column table.acms-table-100fix th,
	.entry-column table.acms-table-100fix td {
		float: none;
		display: table-cell;
		padding: 2px 1px;
		text-align: left;
		font-size: 10px;
		border: 1px solid #DFDFDF;
		border-collapse: collapse;
	}
	.entry-column table.acms-table-100fix th {
		background: #efefef;
	}
}







@media screen and (max-width: 1023px) {
	#adminBox, .acms-admin-box {
/* 		margin-top: 60px; */
	}
	.show-pc {
		display: none;
	}
	.header {
	    position: relative;
	}
	.offcanvas-nav .headerLink a {
		font-size: 90%;
		text-align: left;
	}
	.header-stack .header-logo {
	    padding: 10px 0;	    
	    height: 45px;
	}
	.sitedes{
		font-size: 12px;
		line-height: 1.5;
	}
	.sns-list {
	    position: absolute;
		top: 17px;
		right: 39px;
		display: inline-block;
	    margin: 0px;
	    z-index: 100;	
	}

	.sns-list-item {
	    float: left;
	    margin: 0 3px;
	}

	.site-header-box{
		position: absolute;
		top: 0;
		left: 0;
		width: calc(100% - 120px);
		z-index: 100;
	}
	.header-stack .site-name {
		width: 100%;
	    margin: 12px 0 10px;
	    text-align: left;
	    overflow: hidden;
	}
	.site-logo {
	    width: auto;
	    max-width: 100%;
	    height: auto;
	    max-height: 40px;
	}
	
	.site-header {
		position: relative;
	    width: 100%;
	    height: 40px;
	    margin: 0;
	}
	.nav-menu-btn {
		display: inline-block;
	    margin: 0 !important;
	    font-size: 30px !important;
	}
	.sns-list-item .sns-list-facebook, .sns-list-item .sns-list-twitter, .sns-list-item .sns-list-instagram, .sns-list-item .sns-list-youtube  {
		width: 30px;
		height: 30px;
	}
}

@media screen and (max-width: 767px) {
	.site-header {
	    height: 40px;
	    margin: 0;
	    padding: 0;
	}

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