@charset "UTF-8";
/*  02_base
================================================ */
/* 02_base
================================================ */
html { overflow: auto; }

body { overflow: hidden; min-width: 320px; padding-top: 50px; color: #333; font-size: 1.4rem; line-height: 2; letter-spacing: .06em; font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, "メイリオ", Meiryo, sans-serif; }

@media screen and (min-width: 600px) { body { min-width: 1100px; padding-top: 0; font-size: 1.6rem; } }

img { max-width: 100%; height: auto; }

a { -webkit-transition: all 0.3s ease; transition: all 0.3s ease; color: inherit; text-decoration: underline; }

@media screen and (min-width: 600px) { a:hover { text-decoration: none; }
  a.opacity:hover { opacity: .8; }
  a[href^=tel] { pointer-events: none; } }

em, strong, span { font-weight: inherit; }

/* pc <--> sp切り替え
-------------------------------------- */
#mediaQuery { display: none; font-family: 'sp'; }

@media screen and (min-width: 600px) { #mediaQuery { font-family: 'pc'; } }

@media screen and (max-width: 599px) { .viewPc { display: none; } }

@media screen and (min-width: 600px) { .viewSp { display: none; } }

/* font
-------------------------------------- */
.fontQuicksand { font-family: 'Quicksand', sans-serif; letter-spacing: .15em; }

.is_txt_center { text-align: center !important; }

.is_txt_right { text-align: right !important; }

.is_txt_green { color: #89b03a !important; }

.is_bold { font-weight: 700; }

/* clearfix
-------------------------------------- */
.cf:after { content: ''; display: block; clear: both; }

/* layout
-------------------------------------- */
.mod_inner01 { padding: 0 15px; }

@media screen and (min-width: 600px) { .mod_inner01 { box-sizing: border-box; width: 1100px; padding: 0; margin-right: auto; margin-left: auto; } }

/*  03_layout
================================================ */
/* #breadcrumb
================================================ */
#breadcrumb { letter-spacing: -.5em; padding: 11px 0 13px; }

#breadcrumb .home a { display: block; padding: 0px 0 2px; }

#breadcrumb .home img { vertical-align: middle; }

#breadcrumb li { display: inline-block; margin-right: 5px; font-size: 1.4rem; letter-spacing: .08em; }

#breadcrumb li + li { position: relative; padding-left: 20px; }

#breadcrumb li + li:before { position: absolute; left: 6px; top: 9px; display: block; width: 6px; height: 10px; content: ''; background: url("../img/common/ico_arw01_green.png") no-repeat center; background-size: contain; }

/* #gFooter
================================================ */
@media screen and (min-width: 600px) { .ftImgWrap { margin: 0 -20px; } }

.ftImg { padding: 15px 0; }

.ftImg .item { padding: 0 2px; }

@media screen and (min-width: 600px) { .ftImg { padding: 30px 0; }
  .ftImg .item { padding: 0 5px; } }

/*  #pageTop
================================================ */
@media screen and (max-width: 599px) { #pageTop { line-height: 1; border-width: 1px 0; border-style: solid; border-color: #e0d7c5; text-align: center; background: #f7efde; }
  #pageTop a { display: block; padding: 17px 0 23px; }
  #pageTop img { width: 14px; } }

@media screen and (min-width: 600px) { #pageTop { width: 84px; position: fixed; right: 0; bottom: 10px; z-index: 10; }
  #pageTop a { display: block; } }

/*  .ftMap
================================================ */
.ftMap { color: #fff; text-align: center; }

@media screen and (min-width: 600px) { .ftMap { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -ms-flex-wrap: wrap; flex-wrap: wrap; min-width: 1100px; } }

/*  .ftMap .map
================================================ */
.ftMap .map { position: relative; background: #412210; }

.ftMap .map:before { content: ""; display: block; width: 100%; padding-top: 50%; }

.ftMap .map iframe { position: absolute; top: 0; left: 0; bottom: 0; right: 0; width: 100%; height: 100%; }

@media screen and (min-width: 600px) { .ftMap .map { width: 50%; min-height: 482px; } }

_:-ms-fullscreen, :root .ftMap .data .logo { margin-bottom: -60px; }

/*  .ftMap .data
================================================ */
.ftMap .data { padding-top: 25px; padding-bottom: 40px; background: url("../img/common/bg_tree01.jpg") no-repeat center; background-size: cover; }

.ftMap .data .logo { width: 258px; margin: auto; }

.ftMap .data address { margin-top: 12px; }

.ftMap .data .contact { margin-top: 12px; }

.ftMap .data .contact .tel { width: 286px; margin: auto; }

.ftMap .data .contact .date { margin-top: 6px; font-size: 1.1rem; line-height: 1.73; letter-spacing: .05em; }

.ftMap .data .timeTable { margin-top: 12px; padding: 0 15px; }

@media screen and (min-width: 600px) { .ftMap .data { box-sizing: border-box; width: 50%; padding-top: 4px; padding-bottom: 40px; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -ms-flex-wrap: wrap; flex-wrap: wrap; }
  .ftMap .data .logo { width: 300px; margin: 0 auto; }
  .ftMap .data address { margin-top: 7px; font-size: 1.4rem; }
  .ftMap .data .contact .tel { width: 340px; }
  .ftMap .data .contact .date { margin-top: 12px; }
  .ftMap .data .timeTable { width: 487px; margin-top: 15px; } }

/*  .ftSitemap
================================================ */
.ftSitemap { position: relative; overflow: hidden; border-bottom: 1px solid #969696; background: #f3f3f3; }

.ftSitemap:after { position: absolute; top: 0; bottom: 0; left: 50%; content: ""; display: block; width: 1px; height: 100%; background: #969696; }

.ftSitemap li { box-sizing: border-box; width: 50%; float: left; border-top: 1px solid #969696; }

.ftSitemap a { position: relative; display: block; padding: 10px 10px 10px 30px; font-size: 1.4rem; font-weight: 700; text-decoration: none; }

.ftSitemap a:before { position: absolute; top: 19px; left: 15px; content: ""; display: block; width: 7px; height: 11px; background: url("../img/common/ico_arw01.png") no-repeat center; background-size: contain; }

@media screen and (min-width: 600px) { .ftSitemap { padding: 10px 0 32px; border: 0; background: #fff; text-align: center; }
  .ftSitemap:after { display: none; }
  .ftSitemap li { float: none; display: inline-block; width: auto; height: 15px; border-style: solid; border-width: 0 1px; border-color: #9b9b9b; -webkit-transform: skew(-20deg); -ms-transform: skew(-20deg); transform: skew(-20deg); }
  .ftSitemap li + li { border-left: 0; }
  .ftSitemap a { position: relative; padding: 0 20px; font-size: 1.5rem; text-align: center; -webkit-transform: skew(20deg); -ms-transform: skew(20deg); transform: skew(20deg); margin-top: -7px; }
  .ftSitemap a:hover { color: #8cb737; }
  .ftSitemap a:before { display: none; } }

.ftCopyright { padding: 15px; text-align: center; background: #f7efde; font-size: 1rem; line-height: 2; letter-spacing: .08em; color: #412210; }

@media screen and (min-width: 600px) { .ftCopyright { font-size: 1.3rem; } }

/* #gHeader
================================================ */
#gHeader { position: fixed; top: 0; left: 0; width: 100%; height: 50px; z-index: 10; background: #fff; }

#gHeader .logo { position: absolute; top: 0; left: 0; z-index: 30; width: 174px; }

#gHeader .logo a { display: block; padding: 7px 0 0 14px; }

#gHeader .gnavBtn { position: fixed; top: 0; right: 0; z-index: 30; width: 50px; height: 50px; cursor: pointer; background: #412210; -webkit-transition: all 0.3s ease; transition: all 0.3s ease; }

#gHeader .gnavBtn .line { position: absolute; top: 19px; left: 50%; margin-left: -12px; width: 24px; height: 3px; background: #fff; -webkit-transition: all 0.3s ease; transition: all 0.3s ease; }

#gHeader .gnavBtn .line:nth-child(1) { top: 12px; }

#gHeader .gnavBtn .line:nth-child(3) { top: 26px; }

#gHeader .gnavBtn.is_active .line:nth-child(1) { top: 19px; -webkit-transform: rotate(-34deg); -ms-transform: rotate(-34deg); transform: rotate(-34deg); }

#gHeader .gnavBtn.is_active .line:nth-child(2) { opacity: 0; }

#gHeader .gnavBtn.is_active .line:nth-child(3) { top: 19px; -webkit-transform: rotate(34deg); -ms-transform: rotate(34deg); transform: rotate(34deg); }

#gHeader .gnavBtn .txt { position: absolute; left: 0; bottom: 5px; width: 100%; font-size: 1rem; line-height: 1; text-align: center; color: #fff; letter-spacing: .01em; }

@media screen and (min-width: 600px) { #gHeader { position: relative; height: 110px; min-width: 1100px; }
  #gHeader .logo { top: 0; left: 30px; width: 303px; -webkit-transition: all 0.3s ease; transition: all 0.3s ease; }
  #gHeader .logo a { padding: 14px 0 0 0; } }

/*  #gNav
================================================ */
#gNav .listLink { position: relative; overflow: hidden; border-bottom: 1px solid #969696; }

#gNav .listLink:after { position: absolute; top: 0; bottom: 0; left: 50%; content: ""; display: block; width: 1px; height: 100%; background: #969696; }

#gNav .listLink li { box-sizing: border-box; width: 50%; float: left; border-top: 1px solid #969696; }

#gNav .listLink a { position: relative; display: block; padding: 10px 10px 10px 30px; font-size: 1.4rem; font-weight: 700; text-decoration: none; }

#gNav .listLink a:before { position: absolute; top: 19px; left: 15px; content: ""; display: block; width: 7px; height: 11px; background: url("../img/common/ico_arw01.png") no-repeat center; background-size: contain; }

#gNav .contact { padding-top: 20px; text-align: center; }

#gNav .contact .tel { width: 286px; margin: auto; }

#gNav .contact .time { margin-top: 6px; font-size: 1.1rem; line-height: 1.73; color: #412210; }

#gNav .gnavClose { width: 200px; margin: 15px auto 0; padding: 5px; border: 1px solid #412210; border-radius: 4px; text-align: center; color: #412210; font-size: 1.4rem; cursor: pointer; }

#gNav .gnavClose span { position: relative; display: inline-block; padding-left: 23px; font-weight: 500; }

#gNav .gnavClose span:before, #gNav .gnavClose span:after { position: absolute; top: 50%; left: 2px; content: ""; display: block; width: 15px; height: 2px; background: #333; }

#gNav .gnavClose span:before { -webkit-transform: rotate(34deg); -ms-transform: rotate(34deg); transform: rotate(34deg); }

#gNav .gnavClose span:after { -webkit-transform: rotate(-34deg); -ms-transform: rotate(-34deg); transform: rotate(-34deg); }

@media screen and (max-width: 599px) { #gNav { display: none; position: fixed; z-index: 20; top: 0; bottom: 0; left: 0; width: 100%; overflow-y: scroll; background: #fff; }
  #gNav .gNavContent { position: absolute; top: 0; left: 0; width: 100%; padding: 50px 0 30px; } }

@media screen and (min-width: 600px) { #gNav { box-sizing: border-box; position: absolute; top: 0; right: 0; width: 900px; padding-right: 50px; -webkit-transition: all 0.3s ease; transition: all 0.3s ease; }
  #gNav .gNavContent { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -ms-flex-wrap: wrap; flex-wrap: wrap; }
  #gNav .listLink { box-sizing: border-box; position: relative; width: 505px; padding: 65px 0 0 5px; border: 0; overflow: inherit; }
  #gNav .listLink:after { display: none; }
  #gNav .listLink li { float: left; width: auto; height: 15px; border-style: solid; border-width: 0 1px; border-color: #9b9b9b; -webkit-transform: skew(-20deg); -ms-transform: skew(-20deg); transform: skew(-20deg); }
  #gNav .listLink li + li { border-left: 0; }
  #gNav .listLink a { position: relative; padding: 10px 23px; font-size: 1.5rem; text-align: center; -webkit-transform: skew(20deg); -ms-transform: skew(20deg); transform: skew(20deg); margin-top: -18px; }
  #gNav .listLink a:before { top: 10px; left: 50%; margin-left: -3px; width: 6px; height: 6px; background: #7faf20; border-radius: 50%; opacity: 0; -webkit-transition: all 0.3s ease; transition: all 0.3s ease; }
  #gNav .listLink a:hover:before, #gNav .listLink a.is_current:before { top: 0; opacity: 1; }
  #gNav .listLink a.is_current:hover { color: #7faf20; }
  #gNav .contact { box-sizing: border-box; width: 315px; height: 175px; padding: 21px 35px 0; text-align: center; border-radius: 0 0 6px 6px; background-color: white; box-shadow: 0px 3px 4px 1px rgba(0, 0, 0, 0.2); }
  #gNav .contact .tit { width: 100%; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -ms-flex-wrap: wrap; flex-wrap: wrap; font-size: 1.4rem; font-weight: 700; color: #412210; }
  #gNav .contact .tit:before, #gNav .contact .tit:after { content: ""; display: block; width: 35px; height: 1px; background: #949494; }
  #gNav .contact .tel { width: 235px; }
  #gNav .contact .time { margin-top: 12px; font-size: 1.1rem; line-height: 1.64; text-align: left; letter-spacing: 0; } }

/*  #PC,1230px以下
================================================ */
@media all and (min-width: 600px) and (max-width: 1230px) { #gHeader .logo { width: 205px; }
  #gHeader .logo a { padding-top: 35px; }
  #gNav { padding-right: 0; width: 850px; } }

/* #mainVisual TOPページ
================================================ */
#mainVisual { position: relative; background: url("../img/home/bg_mainvisual01-sp.jpg") no-repeat center; background-size: cover; }

#mainVisual:before { content: ""; display: block; width: 100%; padding-top: 132%; }

#mainVisual .mainTit { position: absolute; top: 50%; left: 50%; -webkit-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); transform: translate(-50%, -50%); width: 88.6%; margin-top: -3%; }

#mainVisual .scroll { position: absolute; left: 50%; bottom: 15px; -webkit-transform: translateX(-50%); -ms-transform: translateX(-50%); transform: translateX(-50%); width: 40px; }

@media screen and (min-width: 600px) { #mainVisual { background-image: url("../img/home/bg_mainvisual01-pc.jpg"); }
  #mainVisual:before { padding-top: 970px; }
  #mainVisual .mainTit { width: 894px; margin-top: 0; }
  #mainVisual .scroll { bottom: 32px; width: 44px; } }

/* #mainImg 下層ページ
================================================ */
#mainImg { position: relative; text-align: center; color: #fff; background: no-repeat center; background-size: cover; height: 200px; }

#mainImg .areaTxt { position: absolute; top: 50%; left: 50%; -webkit-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); transform: translate(-50%, -50%); width: 100%; }

#mainImg .tit { font-size: 2.5rem; font-weight: 700; line-height: 1.76; letter-spacing: .08em; }

#mainImg .en { font-size: 1.3rem; line-height: 1.1; font-weight: 500; letter-spacing: .15em; }

@media screen and (min-width: 600px) { #mainImg { height: 410px; }
  #mainImg .areaTxt { margin-top: -10px; }
  #mainImg .tit { font-size: 5rem; line-height: 1.76; }
  #mainImg .en { margin-top: 2px; font-size: 2rem; } }

/* #sidebar
================================================ */
/*  05_helper
================================================ */
/*  data-slide-from
================================================ */
@media screen and (min-width: 600px) { [data-fade-from] { -webkit-transition: all 1.6s ease; transition: all 1.6s ease; } }

@media screen and (min-width: 600px) { [data-fade-from="bottom"].fadeFromBottom { opacity: 0; -webkit-transform: translateY(100px); -ms-transform: translateY(100px); transform: translateY(100px); }
  [data-fade-from="bottom"].fadeFromBottom.is_active { opacity: 1; -webkit-transform: translateY(0); -ms-transform: translateY(0); transform: translateY(0); } }

@media screen and (min-width: 600px) { [data-fade-from="left"].fadeFromLeft { opacity: 0; -webkit-transform: translateX(-100px); -ms-transform: translateX(-100px); transform: translateX(-100px); }
  [data-fade-from="left"].fadeFromLeft.is_active { opacity: 1; -webkit-transform: translateX(0); -ms-transform: translateX(0); transform: translateX(0); } }

/*  .js-fadein-bg
================================================ */
.js-fadein-bg { position: relative; }

.js-fadein-bg-item { position: absolute; top: 0; bottom: 0; left: 0; width: 102px; }

@media screen and (min-width: 600px) { .js-fadein-bg-item { width: 540px; } }

.js-fadein-bg-content { position: relative; z-index: 1; }

/*  .js-fadein-bg
================================================ */
@media screen and (min-width: 600px) { .js-fadein-mv img { opacity: 0; margin-top: 20px; -webkit-transition: all 1.5s ease; transition: all 1.5s ease; }
  .js-fadein-mv.is_active img { opacity: 1; margin-top: 0; } }

/*!  .js-modal-layer
<p class="js-modal-trigger" data-modal="popup01">トリガー</p>
<div class="js-modal-layer" data-modal="popup01">
	<div class="js-modal-content">
		ここにモーダルの中身のソース
	</div>
</div>
================================================ */
.js-modal-layer { display: none; position: fixed; z-index: 20; top: 0; bottom: 0; left: 0; width: 100%; overflow-y: scroll; background: rgba(0, 0, 0, 0.1); }

.js-modal-layer .js-modal-content { box-sizing: border-box; position: absolute; top: 50%; left: 50%; width: 92%; margin: 50px 0; padding: 30px 40px; -webkit-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); transform: translate(-50%, -50%); background: #fff; box-shadow: 0px 2px 20px 0px rgba(50, 52, 54, 0.2); }

@media all and (min-width: 600px) { .js-modal-layer .js-modal-content { width: 800px; margin: 70px 0; padding: 65px 140px 90px; } }
