.inner2 {
    width: 74%;
    margin: 35px auto;
    max-width: 800px;
}

#main {
    margin-bottom: 100px !important;
}

.data_txt {
    font-size: 14px;
    color: #999;
    margin-bottom: 55px;
}

.ul_list li {
        margin-bottom: 15px;
        padding-bottom: 15px;
        border-bottom: dotted 1px #666;
}

.ul_list span {
        color: #009845;
        font-size: 12px;
        font-weight: 600;
        margin-right: 25px;
}

.nav_link {
    display: flex;
    border-top: solid 1px #ccc;
    border-bottom: solid 1px #ccc;
}

.nav_link li {
    position: relative;
    width: 50%;
    margin: 5px 0;
    font-weight: 600;
}
.nav_link li a {
    padding: 35px;
    display: block;
}

.pre_post {
    border-right: solid 1px #eee;
    text-align: left;
}
.ne_post {
    text-align: right;
}
.pre_post:before {
    bottom: 40%;
    position: absolute;
    margin-right: 10px;
    font-family: "Material Icons";
    content: "\e5c4";
    color: #ccc;
    font-size: 16px;
    font-weight: bold;
}
.ne_post:after {
    bottom: 40%;
    right: 0;
    position: absolute;
    margin-left: 10px;
    font-family: "Material Icons";
    content: "\e5c8";
    color: #ccc;
    font-size: 16px;
    font-weight: bold;
}

.nav_link li span {
    font-size: 14px;
    color: #999;
    display: block;
    font-weight: normal;
}

@media screen and (max-width: 769px) {
    .inner2 {
        width: 90%;
    }
    .nav_link {
        display: block;
    }
    .nav_link li {
        width: 100%;
    }

    .nav_link li a {
        padding: 10px 25px;
    }
    .pre_post {
        border-right: none;
    }
    .ne_post {
        text-align: left;
    }
    .ne_post:after {
        content: "";
    }
    .ne_post:before {
        bottom: 40%;
        position: absolute;
        margin-right: 10px;
        font-family: "Material Icons";
        content: "\e5c4";
        color: #ccc;
        font-size: 16px;
        font-weight: bold;
    }
}

/******************************
 * CONTACT
******************************/
.table-contactform7 {
	margin-top: 55px;
  overflow: hidden;
  table-layout: fixed;
}
#wpcf7cpcnf table {
  margin-top: 55px;
  width: 100%;
}
 
.required-contactform7{
  padding: 0 5px;
  background: #c00;
  color: #fff;
  border-radius: 3px;
  margin-right: 3px;
  font-size: 14px;
  margin-right: 0.5em;
}
 
.unrequired-contactform7{
  padding: 5px;
  background: #BDBDBD;
  color: #fff;
  border-radius: 3px;
  margin-right: 3px;
}

#wpcf7cpcnf table th {
  font-weight:bold;
  padding: 7px 0;
}
.table-contactform7 th{
  font-weight:bold;
}
 
.table-contactform7 input,
.table-contactform7 textarea{
  max-width: 90% !important;
  margin: 5px 10px 10px 5px;
}
 
.address-100 input{
  max-width: 90% !important;
  margin: 5px 10px 10px 5px;
}
 
.message-100 textarea{
  width: 100%;
  margin: 5px 10px 10px 5px;
}

.text-xs-center {
  margin: 25px auto;
  text-align: center;}

.text-xs-center input {
  padding: 5px 35px;
  border: solid 1px #999;
  margin: 25px auto;

}

div.wpcf7cp-btns {
  margin-top: 25px;
  margin: 25px auto;
  text-align: center;
}

button.wpcf7cp-cfm-edit-btn {
  padding: 5px 35px;
  border: solid 1px #999;
  background: #eee !important;
}
button.wpcf7cp-cfm-submit-btn {
  padding: 5px 35px;
  border: solid 1px #999;
  background: #eee !important;
}
div.wpcf7cp-btns button:hover {
  background: #ccc !important;
}

.bg_eee {
  background:#eee;
  padding:15px;
  margin:25px 0;
}
 
