@charset "UTF-8";
@import url(base.css);
/* ------------------------------------------------------------ */
/* 共通、レイアウト設定 */
/* ------------------------------------------------------------ */
* html body {
  background: url(null) fixed;
}

body {
  margin: 0;
  padding: 0;
  font-size: 13px;
  *font-size: small;
  *font: x-small;
  font-family: YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN",
    "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;
}

html {
  overflow-x: hidden;
}

/*folkフォント*/
.font-folk {
  font-family: "Josefin Sans", sans-serif;
  /*font-family: Folk Medium;*/
}

/* float */
.img_left {
  float: left;
  margin: 0 15px 15px 0;
}

.img_right {
  float: right;
  margin: 0 0 15px 15px;
}

/* 縦書き */
.vertical {
  -ms-writing-mode: tb-rl; /* for MS IE8+ */
  -webkit-writing-mode: vertical-rl;
  writing-mode: vertical-rl;
  direction: rtl;
}

/* リンク色 */
::selection {
  color: #95c2b6;
  background: rgba(149, 194, 182, 0.2);
}

a,
a img,
p {
  transition: all 0.3s;
}

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

a:link {
  color: #009d3d;
  text-decoration: none;
}

a:visited {
  color: #009d3d;
  text-decoration: none;
}

a:hover {
  color: #009d3d;
  text-decoration: none;
}

a:active {
  color: #009d3d;
  text-decoration: none;
}

/* リンクボタン */
#sub section a.btn {
  width: 300px;
  margin: 2em auto;
  padding: 0.5em 0;
  text-align: center;
  color: #fff;
  background-color: #009d3d;
  display: block;
  border-radius: 2px;
  text-decoration: none;
}

#sub section a.btn:hover {
  opacity: 0.8;
}

/* ------------------------------------------------------------ */
/* 共通バナー */
/* ------------------------------------------------------------ */
#sub section.b-banner.sp {
  display: none;
}

/* ------------------------------------------------------------ */
/* 全体格納 */
/* ------------------------------------------------------------ */
.wrapper {
  width: 100%;
  margin: 0 auto;
  height: auto;
  overflow: hidden;
}

.inBox {
  width: 100%;
  max-width: 1024px;
  margin: 0 auto;
  height: auto;
  clear: both;
}

/* ------------------------------------------------------------ */
/* 見出し */
/* ------------------------------------------------------------ */
h2 {
  color: #333;
  font-size: 36px;
  letter-spacing: 0.08em;
  margin-bottom: 30px;
  position: relative;
  clear: both;
  z-index: 1;
}

h2 span {
  font-size: 53px;
  padding-left: 20px;
}
h2 span.small {
  font-size: 36px;
  padding-left: 0;
}

