.crumbTitleLnav .lnav ul li.sp { display: block;}
#body > .inner {
  padding-bottom: 220px;
}
.main-swiper {
  margin: 60px;
  text-align: center;
  position: relative;
}
.main-swiper img {
  width: min(100%, 1320px);
  height: auto;
}

.crumbTitleLnav .lnav { display: none;}
.crumbTitleLnav .inner { height: 200px;}
.crumbTitleLnav h1.h101 { padding-bottom: 20px;}

@media only screen and (max-width: 782px) {
  .main-swiper { margin: 2vw;}
  #body > .inner {padding-bottom: 30vw;}
  #header-local-sp { display: none;}
  .crumbTitleLnav .inner { height: 125px;}
  .crumbTitleLnav h1.h101 { padding-bottom: 0px;}
  
  .the-contents img.alignleft {
     float: none;
     margin-right: 0;
     margin-bottom: 2em;
    width: 100%;
    height: auto;
  }

  .the-contents img.alignright {
     float: none;
     margin-bottom: 2em;
    margin-left: 0;
    width: 100%;
    height: auto;
  }
}


.newsBlock article {
  background: #fff;
  padding: 15px 0 10px;
  margin-bottom: 5px;
  display: flex;
  align-items: center;
}
.newsBlock article .header {
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 140px;
  margin-left: 35px;
  text-align: center;
  font-weight: bold;
}
.newsBlock article .header .en {
  background: #002c5b;
  color: #fff;
  font-size: 86%;
  text-align: center;
  padding: 3px;
  letter-spacing: 0.05rem;
}
.newsBlock article .header .jp {
  font-size: 80%;
  padding: 3px;
}
.newsBlock article .date {
  font-weight: bold;
  font-size: 86%;
  margin-left: 35px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.newsBlock article.new .date::after {
  content: "NEW";
  font-family: 'THESPA', sans-serif;
  color: #fff;
  width: 44px;
  height: 20px;
  line-height: 20px;
  font-size: 80%;
  text-align: center;
  background: #e84d70;
  font-weight: normal;
}
.newsBlock article .title {
  font-size: 90%;
  margin-left: 40px;
  font-weight: bold;
}
.newsBlock article .title a:hover { text-decoration: underline;}
.newsBlock p.more {
  margin: 0;
  padding: 0;
  height: 60px;
  line-height: 60px;
  background: #fff;
  text-align: right;
}
.newsBlock p.more a {
  display: inline-block;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 75%;
  padding-left: 30px;
  padding-right: 30px;
  position: relative;
}
.newsBlock p.more a::before {
  content: "";
  width: 10px;
  height: 10px;
  border-top: #002c5b 2px solid;
  border-right: #002c5b 2px solid;
  transform: rotate(45deg);
  position: absolute;
  left: 0;
  top: calc(50% - 5px);
}

@media only screen and (max-width: 782px) {
  .newsBlock article {
    padding: 3vw 5vw;
    display: block;
    margin-bottom: 2.5px;
  }
  .newsBlock article:first-child { padding-top: 7.5vw;}
  .newsBlock article .header {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    width: auto;
    margin-left: 0;
  }
  .newsBlock article .header .en {
    padding: 3px 5vw;
  }
  .newsBlock article .header .jp {
    font-size: 80%;
    padding: 3px;
    margin-left: 2vw;
  }
  .newsBlock article .date {
    font-weight: bold;
    font-size: 86%;
    margin: 2.5vw 0 0 0;
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
  }
  .newsBlock article.new .date::after {
    width: 28px;
    height: 13px;
    line-height: 13px;
    font-size: 70%;
    margin-left: 2vw;
  }
  .newsBlock article .title {
    font-size: 90%;
    margin-left: 0;
  }
  .newsBlock p.more {
    margin: 0;
    padding: 0;
    height: 60px;
    line-height: 60px;
    background: #fff;
    text-align: right;
  }
  .newsBlock p.more a {
    display: inline-block;
    font-family: 'Montserrat', sans-serif;
    font-weight: 600;
    font-size: 75%;
    padding-left: 5vw;
    padding-right: 5vw;
  }
  .newsBlock p.more a::before {
    content: "";
    width: 6px;
    height: 6px;
    border-top: #002c5b 1px solid;
    border-right: #002c5b 1px solid;
    transform: rotate(45deg);
    position: absolute;
    left: 0;
    top: calc(50% - 3px);
  }
}

.h205 {
  display: flex;
  margin-bottom: 50px;
  align-items: baseline;
}
.h205 .en { font-size: 50px; font-weight: bold;}
.h205 .jp { font-size: 114%; font-weight: bold; margin-left: 25px}
.h301 { font-weight: bold; font-size: 145%;}
.h302 {
  display: flex;
  margin-top: 80px;
  margin-bottom: 20px;
  align-items: baseline;
}
.tabContents + .h302 { margin-top: 0;}
.h302 .en { font-size: 40px; }
.h302 .jp { font-weight: bold; margin-left: 20px}

@media only screen and (max-width: 782px) {
  .h205 {
    display: block;
    margin-bottom: 30px;
  }
  .h205 .en { font-size: 25px; display: block; line-height: 1.2;}
  .h205 .jp { font-size: 12px; line-height: 1; display: block; margin-left: 0; margin-top: 10px; }
  .h301 { font-weight: bold; font-size: 125%;}
  .h302 {
    display: block;
    margin-top: 40px;
    margin-bottom: 10px;
  }
  .h302 .en { font-size: 20px; display: inline-block; margin-right: 10px}
  .h302 .jp { display: inline-block; margin-left: 0px; font-size: 12px; line-height: 1;}

}



.flex {
  margin-top: 100px;
  display: flex;
  justify-content: space-between;
}

.select {
  margin-top: 80px;
  display: flex;
  align-items: center;
}
.select label { margin-right: 20px;font-weight: bold; white-space: nowrap;}
.select .cp_ipselect { width: 180px;}

@media only screen and (max-width: 782px) {
  .flex { margin-top: 30px;}
  .select {display: block; margin-top: 40px;}
  .select label { margin-right: 0px; font-size: 10px;}
  .select .cp_ipselect { width: 100px;}
}




.tab {
  margin-top: 80px;
  display: flex;
  justify-content: center;
}
.tab li { width: 360px;}
.tab li + li {
    margin-left: 0px;
}
.tab li a { height: 80px; display: flex; align-items: center; background: #bebebe; font-weight: bold;}
.tab li.on a { background: #002c5b; color: #fff;}
.tabContents { padding-bottom: 50px;}
@media only screen and (max-width: 782px) {
  .membersPhoto { margin: 2vw;}
  .h201 { font-size: 25px; display: block;}
  .h201 .small { margin-left: 0px; display: block;font-size: 12px; line-height: 1;}
  .select {display: block;}
  .select label { margin-right: 0px; font-size: 10px;}
  .select .cp_ipselect { width: 100px;}
  .tab {margin-top: 25px;}
  .tab li { width: 50%;}
  .tab li a { height: 50px; }
  .tabContents { padding-bottom: 20px;}
}


.thumbs {
  display: flex;
  margin-top: 20px;
}
.thumbs h3 { width: calc(100% - 960px);font-size: 50px; line-height: 1.4; font-weight: bold; margin-top: 60px;}
.thumbs h3 span { display: block;}
.thumbs h3 .small { font-size: 28%; letter-spacing: 0;}
.thumbs ul { width: 960px; display: flex; flex-wrap: wrap;}
.thumbs ul li { width: 190px;text-align: right;margin-top: 60px;}
.thumbs li figure {
  position: relative;
  z-index: 1;
}
.thumbs li figure img {
  width: 100%;
  height: 255px;
  object-fit: cover;
}
.thumbs li .text {
  display: inline-block;
  position: relative;
  z-index: 2;
  right: 0;
  margin-top: -30px;
  background: #fff;
  padding: 10px 20px 20px 10px;
  box-sizing: border-box;
  min-width: 150px;
  max-width: 95%;
  font-size: 12px;
}
.thumbs li .text .posi {
  font-size: 169%;
  margin-right: 5px;
  line-height: 1;
}
.thumbs li .text .no {
  font-size: 338%;
  line-height: 1;
}
.thumbs li .text .roman {
  margin-top: 10px;
  font-size: 80%;
  line-height: 1;
}
.thumbs li .text .name {
  margin-top: 10px;
  font-size: 163%;
  line-height: 1.5;
  font-weight: bold;
}
@media only screen and (max-width: 1260px) {
  .thumbs ul.staff-thumbs { margin-top: 100px;}
}
@media only screen and (max-width: 782px) {
  .thumbs {
    display: block;
    margin-top: 10px;
  }
  .thumbs h3 { width: auto;font-size: 25px; margin-top: 30px;}
  .thumbs h3 span { display: inline-block; }
  .thumbs h3 .small { font-size: 40%; margin-left: 10px;}
  .thumbs ul { width: auto; }
  .thumbs ul.staff-thumbs { margin-top: 0px;}
  .thumbs ul li { width: 33.33%;margin-top: 30px;}
  .thumbs li figure img {
    height: 40.6vw;
  }
  .thumbs li .text {
    margin-top: -4vw;
    padding: 10px 10px 20px 10px;
    min-width: 24vw;
    max-width: 90%;
    font-size: 10px;
  }
  
  .thumbs li .text .roman {
    margin-top: 10px;
  }
  .thumbs li .text .name {
    margin-top: 10px;
  }
}

.thumbs + .table-wrapper {width: 960px; margin-left: calc(100% - 960px); margin-top: 60px;}
.under-table-wrapper {width: 960px; margin-left: calc(100% - 960px); margin-top: 20px; font-size: 86%;}
.table-wrapper table { width: 100%;}
.table-wrapper table th {
  background: #002c5b;
  color: #fff;
  text-align: left;
  white-space: nowrap;
  padding: 10px 10px 10px 25px;
}

.table-wrapper table td {
  padding: 10px 10px 10px 25px;
  background: #fff;
  border-top: #f0f0f0 5px solid;
}
.table-wrapper table th.center,
.table-wrapper table td.center {
  text-align: center;
}
.table-wrapper table td a {
  color: #007bfe;
  text-decoration: underline;
}
@media only screen and (max-width: 782px) {
  .thumbs + .table-wrapper,
  .under-table-wrapper,
  .table-wrapper { width: 100%; margin-left:0; margin-top:40px; overflow-x: auto;-webkit-overflow-scrolling: touch; }
  .under-table-wrapper { margin-top:12px;}
  .table-wrapper table th,
  .table-wrapper table td {
    font-size: 12px;
    white-space: nowrap;
  }
  .table-wrapper table td {border-top: #f0f0f0 2.5px solid;}
}

[data-tab="schedule"] .h301 {
  margin-top: 80px;
}
[data-tab="schedule"] .table-wrapper {
  margin: 30px 0;
}
[data-tab="schedule"] th,
[data-tab="schedule"] td {
  font-weight: bold;
  font-size: 90%;
}
table.ranking td.thespa {
  font-weight: normal;
  font-size: 130%;
}
table.ranking td.center.thespa { width: 60px;}
table.schedule .md {
  font-size: 180%;
}
table.schedule td.stadium { font-weight: normal;}
table.schedule td.kekka .score { font-size: 130%;} 
table.schedule .comming td.kekka .score,
table.schedule .calledOff td.kekka .score { display: none;} 
table.schedule .comming td.kekka::before {
  content: "COMMING SOON";
  font-family: 'THESPA', sans-serif;
  font-weight: normal;
  font-size: 90%;
}
table.schedule .calledOff td { background: #d9d9d9;}
table.schedule .calledOff td.kekka::before {
  content: "中止";
  color: #e90000;
  font-weight: bold;
  font-size: 90%;
}

.banners {
  display: flex;
  flex-wrap: wrap;
  width: calc(100% + 30px);
  margin-left: -15px;
}
.banners li {
  margin: 20px 15px 0;
}
@media only screen and (max-width: 782px) {
  .banners {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    width: auto;
    margin-left: 0;
  }
  .banners li {
    margin: 0px 0 5vw;
    width: calc(33.33% - 2.5vw);
  }
  .banners li img { width: 100%; height: auto;}
}
@media only screen and (max-width: 480px) {
  .banners li {width: calc(50% - 2.5vw);}
}




.snsFrame {
  margin-top: 80px;
  display: flex;
  justify-content: space-between;
}
.snsFrame > div {
  width: calc(33.3% - 40px);
  width: calc(50% - 40px);
}
.snsFrame .timeline { height: 600px; /* not work for twitter */}
.snsFrame .timeline iframe {
  width: 100%;
  height: 100%;
}
.snsFrame > div h2 {
  font-weight: bold;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 25px;
}
.snsFrame > div h2 .en {
  font-size: 130%;
}
.snsFrame > div h2 a {
  padding: 5px 2rem;
  font-size: 80%;
  border: #002c5b 1px solid;;
  border-radius: 30px;
}


.fb-page,
.fb-page span,
.timeline iframe{
  width: 100% !important;
  height: 600px !important;
}

@media only screen and (max-width: 782px) {

  .snsFrame {
    margin-top: 10vw;
    display: block;
  }
  .snsFrame > div {
    width: auto;
  }
  .snsFrame > div + div { margin-top: 5vw;}
  .snsFrame .timeline { /*height: 100vw;*/ /* not work for twitter */}
  .snsFrame > div h2 {
    margin-bottom: 5vw;
  }
}