@charset "UTF-8";
body {
  font-family: "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","メイリオ",Meiryo,"ＭＳ Ｐゴシック","MS PGothic",sans-serif;
  overflow: hidden;
}

figcaption{
  font-size: 12px;
}

a{
  color: #008a2a;
}

.breadcrumbs {
  width: auto;
  margin-right: auto;
  margin-left: auto;
  *zoom: 1;
  padding: 19px 22px;
  margin-bottom: 5px !important;
  *zoom: 1;
  color: #fff;
}

@media screen and (max-width: 767px) {
  .breadcrumbs {
    padding: 19px 22px;
  }
}

.breadcrumbs a {
  text-decoration: none;
}

.breadcrumbs:before, .breadcrumbs:after {
  display: table;
  content: "";
  line-height: 0;
}

.breadcrumbs:after {
  clear: both;
}

.breadcrumbs:before, .breadcrumbs:after {
  display: table;
  content: "";
  line-height: 0;
}

.breadcrumbs:after {
  clear: both;
}

.breadcrumbs span {
  font-size: 12px;
  color: #fff;
  margin-right: 2px;
  margin-left: 2px;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .breadcrumbs span {
    font-size: 16px;
  }
}

@media screen and (max-width: 500px) {
  .breadcrumbs span {
    font-size: 12px;
  }
}

.breadcrumbs span:first-child {
  margin-left: 0;
}

.breadcrumbs span:last-child {
  background: none;
}

.breadcrumbs span a {
  color: #fff;
}

.container {
  margin: 0 auto;
  max-width: 805px;
  padding: 0 15px;
}

@media screen and (max-width: 767px) {
  .container {
    padding: 0 40px;
  }
}

@media screen and (max-width: 500px) {
  .container {
    padding: 0 15px;
  }
}

/* ●●●●　↓ギャラリー動画↓　●●●● */
.flex-box .movie_box {
	display: block;
	
	position: relative;
	width: 100%!important;
	padding-top: 56.25%;
	
	margin-bottom: 50px!important;
}
.flex-box .movie_box iframe {
	position: absolute;
	top: 0;
	right: 0;
	width: 100%;
	height: 100%;
}
/* ●●●●　↑ギャラリー動画↑　●●●● */

/* ●●●●　↓糺の森について　動画↓　●●●● */
.movie_box {
	display: block;
	
	position: relative;
	width: 100%!important;
	padding-top: 56.25%;
	
	margin-top: 50px!important;
}
.movie_box iframe {
	position: absolute;
	top: 0;
	right: 0;
	width: 100%;
	height: 100%;
}
/* ●●●●　↑糺の森について　動画↑　●●●● */




.flex-box {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.flex-box.flex1 {
  align-items: center;
}

.flex-box.flex2{
  align-items: flex-start;
}

.flex-box.flex3 > *{
  width: 25.290322%;
}

.flex-box .text {
  width: 64.5%;
}

.flex-box .img {
  width: 29.6%;
  min-width: 160px;
}

.flex-box .img img {
  width: 100%;
}

@media screen and (max-width: 767px) {
  .flex-box.flex1 {
    flex-direction: column;
  }
  .flex-box.flex1 .text {
    width: 100%;
  }
  .flex-box.flex1 .img {
    width: 100%;
    margin-top: 60px;
  }
}

@media screen and (max-width: 500px) {
  .flex-box.flex3 > *{
    width: 47%;
  }
}

li {
  list-style: none;
}

a:hover {
  opacity: 0.8;
}

a.is-clickable{
  color: #333;
  text-decoration: none;
  font-size: 14px;
  font-weight: bold;
}
a.is-clickable span{
  font-weight: normal;
}

.sm-block {
  display: none;
}

@media screen and (max-width: 500px) {
  .sm-block {
    display: block;
  }
}

.sp-block {
  display: none;
}

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

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

.tac {
  text-align: center;
}

.tar {
  text-align: right;
}

.tal {
  text-align: left;
}

.mt5 {
  margin-top: 5px;
}

.mt10 {
  margin-top: 10px;
}

.mt15 {
  margin-top: 15px;
}

.mt20 {
  margin-top: 20px;
}

.mt30 {
  margin-top: 30px;
}

.mt40 {
  margin-top: 40px;
}

.mt60 {
  margin-top: 60px;
}

.mt70 {
  margin-top: 70px;
}

.mt80 {
  margin-top: 80px;
}

.mt160 {
  margin-top: 160px;
}

.fc-key{
  color: #008a2a;
}

.size-full{
  max-width: 100%;
}

.link01 {
  font-size: 14px;
  font-weight: bold;
  color: #008a2a;
  line-height: 1.429;
  text-decoration: none;
  display: inline-block;
  position: relative;
  vertical-align: middle;
}

@media screen and (max-width: 767px) {
  .link01 {
    font-size: 20px;
  }
}

@media screen and (max-width: 500px) {
  .link01 {
    font-size: 16px;
  }
}

.link01:before {
  position: absolute;
  top: 0;
  left: -25px;
  margin: auto;
  content: "";
  vertical-align: middle;
  top: 0;
  box-sizing: border-box;
  width: 20px;
  height: 20px;
  border: 1px solid #59a871;
  -webkit-border-radius: 50%;
  border-radius: 50%;
  background: #fff;
}

@media screen and (max-width: 767px) {
  .link01:before {
    width: 25px;
    height: 25px;
    left: -35px;
    top: 2px;
  }
}

@media screen and (max-width: 500px) {
  .link01:before {
    width: 22px;
    height: 22px;
    left: -35px;
    top: 0;
  }
}

.link01:after {
  position: absolute;
  top: 6px;
  left: -20px;
  margin: auto;
  content: "";
  vertical-align: middle;
  width: 8px;
  height: 8px;
  border-top: 2px solid #008a2a;
  border-right: 2px solid #008a2a;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

@media screen and (max-width: 767px) {
  .link01:after {
    left: -29px;
    top: 9px;
    width: 10px;
    height: 10px;
  }
}

@media screen and (max-width: 500px) {
  .link01:after {
    left: -30px;
    top: 7px;
    width: 9px;
    height: 9px;
  }
}

.link02 {
  font-size: 14px;
  font-weight: bold;
  color: #008a2a;
  line-height: 1.429;
  text-decoration: none;
  display: inline-block;
  position: relative;
  vertical-align: middle;
}

@media screen and (max-width: 767px) {
  .link02 {
    font-size: 20px;
    display: block;
  }
}

@media screen and (max-width: 500px) {
  .link02 {
    font-size: 16px;
  }
}

.link02:before {
  position: absolute;
  top: 0;
  left: -25px;
  margin: auto;
  content: "";
  vertical-align: middle;
  top: 0;
  box-sizing: border-box;
  width: 20px;
  height: 20px;
  -webkit-border-radius: 50%;
  border-radius: 50%;
  background: #008a2a;
}

@media screen and (max-width: 767px) {
  .link02:before {
    width: 25px;
    height: 25px;
    left: -35px;
    top: 2px;
  }
}

@media screen and (max-width: 500px) {
  .link02:before {
    width: 22px;
    height: 22px;
    left: -35px;
    top: 0;
  }
}

.link02:after {
  position: absolute;
  top: 6px;
  left: -20px;
  margin: auto;
  content: "";
  vertical-align: middle;
  width: 8px;
  height: 8px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

@media screen and (max-width: 767px) {
  .link02:after {
    left: -29px;
    top: 9px;
    width: 10px;
    height: 10px;
  }
}

@media screen and (max-width: 500px) {
  .link02:after {
    left: -30px;
    top: 7px;
    width: 9px;
    height: 9px;
  }
}

.heading {
  font-size: 24px;
  color: #333333;
  line-height: 0.833;
  font-weight: normal;
}

@media screen and (max-width: 500px) {
  .heading {
    font-size: 5vw;
  }
}

.heading small {
  display: block;
  font-size: 14px;
  font-family: "Georgia";
  color: #333333;
  line-height: 1.429;
  padding-top: 5px;
}

main {
  margin-left: 285px;
  background: #faf7ea;
  overflow: hidden;
}

@media screen and (max-width: 767px) {
  main {
    margin-left: 0;
  }
}

.sub-title {
  font-size: 20px;
  line-height: 1;
  margin-bottom: 1em;
  font-weight: normal;
  position: relative;
  display: inline-block;
}

.sub-title:before {
  content: '';
  position: absolute;
  left: 0;
  bottom: -15px;
  display: inline-block;
  width: 40px;
  height: 1px;
  background-color: #008a2a;
}

@media screen and (max-width: 767px) {
  .sub-title {
    font-size: 24px;
  }
}

@media screen and (max-width: 500px) {
  .sub-title {
    font-size: 18px;
  }
}

.com-btn-01 {
  display: block;
  font-size: 14px;
  color: #008a2a;
  line-height: 1;
  padding: 27px;
  font-weight: bold;
  border: 1px solid #008a2a;
  width: 383px;
  height: 70px;
  position: relative;
  background: #fff;
  text-decoration: none;
}

@media screen and (max-width: 500px) {
  .com-btn-01 {
    max-width: 100%;
  }
}

.com-btn-01:after {
  content: "";
  width: 8px;
  height: 8px;
  border-top: 2px solid #008a2a;
  border-right: 2px solid #008a2a;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  top: 0;
  bottom: 0;
  right: 14px;
  margin: auto;
  vertical-align: middle;
  position: absolute;
}

.com-btn-02 {
  display: block;
  padding: 15px;
  width: 250px;
  background: #008a2a;
  color: #fff;
  font-size: 14px;
  font-weight: bold;
  border-radius: 8px;
  margin: 30px auto 0;
}

.com-btn-03 {
  display: block;
  padding: 19px;
  width: 100%;
  max-width: 500px;
  background: #008a2a;
  color: #fff;
  font-size: 20px;
  padding: 29px 0;
  font-weight: bold;
  border-radius: 8px;
  margin: 40px auto 0;
  line-height: 1;
  text-align: center;
  text-decoration: none;
}

@media screen and (max-width: 500px) {
  .com-btn-03 {
    font-size: 16px;
  }
}

.com-btn-03 span {
  font-size: 24px;
}

@media screen and (max-width: 500px) {
  .com-btn-03 span {
    font-size: 20px;
  }
}

.com-btn-04 {
  display: block;
  line-height: 1;
  padding: 15px 0;
  text-align: center;
  font-size: 14px;
  background: #fff;
  color: #008a2a;
  border: 2px solid #008a2a;
  text-decoration: none;
  width: 250px;
  max-width: 90%;
  position: relative;
}

.com-btn-04:after {
  content: "";
  width: 8px;
  height: 8px;
  border-top: 2px solid #008a2a;
  border-right: 2px solid #008a2a;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  top: 0;
  bottom: 0;
  right: 20px;
  margin: auto;
  vertical-align: middle;
  position: absolute;
}

@media screen and (max-width: 500px) {
  .com-btn-04:after {
    right: 8px;
  }
}

.com-btn-05 {
  display: inline-block;
  padding: 15px 50px;
  max-width: 250px;
  background: #008a2a;
  color: #fff;
  font-size: 14px;
  font-weight: bold;
  border-radius: 8px;
  text-decoration: none;
  text-align: center;
}

@media screen and (max-width: 500px){
  .com-btn-05{
    display: block;
    margin-top: 10px;
  }
}

.com-tit-01 {
  font-size: 24px;
  color: #333333;
  line-height: 1.5;
  font-weight: normal;
}

.com-tit-02 {
  font-size: 16px;
  color: #008a2a;
  font-weight: bold;
  padding-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .com-tit-02 {
    font-size: 20px;
  }
}

@media screen and (max-width: 767px) {
  .com-tit-02 {
    font-size: 18px;
  }
}

.com-tit-03 {
  font-size: 20px;
  color: #333333;
  line-height: 1;
  margin-bottom: 1em;
  font-weight: normal;
  position: relative;
  display: inline-block;
}

.com-tit-03:before {
  content: '';
  position: absolute;
  left: 0;
  bottom: -15px;
  display: inline-block;
  width: 40px;
  height: 1px;
  background-color: #008a2a;
}

@media screen and (max-width: 767px) {
  .com-tit-03 {
    font-size: 24px;
  }
}

.com-tit-04 {
  font-size: 20px;
}

@media screen and (max-width: 767px) {
  .com-tit-04 {
    font-size: 30px;
  }
}

@media screen and (max-width: 500px) {
  .com-tit-04 {
    font-size: 20px;
  }
}

.com-tit-05 {
  font-size: 24px;
  display: block;
  line-height: 1.5;
  padding-bottom: 34px;
  border-bottom: 2px solid #008a2a;
  font-weight: normal;
}

@media screen and (max-width: 767px) {
  .com-tit-05 {
    padding-bottom: 30px;
  }
}

@media screen and (max-width: 500px) {
  .com-tit-05 {
    font-size: 20px;
  }
}

.com-tit-06{
  background: #008a2a;
  color: #fff;
  font-size: 16px;
  font-weight: normal;
  padding: 16px 0;
}

.com-tit-07{
  border-bottom: 1px solid #333;
  margin-bottom: 20px;
  padding-bottom: 10px;
  text-align: left;
}
.com-tit-07:not(:first-child){
  margin-top: 60px;
}

.com-tit-08{
  margin-top: 20px;
  text-align: left;
}
.com-tit-08:before{
  content: '●';
}

.com-txt-ib {
  display: inline-block;
}

.com-txt-01 {
  font-size: 14px;
  color: #333333;
  line-height: 1.714;
}

@media screen and (max-width: 767px) {
  .com-txt-01 {
    font-size: 20px;
  }
}

@media screen and (max-width: 500px) {
  .com-txt-01 {
    font-size: 17px;
  }
}

.com-list-01 {
  display: table;
  border-bottom: 1px solid #b8b8b8;
  box-sizing: border-box;
  width: 100%;
}

.com-list-01:first-of-type {
  border-top: 1px solid #b8b8b8;
}

.com-list-01 dt {
  width: 200px;
  background: #faf7ea;
  font-size: 14px;
  font-weight: bold;
  line-height: 1.2;
  padding: 23px 0 23px 20px;
  vertical-align: middle;
  display: table-cell;
}
#gokenboku {

	padding-top: 20px;
	display: block;

	}

#gokenboku .com-list-01 dt {
  width: 400px;
}

.tree_form .com-list-01 dt {
  width: 450px;
}
.tree_form .tree_form_t {
	font-size: 110%!important;
	font-weight: bold;
	padding-top: 20px;
}
.tree_form dt span {
	font-size: 120%;
}
.tree_form dt {
	background-color: #ece8d6;
}
.tree_form dd {
	font-size: 110%!important;
}

@media screen and (max-width: 767px) {
  .com-list-01 dt {
    width: 150px;
    font-size: 20px;
    padding: 20px 0 20px 20px;
	}
	#gokenboku {
	margin-top: -30px;
	padding-top: 30px;
	}
	#gokenboku .com-list-01 dt {
	width: 220px!important;
	padding: 20px 10px 20px 20px;
	}
}

@media screen and (max-width: 500px) {
  .com-list-01 dt {
    width: 115px;
    font-size: 14px;
    padding: 23px 0 20px 10px;
	}
	#gokenboku .com-list-01 dt {
	width: 220px!important;
	padding: 23px 10px 20px 10px;
	}
	.tree_form .com-list-01 dt {
	width: 220px!important;
	padding: 23px 10px 20px 10px;
	}
}

.com-list-01 dd {
  width: calc(100% - 200px);
  background: #fff;
  font-size: 14px;
  font-weight: normal;
  line-height: 1.2;
  padding: 23px 0 23px 20px;
  vertical-align: middle;
  display: table-cell;
}

@media screen and (max-width: 767px) {
  .com-list-01 dd {
    width: calc(100% - 150px);
    font-size: 20px;
    padding: 20px 0 20px 20px;
  }
}

@media screen and (max-width: 500px) {
  .com-list-01 dd {
    font-size: 14px;
    padding: 23px 0 20px 10px;
    width: calc(100% - 115px);
  }
}

@media screen and (max-width: 767px) {
  .com-list-01 dd.small {
    font-size: 15px;
  }
}

@media screen and (max-width: 500px) {
  .com-list-01 dd.small {
    font-size: 11px;
  }
}

.sns-icons {
  padding-top: 30px;
}

.sns-icons ul {
  display: flex;
  justify-content: space-between;
  width: 290px;
  margin: 20px auto 80px;
}

.table-01{
  width: 100%;
  border-collapse: collapse;
}

.table-01 th,
.table-01 td{
  font-size: 14px;
  padding: 10px 0 10px 1em;
  border-bottom: 1px solid #dfdfdf;
  text-align: left;
}

.table-01 thead th{
  background-color: #faf7ea;
  border-top: 1px solid #dfdfdf;
}