@media screen and (min-width: 900px){
  #wpcf7cpcnf table th p,
  .table-contactform7 th p{
    width:240px;
  }
}
     
@media screen and (max-width: 900px){
  #wpcf7cpcnf table,
.table-contactform7{
  display:block;
}     
 
#wpcf7cpcnf table tbody,
#wpcf7cpcnf table tr,
  .table-contactform7 tbody,
  .table-contactform7 tr{
    display: block;
    width: 100%;
  }
  #wpcf7cpcnf table th,
  .table-contactform7 th{
  width:100%;
  display:block;
  margin: 0 auto;
  border:none;
}
#wpcf7cpcnf table td,
.table-contactform7 td{
  display: list-item;
  list-style-type:none;
  margin:0;
  padding:0;
  width: 100%;
  border-top: none !important;
}
}

/******************************
 * 個人情報
******************************/
#privacy dl dt {
  font-size: 1.5em;
  color: #009845;
  margin-bottom: 15px;
  font-weight: 600;
  border-bottom: dotted 2px #009845;
  padding-bottom: 5px;

}

#privacy dl dd {
  margin-bottom: 80px;
}

#privacy dl dd span {
  font-weight: 600;
  display: block;
  margin:25px 0 5px 0;
}

#privacy dl dd ol li {
  margin-left: 1em;
  list-style: disc;
}

/******************************
 * 協会について
******************************/
#about_ul ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

#about_ul ul li {
      width: 49%;
      margin-bottom: 25px;
      text-align: center;
      position: relative;
}
#about_ul ul li img {
  width: 100%;
  height: auto;
  max-width: 600px;
  filter: brightness(40%);
  transition-duration: 0.5s;
}
#about_ul ul li img:hover{
  filter: brightness(90%);
  transition-duration: 0.5s;
  color: #000;
}
#about_ul ul li p {
          position: absolute;
          left: 50%;
          top: 50%;
          transform: translate(-50%,-50%);
          font-size: clamp(1.25rem, 1.159rem + 0.45vw, 1.5rem);
          color: #fff;
          line-height: 1.1;
          white-space: nowrap;
}
@media screen and (max-width: 560px) {
  #about_ul ul {
      display: block;
  }
  #about_ul ul li {
          width: 100%;
          margin-bottom: 7px;
  }
  #about_ul .textc {
      text-align: left;
  }  
}

/******************************
 * 設立趣旨・あいさつ
******************************/
#act2 {
  display: flex;
  justify-content: space-between;
}

#act2 .text_act2 {
  width: 65%;
  background: rgb(255, 255, 255, 0.8);
  padding: 55px;
  border: solid 1px #ccc;
  border-radius:25px;
  line-height: 2.2;
}

@media screen and (max-width: 700px) {
  #act2 {
    display: block;
  }
  #act2 .text_act2 {
    width: 100%;
    padding: 35px;
  }
}

/******************************
 * 事務局
******************************/
#jimukyoku dl {
  margin-bottom: 80px;
  display: flex;
  flex-wrap: wrap;
}

#jimukyoku dl dt {
  width: 30%;
  padding: 25px 15px;
  border-bottom: solid 2px #009845;
  font-weight: bold;
}

#jimukyoku dl dd {
  width: 70%;
  padding: 25px 15px;
  border-bottom: solid 1px #ccc;
}

/******************************
 * 活動
******************************/
#act {
  display: flex;
  justify-content: space-between;
}

#act .text_act {
  width: 65%;
}

#act ul li span {
  margin-right: 15px;
  width: 5em;
  display: inline-block;
}

.content_act2 {
  width: 30%;
}

.content_act2 li img {
  width: 100%;
  height: auto;
  margin-bottom: 7px;
}

.content_act {
  width: 30%;

  display: flex;
  justify-content: center;
  align-items: center;
  height: 1000px;
  max-width: 350px;
  position: relative;
  overflow: hidden;
}

.swiper {
  height: 100%;
  width: 100%;
  position: absolute!important;
}
.swiper2{
    left: 0;
    top: 0;
}
.swiper-wrapper {
  transition-timing-function: linear;
}
.swiper-slide img {
    height: 100%;
    width: 150%;
    margin-left: -25%;
    max-width: none;
    object-fit: cover;
    transform: skew(10deg);
}

