@charset "UTF-8";

/*****************************
  pagesec-mission
*****************************/
.pagesec-mission .ttlbox {
  margin-bottom: 2rem;
}
.pagesec-mission .ttlbox .enttl{
  color: #cacaca;
  font-family: "Cormorant Garamond", serif;
  font-size: 8rem;
  line-height: 1;
}
.pagesec-mission .ttlbox .ttl{
  font-size: 2.4rem;
  font-weight: bold;
  padding-left: 4rem;
  position: relative;
}
.pagesec-mission .ttlbox .ttl::before{
  content: "";
  background: #0B97D2;
  position: absolute;
  top: 21px;
  left: 0;
  height: 3px;
  width: 3rem;
}
@media only screen and (max-width: 1180px) {
  
}
@media only screen and (max-width: 1024px) {
  
}
@media only screen and (max-width: 820px) {
  
}
@media only screen and (max-width: 768px) {
  
}
@media only screen and (max-width: 767px) {
  .pagesec-mission .ttlbox .enttl {
    font-size: 6rem;
    margin-left: -1rem;
  }
  .pagesec-mission .ttlbox .ttl {
    font-size: 1.8rem;
    padding-left: 2.5rem;
    padding-right: 1rem;
  }
  .pagesec-mission .ttlbox .ttl::before {
    top: 0;
    left: 1rem;
    height: 80%;
    width: 3px;
  }
}

/*****************************
  pagesec-greeting
*****************************/
.pagesec-greeting .greeting::after{
  content: "";
  clear: both;
}
.pagesec-greeting .imgbox{
  width: 30%;
  float: left;
  padding-right: 2rem;
}
.pagesec-greeting .txtbox .ttl{
  font-size: 2rem;
  font-weight: bold;
  margin-bottom: 1rem;
}
.pagesec-greeting .txtbox .name{
  text-align: right;
}
.pagesec-greeting .linkgr{
  gap: 1rem;
  margin: 5rem auto 0;
}
@media only screen and (max-width: 1180px) {
  
}
@media only screen and (max-width: 1024px) {
  
}
@media only screen and (max-width: 820px) {
  
}
@media only screen and (max-width: 768px) {
  
}
@media only screen and (max-width: 767px) {
  .pagesec-greeting .imgbox{
    float: none;
    margin: 0 auto 2rem;
    padding: 0;
    width: 200px;
  }
}

/*****************************
  pagesec-faq
*****************************/

@media only screen and (max-width: 1180px) {
  
}
@media only screen and (max-width: 1024px) {
  
}
@media only screen and (max-width: 820px) {
  
}
@media only screen and (max-width: 768px) {
  
}
@media only screen and (max-width: 767px) {
  
}

/*****************************
  pagesec-overview
*****************************/
.pagesec-overview .imgbox{
  margin: 2rem 0 1rem;
  text-align: left;
}
.pagesec-overview .contact > div,
.pagesec-overview .access > div,
.pagesec-overview .history > div:not(:last-of-type){
  margin-bottom: 1rem;
}
.pagesec-overview .contact > div dt,
.pagesec-overview .access > div dt{
  font-weight: bold;
}
.pagesec-overview .contact > div dd,
.pagesec-overview .access > div dd{
  margin-left: 2rem;
}
.pagesec-overview .history dt{
  width: 60px;
}
.pagesec-overview .history dd{
  width: calc(100% - 60px);
}
@media only screen and (max-width: 1180px) {
  
}
@media only screen and (max-width: 1024px) {
  
}
@media only screen and (max-width: 820px) {
  
}
@media only screen and (max-width: 768px) {
  
}
@media only screen and (max-width: 767px) {
  .pagesec-overview .history dt,
  .pagesec-overview .history dd{
    width: 100%;
  }
  .pagesec-overview .contact > div dd,
  .pagesec-overview .access > div dd{
    margin-left: 0;
  }
  .pagesec-overview .history dt{
    font-weight: bold;
  }
}

/*****************************
  pagesec-rules
*****************************/
.pagesec-rules dl{
  margin-bottom: 2rem;
}
.pagesec-rules dl > div{
  margin-bottom: 1rem;
}
.pagesec-rules dl dt{
  font-size: 1.8rem;
  font-weight: bold;
  padding-left: 2rem;
  position: relative;
}
.pagesec-rules dl dt::before{
  content: "●";
  color: #0B97D2;
  position: absolute;
  top: 0;
  left: 0;
}
@media only screen and (max-width: 1180px) {
  
}
@media only screen and (max-width: 1024px) {
  
}
@media only screen and (max-width: 820px) {
  
}
@media only screen and (max-width: 768px) {
  
}
@media only screen and (max-width: 767px) {
  .pagesec-rules dl dt{
    font-size: 1.6rem;
  }
}

/*****************************
  pagesec-teikan
*****************************/
.pagesec-teikan .morebtn3{
  text-align: center;
}

.pagesec-teikan .linkgr{
  gap: 1rem;
  margin: 5rem auto 0;
}

/*****************************
  賛助会員
*****************************/
.supmemtbl{
  border-top: 1px solid #0ae;
  border-left: 1px solid #0ae;
  border-collapse: collapse;
  width: 100%;
}
.supmemtbl th{
  border-bottom: 1px solid #0ae;
  border-right: 1px solid #0ae;
  padding: 20px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  background-color: #edf7fc;
  text-align: left;
  vertical-align: middle;
  width: 25%;
  min-width: 180px;
}
.supmemtbl td{
  border-bottom: 1px solid #0ae;
  border-right: 1px solid #0ae;
  padding: 20px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  text-align: left;
}
.supmemtbl ul{
  margin-bottom: 20px;
}

/* スクロールヒント */
.table01 {
  width: 100%;
  text-align: center;
  border-collapse: collapse;
  border-spacing: 0;
}
@media screen and (max-width: 767px) {
    .table01 {
  width: 800px;
  }
  .js-scrollable{
  max-width: 100%;
  overflow: auto;
  }
}

.postbox{
  border: 1px solid #0ae;
  padding: 20px;
  margin-top: 20px;
  display: inline-block;
  text-align: left;
}