.table-01 tbody th{
  font-weight: normal;
}

.table-01 .ttl{
  width: 20%;
}

.table-01 .name{
  width: 30%;
}

/* ヘッダー
----------------------------------------------- */
#header .pc-header {
  font-size: 15px;
  width: 285px;
  height: 675px;
  position: fixed;
  top: 0;
  left: 0;
  background: #fff;
  text-align: center;
  z-index: 20;
}

@media screen and (max-width: 767px) {
  #header .pc-header {
    display: none;
  }
}

#header .pc-header .brand-logo {
  margin: 10px 10px 15px 10px;
  background: #005936;
  width: 265px;
  height: 260px;
  padding: 33px 0;
}

#header .pc-header .brand-logo a {
  text-decoration: none;
  color: #fff;
  display: block;
}

#header .pc-header .brand-logo a:hover {
  opacity: 0.8;
}

#header .pc-header .brand-logo a p {
  font-size: 13px;
  line-height: 1.692;
  margin-bottom: 20px;
  letter-spacing: 5px;
}

#header .pc-header .brand-logo a p span {
  letter-spacing: 7px;
}

#header .pc-header .brand-logo a img {
  width: 127px;
}

#header .pc-header .brand-logo a h1 {
  font-size: 24px;
  font-weight: normal;
}

#header .pc-header #global-nav a {
  display: block;
}

#header .pc-header #global-nav .menu li {
  position: relative;
}

#header .pc-header #global-nav .menu li:last-child {
  margin-bottom: 15px;
}

#header .pc-header #global-nav .menu li a {
  font-size: 14px;
  color: #333333;
  text-decoration: none;
  font-weight: bold;
  line-height: 1;
  padding: 1.45vh 0;
}

#header .pc-header #global-nav .menu > .menu-item-has-children > a {
  position: relative;
}

#header .pc-header #global-nav .menu > .menu-item-has-children > a:after {
  content: url(../img/common/plus.png);
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  padding-left: 9px;
}

#header .pc-header #global-nav .menu > .menu-item-has-children:hover > .sub-menu {
  width: 285px;
}

#header .pc-header #global-nav .menu > .menu-item-has-children > .sub-menu {
  position: fixed;
  background: #005936;
  color: #fff;
  top: 0;
  padding-top: 195px;
  left: 285px;
  width: 0;
  height: 675px;
  display: block;
  overflow: hidden;
  -moz-transition: width .3s ease-out;
  -webkit-transition: width .3s ease-out;
  transition: width .3s ease-out;
  text-align: left;
}

#header .pc-header #global-nav .menu .menu-item-has-children .sub-menu li {
  width: 285px;
  padding-left: 40px;
}

#header .pc-header #global-nav .menu .menu-item-has-children .sub-menu li a {
  color: #fff;
  padding: 13px 0;
  font-weight: normal;
}

#header .pc-header #global-nav .sns-icon {
  display: flex;
  justify-content: center;
  height: 53px;
}

#header .pc-header #global-nav .sns-icon li {
  margin: 0 7.5px;
  margin-bottom: 30px;
}

#header .pc-header #global-nav .menu-nav-bottom {
  display: flex;
}

#header .pc-header #global-nav .menu-nav-bottom li {
  width: 50%;
}

#header .pc-header #global-nav .menu-nav-bottom li:first-child {
  border-right: 2px solid #fff;
}

#header .pc-header #global-nav .menu-nav-bottom li:first-child a {
  padding: 17px 0 15px 13px;
}

#header .pc-header #global-nav .menu-nav-bottom li a {
  display: block;
  background: #008a2a;
  width: 142px;
  height: 70px;
  text-decoration: none;
  color: #fff;
  padding: 27px 0 29px 18px;
  text-align: left;
  letter-spacing: -0.05em;
  position: relative;
  line-height: 1.2;
}

#header .pc-header #global-nav .menu-nav-bottom li a small {
	font-size: 12px;
	margin-top: 7px!important;
	display: block;
}

#header .pc-header #global-nav .menu-nav-bottom li a:after {
  content: "";
  width: 8px;
  height: 8px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  top: 0;
  bottom: 0;
  right: 10px;
  margin: auto;
  vertical-align: middle;
  position: absolute;
}

#header .sp-header {
  display: none;
  height: 110px;
  background: #005936;
}

@media screen and (max-width: 767px) {
  #header .sp-header {
    display: block;
  }
}

@media screen and (max-width: 500px) {
  #header .sp-header {
    height: 80px;
  }
}

.sp-header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  width: 100%;
}

.sp-menu {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  padding: 0 20px;
  z-index: 30;
  height: 110px;
  box-sizing: border-box;
}

@media screen and (max-width: 500px) {
  .sp-menu {
    height: 80px;
  }
}

.sp-menu img {
  width: 300px;
}

.sp-menu .brand-logo-s {
  width: 46.8%;
  min-width: 200px;
  max-width: 300px;
}

.sp-menu .brand-logo-s img {
  width: 100%;
}

.menu-trigger {
  display: inline-block;
  position: relative;
  width: 60px;
  vertical-align: middle;
  cursor: pointer;
  z-index: 30;
  height: 110px;
}

@media screen and (max-width: 500px) {
  .menu-trigger {
    height: 80px;
  }
}

.menu-trigger span {
  display: inline-block;
  box-sizing: border-box;
  position: absolute;
  left: 0;
  width: 100%;
  height: 7px;
  background-color: #fff;
  transition: all .5s .2s;
}

@media screen and (max-width: 500px) {
  .menu-trigger span {
    width: 80%;
    height: 5px;
  }
}

.menu-trigger.active span {
  background-color: #fff;
}

.menu-trigger span:nth-of-type(1) {
  top: 30px;
}

@media screen and (max-width: 500px) {
  .menu-trigger span:nth-of-type(1) {
    top: 18px;
  }
}

.menu-trigger.active span:nth-of-type(1) {
  transform: translateY(12px) rotate(-45deg);
}

@media screen and (max-width: 500px) {
  .menu-trigger.active span:nth-of-type(1) {
    transform: translateY(19px) rotate(-45deg);
  }
}

.menu-trigger span:nth-of-type(2) {
  top: 50px;
}

@media screen and (max-width: 500px) {
  .menu-trigger span:nth-of-type(2) {
    top: 35px;
  }
}

.menu-trigger.active span:nth-of-type(2) {
  opacity: 0;
}

.menu-trigger span:nth-of-type(3) {
  top: 70px;
}

@media screen and (max-width: 500px) {
  .menu-trigger span:nth-of-type(3) {
    top: 52px;
  }
}

.menu-trigger.active span:nth-of-type(3) {
  transform: translateY(-27px) rotate(45deg);
}

@media screen and (max-width: 500px) {
  .menu-trigger.active span:nth-of-type(3) {
    transform: translateY(-15px) rotate(45deg);
  }
}

.sp-nav {
  width: 72%;
  background-color: #005936;
  color: #fff;
  text-align: center;
  display: none;
  position: fixed;
  top: 110px;
  right: 0;
  z-index: 10;
}

#mask {
  display: none;
  transition: all .5s;
}

#mask.active {
  display: block;
  position: fixed;
  top: 110px;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  opacity: .8;
  z-index: 15;
  cursor: pointer;
}

@media screen and (max-width: 500px) {
  .sp-nav,
  #mask.active {
    top: 70px;
  }
}

.sp-nav .menu {
  padding: 0 20px;
}

.sp-nav .menu li {
  padding: 15px 20px;
  text-align: left;
  line-height: 1;
}

.sp-nav .menu li a {
  font-size: 16px;
  text-decoration: none;
  color: #fff;
}

.sp-nav .menu .menu-item-88,
.sp-nav .menu .menu-item-89,
.sp-nav .menu .menu-item-90 {
  padding: 7px 20px;
}

.sp-nav .menu .menu-item-88:nth-of-type(8),
.sp-nav .menu .menu-item-89:nth-of-type(8),
.sp-nav .menu .menu-item-90:nth-of-type(8) {
  padding-top: 30px;
}

.sp-nav .menu .menu-item-88:nth-of-type(10),
.sp-nav .menu .menu-item-89:nth-of-type(10),
.sp-nav .menu .menu-item-90:nth-of-type(10) {
  padding-bottom: 50px;
}

.sp-nav .menu .menu-item-88 a,
.sp-nav .menu .menu-item-89 a,
.sp-nav .menu .menu-item-90 a {
  font-size: 14px;
}

.sp-nav .menu .menu-item {
  border-bottom: 1px solid #fff;
}

.sp-nav .menu .menu-item:first-child {
  border-top: 1px solid #fff;
  margin-top: 40px;
}

.sp-nav .menu .menu-item:nth-of-type(8), .sp-nav .menu .menu-item:nth-of-type(9), .sp-nav .menu .menu-item:nth-of-type(10) {
  border: none;
}

.sp-nav li.menu-item-has-children {
  position: relative;
}

.sp-nav li.menu-item-has-children > a {
  position: relative;
}

.sp-nav .accordionBtn {
  display: block;
  position: absolute;
  top: 15px;
  right: 20px;
}

.sp-nav .accordionBtn.active {
  top: 15px;
  right: 20px;
}

.sp-nav .accordionBtn:before {
  content: "\f067";
  font-family: "Font Awesome 5 Free";
  font-weight: 600;
}

.sp-nav .accordionBtn.active:before {
  content: "\f068";
  font-family: "Font Awesome 5 Free";
  font-weight: 600;
}

.sp-nav .menu .sub-menu {
  padding: 0 20px 5px;
}

.sp-nav .menu > li > .sub-menu {
  padding-top: 30px;
}

.sp-nav .menu > li > .sub-menu .menu-item {
  border: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.sp-nav .sub-menu .menu-item a {
  display: block;
  padding-bottom: 16px;
  font-size: 14px;
  font-weight: normal;
}

.sp-nav .menu .open > .sub-menu {
  display: block;
}

/* フッター
----------------------------------------------- */
footer {
  margin-left: 285px;
  background: #faf7ea;
}

@media screen and (max-width: 767px) {
  footer {
    margin-left: 0;
  }
}

footer .pagetop {
  background-color: #32a256;
  width: 43px;
  height: 43px;
  position: fixed;
  bottom: 13px;
  right: 26px;
  z-index: 10;
  border-radius: 50%;
}

footer .pagetop a {
  position: relative;
  display: block;
  width: 43px;
  height: 43px;
  text-decoration: none;
}

footer .pagetop a:after {
  content: "";
  width: 12px;
  height: 12px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  top: 0;
  bottom: -6px;
  right: 0;
  left: 0;
  margin: auto;
  position: absolute;
}

footer .sns-icons {
  padding-top: 30px;
}

footer .sns-icons ul {
  display: flex;
  justify-content: space-between;
  width: 290px;
  margin: 20px auto 80px;
}

@media screen and (max-width: 767px) {
  footer .menu-nav-bottom {
    display: flex;
  }
}

footer .menu-nav-bottom li {
  width: 50%;
}

footer .menu-nav-bottom li:first-child {
  border-right: 2px solid #fff;
}

@media screen and (max-width: 500px) {
  footer .menu-nav-bottom li:first-child a {
    padding: 16px 0 16px 20px;
  }
}

footer .menu-nav-bottom li a {
  display: block;
  background: #008a2a;
  height: 100px;
  text-decoration: none;
  color: #fff;
  padding: 40px 0 40px 13.3%;
  text-align: left;
  letter-spacing: -0.05em;
  position: relative;
}

footer .menu-nav-bottom li a:after {
  content: "";
  width: 8px;
  height: 8px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  top: 0;
  bottom: 0;
  right: 20px;
  margin: auto;
  vertical-align: middle;
  position: absolute;
}

@media screen and (max-width: 500px) {
  footer .menu-nav-bottom li a:after {
    right: 10px;
  }
}

@media screen and (max-width: 500px) {
  footer .menu-nav-bottom li a {
    height: 80px;
    padding: 28px 0 28px 20px;
  }
}

footer .footer-nav {
  background: url(../img/common/footer-bg.png) no-repeat center/cover;
  padding: 3.5% 0;
}

footer .footer-nav .menu {
  width: 33.3333%;
  padding-left: 3.5%;
  border-right: 1px solid #fff;
}

footer .footer-nav .menu:last-of-type {
  border: none;
}

footer .footer-nav .menu .menu-item a {
  font-size: 14px;
  color: white;
  line-height: 2.286;
  text-decoration: none;
  font-weight: bold;
}

footer .footer-nav .menu .menu-item .sub-menu {
  padding: 0 5% 0 8%;
}

footer .footer-nav .menu .menu-item .sub-menu a {
  font-weight: normal;
  line-height: 1.7;
}

footer .footer-nav .menu .menu-item-58 {
  margin-top: 25px;
}

footer .footer-nav .menu .menu-item-71 {
  margin-top: 20px;
}

footer .footer-info {
  padding: 35px 0;
}

footer .footer-info h2 {
  font-size: 14px;
  color: #333333;
  padding-bottom: 15px;
}

@media screen and (max-width: 767px) {
  footer .footer-info h2 {
    font-size: 20px;
  }
}

@media screen and (max-width: 767px) {
  footer .footer-info ul {
    flex-direction: column;
  }
}

footer .footer-info ul li {
  width: 50%;
  font-size: 14px;
  color: #333333;
  line-height: 1.429;
}

@media screen and (max-width: 767px) {
  footer .footer-info ul li {
    margin-bottom: 30px;
    width: 100%;
  }
  footer .footer-info ul li:last-child {
    margin-bottom: 0;
  }
}

footer .copyright {
  background: #fff;
  padding: 20px 0;
}

footer .copyright p {
  font-size: 12px;
  color: #333333;
  line-height: 1.667;
}

/* ホーム
----------------------------------------------- */
.ZoomSlide {
  width: 100%;
  height: 675px;
  z-index: 0;
  overflow: hidden;
}

@media screen and (max-width: 767px) {
  .ZoomSlide {
    height: 450px;
  }
}

.ZoomSlide .SImg {
  width: 100%;
  height: 675px;
  position: absolute;
  color: transparent;
  background-repeat: none;
  opacity: 0;
  z-index: 0;
  　　-webkit-backface-visibility: hidden;
  -webkit-animation: ImgAnime 18s linear infinite 0s;
  -moz-animation: ImgAnime 18s linear infinite 0s;
  -o-animation: ImgAnime 18s linear infinite 0s;
  -ms-animation: ImgAnime 18s linear infinite 0s;
  animation: ImgAnime 18s linear infinite 0s;
}

@media screen and (max-width: 767px) {
  .ZoomSlide .SImg {
    height: 450px;
  }
}

.ZoomSlide .SImg:nth-child(1) {
  background: url(../img/top/keyvisual01.jpg) no-repeat;
  background-position: center;
  background-size: cover;
}

@media screen and (max-width: 767px) {
  .ZoomSlide .SImg:nth-child(1) {
    background-position: center -80px;
  }
}

.ZoomSlide .SImg:nth-child(2) {
  background: url(../img/top/keyvisual02.jpg) no-repeat;
  background-position: center;
  background-size: cover;
  -webkit-animation-delay: 6s;
  -moz-animation-delay: 6s;
  -o-animation-delay: 6s;
  -ms-animation-delay: 6s;
  animation-delay: 6s;
}

@media screen and (max-width: 767px) {
  .ZoomSlide .SImg:nth-child(2) {
    background-position: center -80px;
  }
}

.ZoomSlide .SImg:nth-child(3) {
  background: url(../img/top/keyvisual03.jpg) no-repeat;
  background-position: center;
  background-size: cover;
  -webkit-animation-delay: 12s;
  -moz-animation-delay: 12s;
  -o-animation-delay: 12s;
  -ms-animation-delay: 12s;
  animation-delay: 12s;
}

@media screen and (max-width: 767px) {
  .ZoomSlide .SImg:nth-child(3) {
    background-position: center -80px;
  }
}

@keyframes ImgAnime {
  0% {
    opacity: 1;
    transform: scale(1);
  }
  16% {
    opacity: 1;
  }
  40% {
    opacity: 1;
  }
  50% {
    opacity: 0;
    transform: scale(1.08);
    z-index: 2;
  }
  100% {
    opacity: 0;
  }
}

#keyvisual {
  height: 675px;
  position: relative;
  overflow: hidden;
}

@media screen and (max-width: 767px) {
  #keyvisual {
    margin-top: 110px;
    height: 450px;
  }
}

@media screen and (max-width: 500px) {
  #keyvisual {
    margin-top: 80px;
  }
}

#keyvisual .title {
  background-color: #005936;
  width: 95%;
  max-width: 600px;
/*  padding: 40px 30px;*/
  position: absolute;
  right: 0;
  bottom: 260px;
  z-index: 10;
}

#keyvisual .title a {
  display: flex;
  padding: 40px 40px 40px 10px;
  text-decoration: none;
  position: relative;
}