@media screen and (max-width: 700px) {
  #act {
    display: block;
  }
  #act .text_act {
    width: 100%;
    margin-bottom: 35px;
  }
  #act .content_act2 {
    width: 100%;
  }
  #act .content_act2 ul {  
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  #act .content_act2 ul li {
    width: 49%;
  }
}

/******************************
 * リンク
******************************/
#link li {
  margin-bottom: 12px;
  border-bottom: dotted 2px #998;
  padding-bottom: 11px;
}
#link li:before {
  bottom: -3px;
  position: relative;
  margin-right: 15px;
  font-family: "Material Icons";
  content: "\e80d";
  color: #009845;
  font-weight: 600;
}

/******************************
 * 入会案内
******************************/
#annai .c_add {
  margin: 55px;
  border: solid 1px #999;
  padding: 25px;
}

#annai .c_add dt {
  font-size: 1.2em;
  padding-bottom: 3px;
  margin-bottom: 25px;
  border-bottom: solid 1px #999;
}

#annai .c_add dd span {
  margin-left: 1em;
}
#annai .c_add dd .material-icons {
  margin-left: 0;
}

.m_price,
.m_price2 {
  margin-bottom: 35px;
}

.m_price dt {
  clear: left;
  float: left;
  width: 10em;
}
.m_price dd {
  margin-left: 10em;
}
.m_price2 dt {
  clear: left;
  float: left;
  width: 18em;
}
.m_price2 dd {
  margin-left: 18em;
}

.button {
  margin-top: 55px
}
.button a {
  position: relative;
  display: flex;
  justify-content: space-around;
  align-items: center;
  margin: 0 auto;
  border-radius: 9999px;
  max-width: 350px;
  padding: 16px;
  color: #fff;
  line-height: 1.8;
  text-decoration: none;
  transition: 0.3s ease-in-out;
  font-weight: 500;
  background: linear-gradient(270deg, #3bade3 0%, #576fe6 25%, #9844b7 51%, #ff357f 100%);
  background-position: 1% 50%;
  background-size: 200% auto;
  transition: all 0.3s ease-out;
  font-size: clamp(1.313rem, 1.153rem + 0.8vw, 1.75rem);
}
.button a:hover {
  color: #fff;
  background-position: 99% 50%;
}
.button a:after {
  content: '';
  width: 15px;
  height: 15px;
  border-top: 3px solid #fff;
  border-right: 3px solid #fff;
  transform: rotate(45deg) translateY(-50%);
  position: absolute;
  top: 48%;
  right: 20px;
  border-radius: 1px;
  transition: 0.3s ease-in-out;
}

@media screen and (max-width: 700px) {
  #annai .c_add {
    margin: 55px 0;
  }
  #annai .c_add dd span {
    margin-left: 0;
    display: block;
  }
}
@media screen and (max-width: 560px) {
  .m_price dt,
  .m_price2 dt {
      float: none;
    width: 100%;
    font-weight: bold;
  }
  .m_price dd,
  .m_price2 dd {
      margin-left: 0;
    margin-bottom: 25px;
  }
  
}

/******************************
 * 組織
******************************/
.member_ichiran {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;

}

.member_ichiran tr th,
.member_ichiran tr td {
  border: solid 1px #999;
  padding: 7px;
}

.member_ichiran th {
  width: 6em;
  background: #eee;
  padding: 7px 10px;
}


.member_ichiran td span {
  display: inline-block;
  vertical-align: text-top;
}
.member_ichiran td span:not(:last-of-type) {
  margin-right: 15px;
}

.member_ichiran td span:first-of-type {
    width: 100%;
    display: block;
}

@media screen and (max-width: 700px) {
  .member_ichiran tr th,
  .member_ichiran tr td {
    display: block;
    width: 100%;
  }
  .member_ichiran tr td {
    border-top: none;
    border-bottom: none;
    line-height: 1.2;
  }
  .member_ichiran td span {
    vertical-align:bottom;
  }
  .member_ichiran td span:not(:last-of-type) {
    margin-top: 7px;
  }
}