p{
  font-family: 'Libre Baskerville','游明朝','Yu Mincho','Hiragino Mincho Pro', serif;
}
@media only screen and (max-width: 428px) {
  main {
    margin-top: 0;
  }
}

#site-header,
#site-header .nav-menu,
#site-header .drop-menu-list {
  background-color: transparent;
}
#site-contents .top-wrap img.top {
  padding-top: 0;
}

#site-contents{
  width: 100%;
  text-align: center;
}

/**** トップイメージ ****/
#site-contents .top-wrap{
  position: relative;
}
#site-contents .top-wrap img.title {
  position: absolute;
  top: 10rem;
  left: 5rem;
  width: 690px;
}
@media screen and (min-width: 768px) {
  #site-contents .top-wrap img.title.sp,
  #site-contents .top-wrap img.top.sp {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  #site-contents .top-wrap img.title.pc,
  #site-contents .top-wrap img.top.pc {
    display: none;
  }
  #site-contents .top-wrap img.title {
    position: absolute;
    top: 8rem;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    width: 150px;
  }
}

/**** メイン ****/
#site-contents .content-wrap .message{
  /*background-image: radial-gradient( ellipse farthest-side at 100% -30%,#004097 15%, #fff 100% );*/
  background-image: url(../img/top/img-message-back.jpg);
  background-size: 100%;
  background-repeat: no-repeat;
}
#site-contents .content-wrap .message .frame{
  max-width: 1100px;
  margin: 0 auto;
  padding-top: 8rem;
  position: relative;
}
#site-contents .content-wrap .message .frame h2{
  color: #fff;
  text-align: right;
  max-width: 530px;
  width: auto;
  margin-left: auto;
  margin-bottom: 6rem;
  padding-bottom: 3rem;
  border-bottom: 1px solid #fff;
}
#site-contents .content-wrap .message .frame .number{
  position: absolute;
  top: 3rem;
  left: -7rem;
  width: 850px;
}
#site-contents .content-wrap .message .frame .box{
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 3rem;
}
#site-contents .content-wrap .message .frame .box .name{
  flex-basis: 400px;
  position: relative;
}
#site-contents .content-wrap .message .frame .box .name div{
  background-color: #fff;
  width: 150px;
  padding: 1.2rem 0;
  position: absolute;
  bottom: -4rem;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
}
#site-contents .content-wrap .message .frame .box .name div img{
  position: absolute;
  left: -0.3rem;
  bottom: 0.3rem;
}
#site-contents .content-wrap .message .frame .box .name div p{
  text-align: center;
  font-weight: bold;
}
#site-contents .content-wrap .message .frame .box .name div p:last-of-type{
  font-size: 20px;
}
#site-contents .content-wrap .message .frame .box .con{
  flex-basis: 45%;
  max-height: 550px;
  height: auto;
  overflow: scroll;
  padding: 0 1rem;
  -ms-overflow-style: none;
}
/*スクロールバー非表示（Chrome・Safari）*/
#site-contents .content-wrap .message .frame .box .con::-webkit-scrollbar{
  display:none;
}
#site-contents .content-wrap .message .frame .box .con h3{
  font-size: 38px;
  color: #fff;
  text-align: center;
  margin-bottom: 1rem;
}
#site-contents .content-wrap .message .frame .box .con p{
  line-height: 400% !important;
}
#site-contents .content-wrap .message .frame .box .con p:last-of-type{
  margin-top: 3rem;
}
#site-contents .content-wrap .message .img{
  margin-top: -3rem;
}
@media screen and (min-width: 768px) {
  #site-contents .content-wrap .message .img img:last-of-type {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  #site-contents .content-wrap .message{
    background-image: url(../img/top/img-message-back-sp.jpg);
  }
  #site-contents .content-wrap .message .frame {
    padding-top: 2rem;
  }
  #site-contents .content-wrap .message .frame .number {
    position: relative;
    top: auto;
    left: auto;
    width: 100%;
  }
  #site-contents .content-wrap .message .frame h2 {
    margin-top: 2rem;
    margin-bottom: 3rem;
    padding-right: 2rem;
  }
  #site-contents .content-wrap .message .frame .box {
    display: block;
    padding: 0 2rem;
  }
  #site-contents .content-wrap .message .frame .box .con {
    margin-top: 8rem;
  }
  #site-contents .content-wrap .message .frame .box .con h3 {
    font-size: 30px;
  }
  #site-contents .content-wrap .message .frame .box .con p {
    line-height: 250% !important;
  }
  #site-contents .content-wrap .message .img img:first-of-type {
    display: none;
  }
}
@media only screen and (max-width: 428px) {
  #site-contents .content-wrap {
    max-width: unset;
  }
}

#site-contents .content-wrap .part{
  padding: 7rem 0;
}
#site-contents .content-wrap .part .frame{
  max-width: 1100px;
  margin: 0 auto;
}
#site-contents .content-wrap .part .part-slider {
  overflow: hidden;
  white-space: nowrap;
}
#site-contents .content-wrap .part .part-slider ul{
  display: inline-block;
  animation: flowing 80s linear infinite;
  transform: translateX(100%);
  margin-bottom: 0;
}
@keyframes flowing {
  0% { transform:translateX(0); }
  100% { transform:translateX(-100%); }
}
#site-contents .content-wrap .part .part-slider ul li{
  width: 550px;
  margin-right: 1rem;
  display: inline-block;
}