#keyvisual .title a .arrow_title {
  position: absolute;
  top: 50%;
  right: 10px;
  -webkit-transform : translateY(-50%);
  transform : translateY(-50%);
}

@media screen and (max-width: 767px) {
  #keyvisual .title {
    max-width: 100%;
    width: 100%;
    bottom: 0;
    top: none;
  }
}

@media screen and (max-width: 500px) {
  #keyvisual .title {
/*    padding: 20px 15px;*/
  }
  #keyvisual .title a {
    padding: 20px 25px 20px 5px;
  }
  #keyvisual .title a .arrow_title {
    width: 26px;
    height: 26px;
    right: 4px;
  }
}

#keyvisual .title h2 {
  text-align: right;
  margin: 0 12px 0 auto;
  font-weight: normal;
  font-size: 26px;
  color: white;
  line-height: 1.2;
}

@media screen and (max-width: 767px) {
  #keyvisual .title h2 {
    font-size: 4.0625vw;
  }
}

@media screen and (max-width: 500px) {
  #keyvisual .title h2 {
    font-size: 4vw;
  }
}

#keyvisual .title h2 small {
  display: block;
  font-size: 18px;
  font-family: "Georgia";
  padding-top: 5px;
}

@media screen and (max-width: 767px) {
  #keyvisual .title h2 small {
    font-size: 2.8125vw;
  }
}

@media screen and (max-width: 500px) {
  #keyvisual .title h2 small {
    font-size: 3.8vw;
  }
}

#home-01 .container .news {
  margin-top: 20px;
}

#home-01 .container .news a {
  text-decoration: none;
  background: #fff;
  width: calc(33.333% - 40px * 2/3);
}

#home-01 .container .news a img {
  vertical-align: middle;
  width: 100%;
  height: 160px;
  object-fit: cover;
  object-position: top;
  font-family: 'object-fit: cover; object-position: top;';
}

#home-01 .container .news a .text {
  display: block;
  text-decoration: none;
  padding: 15px 15px 20px 20px;
}

#home-01 .container .news a .text .date {
  font-size: 14px;
  color: #333333;
  line-height: 1.429;
  font-weight: bold;
}

#home-01 .container .news a .text .desc {
  font-size: 14px;
  margin-top: 10px;
  color: #333333;
  line-height: 1.714;
}

@media screen and (max-width: 767px) {
  #home-01 .container .news a {
    margin-bottom: 40px;
    width: 100%;
  }
  #home-01 .container .news a li {
    display: flex;
    flex-direction: row;
  }
  #home-01 .container .news a li figure {
    width: 50%;
  }
  #home-01 .container .news a li .text {
    width: 50%;
  }
}

#home-02 {
  background: url(../img/top/02_01.jpg) no-repeat;
  background-position: center bottom;
  background-size: cover;
  height: 500px;
  position: relative;
}

@media screen and (max-width: 767px) {
  #home-02 {
    height: auto;
    background: none;
  }
}

#home-02 .sp-img {
  display: none;
}

#home-02 .sp-img img {
  width: 100%;
  vertical-align: bottom;
}

@media screen and (max-width: 767px) {
  #home-02 .sp-img {
    display: block;
  }
}

#home-02 .content {
  background-color: rgba(0, 31, 3, 0.58);
  max-width: 340px;
  position: absolute;
  top: 0;
  left: 0;
}

@media screen and (max-width: 767px) {
  #home-02 .content {
    background: #00400a;
    position: static;
    max-width: 100%;
  }
}

#home-02 .content .inner {
  padding: 80px 37px 25px;
  position: relative;
}

@media screen and (max-width: 767px) {
  #home-02 .content .inner {
    padding: 80px 40px 35px 40px;
  }
}

#home-02 .content .inner .btn {
  text-align: center;
  display: block;
  width: 100%;
  padding-top: 20px;
}

@media screen and (max-width: 767px) {
  #home-02 .content .inner .btn {
    padding-top: 30px;
  }
}

#home-02 .content .inner .btn img {
  width: 30px;
}

@media screen and (max-width: 767px) {
  #home-02 .content .inner .btn img {
    width: 50px;
  }
}

#home-02 .content .inner .heading {
  color: #fff;
}

#home-02 .content .inner .heading small {
  color: #fff;
}

#home-02 .content .inner .lead {
  font-size: 20px;
  color: white;
  line-height: 1.6;
  padding: 30px 0;
}

#home-02 .content .inner .desc {
  font-size: 14px;
  color: white;
  line-height: 1.714;
  letter-spacing: -0.015em;
}

@media screen and (max-width: 767px) {
  #home-02 .content .inner .desc {
    font-size: 20px;
  }
}

#home-02 .content .flex-box {
  text-decoration: none;
}

@media screen and (max-width: 767px) {
  #home-02 .content .flex-box img {
    width: 200px;
  }
}

@media screen and (max-width: 500px) {
  #home-02 .content .flex-box img {
    width: 110px;
  }
}

#home-02 .content .flex-box p {
  font-size: 14px;
  color: white;
  line-height: 1.429;
  background: #008a2a;
  display: block;
  width: 230px;
  padding: 20px 15px;
  position: relative;
}

@media screen and (max-width: 767px) {
  #home-02 .content .flex-box p {
    width: calc(100% - 200px);
    font-size: 20px;
    padding: 50px 30px;
  }
}

@media screen and (max-width: 500px) {
  #home-02 .content .flex-box p {
    width: calc(100% - 110px);
    font-size: 14px;
    padding: 20px 15px;
  }
}

#home-02 .content .flex-box p:after {
  content: "";
  width: 8px;
  height: 8px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  top: 0;
  bottom: 0;
  right: 10px;
  margin: auto;
  vertical-align: middle;
  position: absolute;
}

@media screen and (max-width: 767px) {
  #home-02 .content .flex-box p:after {
    width: 12px;
    height: 12px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    right: 40px;
  }
}

@media screen and (max-width: 500px) {
  #home-02 .content .flex-box p:after {
    right: 20px;
  }
}

#home-03 {
  background: url(../img/top/03_01.jpg) no-repeat;
  background-position: center;
  background-size: cover;
  height: 500px;
  position: relative;
}

@media screen and (max-width: 767px) {
  #home-03 {
    height: auto;
    background: none;
  }
}

#home-03 .sp-img {
  display: none;
}

#home-03 .sp-img img {
  width: 100%;
  vertical-align: bottom;
}

@media screen and (max-width: 767px) {
  #home-03 .sp-img {
    display: block;
  }
}

#home-03 .content {
  background-color: rgba(3, 5, 14, 0.51);
  max-width: 340px;
  position: absolute;
  height: 500px;
  overflow: hidden;
  top: 0;
  right: 0;
}

@media screen and (max-width: 767px) {
  #home-03 .content {
    height: auto;
    position: static;
    max-width: 100%;
    background: #004279;
  }
}

#home-03 .content .inner {
  padding: 80px 25px 25px;
  position: relative;
}

@media screen and (max-width: 767px) {
  #home-03 .content .inner {
    padding: 80px 40px 35px 40px;
  }
}

#home-03 .content .inner .heading {
  color: #fff;
}

#home-03 .content .inner .heading small {
  color: #fff;
}

#home-03 .content .inner .lead {
  font-size: 20px;
  color: white;
  line-height: 1.6;
  padding: 30px 0;
}

#home-03 .content .inner .desc {
  font-size: 14px;
  color: white;
  line-height: 1.714;
  letter-spacing: -0.015em;
}

@media screen and (max-width: 767px) {
  #home-03 .content .inner .desc {
    font-size: 20px;
  }
}

#home-03 .content .inner .btn {
  text-align: center;
  display: block;
  width: 100%;
  padding-top: 28px;
  height: 70px;
}

@media screen and (max-width: 767px) {
  #home-03 .content .inner .btn {
    height: auto;
    padding-top: 30px;
  }
}

#home-03 .content .inner .btn img {
  width: 30px;
}

@media screen and (max-width: 767px) {
  #home-03 .content .inner .btn img {
    width: 50px;
  }
}

#home-03 .content .flex-box li:first-child a {
  border-right: 2px solid transparent;
}

@media screen and (max-width: 767px) {
  #home-03 .content .flex-box li {
    width: 50%;
    font-size: 20px;
    border-right: 2px solid transparent;
  }
}

#home-03 .content .flex-box li a {
  display: block;
  background: #00829a;
  width: 169px;
  height: 70px;
  text-decoration: none;
  color: #fff;
  padding: 22px 0 29px 18px;
  text-align: left;
  letter-spacing: -0.05em;
  position: relative;
}

@media screen and (max-width: 767px) {
  #home-03 .content .flex-box li a {
    padding: 60px 0 60px 40px;
    font-size: 20px;
    height: 150px;
    width: auto;
  }
}

@media screen and (max-width: 500px) {
  #home-03 .content .flex-box li a {
    font-size: 15px;
    padding: 30px 0 30px 10px;
    height: 80px;
  }
}

#home-03 .content .flex-box li a:after {
  content: "";
  width: 8px;
  height: 8px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  top: 0;
  bottom: 0;
  right: 10px;
  margin: auto;
  vertical-align: middle;
  position: absolute;
}

@media screen and (max-width: 767px) {
  #home-03 .content .flex-box li a:after {
    width: 12px;
    height: 12px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    right: 40px;
  }
}

@media screen and (max-width: 500px) {
  #home-03 .content .flex-box li a:after {
    right: 10px;
  }
}

#home-04 {
  background: #fff;
}

#home-04 .flex-box .text {
  padding: 9.3% 0 4.6% 6.7%;
  width: 45%;
}

@media screen and (max-width: 767px) {
  #home-04 .flex-box .text {
    width: 50%;
  }
}

#home-04 .flex-box .text .heading {
  margin-bottom: 30px;
}

#home-04 .flex-box .text time {
  font-size: 14px;
  color: #333333;
  line-height: 1;
  font-weight: bold;
}

#home-04 .flex-box .text .column-title {
  font-size: 14px;
  color: #333333;
  line-height: 1;
  padding: 10px 0 40px;
}

#home-04 .flex-box .text .com-btn-04 {
  display: block;
  line-height: 1;
  padding: 15px 0;
  text-align: center;
  font-size: 14px;
  color: #008a2a;
  border: 2px solid #008a2a;
  text-decoration: none;
  width: 250px;
  max-width: 90%;
  position: relative;
}

@media screen and (max-width: 500px) {
  #home-04 .flex-box .text .com-btn-04 {
    padding: 15px 5px;
    text-align: left;
  }
}

#home-04 .flex-box .text .com-btn-04:after {
  content: "";
  width: 8px;
  height: 8px;
  border-top: 2px solid #008a2a;
  border-right: 2px solid #008a2a;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  top: 0;
  bottom: 0;
  right: 20px;
  margin: auto;
  vertical-align: middle;
  position: absolute;
}

@media screen and (max-width: 500px) {
  #home-04 .flex-box .text .com-btn-04:after {
    right: 8px;
  }
}

#home-04 .flex-box .img {
  width: 55%;
  height: 330px;
}

@media screen and (max-width: 767px) {
  #home-04 .flex-box .img {
    width: 50%;
  }
}

#home-04 .flex-box .img img {
  width: 100%;
  height: 100%;
  margin-top: 40px;
  margin-bottom: -40px;
  object-fit: cover;
  object-position: top;
  font-family: 'object-fit: cover; object-position: top;';
}

#home-05 {
  background: #fff;
}

#home-05 .flex-box .text {
  padding: 9.3% 0 4.6% 6.7%;
  width: 45%;
}

@media screen and (max-width: 767px) {
  #home-05 .flex-box .text {
    width: 50%;
  }
}

#home-05 .flex-box .text .heading {
  margin-bottom: 30px;
}

#home-05 .flex-box .text time {
  font-size: 14px;
  color: #333333;
  line-height: 1;
  font-weight: bold;
}

#home-05 .flex-box .text .column-title {
  font-size: 14px;
  color: #333333;
  line-height: 1;
  padding: 10px 0 40px;
}

#home-05 .flex-box .text .com-btn-04 {
  display: block;
  line-height: 1;
  padding: 15px 0;
  text-align: center;
  font-size: 14px;
  color: #008a2a;
  border: 2px solid #008a2a;
  text-decoration: none;
  width: 250px;
  max-width: 90%;
  position: relative;
}

@media screen and (max-width: 500px) {
  #home-05 .flex-box .text .com-btn-04 {
    padding: 15px 5px;
    text-align: left;
  }
}

#home-05 .flex-box .text .com-btn-04:after {
  content: "";
  width: 8px;
  height: 8px;
  border-top: 2px solid #008a2a;
  border-right: 2px solid #008a2a;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  top: 0;
  bottom: 0;
  right: 20px;
  margin: auto;
  vertical-align: middle;
  position: absolute;
}

@media screen and (max-width: 500px) {
  #home-05 .flex-box .text .com-btn-04:after {
    right: 8px;
  }
}

#home-05 .flex-box .img {
  width: 55%;
  height: 330px;
}

@media screen and (max-width: 767px) {
  #home-05 .flex-box .img {
    width: 50%;
  }
}

#home-05 .flex-box .img img {
  width: 100%;
  height: 100%;
  margin-top: -40px;
  margin-bottom: 40px;
  object-fit: cover;
  font-family: 'object-fit: cover';
  float: right;
}

@media screen and (max-width: 767px) {
  #home-05 .flex-box .img img {
    width: auto;
  }
}

#home-06 .container h4 {
  font-size: 24px;
  color: #333333;
  line-height: 0.833;
  font-weight: normal;
  margin-bottom: 15px;
}

@media screen and (max-width: 500px) {
  #home-06 .container h4 {
    margin-bottom: 20px;
  }
}

#home-06 .container h4:before {
  content: url(../img/common/instagram.svg);
  margin-right: 9px;
}

#home-06 .container .follow-btn {
  display: block;
  border-radius: 8px;
  background-color: #008a2a;
  width: 250px;
  text-align: center;
  text-decoration: none;
  font-size: 14px;
  font-weight: bold;
  line-height: 1;
  padding: 18px 0;
  color: #fff;
  margin: 20px auto 0;
}

@media screen and (max-width: 500px) {
  #home-06 .container .follow-btn {
    margin: 0 auto;
  }
}

#home-07 .container h4 {
  font-size: 24px;
  color: #333333;
  line-height: 0.833;
  font-weight: normal;
  margin-bottom: 15px;
}

#home-07 .container h4:before {
  content: url(../img/common/facebook.svg);
  margin-right: 9px;
}

#home-07 .fb-container {
  max-width: 530px;
  padding: 0 15px;
  margin: 0 auto;
}

#home-08 {
  background: #fff;
  padding: 75px 0;
}

#home-08 iframe {
  margin-top: 15px;
}

/* 糺の森について
----------------------------------------------- */
@-webkit-keyframes slider1 {
  0% {
    width: 100%;
  }
  45% {
    width: 0;
  }
  100% {
    width: 0;
  }
}

@keyframes slider1 {
  0% {
    width: 100%;
  }
  45% {
    width: 0;
  }
  100% {
    width: 0;
  }
}

@-webkit-keyframes slider2 {
  0% {
    width: 100%;
  }
  55% {
    width: 100%;
  }
  100% {
    width: 0;
  }
}

@keyframes slider2 {
  0% {
    width: 100%;
  }
  55% {
    width: 100%;
  }
  100% {
    width: 0;
  }
}

#page-tit-01 {
  background-position: center;
  background-size: cover;
  position: relative;
  height: 280px;
}

@media screen and (max-width: 767px) {
  #page-tit-01 {
    margin-top: 110px;
  }
}

@media screen and (max-width: 500px) {
  #page-tit-01 {
    margin-top: 80px;
  }
}

#page-tit-01 .tit {
  position: absolute;
  top: 95px;
  left: 30px;
}

@media screen and (max-width: 767px) {
  #page-tit-01 .tit {
    top: 120px;
    left: 35px;
  }
}

#page-tit-01 .tit h2 {
  font-size: 32px;
  color: white;
  line-height: 1;
  font-weight: normal;
}

@media screen and (max-width: 500px) {
  #page-tit-01 .tit h2 {
    font-size: 28px;
  }
}

#page-tit-01 .tit h2 small {
  font-size: 14px;
  font-family: "Georgia";
  display: block;
  line-height: 1;
  padding-top: 12px;
}

#page-tit-01 .page-tit-nav {
  position: absolute;
  bottom: 0;
  width: 100%;
}

#page-tit-01 .page-tit-nav ul li {
  display: table;
  height: 60px;
}

#page-tit-01 .page-tit-nav ul li a {
  display: table-cell;
  vertical-align: middle;
  font-size: 14px;
  color: white;
  text-decoration: none;
  text-align: center;
  padding: 0 1.45vw;
  text-align: center;
}

