@charset "UTF-8";
/* CSS Document */
.wf-notosansjapanese {
  font-family: "Noto Sans JP";
}
/*共通部分*/
html {
  font-size: 100%;
}
body {
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
  line-height: 1.7;
  color: #010203; /*テキスト濃紺*/
  margin: 0 auto;
  min-height: 100%;
  display: flex;
  flex-direction: column;
}
a {
  text-decoration: none;
}
img {
  max-width: 100%;
}
article {
  text-align: center;
}
article h1 {
  padding-top: 24px;
  padding-bottom: 24px;
}

/*---------ヘッダー---------------*/
.page-header {
  background-color: #1B2845;
  padding: 0 0 8px 24px;
  color: #EDF2F4;
  position: relative
}
.page-header address {
  position: absolute;
  top: 8px;
  right: 40px;
}
.page-header a {
  color: #EDF2F4;
}
#main-nav {
  background-color: #1B2845;
}
#main-nav ul {
  display: flex;
  margin: 0 auto;
  padding: 0 3%;
  width: 94%;
  max-width: 960px;
}
#main-nav ul li {
  width: calc(100%/6);
  list-style-type: none;
}
#main-nav ul li a {
  display: block;
  padding: 17px 5%;
  width: 96%;
  color: #EDF2F4;
  text-align: center;
  text-decoration: none;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all .3s;
  transition: all .3s;
  border-radius: 25px;
}
#main-nav ul li a:hover {
  background-color: #EDF2F4;
  color: #1B2845;
  opacity: 0.5;
}
.container {
  flex: 1;
  text-align: center;
  min-height: 100vh;
}
.news-page {
  margin: 16px 0 24px 0;
}
.news-page a {
  color: #1B2845;
}
.news-page dd a:hover {
  color: #165BF4;
}
dl.case1 {
  line-height: 1.7;
  width: 960px;
  overflow: hidden;
  zoom: 1;
  margin: 0 auto;
}
dl.case1 dt {
  width: 12rem;
  float: left;
  clear: both;
}
dl.case1 dd {
  margin: 0 10px 10px 0;
  padding: 0 5px 10px 8rem;
  border-bottom: 1px dotted #ccc;
}
/*----------ボタン------*/
.arrow_btn {
  display: inline-block;
  position: relative;
  width: 240px;
  padding: 0.8em;
  text-align: center;
  text-decoration: none;
  color: #1B1B1B;
  background: #fff;
  border-radius: 30px;
  border: 1px solid #1B1B1B;
  transition: transform ease .3s;
	margin: 24px;
}
.arrow_btn:hover {
  text-decoration: none;
  background-color: #1B2845;
  color: #EDF2F4;
}
.arrow_btn span {
  display: inline-block;
  text-decoration: none;
  transition: transform ease .3s;
}
/*--------------試合日程------------*/
.schedule-page {
  background-color: #EDF2F4;
  min-height: 400px;
}
/*----------カードタイプ-------------*/
.grid div:first-of-type {
  box-sizing: border-box;
  background-color: #E4572E;
}
.grid div:nth-child(2n) {
  box-sizing: border-box;
  background-color: #0342AF;
}
.grid div:nth-child(3) {
  box-sizing: border-box;
  background-color: #1B2845;
}
.grid div:nth-child(4) {
  box-sizing: border-box;
  background-color: c;
}
.grid div:last-of-type {
  box-sizing: border-box;
  background-color: #476503;
}
.card a {
  color: #EDF2F4;
}
.grid {
  display: grid;
  grid-template-columns: repeat(5, 192px);
  gap: 15px;
  justify-content: center;
  margin: 16px auto;
}
/*------申し込み---------*/
.entry-page {
  margin: 0 auto;
  text-align: center;
  min-height: 200px;
}
.entry-page p {
  text-align: center;
  padding-bottom: 16px;
}
.album-page {
  background-color: #EDF2F4;
  min-height: 300px;
}
.album-page a {
  color: #1B2845;
}
.album-page dd a:hover {
  color: #165BF4;
}
/*-------------フッター-------------*/
.page-footer {
  color: #EDF2F4;
  background-color: #1B2845;
  margin: 0 auto;
  text-align: center;
  padding: 16px 0;
  width: 100%;
  font-size: 0.75rem;
}
.page-footer a {
  color: #EDF2F4;
}
.footer-border li {
  padding: 0 24px;
  width: 30%;
  display: inline;
  text-align: center;
  border-right: solid #EDF2F4 2px;
}
.footer-border a:hover {
  color: #DCF502;
}
address {
  font-style: normal;
}
.my-color {
  color: #DCF502;
  vertical-align: middle;
}
/*--------テーブル---------*/
body {
  font-family: "Open Sans", sans-serif;
  line-height: 1.25;
}
table {
  border-collapse: collapse;
  margin: 0 auto;
  padding: 0;
  table-layout: fixed;
  color: #010203;
  width: 100%;
}
table tr {
  background-color: #fff;
  padding: .25em;
  border-bottom: 1px solid #bbb;
}
table thead {
  border-bottom: 5px solid #0342af;
}
table tr:last-child {
  border-bottom: none
}
table th, table td {
  padding: 1em 10px 1em 1em;
  border-right: 1px solid #bbb;
}
table th:last-child, table td:last-child {
  border: none;
}
tbody th {
  color: #1B2845;
}
.txt {
  text-align: left;
  font-size: .85em;
}
.name {
  text-align: left;
}
@media screen and (max-width : 486px) {
  table {
    border: 0;
    width: 100%;
  }
  table th {
    display: block;
    border-right: none;
    border-bottom: 5px solid #0342af;
    padding-bottom: .6em;
    margin-bottom: .6em;
  }
  table thead {
    border: none;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
  }
  table tr {
    display: block;
    margin-bottom: 2em;
  }
  table td {
    border-bottom: 1px solid #bbb;
    display: block;
    font-size: .8em;
    text-align: right;
    position: relative;
    padding: .625em .625em .625em 4em;
    border-right: none;
  }
  table td::before {
    content: attr(data-label);
    font-weight: bold;
    position: absolute;
    left: 10px;
  }
  table td:last-child {
    border-bottom: 0;
  }
}
/*PCでは電話できないようにする*/
@media(min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}
@media screen and (max-width: 768px) {
  .page-header address {
    display: none;
  }
}
/*お問い合わせ先*/
.contact {
  width: 650px;
  margin-bottom: 16px;
}
.contact th, .contact td {
  border: 1px solid #ccc;
  padding: 20px;
}
.contact th {
  font-weight: bold;
  background-color: #EDF2F4;
}
@media screen and (max-width : 486px) {
  .contact, .contact tr, .contact td, .contact th {
    display: block;
  }
}
.news {
  font-size: 0.8rem;
  color: #1B2845;
  margin: 16px auto;
}
.css-br::after {
  content: "\A";
  white-space: pre;
}
.my-green {
  color: #217346;
}
.my-red {
  color: #ae0001;
}
#page_top {
  width: 50px;
  height: 50px;
  position: fixed;
  right: 0;
  bottom: 0;
  background: #3f98ef;
  opacity: 0.6;
  border-radius: 50%;
}
#page_top a {
  position: relative;
  display: block;
  width: 50px;
  height: 50px;
  text-decoration: none;
}
#page_top a::before {
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
  content: '\f102';
  font-size: 25px;
  color: #DCF502;
  position: absolute;
  width: 25px;
  height: 25px;
  top: -5px;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;
}
.box01 {
  border: 2px solid #bbb;
  border-radius: 5px;
  position: relative;
  margin-top: 1em;
}
.box01 h3 {
  position: absolute;
  right: 0;
  left: 0;
  top: -1.7em;
  margin-left: 1em;
}
.box01 span {
  padding: 0 .5em;
  background: #E4572E;
  color: #FFF;
  display: inline-block;
  border-radius: 5px;
}
.box01 .inner {
  padding: 1.2em .5em .5em;
}
.main {
  width: 960px;
  margin: 0 auto;
  padding-bottom: 24px;
}
.box02 {
  border: 2px solid #bbb;
  border-radius: 5px;
  position: relative;
  margin-top: 1em;
}
.box02 h3 {
  position: absolute;
  right: 0;
  left: 0;
  top: -1.7em;
  margin-left: 1em;
}
.box02 span {
  padding: 0 .5em;
  background: #0342AF;
  color: #FFF;
  display: inline-block;
  border-radius: 5px;
}
.box02 .inner {
  padding: 1.2em .5em .5em;
}
.box03 {
  border: 2px solid #bbb;
  border-radius: 5px;
  position: relative;
  margin-top: 1em;
}
.box03 h3 {
  position: absolute;
  right: 0;
  left: 0;
  top: -1.7em;
  margin-left: 1em;
}
.box03 span {
  padding: 0 .5em;
  background: #1B2845;
  color: #FFF;
  display: inline-block;
  border-radius: 5px;
}
.box03 .inner {
  padding: 1.2em .5em .5em;
}
.box04 {
  border: 2px solid #bbb;
  border-radius: 5px;
  position: relative;
  margin-top: 1em;
}
.box04 h3 {
  position: absolute;
  right: 0;
  left: 0;
  top: -1.7em;
  margin-left: 1em;
}
.box04 span {
  padding: 0 .5em;
  background: #c10202;
  color: #FFF;
  display: inline-block;
  border-radius: 5px;
}
.box04 .inner {
  padding: 1.2em .5em .5em;
}
.box05 {
  border: 2px solid #bbb;
  border-radius: 5px;
  position: relative;
  margin-top: 1em;
}
.box05 h3 {
  position: absolute;
  right: 0;
  left: 0;
  top: -1.7em;
  margin-left: 1em;
}
.box05 span {
  padding: 0 .5em;
  background: #476503;
  color: #FFF;
  display: inline-block;
  border-radius: 5px;
}
.box05 .inner {
  padding: 1.2em .5em .5em;
}
.schedule {
  text-align: center;
}
.entry-text {
  text-align: left;
  padding-left: 4rem;
  margin-bottom: .75rem;
}
h1 {
  margin: 16px auto;
}
.photogallery {
  display: flex;
  display: -webkit-flex;
  flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
}
.photo {
  position: relative;
  width: 48%;
  height: auto;
  margin: 1%;
  overflow: hidden;
}
.photo:before {
  content: "";
  display: block;
  padding-top: 100%;
}
.photo-inner {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.photo-inner img {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: auto;
  /*  height: 100%;*/
}
/*.photo-rotate {
  position: relative;
  width: 29%;
  height: auto;
  margin: 1%;
  overflow: hidden;
}
.photo-inner-rotate {
  transform: rotate(90deg);
}*/
.album-text {
  padding: 0.5em 1em;
  margin: 0 auto;
  color: #1B2845;
  background: #c6e4ff;
  border-bottom: solid 6px #aac5de;
  border-radius: 9px;
  width: 800px;
  text-align: center;
}
.score-team ol {
  counter-reset: number; /*数字をリセット*/
  list-style-type: none !important; /*数字を一旦消す*/
  padding: 0.5em;
  background: #f5faff;
}
.score-team ol li {
  position: relative;
  padding-left: 30px;
  line-height: 1.5em;
  padding: 0.5em 0.5em 0.5em 30px;
}
.score-team ol li:before {
  /* 以下数字をつける */
  position: absolute;
  counter-increment: number;
  content: counter(number);
  /*以下数字のデザイン変える*/
  display: inline-block;
  background: #5c9ee7;
  color: white;
  font-family: 'Avenir', 'Arial Black', 'Arial', sans-serif;
  font-weight: bold;
  font-size: 15px;
  border-radius: 50%;
  left: 0;
  width: 25px;
  height: 25px;
  line-height: 25px;
  text-align: center;
  /*以下 上下中央寄せのため*/
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.score-team table {
  margin: 20px auto;
}
.tbl-r02 {
  margin-bottom: 48px;
}
.tbl-r02 th {
  background: #1B2845;
  border: solid 1px #ccc;
  color: #fff;
  padding: 10px;
}
.tbl-r02 td {
  border: solid 1px #ccc;
  padding: 10px;
}
.box5 {
  margin: 0 auto;
  width: 80%;
  padding: 0.5em 1em;
  border: double 5px #4ec4d3;
}
.box5 p {
  margin: 0;
  padding: 0;
}
.marker {
  background: linear-gradient(transparent 0%, #fff799 0%);
  font-weight: bold;
  border-radius: 6px;
}
.marker2 {
  background: linear-gradient(transparent 75%, #ff9393 75%);
  font-weight: bold;
}
@media screen and (max-width: 640px) {
  .last td:last-child {
    border-bottom: solid 1px #ccc;
    width: 100%;
  }
  .tbl-r02 {
    width: 80%;
  }
  .tbl-r02 th, .tbl-r02 td {
    border-bottom: none;
    display: block;
    width: 100%;
  }
}