#site-contents .content-wrap .part01{
  background-color: #004097;
}
#site-contents .content-wrap .part01 .frame{
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#site-contents .content-wrap .part01 .frame .number{
  flex-basis: 40%;
}
#site-contents .content-wrap .part01 .frame .box{
  flex-basis: 50%;
}
#site-contents .content-wrap .part01 .frame .box h2{
  color: #fff;
  text-align: right;
  margin-bottom: 3rem;
  padding-top: 0;
  padding-bottom: 3rem;
  border-bottom: 1px solid #fff;
}
#site-contents .content-wrap .part01 .frame .box .con{
  max-width: 460px;
  width: auto;
  margin-left: auto;
}
#site-contents .content-wrap .part01 .frame .box .con p{
  color: #fff;
}
#site-contents .content-wrap .part01 .frame .box .con .img{
  max-width: 450px;
  width: auto;
  margin-left: auto;
  margin-top: 5rem;
  margin-bottom: 2rem;
}
#site-contents .content-wrap .part01 .part-slider {
  margin-top: 3rem;
}
@media screen and (min-width: 768px) {
  #site-contents .content-wrap .part01 .frame .box .number{
    display: none;
  }
}
@media screen and (max-width: 767px) {
  #site-contents .content-wrap .part01 .frame {
    display: block;
  }
  #site-contents .content-wrap .part01 .frame > .number{
    display: none;
  }
  #site-contents .content-wrap .part01 .frame .box h2 {
    width: auto;
    padding-left: 2rem;
    padding-right: 2rem;
  }
  #site-contents .content-wrap .part01 .frame .box .con {
    padding: 0 2rem;
  }
  #site-contents .content-wrap .part01 .frame .box .number{
    max-width: 230px;
    width: auto;
    margin: 0 auto;
    margin-top: 5rem;
  }
  #site-contents .content-wrap .part01 .frame .box .con .img {
    margin-top: 2rem;
  }
  #site-contents .content-wrap .part .part-slider ul li {
    width: 450px;
  }
}

#site-contents .content-wrap .part02{
  background-color: #CCD7DD;
}
#site-contents .content-wrap .part02 .frame {
  margin-top: 3rem;
}
#site-contents .content-wrap .part02 a.btn_02 {
  color: #004097 !important;
  border: 1px solid #004097 !important;
}
#site-contents .content-wrap .part02 a.btn_02:hover {
  color: #fff !important;
}
#site-contents .content-wrap .part02 a.btn_02 svg {
  fill: #004097;
}
#site-contents .content-wrap .part02 a.btn_02:hover .cls-2 {
  stroke: #fff;
}
#site-contents .content-wrap .part02 a.btn_02::after {
  background: #004097;
}
@media screen and (min-width: 768px) {
  #site-contents .content-wrap .part02 .frame .number img:last-of-type {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  #site-contents .content-wrap .part02 .frame {
    padding: 0 2rem;
  }
  #site-contents .content-wrap .part02 .frame .number img:first-of-type {
    display: none;
  }
  #site-contents .content-wrap .part02 .frame .box {
    margin-top: 2rem;
  }
}

#site-contents .content-wrap .club{
  margin-top: -3rem;
}
#site-contents .content-wrap .club .club-t{
  background: linear-gradient(#CCD7DD, 25%, #fff);
  padding-top: 15rem;
}
#site-contents .content-wrap .club .frame{
  display: flex;
  justify-content: space-between;
  align-items: end;
  max-width: 1100px;
  margin: 0 auto;
}
#site-contents .content-wrap .club .frame .box{
  flex-basis: 530px;
}
#site-contents .content-wrap .club .frame section{
  flex-basis: fit-content;
}
#site-contents .content-wrap .club .frame .box h2{
  color: #00348E;
  text-align: justify;
  margin-bottom: 3rem;
  padding-top: 0;
  padding-bottom: 3rem;
  border-bottom: 1px solid #00348E;
}
#site-contents .content-wrap .club .frame .box h2 span{
  color: #F29600;
}
#site-contents .content-wrap .club .frame .box .con{
  max-width: 460px;
  width: auto;
}
#site-contents .content-wrap .club .frame section a.btn_02 {
  color: #004097 !important;
  border: 1px solid #004097 !important;
}
#site-contents .content-wrap .club .frame section a.btn_02:hover {
  color: #fff !important;
}
#site-contents .content-wrap .club .frame section a.btn_02 svg {
  fill: #004097;
}
#site-contents .content-wrap .club .frame section a.btn_02:hover .cls-2 {
  stroke: #fff;
}
#site-contents .content-wrap .club .frame section a.btn_02::after {
  background: #004097;
}
@media screen and (max-width: 767px) {
  #site-contents .content-wrap .club .frame {
    display: block;
  }
  #site-contents .content-wrap .club .frame .box h2 {
    text-align: right;
    width: auto;
    padding-left: 2rem;
    padding-right: 2rem;
  }
  #site-contents .content-wrap .club .frame .box .con {
    padding-left: 2rem;
    padding-right: 2rem;
  }
  #site-contents .content-wrap .club .frame section{
    margin-top: 3rem;
  }
}

@media screen and (max-width: 428px) {
  #site-contents .flex-wrap h2,
  #site-contents .flex-wrap h4,
  #site-contents .back01 .flex-wrap p {
    padding-left: 2rem;
    padding-right: 2rem;
    width: auto;
  }
  #site-contents .content-wrap .part .part-slider ul {
    animation: flowing 30s linear infinite;
}
}
/*ipad版スタート*/
@media only screen and (max-width: 1024px) and (min-width: 429px){
  #site-contents .content-wrap .message .frame .box {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 3rem;
    max-width: 700px;
    margin: 0 auto;
}
#site-contents .content-wrap .club .frame {
    max-width: 700px;
    margin: 0 auto;
}
  #site-contents .content-wrap .part .frame {
    max-width: 700px;
    margin: 0 auto;
}
#site-contents .flex-wrap {
    max-width: 700px;
    margin: 0 auto;
}
}