#page-tit-01 .page-tit-nav ul li a span {
  display: inline-block;
  text-align: left;
}

#page-tit-01 .page-tit-nav ul li a span .small {
  font-size: 12px;
}

#page-tit-02 {
  background-position: center;
  background-size: cover;
  position: relative;
  height: 250px;
}

@media screen and (max-width: 767px) {
  #page-tit-02 {
    margin-top: 110px;
  }
}

@media screen and (max-width: 500px) {
  #page-tit-02 {
    margin-top: 80px;
  }
}

#page-tit-02 .tit {
  position: absolute;
  top: 90px;
  left: 40px;
}

@media screen and (max-width: 767px) {
  #page-tit-02 .tit {
    top: 95px;
    left: 40px;
  }
}

@media screen and (max-width: 500px) {
  #page-tit-02 .tit {
    top: 110px;
    left: 20px;
  }
}

#page-tit-02 .tit h2 {
  font-size: 20px;
  color: white;
  line-height: 1.2;
  font-weight: normal;
}

#page-tit-02 .tit h2 span {
  font-size: 32px;
}

@media screen and (max-width: 767px) {
  #page-tit-02 .tit h2 span {
    font-size: 28px;
  }
}

@media screen and (max-width: 500px) {
  #page-tit-02 .tit h2 span {
    font-size: 24px;
  }
}

#page-tit-02 .tit h2 small {
  font-size: 14px;
  font-family: "Georgia";
  display: block;
  line-height: 1;
  padding-top: 8px;
}

@media screen and (max-width: 767px) {
  #page-tit-02 .tit h2 small {
    font-size: 17px;
  }
}

.about-tit-01 {
  font-size: 24px;
  color: #333333;
  line-height: 1.5;
  font-weight: normal;
}

.about-txt-01 {
  font-size: 14px;
  color: #333333;
  line-height: 1.714;
}

@media screen and (max-width: 767px) {
  .about-txt-01 {
    font-size: 20px;
  }
}

.about-txt-01 span {
  display: block;
  font-size: 16px;
  font-weight: bold;
  padding: 20px 0;
}

@media screen and (max-width: 767px) {
  .about-txt-01 span {
    font-size: 24px;
  }
}

.about-heading {
  background-image: url(../img/about/top.jpg);
}

.about-heading .page-tit-nav {
  background-color: rgba(9, 49, 25, 0.6);
}

.about-heading .page-tit-nav .flex-box {
  justify-content: flex-start;
}

.about-heading .page-tit-nav .flex-box .here {
  background: #008a2a;
}

#about-01 .img {
  margin: 0 auto;
  max-width: 1001px;
  height: 320px;
  margin-bottom: 140px;
  position: relative;
  display: block;
}

#about-01 .img:before {
  margin: 70px 0 140px;
  position: absolute;
  background: #000;
  content: '';
  display: block;
  top: 0;
  right: 0;
  height: 100%;
  width: 100%;
  z-index: 2;
}

#about-01 .img:after {
  margin: 70px 0 140px;
  background-color: #FFF;
  content: '';
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  height: 100%;
  width: 100%;
  z-index: 1;
}

@media screen and (min-width: 1140px) {
  #about-01 .img {
    max-width: 3000px;
  }
}

#about-01 .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  font-family: 'object-fit: cover';
  z-index: -1;
}

#about-01 .active:before {
  -webkit-animation: slider1 1.3s cubic-bezier(0.55, 0, 0.1, 1) both;
  animation: slider1 1.3s cubic-bezier(0.55, 0, 0.1, 1) both;
  animation-delay: 0.8s;
}

#about-01 .active:after {
  -webkit-animation: slider2 1.4s cubic-bezier(0.55, 0, 0.1, 1) both;
  animation: slider2 1.4s cubic-bezier(0.55, 0, 0.1, 1) both;
  animation-delay: 0.8s;
}

#about-02 .img {
  margin: 0 auto;
  max-width: 855px;
  height: 320px;
  margin-bottom: 140px;
  position: relative;
  display: block;
}

#about-02 .img:before {
  margin: 70px 0 140px;
  position: absolute;
  background: #000;
  content: '';
  display: block;
  top: 0;
  right: 0;
  height: 100%;
  width: 100%;
  z-index: 2;
}

#about-02 .img:after {
  margin: 70px 0 140px;
  background-color: #FFF;
  content: '';
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  height: 100%;
  width: 100%;
  z-index: 1;
}

@media screen and (min-width: 1140px) {
  #about-02 .img {
    max-width: 3000px;
  }
}

#about-02 .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  font-family: 'object-fit: cover';
}

#about-02 .active:before {
  -webkit-animation: slider1 1.3s cubic-bezier(0.55, 0, 0.1, 1) both;
  animation: slider1 1.3s cubic-bezier(0.55, 0, 0.1, 1) both;
  animation-delay: 0.8s;
}

#about-02 .active:after {
  -webkit-animation: slider2 1.4s cubic-bezier(0.55, 0, 0.1, 1) both;
  animation: slider2 1.4s cubic-bezier(0.55, 0, 0.1, 1) both;
  animation-delay: 0.8s;
}

#about-03 .img {
  margin: 0 auto;
  max-width: 856px;
  height: 320px;
  position: relative;
  display: block;
  margin-bottom: 70px;
}

#about-03 .img:before {
  margin: 70px 0 0;
  position: absolute;
  background: #000;
  content: '';
  display: block;
  top: 0;
  right: 0;
  height: 100%;
  width: 100%;
  z-index: 2;
}

#about-03 .img:after {
  margin: 70px 0 0;
  background-color: #FFF;
  content: '';
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  height: 100%;
  width: 100%;
  z-index: 1;
}

@media screen and (min-width: 1140px) {
  #about-03 .img {
    max-width: 3000px;
  }
}

#about-03 .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  font-family: 'object-fit: cover';
}

#about-03 .active:before {
  -webkit-animation: slider1 1.3s cubic-bezier(0.55, 0, 0.1, 1) both;
  animation: slider1 1.3s cubic-bezier(0.55, 0, 0.1, 1) both;
  animation-delay: 0.8s;
}

#about-03 .active:after {
  -webkit-animation: slider2 1.4s cubic-bezier(0.55, 0, 0.1, 1) both;
  animation: slider2 1.4s cubic-bezier(0.55, 0, 0.1, 1) both;
  animation-delay: 0.8s;
}

.about-03-btn {
  background: #fff;
  padding: 80px 0 70px;
  position: relative;
}

.about-03-btn .flex-box li {
  margin: 0 auto 10px;
  max-width: 100%;
}

/* アクセス
----------------------------------------------- */
#access-01 .access-layout-01 {
  background: #fff;
  padding: 80px 0;
}

#access-01 .access-layout-01 .map01-inner {
  max-width: 738px;
  padding: 0 40px;
  margin: 0 auto;
}

#access-01 .access-layout-01 .map01-inner .map01 {
  width: 100%;
  max-width: 100%;
}

#access-01 .access-layout-01 .map01-inner .link-btn {
  text-align: right;
}

@media screen and (max-width: 767px) {
  #access-01 .access-layout-01 .map01-inner .link-btn {
    text-align: center;
  }
}

#access-01 .access-layout-01 .map01-inner .link-btn .link01 {
  margin-left: auto;
  margin-top: 25px;
}

@media screen and (max-width: 767px) {
  #access-01 .access-layout-01 .map01-inner .link-btn .link01 {
    margin: 40px auto 0;
  }
}

#access-01 .access-layout-01 .con .tit {
  font-size: 16px;
  color: #008a2a;
  font-weight: bold;
  padding-bottom: 10px;
}

@media screen and (max-width: 767px) {
  #access-01 .access-layout-01 .con .tit {
    font-size: 20px;
  }
}

#access-01 .access-layout-01 .con .accent {
  position: relative;
  padding-left: 16px;
}

#access-01 .access-layout-01 .con .accent:nth-of-type(3) {
  margin-top: 10px;
}

#access-01 .access-layout-01 .con .accent:before {
  position: absolute;
  content: '※';
  left: 0;
  top: 0;
  font-size: 14px;
}

@media screen and (max-width: 767px) {
  #access-01 .access-layout-01 .con .accent:before {
    font-style: 20px;
  }
}

#access-01 .access-layout-02 .flex-box {
  padding: 80px 0;
}

@media screen and (max-width: 767px) {
  #access-01 .access-layout-02 .flex-box {
    flex-direction: column;
  }
}

#access-01 .access-layout-02 .flex-box .cons {
  width: 50%;
}

@media screen and (max-width: 767px) {
  #access-01 .access-layout-02 .flex-box .cons {
    width: 100%;
  }
}

#access-01 .access-layout-02 .flex-box .cons .con .tit {
  font-size: 16px;
  color: #008a2a;
  font-weight: bold;
  padding-bottom: 10px;
}

@media screen and (max-width: 767px) {
  #access-01 .access-layout-02 .flex-box .cons .con .tit {
    font-size: 20px;
  }
}

#access-01 .access-layout-02 .flex-box .map {
  width: 50%;
}

@media screen and (max-width: 767px) {
  #access-01 .access-layout-02 .flex-box .map {
    margin: 60px auto 0;
    width: 100%;
    text-align: center;
  }
}

#access-01 .access-layout-02 .flex-box .map img {
  max-width: 392px;
  width: 100%;
}

#access-01 .access-layout-02 .flex-box .map .link-btn {
  text-align: right;
}

@media screen and (max-width: 767px) {
  #access-01 .access-layout-02 .flex-box .map .link-btn {
    text-align: center;
  }
}

#access-01 .access-layout-02 .flex-box .map .link-btn .pop-box {
  margin-left: auto;
  margin-top: 25px;
}

@media screen and (max-width: 767px) {
  #access-01 .access-layout-02 .flex-box .map .link-btn .pop-box {
    margin: 40px auto 0;
  }
}

#access-01 .access-layout-02 .flex-box .map .link-btn .pop-box #popup-on {
  display: none;
}

#access-01 .access-layout-02 .flex-box .map .link-btn .pop-box #popup-on:checked + .popup {
  display: block;
}

#access-01 .access-layout-02 .flex-box .map .link-btn .pop-box .popup {
  background-color: #efefef;
  box-shadow: 0 0 0 9999px rgba(0, 0, 0, 0.8);
  display: none;
  position: fixed;
  z-index: 9999;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 80vw;
  height: 90vh;
  overflow-y: scroll;
}

#access-01 .access-layout-02 .flex-box .map .link-btn .pop-box .popup .popup-content {
  position: relative;
  width: 100%;
  height: 100%;
  margin: 0 auto;
}

#access-01 .access-layout-02 .flex-box .map .link-btn .pop-box .popup .popup-content img {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  top: 0;
  margin: auto;
}

/* お問い合わせフォーム（糺の森財団 入会申込み・継続申込み）
----------------------------------------------- */
#annual_events-01 .annual_events-layout-01 {
  background: #fff;
  padding: 80px 0;
}

@media screen and (max-width: 767px) {
  #annual_events-01 .annual_events-layout-01 {
    padding: 80px 0 0;
  }
}

/* お問い合わせフォーム（糺の森財団 入会申込み・継続申込み）
----------------------------------------------- */
/* 糺の森財団へのご寄附フォーム
----------------------------------------------- */
/* お問い合わせフォーム
----------------------------------------------- */
.other-heading {
  background-image: url(../img/other/top.png);
}

#join-01 {
  background: #fff;
  padding: 80px 0;
}

#join-01 .tc {
  text-align: center;
  padding: 40px 0;
  font-size: 14px;
}

#join-01 .tc span {
  display: inline;
}

@media screen and (max-width: 767px) {
  #join-01 .tc {
    text-align: left;
    padding: 35px 0;
    font-size: 20px;
  }
}

@media screen and (max-width: 500px) {
  #join-01 .tc {
    font-size: 16px;
  }
}

#join-01 .txt {
  padding: 40px 0;
  border-bottom: 1px solid #ccc;
  font-size: 14px;
  vertical-align: middle;
}

@media screen and (max-width: 767px) {
  #join-01 .txt {
    font-size: 20px;
    padding: 35px 0;
  }
}

@media screen and (max-width: 500px) {
  #join-01 .txt {
    font-size: 16px;
  }
}

#join-01 .agree {
  text-align: center;
}

#join-01 .agree .wpcf7-form-control-wrap {
  display: inline-block;
  vertical-align: middle;
}

#join-01 .agree .com-txt-ib {
  font-size: 14px;
  vertical-align: middle;
}

@media screen and (max-width: 767px) {
  #join-01 .agree .com-txt-ib {
    font-size: 20px;
  }
}

@media screen and (max-width: 500px) {
  #join-01 .agree .com-txt-ib {
    font-size: 16px;
  }
}

#join-01 .agree .com-txt-ib a {
  color: #008a2a;
  font-size: 14px;
}

@media screen and (max-width: 767px) {
  #join-01 .agree .com-txt-ib a {
    font-size: 20px;
  }
}

@media screen and (max-width: 500px) {
  #join-01 .agree .com-txt-ib a {
    font-size: 16px;
  }
}

/*Contact Form 7カスタマイズ*/
/*スマホContact Form 7カスタマイズ*/
@media (max-width: 930px) {
  .inquiry th, .inquiry td {
    display: block !important;
    width: 100% !important;
    -webkit-box-sizing: border-box !important;
    -moz-box-sizing: border-box !important;
    box-sizing: border-box !important;
  }
  /* 必須のサイズ調整 */
  .inquiry .haveto {
    font-size: 14px;
    margin-left: 15px;
  }
}

.inquiry {
  border-collapse: collapse;
  margin-top: 35px;
}

/*見出し欄*/
.inquiry th {
  text-align: left;
  font-weight: bold;
  font-size: 14px;
  color: #444;
  line-height: 1.7;
  padding: 15px 20px;
  width: 42.7%;
  border-top: solid 1px #ccc;
  background: #faf7ea;
  min-width: 222px;
}

@media screen and (max-width: 767px) {
  .inquiry th {
    font-size: 20px;
    padding: 9px 10px;
    width: 100%;
    min-width: 100%;
  }
}

@media screen and (max-width: 500px) {
  .inquiry th {
    font-size: 16px;
    padding: 9px 10px;
  }
}

.inquiry tr:last-child th {
  border-bottom: solid 1px #ccc;
}

@media screen and (max-width: 500px) {
  .inquiry tr:last-child th {
    border-bottom: none;
  }
}

/*通常欄*/
.inquiry td {
  font-size: 14px;
  background: #fff;
  border-top: solid 1px #ccc;
  padding: 10px 20px;
  font-weight: normal;
  vertical-align: middle;
}

@media screen and (max-width: 767px) {
  .inquiry td {
    font-size: 20px;
    padding: 18px 20px;
    border-top: none;
  }
}

@media screen and (max-width: 500px) {
  .inquiry td {
    font-size: 16px;
    padding: 18px 10px;
  }
}

.inquiry tr:last-child td {
  border-bottom: solid 1px #ccc;
}

@media screen and (max-width: 767px) {
  .inquiry tr:last-child td {
    border-bottom: none;
  }
}

.inquiry td .span1 {
  margin-left: 10px;
}

.inquiry td .span2 {
  margin-right: 10px;
}

.inquiry td .span3 {
  margin-right: 10px;
}

.inquiry td .span4 {
  margin-right: 10px;
  margin-left: 15px;
}

@media screen and (max-width: 767px) {
	.inquiry td .span1 {
  margin-left: 2px;
}

.inquiry td .span2 {
  margin-right: 2px;
}

  .inquiry td .span4 {
    margin-left: 0;
  }
}

.inquiry td .span5 {
  margin-right: 24px;
}

.inquiry td .span6 {
  margin-right: 24px;
  margin-left: 15px;
}

@media screen and (max-width: 767px) {
  .inquiry td .span6 {
    margin-left: 0;
  }
}

/*入力欄*/
.inquiry td input[type="number"],
.inquiry td input[type="text"],
.inquiry td input[type="tel"],
.inquiry td input[type="fax"],
.inquiry td input[type="email"],
.inquiry td input[type="checkbox"],
.inquiry td select {
  background: #faf7ea;
  vertical-align: middle;
  border: solid 1px #ccc;
  height: 35px;
  border-radius: 0;
  padding-left: 5px;
}

.inquiry td input[type="checkbox"]{
  background: transparent;
  vertical-align: middle;
  border: solid 1px #ccc;
  height: 35px;
  border-radius: 0;
  padding-left: 5px;
}

.inquiry td select {
  border: 0;
  outline: 1px solid #ccc;
  outline-offset: -1px;
  padding-left: 0;
}

.inquiry td textarea[name="text-10"] {
  padding-left: 5px;
}

.inquiry td input[type="checkbox"],
.agree input[type="checkbox"] {
  height: 35px;
  width: 18px;
}