h3 {
  /*font-family: Folk Medium;*/
  font-family: "Josefin Sans", sans-serif;
  margin: 50px auto 25px;
  font-size: 20px;
  position: relative;
  padding: 15px 0 15px 35px;
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  border-radius: 5px;
  background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    color-stop(1, #dceddb),
    color-stop(0, #fff)
  );
  background: -webkit-linear-gradient(#fff, #dceddb);
  background: -moz-linear-gradient(#fff, #dceddb);
  background: -o-linear-gradient(#fff, #dceddb);
  background: -ms-linear-gradient(#fff, #dceddb);
  background: linear-gradient(#fff, #dceddb);
  border: 1px solid #d8d8d8;
  letter-spacing: 0.1em;
  clear: both;
}

h3:first-child {
  margin: 0 auto 25px;
}

h3:after {
  position: absolute;
  top: 12px;
  left: 15px;
  content: "";
  width: 5px;
  height: 38px;
  background-color: #009d3d;
  -webkit-border-radius: 2.5px;
  -moz-border-radius: 2.5px;
  border-radius: 2.5px;
}

h3 span {
  position: absolute;
  right: 15px;
}

h3 span.entitle {
  display: block;
  position: relative;
  right: inherit;
}

h3 span a {
  display: inline-block;
  font-size: 14px;
  font-weight: normal;
  color: #333 !important;
  background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    color-stop(1, #efefef),
    color-stop(0, #fff)
  );
  background: -webkit-linear-gradient(#fff, #efefef);
  background: -moz-linear-gradient(#fff, #efefef);
  background: -o-linear-gradient(#fff, #efefef);
  background: -ms-linear-gradient(#fff, #efefef);
  background: linear-gradient(#fff, #efefef);
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  border-radius: 5px;
  border: 1px solid #bdbcbd;
  padding: 5px 35px 5px 15px;
  font-family: "游ゴシック", "Yu Gothic", YuGothic, "Hiragino Kaku Gothic ProN",
    "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;
}

h3 span a:hover {
  color: #333;
  background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    color-stop(1, #fff),
    color-stop(0, #efefef)
  );
  background: -webkit-linear-gradient(#efefef, #fff);
  background: -moz-linear-gradient(#efefef, #fff);
  background: -o-linear-gradient(#efefef, #fff);
  background: -ms-linear-gradient(#efefef, #fff);
  background: linear-gradient(#efefef, #fff);
}

h3 span a:after {
  position: absolute;
  content: "\f0da";
  font-family: FontAwesome;
  right: 15px;
}

h4 {
  font-size: 22px;
  margin: 1em 0;
  padding: 0.3em 1em;
  color: #1a1a1a;
  position: relative;
  background-color: #ebf6f7;
  border-bottom: 3px solid #009d3d;
  letter-spacing: 0.1em;
  clear: both;
  overflow: hidden;
}

h4 span.small {
  font-size: 70%;
  font-weight: normal;
  letter-spacing: normal;
}

h5 {
  font-size: 20px;
  color: #1a1a1a;
  margin: 1.5em 0 0.5em;
  padding: 0 0.8em 0.1em;
  position: relative;
  z-index: 10;
  letter-spacing: 0.1em;
  clear: both;
}

h5:after {
  opacity: 0.8;
  content: "";
  position: absolute;
  left: 0;
  top: 0.9em;
  width: 100%;
  height: 0.7em;
  background: -webkit-repeating-linear-gradient(
    -45deg,
    #a7d6ff,
    #a7d6ff 2px,
    rgb(255, 255, 255) 2px,
    rgb(255, 255, 255) 4px
  );
  background: repeating-linear-gradient(
    -45deg,
    #a7d6ff,
    #a7d6ff 2px,
    rgb(255, 255, 255) 2px,
    rgb(255, 255, 255) 4px
  );
  z-index: -1;
}

h6 {
  font-size: 16px;
  margin: 0.5em 0;
  color: #333;
  padding: 0.5em 1em 0.5em 0.7em;
  display: inline-block;
  background-color: #dceddb;
  border-radius: 23px 0px 0px 23px;
  line-height: 1.3;
  clear: both;
}

h6:before {
  content: "●";
  color: #fff;
  margin-right: 8px;
}

.clear {
  clear: both;
  display: block;
  margin: 0.5em 0;
}

/* ------------------------------------------------------------ */
/* ヘッダー */
/* ------------------------------------------------------------ */
header {
  position: relative;
  z-index: 100;
  width: 100%;
  padding-bottom: 20px;
  background: #fff;
  -webkit-box-shadow: 0px 4px 2px -2px rgba(4, 0, 0, 0.35);
  -moz-box-shadow: 0px 4px 2px -2px rgba(4, 0, 0, 0.35);
  box-shadow: 0px 4px 2px -2px rgba(4, 0, 0, 0.35);
}

header::after {
  content: "";
  clear: both;
  display: block;
}

/* ヘッダー上テキスト */
header .greenArea {
  background: #009d3d;
  padding: 8px 0;
  color: #fff;
  font-size: 12px;
}

.greenArea .left {
  float: left;
}

.greenArea .right {
  float: right;
}

.greenArea .right a {
  text-align: right;
  display: inline-block;
  margin-left: 35px;
  position: relative;
  color: #fff;
}

.greenArea .right a:hover {
  text-decoration: underline;
}

.greenArea .right a:before {
  content: "\f0da";
  font-family: FontAwesome;
  display: inline-block;
  margin: 0 5px 0 0;
  /* position: absolute; */
  /* top: 1px; */
  /* left: 25px; */
}

/* ------------------------------------------------------------ */
/* ナビエリア */
/* ------------------------------------------------------------ */
header nav {
  /*background: #fff;*/
}

/* ロゴ */
.gNav h1 {
  /*width: 135px;*/
  width: 30%;
  float: left;
  padding-top: 25px;
}

.gNav h1 a {
  display: block;
  width: 100%;
}
.gNav h1 img {
  width: 100%;
  height: auto;
}

/* グローバルナビ */
.gNav .rightArea {
  width: 600px;
  float: right;
}

/* 検索・文字サイズエリア */
.gNav .rightArea .serch_size {
  width: 460px;
  margin: 0 0 10px 140px;
}

.gNav .rightArea .serch_size.test {
  width: 590px;
  margin: 0 0 10px 10px;
}

/* IGアイコン */
.gNav .icon-sns {
  width: 110px;
  /* width: 30px; */
  height: 30px;
  padding-top: 15px;
  margin-left: 10px;
  float: right;
}

/* google検索 */
.serch_size .serch {
  width: 280px;
  float: left;
  margin-right: 25px;
  padding-top: 15px;
}

.serch_size .serch .cse .gsc-control-cse,
.serch_size .serch .gsc-control-cse {
  padding: 0;
  width: 280px;
}

.serch_size .serch.gsc-control-cse {
  font-family: "游ゴシック", "Yu Gothic", YuGothic, "Hiragino Kaku Gothic ProN",
    "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;
  border-color: #ffffff;
  background-color: #ffffff;
}

.serch_size .serch .cse .gsc-control-cse,
.serch_size .serch .gsc-control-cse {
  background-color: #fff;
  border: none;
}

.serch_size .serch form.gsc-search-box {
  font-size: 14px;
  margin-bottom: 0;
}

.serch_size .serch .gsc-search-box-tools .gsc-search-box .gsc-input {
  padding: 0;
  background: none !important;
  text-indent: 0 !important;
}

.serch_size .serch .gsc-input-box {
  border: none;
  background: #eeeeee;
  height: 25px;
  -webkit-border-top-left-radius: 3px;
  -moz-border-radius-topleft: 3px;
  border-top-left-radius: 3px;
  -webkit-border-bottom-left-radius: 3px;
  -moz-border-radius-bottomleft: 3px;
  border-bottom-left-radius: 3px;
}

.serch_size .serch .cse input.gsc-search-button,
input.gsc-search-button {
  color: #2d2d2d;
  padding: 0 8px;
  height: 29px;
  min-width: 30px;
  border: none !important;
  -webkit-border-top-right-radius: 3px;
  -moz-border-radius-topright: 3px;
  border-top-right-radius: 3px;
  -webkit-border-bottom-right-radius: 3px;
  -moz-border-radius-bottomright: 3px;
  border-bottom-right-radius: 3px;
  border-color: #3079ed;
  background-color: #4d90fe;
  background-image: -webkit-gradient(
    linear,
    left top,
    left bottom,
    from(#4d90fe),
    to(#4787ed)
  );
  background-image: -webkit-linear-gradient(top, #4d90fe, #4787ed);
  background-image: -moz-linear-gradient(top, #4d90fe, #4787ed);
  background-image: -ms-linear-gradient(top, #4d90fe, #4787ed);
  background-image: -o-linear-gradient(top, #4d90fe, #4787ed);
  background-image: linear-gradient(top, #4d90fe, #4787ed);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorStr='#4d90fe', EndColorStr='#4787ed');
}

.serch_size .serch input.gsc-search-button {
  margin-left: 0;
}

.serch_size .serch input.gsc-search-button,
.serch_size .serch input.gsc-search-button:hover,
.serch_size .serch input.gsc-search-button:focus {
  background-color: #eee;
}

.serch_size .serch .cse .gsc-search-button input.gsc-search-button-v2,
.serch_size .serch input.gsc-search-button-v2 {
  width: 13px;
  height: 13px;
  padding: 6px 10px;
  min-width: 13px;
  margin-top: 5px;
}

/*文字サイズ*/
.serch_size .size p {
  float: left;
  font-size: 12px;
  color: #009d3d;
  padding-top: 25px;
  margin-right: 7px;
}

.serch_size .size ul li {
  float: left;
  margin-left: 5px;
}

.serch_size .size ul li a {
  display: inline-block;
  color: #fff;
  background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    color-stop(1, #009b3c),
    color-stop(0, #008032)
  );
  background: -webkit-linear-gradient(#008032, #009b3c);
  background: -moz-linear-gradient(#008032, #009b3c);
  background: -o-linear-gradient(#008032, #009b3c);
  background: -ms-linear-gradient(#008032, #009b3c);
  background: linear-gradient(#008032, #009b3c);
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  border-radius: 5px;
}

.serch_size .size ul li.normal {
  padding-top: 22px;
}

.serch_size .size ul li.normal a {
  padding: 2px 5px;
  font-size: 12px;
}

.serch_size .size ul li.bigger {
  padding-top: 17px;
}

.serch_size .size ul li.bigger a {
  padding: 3px 6px;
  font-size: 14px;
}

/* ------------------------------------------------------------ */
/* ナビ */
/* ------------------------------------------------------------ */
.navArea li {
  float: right;
  margin-left: 7px;
  position: relative;
}

.navArea li a {
  display: inline-block;
  font-size: 15px;
  color: #333;
  background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    color-stop(1, #efefef),
    color-stop(0, #fff)
  );
  background: -webkit-linear-gradient(#fff, #efefef);
  background: -moz-linear-gradient(#fff, #efefef);
  background: -o-linear-gradient(#fff, #efefef);
  background: -ms-linear-gradient(#fff, #efefef);
  background: linear-gradient(#fff, #efefef);
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  border-radius: 5px;
  border: 1px solid #bdbcbd;
  padding: 8px 15px;
}

.navArea li a:hover {
  background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    color-stop(1, #fff),
    color-stop(0, #efefef)
  );
  background: -webkit-linear-gradient(#efefef, #fff);
  background: -moz-linear-gradient(#efefef, #fff);
  background: -o-linear-gradient(#efefef, #fff);
  background: -ms-linear-gradient(#efefef, #fff);
  background: linear-gradient(#efefef, #fff);
}

/*カレント*/
.navArea li.current:hover {
}

.navArea li.current:hover:before {
  content: "";
  height: 0;
  position: absolute;
  width: 0;
  border: 6px solid transparent;
  border-top-color: #009d3d;
  top: 60px;
  left: 45%;
  z-index: 100;
}

.navArea li.current:hover:after {
  position: absolute;
  content: "";
  width: 80%;
  padding: 17px 0 0 20px;
  border-bottom: 3px solid #009d3d;
  bottom: -20px;
  left: 0;
}

/*Safariだけに適用されるCSSハック*/
/*@media screen and (-webkit-min-device-pixel-ratio:0) {
_::-webkit-full-page-media, _:future, :root .navArea li.current:hover:after {
 height:40px;
 left:0;
}
}*/

/*ieだけに適用されるCSSハック*/
/*.navArea li.current:hover:after {
	height: 40px\9;
	left: 0\9;
}*/

/*@media all and (-ms-high-contrast: none) {
.navArea li.current:hover:after {
	height: 40px;
	left: 0;
	width: 100%;
	float: none;
	margin-bottom: 50px;
	border-bottom: 1px solid #009d3d;
	border-right: none;
}
}*/

/*@media all and (-ms-high-contrast: none) {

.navArea li.current:hover:after {
	width: 100%;
	float: none;
	margin-bottom: 50px;
	border-bottom: 1px solid #009d3d;
	border-right: none;
}
}*/

/* ドロップダウンメニュー */
.navArea li ul.bg {
  margin: 60px auto 0;
  top: 0;
  display: none;
  position: absolute;
  width: 1500px;
  height: auto;
  padding: 30px 0;
  background: #f1f1f1;
  z-index: 1;
}

.navArea li.mddm01 ul.bg {
  left: -798px;
}

.navArea li.mddm02 ul.bg {
  left: -927px;
}

.navArea li.mddm03 ul.bg {
  left: -1056px;
}

.navArea li:hover > ul.bg {
  display: block;
}

/*.navArea li ul.bg .title*/
ul.bg .title {
  /*font-size: 30px;*/
  /*border-right: 1px solid #009d3d;*/
  color: #009d3d;
  padding: 0;
  float: left;
  margin-right: 35px;
  width: 55px;
  /*position:relative;*/
}
/*ul.bg .title:after {
	content:"";
	display:block;
	position:absolute;
	top:0;
	left: 65px;
	width:1px;
	height:100%;
	background: #009d3d;
}*/

/*ieだけに適用されるCSSハック*/
/*@media all and (-ms-high-contrast: none) {
ul.bg .title {
	height: 180px;
}

}*/
/*.navArea li ul.bg .title*/
ul.bg .title {
  /*width: 100%\9;
	float: none\9;
	height: 180px\9;*/
  /*margin-bottom: 50px\9;
	border-bottom: 1px solid #009d3d\9;
	border-right: none\9;*/
}

/*.navArea li ul.bg li*/
ul.bg li {
  float: left;
  width: 180px;
  margin-right: 35px;
  /*width: calc(100%/4 - 76px);*/
}
ul.bg li ul {
  margin-bottom: 30px;
}

/*.navArea li ul.bg li span,
.navArea li ul.bg li a.none*/
ul.bg li span,
ul.bg li a.none {
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 2px;
}

/*.navArea li ul.bg li a.none*/
ul.bg li a.none {
  background: none;
  border: none;
  padding: 0;
}

/*.navArea li ul.bg li a.none:hover*/
ul.bg li a.none:hover {
  color: #939393;
}

/*.navArea li ul.bg li ul li.child*/
ul.bg .child {
  /*margin: 0 15px 5px 0;*/
  margin: 0 35px 5px 0;
  width: 100%;
  max-width: 185px;
}
/*.navArea li ul.bg li ul li.child:last-child*/
/*ul.bg .child:last-child {
	margin-bottom: 30px;
}*/

/*.navArea li ul.bg li ul li.child a*/
ul.bg .child a {
  position: relative;
  display: block;
  font-size: 14px;
  padding: 7px 18px 7px 10px;
  background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    color-stop(1, #dceddb),
    color-stop(0, #fff)
  );
  background: -webkit-linear-gradient(#fff, #dceddb);
  background: -moz-linear-gradient(#fff, #dceddb);
  background: -o-linear-gradient(#fff, #dceddb);
  background: -ms-linear-gradient(#fff, #dceddb);
  background: linear-gradient(#fff, #dceddb);
  border: 1px solid #d8d8d8;
}
/*.navArea li ul.bg li ul li.child a:hover*/
ul.bg .child a:hover {
  background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    color-stop(1, #fff),
    color-stop(0, #dceddb)
  );
  background: -webkit-linear-gradient(#dceddb, #fff);
  background: -moz-linear-gradient(#dceddb, #fff);
  background: -o-linear-gradient(#dceddb, #fff);
  background: -ms-linear-gradient(#dceddb, #fff);
  background: linear-gradient(#dceddb, #fff);
}
/*.navArea li ul.bg li ul li.child a:after*/
ul.bg .child a:after {
  position: absolute;
  content: "\f0da";
  font-family: FontAwesome;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
}

/* ------------------------------------------------------------ */
/* メインビジュアル */
/* ------------------------------------------------------------ */
.main-visual {
  width: 100%;
  height: auto;
  margin: 0 auto;
  position: relative;
}

.mv_slide {
  max-width: 100%;
  margin: 0 auto;
}

.main-visual .onText {
  width: 40%;
  position: absolute;
  left: 5%;
  top: 8%;
  height: 73%;
  background: url(../img/bk-onText.png) no-repeat left 15% top 50%
    rgba(255, 255, 255, 0.8);
  background-size: auto 88%;
}
.main-visual .onText p {
  font-size: 1.7vw;
  line-height: 1.7em;
  padding: 36% 3% 0 5%;
}
/*.main-visual .onText {
	position: absolute;
	left: 10%;
	top: 5%;
	height: 100%;
	background: url(../img/bk-onText.png) no-repeat 0 0;
	background-size: auto 85%;
}
*/
/*.main-visual .onText p {
	font-size: 1.9vw;
	line-height: 1.7em;
	padding-top: 40%;
}*/

/* ------------------------------------------------------------ */
/* コンテンツ */
/* ------------------------------------------------------------ */
.content {
  display: block;
  width: 100%;
  margin: -70px auto 0;
  position: relative;
}

/* ------------------------------------------------------------ */
/* お知らせエリア */
.content .newsArea {
  margin-bottom: 60px;
}

.content .newsArea .banner {
  /*display: block;*/
  width: 410px;
  float: left;
}

.content .newsArea .banner li {
  margin-bottom: 15px;
}

.content .newsArea .banner li a {
  display: block;
}

.auxiliary {
  display: flex;
  justify-content: space-between;
}
.auxiliary .aux-item {
  width: 48%;
}
.auxiliary .aux-item img {
  width: 100%;
  height: auto;
}

/* ------------------------------------------------------------ */
/* 新着リストエリア */
.content .newsArea .news {
  width: 560px;
  float: right;
  padding-top: 120px;
}

.content .newsArea .news dl {
  padding-bottom: 13px;
  margin-bottom: 13px;
  border-bottom: 1px solid #ebebeb;
}

.content .newsArea .news dl a {
  color: #333;
}

.content .newsArea .news dl .day {
  display: inline-block;
  margin: 0 10px 0 0;
  color: #999;
  font-size: 14px;
}

.content .newsArea .news dl a dd.title {
  font-size: 129%;
  color: #009d3d;
  margin: 0 auto 5px;
}
/* ------------------------------------------------------------ */
/* インスタグラムアカウントリスト */
.instaArea {
  padding: 5em 0;
  background: #fff6d9;
  position: relative;
  width: 100vw;
  /* mask なみなみ 上 */
  --mask: radial-gradient(3.05vmin at 50% 4.3vmin, #000 99%, #0000 101%)
      calc(50% - 4vmin) 0/8vmin 100%,
    radial-gradient(3.05vmin at 50% -2.3vmin, #0000 99%, #000 101%) 50% 2vmin/8vmin
      100% repeat-x;
  -webkit-mask: var(--mask);
  mask: var(--mask);
}
.instaArea h3 {
  width: 150px;
  margin: 0 auto 1em;
  background: none;
  border: none;
  text-align: center;
}
.instaArea h3:after {
  display: none;
}
.instaArea h3 img {
  width: 100%;
  height: auto;
}
.instaArea .caption {
  text-align: center;
  font-size: 1.2rem;
  margin-bottom: 3em;
}
.insta-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 1.5em 1.5%;
}
.insta-list li {
  width: calc(95.5% / 4);
}
.insta-list li a {
  display: block;
  text-align: center;
  position: relative;
  font-size: 1.1rem;
  font-weight: bold;
  color: #eb4470;
  padding: 1em 1em 1em calc(1.5em - 22px);
  background: #fff;
  border: 3px solid #fac4d0;
  border-radius: 10px;
  line-height: 1.1em;
  box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.24);
}
.insta-list li a:hover {
  box-shadow: none;
  color: #c04bf4;
  border-color: #e9c8f5;
}
.insta-list li a::after {
  position: absolute;
  content: "";
  width: calc(22px + 0.5em);
  height: 22px;
  background: url(../img/icon-ig_pink.svg) no-repeat right center / contain;
  transition: all 0.3s;
}
.insta-list li a:hover::after {
  transform: scale(1.1);
}

/* ------------------------------------------------------------ */
/* 施設情報エリア */
.content .facility {
  background: url(../img/bk-facility.png) no-repeat center center;
  background-size: cover;
  padding: 80px 0 110px;
}

.content .facility h3 {
  background: none;
  border: none;
  text-align: center;
  padding: 0;
  margin-bottom: 40px;
  font-size: 28px;
  letter-spacing: 0.1em;
  line-height: 1em;
}

.content .facility h3:after {
  display: none;
}

.content .facility h3 span {
  font-family: "Josefin Sans", sans-serif;
  color: #009d3d;
  font-size: 16px;
  letter-spacing: 0;
}

.content .facility .faciList {
  width: 100%;
  overflow: hidden;
}

.content .facility .faciList ul {
}

.content .facility .faciList ul li {
  float: left;
  width: 23%;
  height: 310px;
  margin: 10px 1% 20px;
  background: #fff;
  -moz-box-shadow: 0px 0px 6px 0px #898989;
  -webkit-box-shadow: 0px 0px 6px 0px #898989;
  box-shadow: 0px 0px 6px 0px #898989;
  -moz-border-radius: 6px;
  -webkit-border-radius: 6px;
  border-radius: 6px;
  text-align: center;
  padding-bottom: 15px;
  overflow: hidden;
}

.content .facility .faciList ul li a {
  display: block;
  color: #333;
}
.content .facility .faciList ul li .thum {
  height: 165px;
  overflow: hidden;
  -moz-border-radius: 6px 6px 0px 0px;
  -webkit-border-radius: 6px 6px 0px 0px;
  border-radius: 6px 6px 0px 0px;
  position: relative;
}

.content .facility .faciList ul li .thum img {
  width: 100%;
  height: auto;
}

.content .facility .faciList ul li .ctgr {
  font-size: 18px;
  background: #fff;
  width: 175px;
  padding: 7px 0;
  -moz-border-radius: 6px;
  -webkit-border-radius: 6px;
  border-radius: 6px;
  position: relative;
  margin: -25px auto 5px;
}

.content .facility .faciList ul li .title {
  font-size: 20px;
  color: #009d3d;
  margin-bottom: 20px;
  font-weight: bold;
}

.content .facility .faciList ul li a .btn {
  position: relative;
  width: 80%;
  margin: 0 auto;
  background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    color-stop(1, #efefef),
    color-stop(0, #fff)
  );
  background: -webkit-linear-gradient(#fff, #efefef);
  background: -moz-linear-gradient(#fff, #efefef);
  background: -o-linear-gradient(#fff, #efefef);
  background: -ms-linear-gradient(#fff, #efefef);
  background: linear-gradient(#fff, #efefef);
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  border-radius: 5px;
  border: 1px solid #bdbcbd;
  padding: 6px 0;
  font-size: 15px;
}

.content .facility .faciList ul li a:hover .btn {
  background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    color-stop(1, #fff),
    color-stop(0, #efefef)
  );
  background: -webkit-linear-gradient(#efefef, #fff);
  background: -moz-linear-gradient(#efefef, #fff);
  background: -o-linear-gradient(#efefef, #fff);
  background: -ms-linear-gradient(#efefef, #fff);
  background: linear-gradient(#efefef, #fff);
}

.content .facility .faciList ul li a .btn:after {
  content: "\f0da";
  font-family: FontAwesome;
  position: absolute;
  right: 15px;
}

/* ------------------------------------------------------------ */
/* ページトップ */
/* ------------------------------------------------------------ */
#ft_fix {
  right: 2%;
  z-index: 9999;
}

.pageTop {
  width: 50px;
  height: 50px;
  line-height: 50px;
  color: #fff !important;
  font-size: 300%;
  text-align: center;
  background: #009d3d;
  /*bottom: 50px;
	display: none;
	position: fixed;*/
  /*-webkit-transform: translateZ(0);*/
}
.pageTop a {
  color: #fff !important;
}

.pageTop:hover {
  opacity: 0.7;
}

/* ------------------------------------------------------------ */
/* フッター */
/* ------------------------------------------------------------ */
footer {
  background: #fff;
  color: #fff;
  text-align: center;
  padding: 40px 0 0;
  z-index: 9999;
}

footer h1 {
  padding-bottom: 30px;
}

.icon-sns img {
  width: 100%;
  height: auto;
}
.icon-sns a {
  display: block;
}
footer .icon-sns {
  width: 110px;
  /* width: 30px; */
  height: 30px;
  margin: 0 auto 2em;
}

footer .copy {
  color: #333;
  font-size: 13px;
  padding: 15px 0;
  border-top: 1px solid #dadada;
}

@media screen and (min-width: 1500px) {
  .main-visual .onText P {
    font-size: 26px;
    padding-top: 250px;
  }
}

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

@media screen and (max-width: 1023px) {
  .pc {
    display: none;
  }
  .sp {
    display: block;
  }

  /* ------------------------------------------------------------ */
  /* 共通バナー */
  /* ------------------------------------------------------------ */
  #sub section.b-banner.sp {
    display: block;
  }

  .content .b-banner {
    padding: 50px 0 80px;
  }
  #sub .b-banner {
    padding: 0 0 60px;
  }

  .content .b-banner a {
    display: block;
    max-width: 380px;
    margin: 0 auto 15px;
  }
  .auxiliary {
    max-width: 380px;
    margin: 0 auto;
  }

  .content .b-banner a img {
    width: 100%;
    height: auto;
  }

  /* ------------------------------------------------------------ */
  /* 全体格納 */
  /* ------------------------------------------------------------ */
  .inBox {
    width: 90%;
    max-width: 100%;
    margin: 0 auto;
  }

  /* ------------------------------------------------------------ */
  /* ヘッダー */
  /* ------------------------------------------------------------ */
  header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 70px;
    padding: 10px 0;
    z-index: 2;
    background: rgba(255, 255, 255, 0.84);
    box-sizing: border-box;
  }

  header h1 {
    /*display: inline-block;*/
    margin: 0 auto 0 15px;
  }

  header h1 a {
    display: block;
  }

  header h1 a img {
    height: 48px;
    width: auto;
    /*padding: 3px 0 3px 10px;*/
  }

  /* ------------------------------------------------------------ */
  /* ナビ */
  /* ------------------------------------------------------------ */
  .sb-toggle-right {
    position: absolute;
    top: 10px;
    right: 15px;
  }
  #button {
    padding: 0;
    margin: 0;
    border: none;
  }
  #button img {
    width: 50px;
    height: auto;
  }

  /* SPサイドナビ */
  .sb-slidebar {
    padding: 0;
    background-color: #fff !important;
    border-left: 2px solid #d8efe1;
  }

  .sb-slidebar.sb-right {
    -webkit-overflow-scrolling: touch;
  }

  .sb-right-inner {
    border: none;
    width: 100%;
    height: 100%;
  }
  .sb-right-inner h2 {
    width: 60%;
    margin: 0 auto;
    padding: 0 0 15px;
    box-sizing: border-box;
  }
  .sb-right-inner h2 img {
    width: 100%;
    height: auto;
  }

  .sb-slidebar ul {
    padding: 0;
  }

  .sb-slidebar ul.linknav {
    padding: 20px 10px;
    box-sizing: border-box;
    width: 100%;
    margin: 0 auto;
  }
  ul.linknav li a {
    display: block;
    line-height: 30px;
    position: relative;
    padding: 0 10px;
    box-sizing: border-box;
  }
  ul.linknav li a:before {
    content: "\f0da";
    font-family: FontAwesome;
    display: block;
    position: absolute;
    color: #009d3d;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
  }

  .sb-slidebar .icon-sns {
    width: 110px;
    /* width: 30px; */
    height: 30px;
    margin: 0 auto;
    padding-top: 1em;
  }

  /* アコーディオン */
  .ac_menu {
    border-top: 2px solid #d8efe1;
    position: relative;
    z-index: 3;
  }
  .ac_menu p a,
  .ac_menu label {
    padding: 10px;
    display: block;
    margin: 0;
    color: #009d3d;
    background: #fff;
    border-bottom: 1px dotted #afcab9;
    position: relative;
    cursor: pointer;
  }

  .ac_menu label:before {
    content: "\f0d7";
    font-family: FontAwesome;
    display: block;
    position: absolute;
    color: #009d3d;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
  }

  .ac_menu p a:after,
  .ac_menu li a:after {
    content: "\f105";
    font-family: FontAwesome;
    display: block;
    position: absolute;
    color: #009d3d;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
  }

  input[type="checkbox"].bellows {
    display: none;
  }
  input[type="checkbox"].bellows + ul {
    height: 0;
    overflow: hidden;
  }

  /* メニュー開閉時アニメーション */
  .ac_menu ul {
    background: #edf5f0;
    -webkit-transition: all 0.5s;
    -moz-transition: all 0.5s;
    -ms-transition: all 0.5s;
    -o-transition: all 0.5s;
    transition: all 0.5s;
    margin: 0;
    padding: 0;
    list-style: none;
  }

  .ac_menu li a,
  .ac_menu li.item span {
    display: block;
    padding: 0 20px;
    line-height: 35px;
    box-sizing: border-box;
  }
  .ac_menu ul li {
    border-bottom: 1px dotted #afcab9;
    height: auto;
  }
  .ac_menu ul li.item {
    /*border-bottom: none;*/
  }
  .ac_menu li.item span {
    color: #666;
    background: #d8efe1;
    padding: 0 10px;
  }

  .ac_menu ul.sub li {
    border-top: 1px solid #fff;
    border-bottom: none;
  }
  /*.ac_menu ul.sub li:last-child {
    border-bottom: none;
}*/

  /* ▽▽アコーディオン開閉指定▽▽ */
  input[type="checkbox"].bellows + ul {
    height: 0; /* チェックが入っていない時の高さ */
    overflow: hidden;
  }
  input#nav01[type="checkbox"].bellows:checked + ul {
    height: 180px;
  }
  input#nav02[type="checkbox"].bellows:checked + ul {
    height: 863px;
  }
  input#nav03[type="checkbox"].bellows:checked + ul {
    height: 576px;
  }
  /* △△アコーディオン開閉指定△△ */

  /* ------------------------------------------------------------ */
  /* コンテンツ */
  /* ------------------------------------------------------------ */
  .wrapper {
    padding-top: 70px;
  }

  .content {
    margin: 0 auto;
    padding-top: 35px;
  }

  .content .newsArea {
    margin-bottom: 40px;
  }

  .content .newsArea .news {
    width: 100%;
    float: none;
    padding-top: 40px;
  }

  /* ------------------------------------------------------------ */
  /* インスタグラムアカウントリスト */
  .insta-list {
    gap: 1em 1.5%;
  }
  .insta-list li {
    width: calc(95.5% / 2);
  }

  .content .facility {
    padding: 50px 0;
  }

  .content .facility .faciList ul li {
    height: 260px;
    margin: 10px 1%;
  }
  .content .facility .faciList ul li .thum {
    height: auto;
    margin: 0 auto 5px;
  }
  .content .facility .faciList ul li .ctgr {
    font-size: 14px;
    width: 90%;
    margin: 0 auto;
  }

  .content .facility .faciList ul li .title {
    font-size: 15px;
    width: 90%;
    margin: 0 auto 20px;
  }

  .content .facility .faciList ul li a .btn {
    width: 90%;
    font-size: 14px;
  }

  /* ------------------------------------------------------------ */
  /* フッター */
  /* ------------------------------------------------------------ */
  /*.pageTop.pc {
	display: none !important;
}*/

  /*.pageTop {
	width: 100%;
	background: #acdec5;
	right: 0;
	bottom: 220px;
}*/

  .pageTop i {
    color: #fff;
    background: #009d3d;
    padding: 5px 5%;
  }

  #ft_fix.fixed {
    right: 0;
    width: 100%;
    margin: 0 auto 80px;
  }

  /*#ft_fix,
#ft_fix p.pagetop,
.pageTop a {
    -webkit-transform-origin: center;
    transform-origin: center;
}*/

  #ft_fix.fixed .pageTop {
    width: 100%;
    height: 50px;
    background: #acdec5;
  }
  .pageTop a.fixed {
    display: block;
    width: 100%;
  }

  .pageTop:hover {
    opacity: 1;
  }
}

@media screen and (max-width: 767px) {
  /* ------------------------------------------------------------ */
  /*メインビジュアル*/
  /* ------------------------------------------------------------ */
  .main-visual .onText {
    width: 60%;
  }
  .main-visual .onText p {
    font-size: 2.2vw;
    padding: 25% 3% 0 5%;
  }
  /*.main-visual .onText p {
	font-size: 2.7vw;
	padding-top: 30%;
}
*/
  /* ------------------------------------------------------------ */
  /*コンテンツ*/
  /* ------------------------------------------------------------ */
  .content .facility .faciList ul li {
    width: 31%;
    height: 270px;
  }

  .content .facility .faciList ul li .ctgr {
    width: 85%;
  }
  /* ------------------------------------------------------------ */
  /* インスタグラムアカウントリスト */
  .insta-list {
    gap: 0.5em 1.5%;
  }
  .insta-list li {
    width: calc(95.5% / 1);
  }

  /* ------------------------------------------------------------ */
  /*フッター*/
  /* ------------------------------------------------------------ */
  .pageTop a i {
    padding: 5px 10%;
  }

  footer {
    padding: 30px 0 0;
  }

  footer h1 img {
    width: 50%;
    max-width: 250px;
    min-width: 100px;
    height: auto;
  }
}

@media screen and (max-width: 479px) {
  h3 span a {
    padding: 5px 15px;
  }
  h3 span a:after {
    right: 5px;
  }
  #sub section a.btn {
    width: 100%;
  }
  /* ------------------------------------------------------------ */
  /*メインビジュアル*/
  /* ------------------------------------------------------------ */
  .main-visual .onText {
    top: 10%;
    left: 2%;
    height: 80%;
    background: url(../img/bk-onText_sp.png) no-repeat center 92%
      rgba(255, 255, 255, 0.8);
    background-size: 90% auto;
    width: 70%;
  }
  .main-visual .onText p {
    font-size: 2.8vw;
    padding: 6% 3% 0 5%;
  }
  /*.main-visual .onText {
	top: 5%;
	left: 2%;
	height: 100%;
	background: url(../img/bk-onText_sp.png) no-repeat 0 80%;
	background-size: 100% auto;
}

.main-visual .onText p {
	font-size: 3.1vw;
	padding-top: 12%;
}
*/
  /* ------------------------------------------------------------ */
  /*コンテンツ*/
  /* ------------------------------------------------------------ */
  .content .newsArea {
    margin-bottom: 20px;
  }

  .content .newsArea .news {
    padding-top: 30px;
  }

  .content .facility .faciList ul li {
    width: 48%;
    margin: 10px 1% 10px;
    height: 260px;
  }

  /* ------------------------------------------------------------ */
  /*フッター*/
  /* ------------------------------------------------------------ */
  #ft_fix.fixed {
    margin: 0 auto 60px;
  }

  footer {
    padding: 20px 0 0;
  }

  footer h1 {
    padding-bottom: 20px;
  }

  footer .copy {
    font-size: 10px;
  }
}

@media screen and (max-width: 320px) {
  .main-visual .onText {
    width: 80%;
  }
  .content .facility .faciList ul li {
    height: 240px;
  }

  .content .facility .faciList ul li .ctgr {
    font-size: 13px;
  }

  .content .facility .faciList ul li .title {
    font-size: 13px;
  }

  .content .facility .faciList ul li a .btn {
    font-size: 13px;
  }
}
@charset "UTF-8";
/* ------------------------------------ */
/* 下層 */
/* ------------------------------------ */
#sub .wrapper {
  position: relative;
}

#sub .content {
  margin: 0 auto;
  background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    color-stop(1, #fff),
    color-stop(0.2, #f2f9ff),
    color-stop(0, #b2daff)
  );
  background: -webkit-linear-gradient(top, #b2daff 0%, #f2f9ff 20%, #fff 100%);
  background: -moz-linear-gradient(top, #b2daff 0%, #f2f9ff 20%, #fff 100%);
  background: -o-linear-gradient(top, #b2daff 0%, #f2f9ff 20%, #fff 100%);
  background: -ms-linear-gradient(top, #b2daff 0%, #f2f9ff 20%, #fff 100%);
  background: linear-gradient(to bottom, #b2daff 0%, #f2f9ff 20%, #fff 100%);
  position: relative;
}

#sub .content:before {
  content: url(../img/bk_subTop.png);
  height: 211px;
  width: 520px;
  position: absolute;
  right: 5%;
  top: 0;
}

#sub .content:after {
  content: "";
  position: absolute;
  height: 10px;
  width: 100%;
  background: url(../img/footer_wave.png) repeat-x 0 0;
  bottom: 0;
  left: 0;
  right: 0;
}

/* ------------------------------------ */
/* サイドバー */
/* ------------------------------------ */
.sidebar {
  width: 300px;
  padding: 0 15px 15px;
  margin-bottom: 30px;
  float: right;
  position: relative;
  background: #009d3d;
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  border-radius: 5px;
}

/*概要文*/
.sidebar .dscrpt {
  background: #fff9b0;
  -moz-box-shadow: 0px 0px 6px 0px #898989;
  -webkit-box-shadow: 0px 0px 6px 0px #898989;
  box-shadow: 0px 0px 6px 0px #898989;
  margin: -10px 6px 30px;
  /*padding: 35px 20px 20px;*/
  padding: 39px 20px 20px;
  position: relative;
}

.sidebar .dscrpt:before {
  position: absolute;
  content: url("../img/side_clip.png");
  top: -31px;
  left: 10px;
}

.sidebar .dscrpt h2.sidetit {
  /*text-align: center;*/
  text-align: left;
  font-size: 18px !important;
  margin-bottom: 20px;
  line-height: 1em;
}

/*.sidebar .dscrpt h2 span {
	font-size: 21px;
	padding-left: 10px !important;
}*/
.sidebar .dscrpt h2.sidetit span {
  display: block;
  font-size: 22px;
  padding-left: 0px !important;
  margin-top: 0.2em;
  line-height: 1.35em;
}
.sidebar .dscrpt h2.sidetit span.small {
  font-size: 18px;
}
.sidebar .dscrpt h2.sidetit span.cngfont {
  font-size: 22px;
}

.sidebar .dscrpt .text {
  font-size: 114%;
  margin-bottom: 15px;
}

.sidebar .dscrpt .add {
  font-size: 114%;
  margin-bottom: 15px;
  font-weight: bold;
}
.sidebar .dscrpt .btnArea:after {
  content: "";
  display: block;
  clear: both;
}

.sidebar .dscrpt .btnArea a,
.sidebar .dscrpt .btnArea .sidebtn {
  position: relative;
  display: block;
  float: left;
  color: #333;
  font-size: 14px;
  font-weight: normal;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(1, #efefef), color-stop(0, #fff));
  background: -webkit-linear-gradient(#fff, #efefef);
  background: -moz-linear-gradient(#fff, #efefef);
  background: -o-linear-gradient(#fff, #efefef);
  background: -ms-linear-gradient(#fff, #efefef);
  background: linear-gradient(#fff, #efefef);
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  border-radius: 5px;
  border: 1px solid #bdbcbd;
  padding: 5px 18px 5px 8px;
  margin: 0 1px;
}
.sidebar .dscrpt .btnArea .sidebtn {
  font-size: 13px;
  padding: 6px 8px;
}

.sidebar .dscrpt .btnArea a:hover {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(1, #fff), color-stop(0, #efefef));
  background: -webkit-linear-gradient(#efefef, #fff);
  background: -moz-linear-gradient(#efefef, #fff);
  background: -o-linear-gradient(#efefef, #fff);
  background: -ms-linear-gradient(#efefef, #fff);
  background: linear-gradient(#efefef, #fff);
}

.sidebar .dscrpt .btnArea a:after {
  position: absolute;
  content: "\f0da";
  font-family: FontAwesome;
  right: 8px;
}

/*ローカルなビ*/
.sidebar .toDetail {
  margin-bottom: 20px;
}

.sidebar .toDetail li {
  margin-bottom: 5px;
}

.sidebar .toDetail li a {
  display: block;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(1, #dceddb), color-stop(0, #fff));
  background: -webkit-linear-gradient(#fff, #dceddb);
  background: -moz-linear-gradient(#fff, #dceddb);
  background: -o-linear-gradient(#fff, #dceddb);
  background: -ms-linear-gradient(#fff, #dceddb);
  background: linear-gradient(#fff, #dceddb);
  border: 1px solid #d8d8d8;
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  border-radius: 5px;
  /*border:1px solid #bdbcbd;*/
  padding: 10px 35px 10px 25px;
  color: #333;
  font-weight: bold;
  font-size: 16px;
  position: relative;
  word-wrap: break-word;
}
.sidebar .toDetail li a .small {
  font-size: 13px;
  display: inline-block;
  margin: 0 5px 0 0;
}

.sidebar .toDetail li a:before {
  position: absolute;
  content: "";
  border-left: 4px solid #333;
  height: 23px;
  left: 10px;
}

.sidebar .toDetail li a:after {
  content: "\f0da";
  font-family: FontAwesome;
  position: absolute;
  top: 12px;
  right: 8px;
  width: 16px;
  height: 16px;
  padding: 3px;
  line-height: 1;
  text-align: center;
  background: #fff;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  border-radius: 50%;
  -moz-box-shadow: 0px 0px 3px 0px #a4a4a4;
  -webkit-box-shadow: 0px 0px 3px 0px #a4a4a4;
  box-shadow: 0px 0px 3px 0px #a4a4a4;
}

.sidebar .toDetail li a:hover {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(1, #fff), color-stop(0, #dceddb));
  background: -webkit-linear-gradient(#dceddb, #fff);
  background: -moz-linear-gradient(#dceddb, #fff);
  background: -o-linear-gradient(#dceddb, #fff);
  background: -ms-linear-gradient(#dceddb, #fff);
  background: linear-gradient(#dceddb, #fff);
}

/*サイドバー内のバナー*/
.sidebar .banner a {
  display: block;
  margin-bottom: 10px;
}

.sidebar .banner img {
  width: 100%;
  height: auto;
}

/*パンくず*/
.pancz {
  font-size: 12px;
  color: #333;
  padding-top: 15px;
  margin-bottom: 10px;
  position: relative;
  z-index: 1;
}

.pancz a {
  color: #009d3d;
  position: relative;
  padding-right: 15px;
  margin-right: 15px;
}

.pancz a:after {
  position: absolute;
  content: "\f105";
  font-family: FontAwesome;
  right: 0;
}

.pancz a:hover {
  text-decoration: underline;
}

/*下層共通*/
/*テーブル*/
#sub section table {
  width: 95%;
  margin: 0 auto 20px;
  border-top: 1px solid #ddd;
  background: #fff;
}

#sub section table th {
  background: #dceddb;
  table-layout: fixed;
  padding: 7px;
  text-align: center;
  border-bottom: 1px solid #ddd;
  min-width: 25%;
  vertical-align: top;
  box-sizing: border-box;
}

#sub section table td {
  table-layout: fixed;
  padding: 7px;
  border-bottom: 1px solid #ddd;
  vertical-align: top;
  width: 75%;
  box-sizing: border-box;
}

#sub section table p {
  font-size: 100%;
}

/*ul li*/
#sub section ul {
  /*list-style:disc !important;*/
  padding-left: 20px;
}

#sub section ul li {
  font-size: 107%;
}

/*TextLink*/
#sub section a {
  text-decoration: underline;
}

#sub section a:hover {
  text-decoration: none;
}

/*メイン（サイドバーあり）*/
.subvisual,
.mainArea {
  width: 660px;
  float: left;
}

#sub .subvisual .bx-wrapper img {
  width: 100%;
  height: auto;
}

#sub section {
  display: block;
  margin-bottom: 60px;
}

#sub section p {
  font-size: 107%;
  line-height: 1.7em;
  margin-bottom: 0.8em;
}

/*ニュースエリア*/
#sub .content .newsArea .news {
  width: 100%;
  float: none;
  padding-top: 0;
}

/*ギャラリー*/
#sub section.gallery ul {
  width: 103%;
  padding: 0;
  overflow: hidden;
	display: flex;
	flex-wrap: wrap;
}

.gallery ul li {
  /* float: left; */
  width: 30%;
  margin: 0 3% 25px 0;
  list-style: none !important;
  /* height: 205px;
  overflow: hidden; */
}
.gallery.g_post ul li {
  height: auto;
}

.gallery ul li a {
  color: #333;
}

.gallery ul li .thum {
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  margin-bottom: 5px;
}

.gallery ul li img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.gallery ul li .day {
  font-size: 12px;
}

.gallery ul li .title {
  font-size: 14px;
}

/* editor */
.post_wrap {
  margin: 0 auto 20px;
}

/* 各施設写真ギャラリー一覧：本文 */
.gallery.g_post .post_wrap {
  margin: 0 auto;
}

.news .post_wrap {
  margin: 0 auto 60px;
}

.post_wrap p {
  display: block;
  margin: 1em 0;
}

.post_wrap strong {
  font-weight: bold;
}

.post_wrap em {
  font-style: italic;
}

.post_wrap blockquote {
  display: block;
  -webkit-margin-before: 1em;
  -webkit-margin-after: 1em;
  -webkit-margin-start: 40px;
  -webkit-margin-end: 40px;
}

.post_wrap img[class*="wp-image-"],
.post_wrap img[class*="attachment-"] {
  height: auto;
  max-width: 31%;
  width: 100%;
}

.post_wrap .wp-caption img[class*="wp-image-"] {
  max-width: 100%;
}

.post_wrap p.wp-caption-text {
  margin: 0 auto 1em;
  font-size: 92% !important;
  text-align: center;
}

/* img */
.post_wrap .aligncenter,
.aligncenter {
  display: block;
  margin: 0 auto;
}

.post_wrap .alignright,
.alignright {
  float: right;
  margin: 0 0 1em 1em;
}

.post_wrap .alignleft,
.alignleft {
  float: left;
  margin: 0 1em 1em 0;
}

/* キャプションつき */
.post_wrap .wp-caption {
  width: auto !important;
  max-width: 31% !important;
  margin: 0 auto 1em;
}

/*.post_wrap div[id*="attachment_"] {
	height: auto;
	max-width: 100% !important;
	display: inline-block;
	width: calc(100%/3) !important;
	padding: 0 5px;	
	margin: 0 auto 1em;
	float: none;
}*/

/* iframe */
#sub section iframe {
  width: 100%;
  height: 300px;
}

/*recruit*/
h4 .alignright {
  float: right;
  margin: 5px 0 5px 15px;
}

#sub section .leftbox {
  float: left;
  width: 60%;
  margin: 0 2% 0 0;
  text-align: center;
}

#sub section .rightbox {
  float: right;
  width: 38%;
  text-align: right;
}

#sub section .rightbox img {
  width: 100%;
  height: auto;
}

#sub section .leftbox .message {
  width: 96%;
  padding: 1.2em 2%;
  margin: 0 0 1em 0;
  background-color: #fcf9d9;
  font-size: 125%;
  font-weight: bold;
  border-radius: 10px;
  text-align: center;
}

/*ページナビ*/
.pageNav {
  text-align: center;
  margin: 0 auto;
  padding: 10px 0 0;
  box-sizing: border-box;
}

.pageNav a.all {
  padding: 10px;
  border-radius: 5px;
  color: #fff;
  font-size: 1.1em;
  background: #009d3d;
  margin: 0 auto;
  box-sizing: border-box;
}

.pageNav a.all:hover {
  opacity: 0.7;
}

/*フッター*/
#sub footer {
  padding-top: 10px;
  background: #ebf6f7;
}

/* お問い合わせ */
.formBox {
  width: 100%;
  height: auto;
  margin: 0 auto;
  clear: both;
}
.sent .formBox {
  display: none;
}

.required {
  color: #de0012;
}

.formBox dl {
  width: 100%;
  height: auto;
  margin: 0 auto 10px;
}
.formBox dt {
  width: 100%;
  height: auto;
  margin: 0 auto 5px;
  font-size: 1.1em;
  font-weight: bold;
}
.formBox dt .required {
  margin: 0 0 0 5px;
}

.formBox dd {
  width: 100%;
  height: auto;
  margin: 0 auto;
}

.formBox dl.submitBox {
  padding: 10px 0 0;
}
/*.formBox dl.submitBox dd {
	display: inline-block;
	margin: 0 20px 0 0;
}*/

input,
button,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  -ms-appearance: none;
  -o-appearance: none;
  appearance: none;
  outline: none;
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  font-size: 1em;
  cursor: pointer;
}

.formBox :focus {
  box-shadow: 0 0 6px 0 rgba(0, 155, 12, 0.5);
  border: 1px solid #009d3d !important;
}

input[type="text"],
input[type="email"],
input[type="tel"],
textarea {
  width: 100%;
  padding: 10px;
  background: #fff;
  border: 1px solid #999;
  border-radius: 3px;
  box-sizing: border-box;
}

textarea {
  height: 180px;
}

input[type="submit"],
input[type="reset"],
input[type="button"] {
  padding: 5px 15px;
  border: 1px solid #009d3d;
  width: auto;
  cursor: pointer;
  transition: all 0.5s;
  -webkit-transition: all 0.5s;
  font-size: 1.1em;
  box-sizing: border-box;
  display: inline-block;
  margin: 0 20px 0 0;
}

input[type="submit"] {
  background: #009d3d;
  color: #fff;
}
input[type="reset"],
input[type="button"] {
  background: #fff;
  color: #009d3d;
}

input[type="submit"]:hover,
input[type="reset"]:hover,
input[type="button"]:hover {
  opacity: 0.7;
}

input[type="text"]:-webkit-autofill,
input[type="email"]:-webkit-autofill,
input[type="tel"]:-webkit-autofill,
textarea:-webkit-autofill {
  background-color: #fff !important;
  background-image: none;
  color: #333 !important;
}
.wpcf7c-conf {
  background-color: rgb(250, 255, 189) !important;
  color: #333 !important;
  border: 1px solid #999 !important;
}

/* recaptcha バッヂ左表示 */
.grecaptcha-badge {
  width: 70px !important;
  overflow: hidden !important;
  transition: all 0.3s ease !important;
  left: -2px !important;
  z-index: 9999;
}
.grecaptcha-badge:hover {
  width: 256px !important;
}

@media screen and (max-width: 1023px) {
  #sub .inBox {
    position: relative;
    width: 100%;
    margin: 0 auto;
  }

  .content {
    padding-top: 0;
  }

  /*#sub.subpage .content {
	padding-top: 90px;
}*/

  #sub .content:before,
  #sub .content:after {
    display: none;
  }
  #sub.subpage h2.pagetit {
    font-size: 2.5em;
    margin: 0 auto 90px;
    width: 90%;
    padding: 20px 0 0;
  }
  #sub.subpage h2.pagetit span {
    font-size: 1.5em;
    padding-left: 5px;
  }
  #sub.subpage h2.pagetit span.small {
    font-size: 1em;
    padding-left: 0;
  }

  .sidebar {
    width: 90%;
    margin: 0 auto 50px;
    padding: 0;
    float: none;
    background: none;
  }

  .sidebar .dscrpt {
    -moz-box-shadow: none;
    -webkit-box-shadow: none;
    box-shadow: none;
    margin: -50px auto 30px;
    padding: 35px 5%;
    text-align: center;
  }
  .sidebar .dscrpt h2.sidetit {
    text-align: center;
  }
  .sidebar .dscrpt h2 span {
    font-size: 24px;
  }
  .sidebar .dscrpt h2.sidetit span.small {
    font-size: 18px;
  }
  .sidebar .dscrpt h2.sidetit span.cngfont {
    font-size: 24px;
  }

  .sidebar .dscrpt .text {
    text-align: left;
  }

  .sidebar .dscrpt .add {
    font-size: 122%;
  }

  .sidebar .dscrpt .btnArea a,
  .sidebar .dscrpt .btnArea .sidebtn {
    font-size: 16px;
    padding: 7px 8% 7px 4%;
    margin: 0 3px;
  }
  .sidebar .dscrpt .btnArea .sidebtn {
    padding: 7px;
  }

  .sidebar .toDetail {
    width: 101%;
    overflow: hidden;
  }

  .sidebar .toDetail li {
    float: left;
    width: 49%;
    margin: 0 1% 5px 0;
  }

  .sidebar .toDetail li.parent {
    float: none;
    width: 100%;
    margin: 0 auto 5px;
    clear: both;
  }
  .sidebar .toDetail li.fl_clear:after {
    content: "";
    display: block;
    clear: both;
  }

  #sub .subvisual {
    width: 100%;
    float: none;
  }

  #sub .subvisual section {
    margin-bottom: 0;
  }
  #sub .subvisual section ul {
    padding-left: 0;
  }
  #sub .bx-wrapper .bx-pager {
    display: none;
  }

  .mainArea {
    width: 90%;
    float: none;
    margin: 0 auto;
  }

  #sub footer {
    background: #fff;
  }
}

@media screen and (max-width: 767px) {
  /* .gallery ul li {
    height: 155px;
  } */
  /* .gallery ul li .thum {
    height: 100px;
  } */

  #sub section table {
    width: 100%;
    margin: 0 auto 20px;
  }
}

@media screen and (max-width: 479px) {
  #sub.subpage h2.pagetit {
    font-size: 1.8em;
    margin: 0 auto 60px;
    line-height: 1.4em;
  }
  #sub.subpage h2.pagetit span {
    display: block;
    font-size: 1.4em;
    padding-left: 0;
  }
  #sub.subpage h2.pagetit br {
    display: none;
  }

  .sidebar .dscrpt {
    padding: 35px 5% 20px;
    margin: -20px auto 30px;
  }

  .sidebar .toDetail li a {
    font-size: 14px;
  }
  .sidebar .toDetail li a:after {
    display: none;
  }

  .gallery ul li {
    float: left;
    width: 47%;
    margin: 0 3% 15px 0;
    /* height: 160px; */
  }

  /* .gallery ul li .thum {
    height: 110px;
  } */

  .gallery.single ul li {
    height: auto;
    margin: 0 3% 5px 0;
  }

  .gallery.single ul li .thum {
    height: auto;
  }

  #sub section table th,
  #sub section table td {
    display: block;
  }

  /* img */
  .post_wrap .aligncenter,
  .aligncenter {
    display: block;
    margin: 0 auto;
  }

  .post_wrap .alignright,
  .alignright,
  .post_wrap .alignleft,
  .alignleft,
  .post_wrap .aligncenter,
  .aligncenter {
    float: none;
    margin: 0 auto 1em;
    display: block;
    text-align: center;
  }

  .post_wrap img[class*="wp-image-"],
  .post_wrap img[class*="attachment-"] {
    height: auto;
    max-width: 100%;
    width: auto;
    margin: 0 auto 0.5em;
  }
  .post_wrap .wp-caption img[class*="wp-image-"] {
    margin: 0 auto;
  }

  .post_wrap .wp-caption {
    width: auto !important;
    max-width: 100% !important;
    margin: 0 auto 0.5em;
  }

  #sub section table.recruit {
    width: 100%;
    border-top: none;
    border-bottom: 1px solid #ddd;
  }

  #sub section table.recruit th,
  #sub section table.recruit td {
    display: block;
    /* width: 96%; */
    width: 100%;
    padding: 7px 4%;
    min-width: inherit;
    vertical-align: middle;
    border-left: 1px solid #ddd;
    border-right: 1px solid #ddd;
  }

  #sub section table.recruit th {
    border-top: 1px solid #ddd;
  }

  #sub section table.recruit td {
    border-bottom: none;
  }

  #sub section .leftbox {
    float: none;
    width: 100%;
  }

  #sub section .rightbox {
    float: none;
    width: 100%;
    text-align: center;
  }

  #sub section .rightbox img {
    max-width: 300px;
  }

  #sub section .leftbox .message {
    width: 90%;
    padding: 1.2em 2%;
    margin: 0 auto 1em;
  }
}

@media screen and (max-width: 320px) {
  .sidebar .dscrpt .btnArea a {
    font-size: 16px;
    padding: 7px 8% 7px 4%;
    margin: 0 3px 5px;
  }

  .sidebar .toDetail li {
    float: none;
    width: 100%;
    margin: 0 0 5px 0;
  }
}