@media screen and (max-width: 767px) {
  .inquiry td input[type="checkbox"],
  .agree input[type="checkbox"] {
    width: 32px;
    height: 50px;
  }
}

@media screen and (max-width: 500px) {
  .inquiry td input[type="checkbox"],
  .agree input[type="checkbox"] {
    width: 24px;
    height: 40px;
  }
}

.inquiry td textarea {
  background: #faf7ea;
  border: solid 1px #ccc;
}

/*必須の調整*/
.haveto {
  font-size: 14px;
  padding: 3px;
  font-weight: normal;
  background: #ff0000;
  color: #fff;
  border-radius: 2px;
  margin-left: 5px;
  position: relative;
  bottom: 1px;
}

.asneed {
  font-size: 12px;
  color: red;
}

@media screen and (max-width: 767px) {
  .asneed {
    font-size: 20px;
  }
}

@media screen and (max-width: 500px) {
  .asneed {
    font-size: 16px;
  }
}

/*ラジオボタンを縦並び指定*/
.verticallist .wpcf7-list-item {
  display: block;
  margin-left: 0;
  padding: 10px 0;
}

span.first {
  margin-left: 0 !important;
}

.radio-2 > .radio1 .wpcf7-list-item:nth-of-type(1) {
  margin-right: 10px;
}

.radio-2 > .radio1 .wpcf7-list-item:nth-of-type(2) {
  margin-left: 0 !important;
}

.checkbox-3 > .check2 .wpcf7-list-item:nth-of-type(1) {
  margin-right: 10px;
}

.checkbox-3 > .check2 .wpcf7-list-item:nth-of-type(2) {
  margin-left: 0 !important;
  margin-right: 10px;
}

.checkbox-3 > .check2 .wpcf7-list-item:nth-of-type(3) {
  margin-left: 0 !important;
  margin-right: 10px;
}

.checkbox-3 > .check2 .wpcf7-list-item:nth-of-type(4) {
  margin-left: 0 !important;
  margin-right: 10px;
}

.checkbox-3 > .check2 .wpcf7-list-item:nth-of-type(5) {
  margin-left: 0 !important;
  margin-right: 10px;
}

.checkbox-3 > .check2 .wpcf7-list-item:nth-of-type(6) {
  margin-left: 0 !important;
}

.checkbox-2 > .check4 .wpcf7-list-item:nth-of-type(1) {
  margin-right: 12px;
}

.checkbox-6 > .check6 .wpcf7-list-item:nth-of-type(1) {
  margin-right: 12px;
}

.checkbox-3 .wpcf7-list-item {
/*  height: 40px;*/
}

.checkbox-5 span.wpcf7-list-item {
  display: block;
}

.checkbox-5 span.wpcf7-list-item.last {
  display: inline-block;
}

/* ●●●●●● 2022.04 クレジットカード追加 ●●●●●● */
.radio-5 .wpcf7-list-item.last {
  margin-left: 1em !important;
}

@media screen and (max-width: 767px) {
  .radio-5 .wpcf7-list-item.last {
    margin-left: 0 !important;
  }
  .radio-5 .wpcf7-list-item {
	display: block;
	margin-bottom: 10px;
  }
}


/*送信ボタンのデザイン変更*/
#essformbtn,
#conformbtn,
#backbtn,
#formbtn {
  display: block;
  padding: 19px;
  width: 250px;
  background: #008a2a;
  color: #fff;
  font-size: 14px;
  font-weight: bold;
  border-radius: 8px;
  margin: 30px auto 0;
}

.formbtn {
  display: block;
  margin: 0 auto;
  text-align: center;
}

.formbtn #backbtn {
  display: inline-block;
  width: 130px;
  margin-right: 10px;
}

.formbtn #formbtn {
  display: inline-block;
  width: 130px;
}

.formbtn #essformbtn {
  display: inline-block;
  width: 160px;
}

/*送信ボタンマウスホバー時*/
#conformbtn:hover,
#backbtn:hover,
#formbtn:hover {
  opacity: 0.8;
}

td .checkbox-2 {
  display: inline-block;
}

.wpcf7-form-control-wrap input[name="number-01"],
.wpcf7-form-control-wrap input[name="number-02"],
.wpcf7-form-control-wrap input[name="calculated-906"],
.wpcf7-form-control-wrap input[name="calculated-315"] {
  width: 46%;
}

@media screen and (max-width: 767px) {
  .wpcf7-form-control-wrap input[name="number-01"],
  .wpcf7-form-control-wrap input[name="number-02"],
  .wpcf7-form-control-wrap input[name="calculated-906"],
  .wpcf7-form-control-wrap input[name="calculated-315"] {
    width: 71%;
    min-width: 200px;
  }
}

.wpcf7-form-control-wrap input[name="text-01"],
.wpcf7-form-control-wrap input[name="text-02"],
.wpcf7-form-control-wrap input[name="text-03"],
.wpcf7-form-control-wrap input[name="city"],
.wpcf7-form-control-wrap input[name="addr"],
.wpcf7-form-control-wrap input[name="inquiry_mail"],
.wpcf7-form-control-wrap input[name="inquiry_mail_confirm"] {
  width: 77%;
}

@media screen and (max-width: 767px) {
  .wpcf7-form-control-wrap input[name="text-01"],
  .wpcf7-form-control-wrap input[name="text-02"],
  .wpcf7-form-control-wrap input[name="text-03"],
  .wpcf7-form-control-wrap input[name="city"],
  .wpcf7-form-control-wrap input[name="addr"],
  .wpcf7-form-control-wrap input[name="inquiry_mail"],
  .wpcf7-form-control-wrap input[name="inquiry_mail_confirm"] {
    width: 100%;
  }
}

.wpcf7-form-control-wrap input[name="text-04"],
.wpcf7-form-control-wrap input[name="text-05"],
.wpcf7-form-control-wrap input[name="text-06"],
.wpcf7-form-control-wrap input[name="text-07"] {
  width: 36%;
}

@media screen and (max-width: 767px) {
  .wpcf7-form-control-wrap input[name="text-04"],
  .wpcf7-form-control-wrap input[name="text-05"],
  .wpcf7-form-control-wrap input[name="text-06"],
  .wpcf7-form-control-wrap input[name="text-07"] {
    width: 71%;
  }
}

@media screen and (max-width: 767px) {
  .wpcf7-form-control-wrap input[name="text-04"],
  .wpcf7-form-control-wrap input[name="text-06"] {
    margin-bottom: 20px;
  }
}

.wpcf7-form-control-wrap input[name="number-03"],
.wpcf7-form-control-wrap input[name="zip"],
.wpcf7-form-control-wrap input[name="pref"] {
  width: 27%;
}

@media screen and (max-width: 767px) {
  .wpcf7-form-control-wrap input[name="number-03"],
.wpcf7-form-control-wrap input[name="zip"],
.wpcf7-form-control-wrap input[name="pref"] {
  width: 40%;
}
}

.wpcf7-form-control-wrap input[name="number-04"],
.wpcf7-form-control-wrap input[name="number-05"],
.wpcf7-form-control-wrap input[name="number-06"]{
  width: 12%;
}


.wpcf7-form-control-wrap input[name="tel-01"],
.wpcf7-form-control-wrap input[name="tel-02"],
.wpcf7-form-control-wrap input[name="tel-03"] {
  width: 18%;
}

@media screen and (max-width: 767px) {
  .wpcf7-form-control-wrap input[name="tel-01"],
  .wpcf7-form-control-wrap input[name="tel-02"],
  .wpcf7-form-control-wrap input[name="tel-03"] {
    width: calc(33.3333% - 40px * 2/3);
  }
}

.wpcf7-form-control-wrap input[name="fax-01"],
.wpcf7-form-control-wrap input[name="fax-02"],
.wpcf7-form-control-wrap input[name="fax-03"] {
  width: 18%;
}

@media screen and (max-width: 767px) {
  .wpcf7-form-control-wrap input[name="fax-01"],
  .wpcf7-form-control-wrap input[name="fax-02"],
  .wpcf7-form-control-wrap input[name="fax-03"] {
    width: calc(33.3333% - 40px * 2/3);
  }
}

.wpcf7-free-text{
  width:170px;
}
.has-free-text{
  display: inline-block;
}

.wpcf7-form-control-wrap .check4 {
/*  margin-top: 10px;*/
  display: inline-block;
}

.wpcf7-form-control-wrap input[name="text-08"] {
  width: 45%;
}

.wpcf7-form-control-wrap input[name="text-09"] {
  width: 78%;
}

.wpcf7-form-control-wrap textarea[name="text-10"] {
  width: 100%;
}

.wpcf7-form-control-wrap input[name="text-11"] {
  width: 78%;
}

/* 
.wpcf7-not-valid {
  background-color: #f8cdcd!important;
}
 */

input[type="radio"] {
  position: relative;
  -webkit-appearance: button;
  appearance: button;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 18px;
  height: 18px;
  content: "";
  background-color: #FFFFFF;
  border: 1px solid #999999;
  -webkit-border-radius: 18px;
  border-radius: 18px;
  vertical-align: middle;
  cursor: pointer;
}

@media screen and (max-width: 767px) {
  input[type="radio"] {
    width: 32px;
    height: 32px;
    -webkit-border-radius: 32px;
    border-radius: 32px;
  }
}

@media screen and (max-width: 500px) {
  input[type="radio"] {
    width: 18px;
    height: 18px;
    -webkit-border-radius: 18px;
    border-radius: 18px;
  }
}

input[type="radio"]:checked:after {
  display: block;
  position: absolute;
  top: 4px;
  left: 4px;
  content: "";
  width: 8px;
  height: 8px;
  background: #333;
  -webkit-border-radius: 8px;
  border-radius: 8px;
}

@media screen and (max-width: 767px) {
  input[type="radio"]:checked:after {
    width: 14px;
    height: 14px;
    -webkit-border-radius: 14px;
    border-radius: 14px;
    top: 8px;
    left: 8px;
  }
}

@media screen and (max-width: 500px) {
  input[type="radio"]:checked:after {
    width: 8px;
    height: 8px;
    -webkit-border-radius: 8px;
    border-radius: 8px;
    top: 4px;
    left: 4px;
  }
}



/* 献木フォーム　樹種と本数　　横並び */

ul.donation_tree_list {
	display: flex;
}
ul.donation_tree_list li.tree01 {
	width: 200px;
}


@media screen and (max-width: 767px) {
  ul.donation_tree_list {
	display: flex;
	}
	ul.donation_tree_list li.tree01 {
	width: 70%;
  }
}

@media screen and (max-width: 500px) {
  ul.donation_tree_list {
	display: flex;
	}
	ul.donation_tree_list li.tree01 {
	width: 70%;
  }
}


/* 糺の森財団について
----------------------------------------------- */
.about_foundation-heading {
  background-image: url(../img/found/top.jpg);
}

.about_foundation-heading .page-tit-nav {
  background-color: rgba(3, 5, 14, 0.51);
}

.about_foundation-heading .page-tit-nav .flex-box .here {
  background: #00829a;
}

.about_foundation-heading .page-tit-nav .flex-box a {
  padding: 0 1.3156vw;
  font-size: 1.2270vw;
}

.about_foundation-heading .page-tit-nav .flex-box a .small {
  font-size: 14px;
}

@media (max-width: 1100px) {
  .about_foundation-heading .page-tit-nav ul.flex-box {
    justify-content: flex-start;
  }
  .about_foundation-heading .page-tit-nav ul.flex-box li {
    height: 45px !important;
    width: 25%;
  }
  .about_foundation-heading .page-tit-nav ul.flex-box li a {
    padding: 0 15px;
  }
}

#found-01 .found-layout-01 {
  background: #fcfbfe url(../img/found/top_01.jpg) no-repeat center bottom / contain;
  position: relative;
  padding: 80px 0;
  margin-top: 70px;
}

@media screen and (max-width: 767px) {
  #found-01 .found-layout-01 {
    background-image: url(../img/found/top_01_sp.jpg);
  }
}

#found-01 .found-layout-01 .container .box {
  padding: 0;
  text-align: center;
  border: 2px solid #008a2a;
  max-width: 690px;
  margin: 0 auto 200px;
}

@media screen and (max-width: 767px) {
  #found-01 .found-layout-01 .container .box {
    margin-bottom: 100px;
  }
}

#found-01 .found-layout-01 .container .box-inr {
  padding: 25px 30px;
}

@media screen and (max-width: 767px) {
  #found-01 .found-layout-01 .container .box-inr {
    padding: 30px 25px;
  }
}

@media screen and (max-width: 500px) {
  #found-01 .found-layout-01 .container .box-inr {
    padding: 20px 15px;
  }
}

#found-01 .found-layout-01 .container .box-inr a{
  color: #008a2a;
}

#found-01 .found-layout-01 .container .box .com-tit-02 {
  margin-bottom: 10px;
}

@media screen and (max-width: 500px) {
  #found-01 .found-layout-01 .container .box .com-tit-02 {
    font-size: 16px;
    margin-bottom: 5px;
  }
}

@media screen and (max-width: 500px) {
  #found-01 .found-layout-01 .container .box .com-tit-02 .com-txt-01 {
    font-size: 13px;
  }
}

#found-01 .found-layout-01 .container .box .accent {
  padding-left: 20px;
  position: relative;
  text-align: left;
}

#found-01 .found-layout-01 .container .box .accent:before {
  position: absolute;
  content: '・';
  top: 0;
  left: 0;
}

@media screen and (max-width: 500px) {
  #found-01 .found-layout-01 .container .box .accent {
    font-size: 13px;
    padding-left: 10px;
  }
}

#found-01 .found-layout-01 .container .box-figurelist{
  display: flex;
  justify-content: space-between;
  margin-bottom: 30px;
}

#found-01 .found-layout-01 .container .box-figurelist.var-arrow{
  background: url('/wp-content/themes/tadasunomori/img/found/top/arrow.png') no-repeat center center / 4.632587% auto;
}

#found-01 .found-layout-01 .container .box-figurelist figure{
  width: 46.325879%;
}

#found-01 .found-layout-01 .container .box-figurelist figcaption{
  font-size: 14px;
}

#found-01 .found-layout-01 .container .box-figurelist img{
  max-width: 100%;
}

#found-01 .found-layout-01 .btn-found{
  padding-bottom: 200px;
}

@media screen and (max-width: 767px) {
  .btn-found {
    margin-top: 40px;
  }
}

@media screen and (max-width: 767px) {
  .btn-found .flex-box {
    justify-content: center;
  }
}

.btn-found .flex-box .com-btn-01 {
  width: calc(50% - 9px * 1/2);
  margin-bottom: 10px;
  border: 2px solid #008a2a;
}

@media screen and (max-width: 767px) {
  .btn-found .flex-box .com-btn-01 {
    max-width: 100%;
    width: 380px;
  }
}

/* 森を守る（ご寄付・ご入会）
----------------------------------------------- */
#save_forest-01 {
  position: relative;
}

#save_forest-01 .container {
  padding-bottom: 80px;
}

#save_forest-01 .container .img_pc {
  position: absolute;
  right: 0px;
  top: 0;
  width: 40%;
  max-width: 312px;
}

@media screen and (max-width: 767px) {
  #save_forest-01 .container .img_pc {
    display: none;
  }
}

#save_forest-01 .container .w60 {
  width: 60%;
}

@media screen and (max-width: 767px) {
  #save_forest-01 .container .w60 {
    width: 100%;
  }
}

#save_forest-01 .container .con .com-btn-02 {
  margin-left: 0;
  text-decoration: none;
  text-align: center;
}

@media screen and (max-width: 767px) {
  #save_forest-01 .container .con .com-btn-02 {
    margin-left: auto;
    margin-right: auto;
  }
}

@media screen and (max-width: 767px) {
  #save_forest-01 .container .con .com-btn-04 {
    margin: 10px auto 0;
  }
}

#save_forest-01 .container .con .pdf {
  padding: 8px 0;
  display: inline-block;
  text-decoration: none;
}

#save_forest-01 .container .con .pdf:before {
  content: "";
  background-image: url(../img/found/save_forest/icon_pdf.svg);
  vertical-align: middle;
  display: inline-block;
  background-size: contain;
  height: 25px;
  width: 27px;
  margin-right: 8px;
}

#save_forest-01 .container .img_sp {
  width: 100%;
  margin-top: 60px;
  display: none;
}

@media screen and (max-width: 767px) {
  #save_forest-01 .container .img_sp {
    display: block;
  }
}

#save_forest-02 {
  background: #fff;
  padding: 80px 0;
}

#save_forest-02 .container .accent {
  padding-left: 13px;
  position: relative;
}

#save_forest-02 .container .accent:before {
  position: absolute;
  content: '＊';
  top: 0;
  left: 0;
}

#save_forest-02 .container .accent a {
  color: #008a2a;
}

@media screen and (max-width: 767px) {
  #save_forest-02 .container .accent {
    padding-left: 20px;
  }
}

@media screen and (max-width: 500px) {
  #save_forest-02 .container .accent {
    font-size: 13px;
  }
}

@media screen and (max-width: 500px) {
  #save_forest-02 .container .com-list-01 dt {
    width: 100px;
  }
  #save_forest-02 .container .com-list-01 dd {
    width: calc(100% - 100px);
  }
}

/* 糺の森財団の概要・あゆみ
----------------------------------------------- */
#summary-01 .summary-layout-01 {
  padding: 80px 0;
  background: #fff;
}

#summary-01 .summary-layout-01 .container .accent {
  padding-left: 12px;
  position: relative;
}

#summary-01 .summary-layout-01 .container .accent:before {
  position: absolute;
  content: '・';
  left: 0;
  top: 0;
  font-size: 14px;
}

.summary-layout-01 table {
  border-collapse: collapse;
  border-spacing: 0;
  width: 100%;
}

.summary-layout-01 table tr {
  border-bottom: 1px solid #b8b8b8;
  box-sizing: border-box;
  width: 100%;
}

.summary-layout-01 table tr:first-of-type {
  border-top: 1px solid #b8b8b8;
}

.summary-layout-01 table tr th {
  text-align: left;
  width: 200px;
  background: #faf7ea;
  font-size: 14px;
  font-weight: bold;
  line-height: 1.2;
  padding: 23px 0 23px 20px;
  vertical-align: middle;
}

@media screen and (max-width: 767px) {
  .summary-layout-01 table tr th {
    width: 150px;
    font-size: 20px;
    padding: 20px 0 20px 20px;
  }
}

@media screen and (max-width: 500px) {
  .summary-layout-01 table tr th {
    width: 115px;
    font-size: 14px;
    padding: 23px 0 20px 10px;
  }
}

.summary-layout-01 table tr td {
  width: calc(100% - 200px);
  background: #fff;
  font-size: 14px;
  font-weight: normal;
  line-height: 1.2;
  padding: 23px 0 23px 20px;
  vertical-align: middle;
  display: table-cell;
}

@media screen and (max-width: 767px) {
  .summary-layout-01 table tr td {
    width: calc(100% - 150px);
    font-size: 20px;
    padding: 20px 0 20px 20px;
  }
}

@media screen and (max-width: 500px) {
  .summary-layout-01 table tr td {
    font-size: 14px;
    padding: 23px 0 20px 10px;
    width: calc(100% - 115px);
  }
}

@media screen and (max-width: 767px) {
  .summary-layout-01 table tr td.small {
    font-size: 15px;
  }
}

@media screen and (max-width: 500px) {
  .summary-layout-01 table tr td.small {
    font-size: 11px;
  }
}

.summary-layout-01 table tr td.small a {
  text-decoration: none;
  color: #333;
}

/* 役員とご挨拶
----------------------------------------------- */
#officer-01 .officer-layout-01 {
  padding: 80px 0;
  background: #fff;
}

@media screen and (max-width: 500px) {
  #officer-01 .officer-layout-01 .small {
    font-size: 14px;
  }
}

/* 会員規約
----------------------------------------------- */
#membership_provisions-01 .membership_provisions-layout-01 {
  background: #fff;
  padding: 80px 0;
}

#membership_provisions-01 .membership_provisions-layout-01 .accent1 {
  padding-left: 15px;
  position: relative;
}

#membership_provisions-01 .membership_provisions-layout-01 .accent1:before {
  position: absolute;
  content: '1';
  top: 0;
  left: 0;
}

#membership_provisions-01 .membership_provisions-layout-01 .accent2 {
  padding-left: 15px;
  position: relative;
}

#membership_provisions-01 .membership_provisions-layout-01 .accent2:before {
  position: absolute;
  content: '2';
  top: 0;
  left: 0;
}

/* 情報公開
----------------------------------------------- */
#info_disclosure-01 .info_disclosure-layout-01 {
  background: #fff;
  padding: 80px 0;
}

#info_disclosure-01 .info_disclosure-layout-01 .pdf {
  padding: 8px 0;
  display: inline-block;
  vertical-align: middle;
  text-decoration: none;
}

#info_disclosure-01 .info_disclosure-layout-01 .pdf:before {
  content: "";
  background-image: url(../img/found/save_forest/icon_pdf.svg);
  vertical-align: middle;
  display: inline-block;
  background-size: contain;
  height: 25px;
  width: 27px;
  margin-right: 8px;
}

/* 税制上の優遇処置について
----------------------------------------------- */
#tax_incentives-01 .tax_incentives-layout-01 {
  padding: 80px 0;
  background: #fff;
}

#tax_incentives-01 .tax_incentives-layout-01 .img_01 {
  width: 100%;
  max-width: 560px;
  display: block;
  margin: 30px auto 0;
}

#tax_incentives-01 .tax_incentives-layout-01 .img_02 {
  width: 100%;
  max-width: 560px;
  display: block;
  margin: 30px auto 0;
}

#tax_incentives-01 .tax_incentives-layout-01 .img_03 {
  width: 100%;
  max-width: 400px;
  display: block;
  margin: 40px auto 0;
}

#tax_incentives-01 .tax_incentives-layout-01 .pdf {
  padding: 8px 0;
  display: block;
  text-decoration: none;
  margin: 30px auto 0;
  text-align: center;
}

#tax_incentives-01 .tax_incentives-layout-01 .pdf:before {
  content: "";
  background-image: url(../img/found/save_forest/icon_pdf.svg);
  vertical-align: middle;
  display: inline-block;
  background-size: contain;
  height: 25px;
  width: 27px;
  margin-right: 8px;
}

/* 会員特典
----------------------------------------------- */
#benefit-01 .benefit-layout-01 {
  padding: 80px 0;
  background: #fff;
}

#benefit-01 .benefit-layout-01 .accent {
  padding-left: 20px;
  position: relative;
  text-align: left;
}

#benefit-01 .benefit-layout-01 .accent:before {
  position: absolute;
  content: '・';
  top: 0;
  left: 0;
}

@media screen and (max-width: 500px) {
  #benefit-01 .benefit-layout-01 .accent {
    font-size: 13px;
    padding-left: 15px;
  }
}

#benefit-01 .benefit-layout-01 .ChangeElem_Btn_Content {
  width: 100%;
  justify-content: space-between;
}

#benefit-01 .benefit-layout-01 .ChangeElem_Btn_Content .ChangeElem_Btn {
  width: calc(16.6666% - 0.87vw * 5/6);
  font-size: 14px;
  background: #ece8d6;
  height: 50px;
}

@media screen and (max-width: 767px) {
  #benefit-01 .benefit-layout-01 .ChangeElem_Btn_Content .ChangeElem_Btn {
    width: calc(20% - 10px * 4/5);
    margin-bottom: 10px;
    font-size: 20px;
    height: 70px;
  }
}

@media screen and (max-width: 600px) {
  #benefit-01 .benefit-layout-01 .ChangeElem_Btn_Content .ChangeElem_Btn {
    width: calc(33.3333% - 10px * 2/3);
  }
}

@media screen and (max-width: 500px) {
  #benefit-01 .benefit-layout-01 .ChangeElem_Btn_Content .ChangeElem_Btn {
    font-size: 16px;
  }
}

#benefit-01 .benefit-layout-01 .ChangeElem_Btn_Content .ChangeElem_Btn:hover {
  background: #008a2a;
  color: #fff;
}

#benefit-01 .benefit-layout-01 .ChangeElem_Btn_Content .is-active {
  background: #008a2a;
  color: #fff;
}

#benefit-01 .benefit-layout-01 ul .ChangeElem_Panel {
  display: none;
}

#benefit-01 .benefit-layout-01 ul .ChangeElem_Panel .box {
  border: 1px solid #ccc;
}

#benefit-01 .benefit-layout-01 ul .ChangeElem_Panel .box .cat {
  background: #008a2a;
  border: 1px solid #008a2a;
}

#benefit-01 .benefit-layout-01 ul .ChangeElem_Panel .box .cat p {
  padding-left: 21px;
  color: #fff;
  height: 30px;
  line-height: 30px;
}

@media screen and (max-width: 767px) {
  #benefit-01 .benefit-layout-01 ul .ChangeElem_Panel .box .cat p {
    height: 40px;
    line-height: 40px;
  }
}

#benefit-01 .benefit-layout-01 ul .ChangeElem_Panel .box .flex2 {
  align-items: center;
  padding: 20px;
}

@media screen and (max-width: 767px) {
  #benefit-01 .benefit-layout-01 ul .ChangeElem_Panel .box .flex2 {
    padding: 30px 20px;
  }
}

#benefit-01 .benefit-layout-01 ul .ChangeElem_Panel .box .flex2 .content {
  width: calc(100% - 31.5%);
}

@media screen and (max-width: 767px) {
  #benefit-01 .benefit-layout-01 ul .ChangeElem_Panel .box .flex2 .content {
    width: 100%;
  }
}

#benefit-01 .benefit-layout-01 ul .ChangeElem_Panel .box .flex2 .content .com-tit-04 {
  margin-top: 10px;
  display: inline-block;
  vertical-align: middle;
}

#benefit-01 .benefit-layout-01 ul .ChangeElem_Panel .box .flex2 .content .link02 {
  margin-left: 40px;
  margin-top: 10px;
  vertical-align: middle;
}

@media screen and (max-width: 767px) {
  #benefit-01 .benefit-layout-01 ul .ChangeElem_Panel .box .flex2 .content .link02 {
    padding-bottom: 10px;
    margin-left: 37px;
  }
}

#benefit-01 .benefit-layout-01 ul .ChangeElem_Panel .box .flex2 .img {
  width: 31.5%;
}

#benefit-01 .benefit-layout-01 ul .ChangeElem_Panel .box .flex2 .img img {
  width: 100%;
}

#benefit-01 .benefit-layout-01 ul .ChangeElem_Panel .box .discount {
  background: #ffffcc;
  padding: 15px 20px;
}

@media screen and (max-width: 767px) {
  #benefit-01 .benefit-layout-01 ul .ChangeElem_Panel .box .discount {
    padding: 35px;
  }
}

#benefit-01 .benefit-layout-01 ul .ChangeElem_Panel .box .discount .com-tit-02 {
  padding-bottom: 0;
}

@media screen and (max-width: 767px) {
  #benefit-01 .benefit-layout-01 ul .ChangeElem_Panel .box .discount .com-tit-02 {
    font-size: 24px;
  }
}

@media screen and (max-width: 500px) {
  #benefit-01 .benefit-layout-01 ul .ChangeElem_Panel .box .discount .com-tit-02 {
    font-size: 18px;
  }
}

#benefit-01 .benefit-layout-01 ul .ChangeElem_Panel .box .sp-img {
  width: 100%;
  padding: 23px;
}

#benefit-01 .benefit-layout-01 ul .ChangeElem_Panel .box .sp-img img {
  width: 100%;
}

#benefit-01 .benefit-layout-01 ul .ChangeElem_Panel .topbtn {
  width: 100%;
  text-align: right;
  display: inline-block;
  margin-top: 20px;
}

#benefit-01 .benefit-layout-01 ul .ChangeElem_Panel .topbtn img {
  width: 67px;
}

#benefit-01 .benefit-layout-01 .com-btn-04 {
  margin: 40px auto 0;
  width: 500px;
  padding: 26px 0;
  font-weight: bold;
  font-size: 20px;
  max-width: 100%;
}

@media screen and (max-width: 767px) {
  #benefit-01 .benefit-layout-01 .com-btn-04 {
    width: 380px;
  }
}

@media screen and (max-width: 500px) {
  #benefit-01 .benefit-layout-01 .com-btn-04 {
    font-size: 16px;
  }
}

#benefit-01 .benefit-layout-01 .flex-box.flex3 > figure:nth-child(3n+2):last-child {
  margin-left: auto;
  margin-right: 37.33%;
}

/* サイトマップ
----------------------------------------------- */
#sitemap-01 {
  background: #fff;
}

#sitemap-01 .flex-box {
  padding: 45px 0 75px;
  justify-items: flex-start;
}

@media screen and (max-width: 767px) {
  #sitemap-01 .flex-box {
    padding: 45px 40px 75px;
  }
}

@media screen and (max-width: 500px) {
  #sitemap-01 .flex-box {
    padding: 30px 15px 60px;
  }
}

#sitemap-01 .flex-box .menu {
  width: calc(50% - 20px * 1/2);
}

@media screen and (max-width: 767px) {
  #sitemap-01 .flex-box .menu {
    width: 100%;
  }
}

#sitemap-01 .flex-box .menu .menu-item {
  padding: 25px 0 25px 45px;
  position: relative;
  vertical-align: middle;
  border-top: 1px solid #ccc;
  line-height: 1;
}

#sitemap-01 .flex-box .menu .menu-item:last-child {
  border-bottom: 1px solid #ccc;
}

#sitemap-01 .flex-box .menu .menu-item:before {
  position: absolute;
  top: 28px;
  left: 15px;
  margin: auto;
  content: "";
  vertical-align: middle;
  width: 12px;
  height: 12px;
  border-top: 2px solid #008a2a;
  border-right: 2px solid #008a2a;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

#sitemap-01 .flex-box .menu .menu-item a {
  text-decoration: none;
  font-size: 14px;
  color: #333333;
  font-weight: bold;
}

@media screen and (max-width: 767px) {
  #sitemap-01 .flex-box .menu .menu-item a {
    font-size: 20px;
  }
}

@media screen and (max-width: 500px) {
  #sitemap-01 .flex-box .menu .menu-item a {
    font-size: 18px;
  }
}

#sitemap-01 .flex-box .menu .menu-item .sub-menu .menu-item {
  border: none;
  padding: 8px 10px;
}

#sitemap-01 .flex-box .menu .menu-item .sub-menu .menu-item:first-child {
  padding-top: 12px;
}

#sitemap-01 .flex-box .menu .menu-item .sub-menu .menu-item:last-child {
  padding-bottom: 0;
}

#sitemap-01 .flex-box .menu .menu-item .sub-menu .menu-item:before {
  display: none;
}

#sitemap-01 .flex-box .menu .menu-item .sub-menu .menu-item a {
  font-weight: normal;
}

/* プライバシポリシー
----------------------------------------------- */
#privacy-01 {
  background: #fff;
  padding: 70px 0 70px;
}

@media screen and (max-width: 767px) {
  #privacy-01 .com-list-01 dt {
    width: 170px;
    font-size: 20px;
    padding: 20px 0 20px 20px;
  }
}

@media screen and (max-width: 500px) {
  #privacy-01 .com-list-01 dt {
    width: 115px;
    font-size: 14px;
    padding: 23px 0 20px 10px;
  }
}

@media screen and (max-width: 767px) {
  #privacy-01 .com-list-01 dd {
    width: calc(100% - 170px);
    font-size: 20px;
    padding: 20px 0 20px 20px;
  }
}

@media screen and (max-width: 500px) {
  #privacy-01 .com-list-01 dd {
    font-size: 14px;
    padding: 23px 0 20px 10px;
    width: calc(100% - 115px);
  }
}

@media screen and (max-width: 767px) {
  #privacy-01 .com-list-01 dd.small {
    font-size: 15px;
  }
}

@media screen and (max-width: 500px) {
  #privacy-01 .com-list-01 dd.small {
    font-size: 11px;
  }
}

#privacy-01 .com-list-01 dd.small a {
  text-decoration: none;
  color: #333;
}

/* 関連リンク
----------------------------------------------- */
#link-01 {
  background: #fff;
  padding: 80px 0;
}

#link-01 .container dl.com-list-01 dd a {
  text-decoration: none;
  color: #333;
}

@media screen and (max-width: 767px) {
  #link-01 .container dl.com-list-01 {
    flex-wrap: wrap;
    display: flex;
  }
  #link-01 .container dl.com-list-01 dt {
    width: 100%;
  }
  #link-01 .container dl.com-list-01 dd {
    width: 100%;
  }
}

@media screen and (max-width: 500px) {
  #link-01 .container dl.com-list-01 dd {
    font-size: 14px;
  }
}

/* インスタグラム
----------------------------------------------- */
.inst_wrap {
  background: #faf7ea;
  width: 100%;
  max-width: 775px;
  border-radius: 4px;
  overflow: hidden;
}

.inst_container {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
}

.inst_list_item {
  width: calc(25% - 20px * 3/4);
 margin-right:20px;
  position: relative;
  margin-bottom: 20px;
}

.inst_list_item:nth-of-type(4n) {
 margin-right: 0px;
}

.inst_list_item::before {
  content: "";
  display: block;
  padding-top: 100%;
}

@media screen and (max-width: 767px) {
  .inst_list_item {
    width: calc(50% - 40px * 1/2);
	  margin-right:40px;
    position: relative;
    margin-bottom: 40px;
  }
	.inst_list_item:nth-of-type(2n) {
 margin-right: 0px;
}
}

@media screen and (max-width: 500px) {
  .inst_list_item {
    width: calc(50% - 20px * 1/2);
    position: relative;
    margin-bottom: 20px;
	  margin-right:20px;
  }
	.inst_list_item:nth-of-type(2n) {
 margin-right: 0px;
}
}

.inst_thumb img {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  object-fit: cover;
  font-family: 'object-fit: cover';
}

.inst_thumb:hover img {
  opacity: .5;
}

/* 糺の森だより(記事一覧)
----------------------------------------------- */
.news-heading {
  background: url(../img/news/top.jpg);
}

#news-01 .container .ChangeElem_Btn_Content {
  margin: 30px 0 20px;
  width: 100%;
  justify-content: flex-start;
}

#news-01 .container .ChangeElem_Btn_Content .ChangeElem_Btn {
  width: calc(16.6666% - 0.87vw * 5/6);
  font-size: 14px;
  background: #ece8d6;
  height: 50px;
  margin-bottom: 10px;
  margin-right: 10px;
}

@media screen and (max-width: 767px) {
  #news-01 .container .ChangeElem_Btn_Content .ChangeElem_Btn {
    width: calc(20% - 10px * 4/5);
    font-size: 20px;
    height: 70px;
  }
}

@media screen and (max-width: 600px) {
  #news-01 .container .ChangeElem_Btn_Content .ChangeElem_Btn {
    width: calc(33.3333% - 10px * 2/3);
  }
}

@media screen and (max-width: 500px) {
  #news-01 .container .ChangeElem_Btn_Content .ChangeElem_Btn {
    font-size: 16px;
  }
}

#news-01 .container .ChangeElem_Btn_Content .ChangeElem_Btn:hover {
  background: #008a2a;
  color: #fff;
}

#news-01 .container .ChangeElem_Btn_Content .is-active {
  background: #008a2a;
  color: #fff;
}

#news-01 .news-layout-01 {
  background: #fff;
  padding: 40px 0 30px;
}

#news-01 .news-layout-01 .container ul .ChangeElem_Panel {
  justify-content: flex-start;
}

#news-01 .news-layout-01 .container ul .ChangeElem_Panel a {
  text-decoration: none;
  background: #fff;
  margin-top: 20px;
  width: calc(33.333% - 3.5vw * 2/3);
  margin-right: 3.5vw;
  margin-bottom: 40px;
  border: 1px solid #eee;
}

#news-01 .news-layout-01 .container ul .ChangeElem_Panel a:nth-of-type(3n) {
  margin-right: 0;
}

@media screen and (max-width: 767px) {
  #news-01 .news-layout-01 .container ul .ChangeElem_Panel a {
    margin-right: 0;
  }
}

#news-01 .news-layout-01 .container ul .ChangeElem_Panel a img {
  vertical-align: middle;
  width: 100%;
  height: 160px;
  object-fit: cover;
  object-position: top;
  font-family: 'object-fit: cover; object-position: top;';
}

@media screen and (max-width: 767px) {
  #news-01 .news-layout-01 .container ul .ChangeElem_Panel a img {
    width: 110%;
    height: 162px;
    object-position: -10px 0;
  }
}

#news-01 .news-layout-01 .container ul .ChangeElem_Panel a .text {
  display: block;
  text-decoration: none;
  padding: 15px 15px 20px 20px;
}

#news-01 .news-layout-01 .container ul .ChangeElem_Panel a .text .date {
  font-size: 14px;
  color: #333333;
  line-height: 1.429;
  font-weight: bold;
}

#news-01 .news-layout-01 .container ul .ChangeElem_Panel a .text .desc {
  font-size: 14px;
  margin-top: 10px;
  color: #333333;
  line-height: 1.714;
}

@media screen and (max-width: 767px) {
  #news-01 .news-layout-01 .container ul .ChangeElem_Panel a {
    margin-bottom: 40px;
    width: 100%;
  }
  #news-01 .news-layout-01 .container ul .ChangeElem_Panel a .postid {
    display: flex;
    flex-direction: row;
  }
  #news-01 .news-layout-01 .container ul .ChangeElem_Panel a .postid figure {
    width: 50%;
    overflow: hidden;
  }
  #news-01 .news-layout-01 .container ul .ChangeElem_Panel a .postid .text {
    width: 50%;
  }
}

/* 糺の森だより(個別記事)
----------------------------------------------- */
#news-single-01 {
  background: #fff;
  padding: 80px 0 70px;
}

#news-single-01 .container .flex-box {
  padding: 20px 0 60px;
}

#news-single-01 .container .flex-box .time {
  font-weight: bold;
}

#news-single-01 .container .flex-box .tag a {
  color: #008a2a;
  text-decoration: none;
  font-size: 14px;
}

@media screen and (max-width: 767px) {
  #news-single-01 .container .flex-box .tag a {
    font-size: 20px;
  }
}

@media screen and (max-width: 500px) {
  #news-single-01 .container .flex-box .tag a {
    font-size: 16px;
  }
}

#news-single-01 .container .content {
  margin-bottom: 80px;
}

#news-single-01 .container .content p.parent {
  display: block;
  margin: 0 auto;
  max-width: 560px;
}

#news-single-01 .container .content p.parent img.post-image {
  width: 100%;
  height: auto;
}

#news-single-01 .container .content p.pdf_dl {
  text-align: center;
}

#news-single-01 .container .content p.pdf_dl a.download-link {
  background: url(../img/common/icon_pdf.svg) no-repeat left;
  padding-top: 10px;
  padding-bottom: 10px;
  padding-left: 50px;
  padding-right: 0;
  overflow: hidden;
  margin-top: 0;
  margin-left: 0;
  text-decoration: none;
  display: inline-block;
  font-size: 14px;
  color: #333;
}

@media screen and (max-width: 767px) {
  #news-single-01 .container .content p.pdf_dl a.download-link {
    font-size: 20px;
  }
}

@media screen and (max-width: 500px) {
  #news-single-01 .container .content p.pdf_dl a.download-link {
    font-size: 16px;
  }
}

#news-single-01 .container .com-btn-04 {
  margin: 0 auto;
}

/* 糺の森コラム(記事一覧)
----------------------------------------------- */
.column-heading {
  background: url(../img/column/top.jpg);
}

#column-01 .txt_top {
  margin-top: 30px;
}

@media screen and (max-width: 767px) {
  #column-01 .txt_top {
    margin-top: 70px;
  }
}

#column-01 .column-layout-01 {
  padding: 40px 0 80px;
  background: #fff;
  margin-top: 30px;
}

@media screen and (max-width: 767px) {
  #column-01 .column-layout-01 {
    margin-top: 70px;
    padding-top: 80px;
  }
}

#column-01 .column-layout-01 .column {
  justify-content: flex-start;
}

#column-01 .column-layout-01 .column a {
  text-decoration: none;
  background: #fff;
  width: calc(33.333% - 3.5vw * 2/3);
  margin-right: 3.5vw;
  border: 1px solid #ccc;
  margin-bottom: 40px;
}

#column-01 .column-layout-01 .column a:nth-of-type(3n) {
  margin-right: 0;
}

@media screen and (max-width: 767px) {
  #column-01 .column-layout-01 .column a {
    border: none;
    margin-right: 0;
  }
}

#column-01 .column-layout-01 .column a img {
  vertical-align: middle;
  width: 100%;
  height: 160px;
  object-fit: cover;
  object-position: top;
  font-family: 'object-fit: cover; object-position: top;';
}

#column-01 .column-layout-01 .column a .text {
  display: block;
  text-decoration: none;
  padding: 15px 15px 20px 20px;
  height: 135px;
}

@media screen and (max-width: 767px) {
  #column-01 .column-layout-01 .column a .text {
    height: auto;
  }
}

#column-01 .column-layout-01 .column a .text .date {
  font-size: 14px;
  color: #333333;
  line-height: 1.429;
  font-weight: bold;
}

@media screen and (max-width: 767px) {
  #column-01 .column-layout-01 .column a .text .date {
    font-size: 20px;
  }
}

@media screen and (max-width: 500px) {
  #column-01 .column-layout-01 .column a .text .date {
    font-size: 14px;
  }
}

#column-01 .column-layout-01 .column a .text .desc {
  font-size: 14px;
  margin-top: 10px;
  color: #333333;
  line-height: 1.714;
}

@media screen and (max-width: 767px) {
  #column-01 .column-layout-01 .column a .text .desc {
    font-size: 20px;
  }
}

@media screen and (max-width: 500px) {
  #column-01 .column-layout-01 .column a .text .desc {
    font-size: 14px;
  }
}

@media screen and (max-width: 767px) {
  #column-01 .column-layout-01 .column a {
    margin-bottom: 40px;
    width: 100%;
  }
  #column-01 .column-layout-01 .column a li {
    display: flex;
    flex-direction: row;
  }
  #column-01 .column-layout-01 .column a li figure {
    width: 50%;
  }
  #column-01 .column-layout-01 .column a li .text {
    width: 50%;
  }
}

#column-01 .column-layout-01 .wp-pagenavi {
  text-align: center;
  padding-top: 40px;
}

#column-01 .column-layout-01 .wp-pagenavi .page {
  box-sizing: border-box;
  background: #fff;
  display: inline-block;
  color: #333;
  font-size: 16px;
  font-weight: bold;
  border: 1px solid #ccc;
  width: 35px;
  height: 35px;
  text-decoration: none;
  line-height: 35px;
  margin-right: 6px;
}

@media screen and (max-width: 767px) {
  #column-01 .column-layout-01 .wp-pagenavi .page {
    font-size: 20px;
    width: 50px;
    height: 50px;
    margin-right: 10px;
    line-height: 50px;
  }
}

@media screen and (max-width: 500px) {
  #column-01 .column-layout-01 .wp-pagenavi .page {
    margin-right: 6px;
    font-size: 16px;
    width: 35px;
    height: 35px;
    line-height: 35px;
  }
}

#column-01 .column-layout-01 .wp-pagenavi .current {
  box-sizing: border-box;
  border: 1px solid #008a2a;
  background: #008a2a;
  color: #fff;
  display: inline-block;
  font-size: 16px;
  line-height: 35px;
  width: 35px;
  height: 35px;
  margin-right: 6px;
}

@media screen and (max-width: 767px) {
  #column-01 .column-layout-01 .wp-pagenavi .current {
    font-size: 20px;
    line-height: 50;
    width: 50px;
    height: 50px;
    margin-right: 10px;
    line-height: 50px;
  }
}

@media screen and (max-width: 500px) {
  #column-01 .column-layout-01 .wp-pagenavi .current {
    line-height: 35;
    margin-right: 6px;
    font-size: 16px;
    width: 35px;
    height: 35px;
    line-height: 35px;
  }
}

#column-01 .column-layout-01 .wp-pagenavi .nextpostslink {
  text-decoration: none;
  border: none;
  font-size: 16px;
  font-weight: bold;
  padding-left: 10px;
  color: #333;
}

@media screen and (max-width: 767px) {
  #column-01 .column-layout-01 .wp-pagenavi .nextpostslink {
    font-size: 20px;
  }
}

@media screen and (max-width: 500px) {
  #column-01 .column-layout-01 .wp-pagenavi .nextpostslink {
    font-size: 16px;
  }
}

#column-01 .column-layout-01 .wp-pagenavi .previouspostslink {
  text-decoration: none;
  border: none;
  font-size: 16px;
  font-weight: bold;
  padding-right: 10px;
  color: #333;
}

@media screen and (max-width: 767px) {
  #column-01 .column-layout-01 .wp-pagenavi .previouspostslink {
    font-size: 20px;
  }
}

@media screen and (max-width: 500px) {
  #column-01 .column-layout-01 .wp-pagenavi .previouspostslink {
    font-size: 16px;
  }
}

/* 糺の森だより(個別記事)
----------------------------------------------- */
#column-single-01 {
  background: #fff;
  padding: 80px 0 70px;
}

#column-single-01 .container .vol {
  width: 85px;
  height: 24px;
  line-height: 24px;
  background: #008a2a;
  color: #fff;
  font-size: 14px;
  font-weight: bold;
  border-radius: 12px;
  text-align: center;
  margin-bottom: 20px;
}

#column-single-01 .container .time {
  font-weight: bold;
  margin: 20px 0 60px;
  font-size: 14px;
}

#column-single-01 .container .content {
  margin-bottom: 80px;
}

#column-single-01 .container .content p.parent {
  display: block;
  margin: 0 auto;
  max-width: 560px;
}

#column-single-01 .container .content p.parent img.post-image {
  width: 100%;
  height: auto;
}

#column-single-01 .container .com-btn-04 {
  margin: 0 auto;
}

.newMark {
  color: #ff0000;
  display: inline-block;
  font-size: 14px;
  padding-left: 7px;
  text-align: center;
  font-weight: bold;
}

@media screen and (max-width: 767px) {
  .newMark {
    font-size: 20px;
    padding-left: 12px;
  }
}

@media screen and (max-width: 500px) {
  .newMark {
    font-size: 14px;
    padding-left: 0px;
  }
}

/* 糺の森ギャラリー(記事一覧)
----------------------------------------------- */
.gallery-heading {
  background: url(../img/gallery/top.jpg);
}

#gallery-01 {
  padding-top: 30px;
}

@media screen and (max-width: 767px) {
  #gallery-01 {
    padding-top: 70px;
  }
}

#gallery-01 #tab {
  justify-content: left;
  align-items: flex-start;
  margin-top: 35px;
}

@media screen and (max-width: 767px) {
  #gallery-01 #tab {
    margin-top: 70px;
  }
}

#gallery-01 #tab .select_btn {
  margin-right: 10px;
  width: 10.5263vw;
  height: 100px;
  font-size: 24px;
  text-align: center;
  background: #ece8d6;
  color: #333;
  position: relative;
  max-width: 120px;
  min-width: 65px;
}

@media screen and (max-width: 767px) {
  #gallery-01 #tab .select_btn {
    width: 18.75vw;
  }
}

@media screen and (max-width: 500px) {
  #gallery-01 #tab .select_btn {
    font-size: 20px;
  }
}

#gallery-01 #tab .select_btn:nth-of-type(4) {
  margin-right: 0;
}

#gallery-01 #tab .select_btn:hover:after {
  border-color: #fff;
}

#gallery-01 #tab .select_btn:hover div {
  background: transparent !important;
}

#gallery-01 #tab .select_btn:after {
  content: "";
  width: 8px;
  height: 8px;
  border-top: 1px solid #333;
  border-right: 1px solid #333;
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
  bottom: 15px;
  left: 0;
  right: 0;
  margin: auto;
  position: absolute;
}

@media screen and (max-width: 767px) {
  #gallery-01 #tab .select_btn {
    font-size: 20px;
  }
}

#gallery-01 #tab .select_btn span {
  display: block;
  font-size: 14px;
}

@media screen and (max-width: 500px) {
  #gallery-01 #tab .select_btn span {
    font-size: 12px;
  }
}

#gallery-01 #tab #tab1 {
  background: #f19ec2;
}

#gallery-01 #tab #tab1:hover {
  background: #f19ec2;
  color: #fff;
}

#gallery-01 #tab #tab1 div {
  background: #ece8d6;
  display: block;
  width: 10.5263vw;
  height: 100px;
  padding: 15px 0 30px;
  max-width: 120px;
  min-width: 65px;
}

@media screen and (max-width: 767px) {
  #gallery-01 #tab #tab1 div {
    width: 18.75vw;
  }
}

#gallery-01 #tab #tab2 {
  background: #b3d465;
}

#gallery-01 #tab #tab2:hover {
  background: #b3d465;
  color: #fff;
}

#gallery-01 #tab #tab2 div {
  background: #ece8d6;
  display: block;
  width: 10.5263vw;
  height: 100px;
  padding: 15px 0 30px;
  max-width: 120px;
  min-width: 65px;
}

@media screen and (max-width: 767px) {
  #gallery-01 #tab #tab2 div {
    width: 18.75vw;
  }
}

#gallery-01 #tab #tab3 {
  background: #cfa972;
}

#gallery-01 #tab #tab3:hover {
  background: #cfa972;
  color: #fff;
}

#gallery-01 #tab #tab3 div {
  background: #ece8d6;
  display: block;
  width: 10.5263vw;
  height: 100px;
  padding: 15px 0 30px;
  max-width: 120px;
  min-width: 65px;
}

@media screen and (max-width: 767px) {
  #gallery-01 #tab #tab3 div {
    width: 18.75vw;
  }
}

#gallery-01 #tab #tab4 {
  background: #7ecef4;
}

#gallery-01 #tab #tab4:hover {
  background: #7ecef4;
  color: #fff;
}

#gallery-01 #tab #tab4 div {
  background: #ece8d6;
  display: block;
  width: 10.5263vw;
  height: 100px;
  padding: 15px 0 30px;
  max-width: 120px;
  min-width: 65px;
}

@media screen and (max-width: 767px) {
  #gallery-01 #tab #tab4 div {
    width: 18.75vw;
  }
}

#gallery-01 #tab .current {
  color: #fff;
  border-color: #fff;
}

#gallery-01 #tab .current:after {
  color: #fff;
  border-color: #fff;
}

#gallery-01 #tab .current > div {
  background: transparent !important;
}

#gallery-01 .gallery-layout-01 {
  padding-bottom: 80px;
  background: #fff;
}

#gallery-01 .gallery-layout-01 #gallery-wrapper .contents {
  padding: 40px 0 45px;
}

#gallery-01 .gallery-layout-01 #gallery-wrapper .contents .img {
  width: calc(50% - 35px * 1/2);
  margin-bottom: 35px;
  height: 255px;
  margin-right: 35px;
}

@media screen and (max-width: 767px) {
  #gallery-01 .gallery-layout-01 #gallery-wrapper .contents .img {
    width: calc(50% - 20px * 1/2);
    margin-right: 20px;
    height: 187px;
    margin-bottom: 20px;
  }
}

@media screen and (max-width: 500px) {
  #gallery-01 .gallery-layout-01 #gallery-wrapper .contents .img {
    width: calc(50% - 10px * 1/2);
    margin-right: 10px;
    height: 130px;
    margin-bottom: 10px;
  }
}

/* ●●●●●　ここ変更　「nth-of-type(2n)」を「nth-of-type(1n)」に　
#gallery-01 .gallery-layout-01 #gallery-wrapper .contents .img:nth-of-type(2n) {
  margin-right: 0;
}
●●●●● */
#gallery-01 .gallery-layout-01 #gallery-wrapper .contents .img:nth-of-type(1n) {
  margin-right: 0;
}

#gallery-01 .gallery-layout-01 #gallery-wrapper .contents .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  font-family: 'object-fit: cover';
}

#gallery-01 #jquery-tab-pager-navi {
  text-align: center;
}

#gallery-01 #jquery-tab-pager-navi li {
  box-sizing: border-box;
  background: #fff;
  display: inline-block;
  color: #333;
  font-size: 16px;
  font-weight: bold;
}

#gallery-01 #jquery-tab-pager-navi li a {
  border: 1px solid #ccc;
  line-height: 35px;
  width: 35px;
  height: 35px;
  text-decoration: none;
  color: #333;
}

@media screen and (max-width: 767px) {
  #gallery-01 #jquery-tab-pager-navi li a {
    font-size: 20px;
    width: 50px;
    height: 50px;
    line-height: 50px;
  }
}

@media screen and (max-width: 500px) {
  #gallery-01 #jquery-tab-pager-navi li a {
    font-size: 16px;
    width: 35px;
    height: 35px;
    line-height: 35px;
  }
}

#gallery-01 #jquery-tab-pager-navi .current {
  box-sizing: border-box;
  border: 1px solid #008a2a;
  background: #008a2a;
  color: #fff;
  display: inline-block;
  font-size: 16px;
  line-height: 35px;
  width: 35px;
  height: 35px;
}

@media screen and (max-width: 767px) {
  #gallery-01 #jquery-tab-pager-navi .current {
    font-size: 20px;
    line-height: 50;
    width: 50px;
    height: 50px;
    line-height: 50px;
  }
}

@media screen and (max-width: 500px) {
  #gallery-01 #jquery-tab-pager-navi .current {
    line-height: 35;
    margin-right: 6px;
    font-size: 16px;
    width: 35px;
    height: 35px;
    line-height: 35px;
  }
}

#gallery-01 #jquery-tab-pager-navi .next {
  text-decoration: none;
  border: none;
  font-size: 16px;
  font-weight: bold;
  padding-left: 10px;
  color: #333;
  width: auto;
  border: none;
}

@media screen and (max-width: 767px) {
  #gallery-01 #jquery-tab-pager-navi .next {
    font-size: 20px;
  }
}

@media screen and (max-width: 500px) {
  #gallery-01 #jquery-tab-pager-navi .next {
    font-size: 16px;
  }
}

#gallery-01 #jquery-tab-pager-navi .previos {
  text-decoration: none;
  border: none;
  font-size: 16px;
  font-weight: bold;
  padding-right: 10px;
  color: #333;
  width: auto;
  border: none;
}

@media screen and (max-width: 767px) {
  #gallery-01 #jquery-tab-pager-navi .previos {
    font-size: 20px;
  }
}

@media screen and (max-width: 500px) {
  #gallery-01 #jquery-tab-pager-navi .previos {
    font-size: 16px;
  }
}

/* Thanksページ
----------------------------------------------- */
#thanks-01 {
  padding: 30px 0 400px;
}

#thanks-01 .container .com-txt-01 {
  margin: 15px 0;
}

/* コンタクトフォーム ７確認ページ
----------------------------------------------- */
input.wpcf7c-conf,
textarea.wpcf7c-conf {
  border: 0;
  padding: 0;
  background: #fff !important;
  border: none !important;
}

select.wpcf7c-conf {
  outline: none !important;
}

.wpcf7c-conf, .wpcf7c-conf:focus {
  background-color: transparent !important;
  border: none !important;
}

.wpcf7-text:-webkit-autofill {
  box-shadow: 0 0 0 1000px #fff inset !important;
}

.wpcf7.is_confirm input:-webkit-autofill {
  box-shadow: 0 0 0px 1000px #fff inset !important;
}

input:-webkit-autofill.wpcf7c-conf {
  -webkit-box-shadow: 0 0 0px 1000px #fff inset !important;
  border: none !important;
  background: #fff !important;
}

input:-webkit-autofill.wpcf7c-conf:focus {
  border: none !important;
}

.wpcf7c-conf {
  background: #fff !important;
  border-color: #fff !important;
}

.wpcf7c-conf:focus {
  border-color: transparent !important;
}

span.wpcf7-list-item {
  margin-left: 0 !important;
}

.radio1 span.wpcf7-list-item:nth-of-type(1) {
  margin-right: 1em;
}

.radio-6 span.wpcf7-list-item:nth-of-type(1) {
  margin-right: 1em;
}

figure img {
  object-fit: cover;
  object-position: top;
  font-family: 'object-fit: cover; object-position: top;';
}

/* 404ページ
----------------------------------------------- */
#error-01 .container{
	padding:80px 0px 100px;

}

#error-01 .com-txt-01{
	font-size:24px;
	text-align:center;
}

@media screen and (max-width: 767px) {
  #error-01 .com-txt-01{
	font-size:18px;
	text-align:center;

}
}

#error-01 .com-btn-01{
	margin:40px auto 0;
	border:1px solid #ccc;
	border-radius:10px;
	color:#333;
	width:150px;
	height:50px;
	text-align:center;
	padding:17px;
}
#error-01 .com-btn-01:after{
	display:none;
}

/* タグページ
----------------------------------------------- */
#tag-01 .txt_top {
  margin-top: 30px;
}

@media screen and (max-width: 767px) {
  #tag-01 .txt_top {
    margin-top: 70px;
  }
}

#tag-01 .tag-layout-01 {
  padding: 40px 0 80px;
  background: #fff;
  margin-top: 30px;
}

@media screen and (max-width: 767px) {
  #tag-01 .tag-layout-01 {
    margin-top: 70px;
    padding-top: 80px;
  }
}

#tag-01 .tag-layout-01 .tag {
  justify-content: flex-start;
}

#tag-01 .tag-layout-01 .tag a {
  text-decoration: none;
  background: #fff;
  width: calc(33.333% - 3.5vw * 2/3);
  margin-right: 3.5vw;
  border: 1px solid #ccc;
  margin-bottom: 40px;
}

#tag-01 .tag-layout-01 .tag a:nth-of-type(3n) {
  margin-right: 0;
}

@media screen and (max-width: 767px) {
  #tag-01 .tag-layout-01 .tag a {
    border: none;
    margin-right: 0;
  }
}

#tag-01 .tag-layout-01 .tag a img {
  vertical-align: middle;
  width: 100%;
  height: 160px;
  object-fit: cover;
  object-position: top;
  font-family: 'object-fit: cover; object-position: top;';
}

#tag-01 .tag-layout-01 .tag a .text {
  display: block;
  text-decoration: none;
  padding: 15px 15px 20px 20px;
  height: 135px;
}

@media screen and (max-width: 767px) {
  #tag-01 .tag-layout-01 .tag a .text {
    height: auto;
  }
}

#tag-01 .tag-layout-01 .tag a .text .date {
  font-size: 14px;
  color: #333333;
  line-height: 1.429;
  font-weight: bold;
}

@media screen and (max-width: 767px) {
  #tag-01 .tag-layout-01 .tag a .text .date {
    font-size: 20px;
  }
}

@media screen and (max-width: 500px) {
  #tag-01 .tag-layout-01 .tag a .text .date {
    font-size: 14px;
  }
}

#tag-01 .tag-layout-01 .tag a .text .desc {
  font-size: 14px;
  margin-top: 10px;
  color: #333333;
  line-height: 1.714;
}

@media screen and (max-width: 767px) {
  #tag-01 .tag-layout-01 .tag a .text .desc {
    font-size: 20px;
  }
}

@media screen and (max-width: 500px) {
  #tag-01 .tag-layout-01 .tag a .text .desc {
    font-size: 14px;
  }
}

@media screen and (max-width: 767px) {
  #tag-01 .tag-layout-01 .tag a {
    margin-bottom: 40px;
    width: 100%;
  }
  #tag-01 .tag-layout-01 .tag a li {
    display: flex;
    flex-direction: row;
  }
  #tag-01 .tag-layout-01 .tag a li figure {
    width: 50%;
  }
  #tag-01 .tag-layout-01 .tag a li .text {
    width: 50%;
  }
}

#tag-01 .tag-layout-01 .wp-pagenavi {
  text-align: center;
  padding-top: 40px;
}

#tag-01 .tag-layout-01 .wp-pagenavi .page {
  box-sizing: border-box;
  background: #fff;
  display: inline-block;
  color: #333;
  font-size: 16px;
  font-weight: bold;
  border: 1px solid #ccc;
  width: 35px;
  height: 35px;
  text-decoration: none;
  line-height: 35px;
  margin-right: 6px;
}

@media screen and (max-width: 767px) {
  #tag-01 .tag-layout-01 .wp-pagenavi .page {
    font-size: 20px;
    width: 50px;
    height: 50px;
    margin-right: 10px;
    line-height: 50px;
  }
}

@media screen and (max-width: 500px) {
  #tag-01 .tag-layout-01 .wp-pagenavi .page {
    margin-right: 6px;
    font-size: 16px;
    width: 35px;
    height: 35px;
    line-height: 35px;
  }
}

#tag-01 .tag-layout-01 .wp-pagenavi .current {
  box-sizing: border-box;
  border: 1px solid #008a2a;
  background: #008a2a;
  color: #fff;
  display: inline-block;
  font-size: 16px;
  line-height: 35px;
  width: 35px;
  height: 35px;
  margin-right: 6px;
}

@media screen and (max-width: 767px) {
  #tag-01 .tag-layout-01 .wp-pagenavi .current {
    font-size: 20px;
    line-height: 50;
    width: 50px;
    height: 50px;
    margin-right: 10px;
    line-height: 50px;
  }
}

@media screen and (max-width: 500px) {
  #tag-01 .tag-layout-01 .wp-pagenavi .current {
    line-height: 35;
    margin-right: 6px;
    font-size: 16px;
    width: 35px;
    height: 35px;
    line-height: 35px;
  }
}

#tag-01 .tag-layout-01 .wp-pagenavi .nextpostslink {
  text-decoration: none;
  border: none;
  font-size: 16px;
  font-weight: bold;
  padding-left: 10px;
  color: #333;
}

@media screen and (max-width: 767px) {
  #tag-01 .tag-layout-01 .wp-pagenavi .nextpostslink {
    font-size: 20px;
  }
}

@media screen and (max-width: 500px) {
  #tag-01 .tag-layout-01 .wp-pagenavi .nextpostslink {
    font-size: 16px;
  }
}

#tag-01 .tag-layout-01 .wp-pagenavi .previouspostslink {
  text-decoration: none;
  border: none;
  font-size: 16px;
  font-weight: bold;
  padding-right: 10px;
  color: #333;
}

@media screen and (max-width: 767px) {
  #tag-01 .tag-layout-01 .wp-pagenavi .previouspostslink {
    font-size: 20px;
  }
}

@media screen and (max-width: 500px) {
  #tag-01 .tag-layout-01 .wp-pagenavi .previouspostslink {
    font-size: 16px;
  }
}


/* singleページの文字調整
----------------------------------------------- */
#news-single-01 ul,
#column-single-01 ul,
#news-single-01 ol,
#column-single-01 ol{
	padding-left:30px;
}

#news-single-01 ul li,
#column-single-01 ul li{
	list-style: disc;
}

#news-single-01 ol li,
#column-single-01 ol li{
	list-style: decimal
}

#news-single-01 ul .time,
#column-single-01 ul .time,
#news-single-01 ul .tag,
#column-single-01 ul .tag,
#news-single-01 ul .sns-share,
#column-single-01 ul .sns-share{
	list-style: none;
}

#news-single-01 .sns-share-btn,
#column-single-01 .sns-share-btn{
	padding-left:0;
}

#news-single-01 blockquote,
#column-single-01 blockquote{
	position: relative;
margin: 2em 0;
padding: 1em 1em 1em 2em;
font-size: .9em;
border-left: 5px solid #CCC;
border-radius: 2px;
	display: inline-block;
    font-style: italic;
}

#news-single-01 blockquote:after,
#column-single-01 blockquote:after{
	position: absolute;
bottom: -40px;
right: 0;
content: '”';
font-family: sans-serif;
font-size: 6em;
opacity: .1;
}

#news-single-01 table,
#column-single-01 table,
#news-single-01 table tbody,
#column-single-01 table tbody,
#news-single-01 table tbody tr,
#column-single-01 table tbody tr,
#news-single-01 table tbody tr td,
#column-single-01 table tbody tr td{

}



#news-single-01 p,
#column-single-01 p{
padding-top:1em;
}

#column-single-01 .vol,
#news-single-01 .time,
#news-single-01 .tag,
#column-single-01 .time{
padding-top:0;
}

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

/* ■■■スマホ版フッター固定バナー■■■■■■■■■■■■ */
  
	@media screen and (max-width: 767px) {

.bn_bottom{
  position: fixed;
  left: 0;
  bottom: 0;
  font-size: 13px;
  font-weight: bold;
  color: #fff;
  background: #245839;
  padding: 7px 10px;
  cursor: pointer;
  transition: .3s;
  z-index: 9;
  margin-bottom: 13px;
  margin-left: -2px;
  border: 2px solid #fff;
  
  /*デフォルトで非表示にする*/
  opacity: 0;
  visibility: hidden;
}

.bn_bottom a{
  color: #fff;
  text-decoration: none;
}


/* 
.bn_bottom a:after {
    width: 12px;
    height: 12px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
}

.bn_bottom a:after {
    content: "";
    width: 8px;
    height: 8px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    -webkit-transform: rotate(
45deg
);
    transform: rotate(
45deg
);
    top: 0;
    bottom: 0;
    right: 10px;
    margin: auto;
    vertical-align: middle;
    position: absolute;
}

*/

/*このクラスが付与されると表示する*/
.active{
  opacity: 1;
  visibility: visible;
}
	}
	
	
/* ●●● 銀行振込での納入　/　クレジットカードでの納入 ●●● */
#card_conts .img_card_list_sp {
	width: 100%;
	margin-top: 20px;
	display: none;
}
#card_conts .img_card_list_pc {
	width: 100%;
	}
#card_conts .card_list dd {
	padding-left: 20px;
}
#card_conts .card_list dt {
	font-size: 18px;
}
#card_conts .com-list-01 dt {
	border-right: 1px solid #b8b8b8;
	border-left: 1px solid #b8b8b8;
	background-color: #e5e3cf;
}
#card_conts .com-list-01 dd {
	border-right: 1px solid #b8b8b8;
}
#join-01 #card_conts {
	padding-bottom: 40px;
	padding-top: 0;
	border-bottom: 1px solid #ccc;
}
	
	
@media screen and (max-width: 767px) {
	#card_conts .img_card_list_sp {
		display: block;
	}
	#card_conts .img_card_list_pc {
		display: none;
	}
	#card_conts .card_list dt {
		font-size: 19px;
	}
	#card_conts .card_list dd {
		padding-left: 0;
	}
}

	
	