.h201 {
  margin: 80px 0 30px;
  display: flex;
  align-items: baseline;
  font-size: 50px;
  font-weight: bold;
}
.h201 .en { font-weight: 700;}
.h201 .small { font-size: 35%; margin-left: 20px;}
@media only screen and (max-width: 782px) {
  .h201 { font-size: 25px; display: block; margin: 5vw 0;}
  .h201 .small { margin-left: 0px; display: block; font-size: 12px; line-height: 1;}
}
.resultSection {
}
.resultSection h3 {
  background: #002c5b;
  color: #fff;
  text-align: center;
  padding: 15px 30px;
  font-size: 24px;
  font-weight: bold;
}
.resultSection .result {
  display: flex;
  justify-content: center;
  position: relative;
  background: #fff;
  margin-top: 5px;
  padding: 40px;
}

@media only screen and (max-width: 782px) {
  .resultSection {}
  .resultSection h3 {padding: 10px 2.5vw;font-size: max(2.7vw,12px);}
  .resultSection .result { padding: 2.5vw; margin-top: 2.5px;}
}

.resultSection .team {
  width: 300px;
  text-align: center;
}
.resultSection .team h5 {
  font-size: 156%;
  line-height: 1;
  margin: 10px auto 0;
  overflow: hidden;
  position: relative;
}
.resultSection .team h5::before,
.resultSection .team h5::after {
  content: "";
  position: absolute;
  width: 50px;
  height: 2px;
  background: #002c5b;
  top: calc(50% - 1px);
}
.resultSection .team h5::before { left: calc(50% - 90px);}
.resultSection .team h5::after { left: calc(50% + 40px);}
.resultSection .team figure { margin-top: 10px;}
.resultSection .team figure img {
  width: 210px;
  height: 210px;
  object-fit: contain;
}
.resultSection .team p { margin-top: 10px; font-size: 130%; letter-spacing: 1.5; font-weight: bold;}
@media only screen and (max-width: 782px) {
  .resultSection .team {
    width: 16vw;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
  .resultSection .team h5 {
    font-size: 130%;
    margin: 0 auto 0;
  }
  .resultSection .team h5::before,
  .resultSection .team h5::after {display: none;}
  .resultSection .team figure { margin-top: 10px;}
  .resultSection .team figure img {
    width: 16vw;
    height: 16vw;
    object-fit: contain;
  }
  .resultSection .team p { margin-top: 8px; font-size: 130%; letter-spacing: 1.5;}
}

.resultSection .info {
  width: 480px;
  position: relative;
  text-align: center;
}
.resultSection .info h4 {
  font-size: 26px;
  line-height: 1;
}

.resultSection .info h4 .week {
  margin-left: 5px;
  margin-right: 12px;
}
.resultSection .info p.stadium { margin: 10px 0 0 0; font-weight: bold;}
.resultSection .info .score {
  margin-top: 15px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  white-space: nowrap;
}
.resultSection .info .score .total {
  font-size: 1000%;
  line-height: 1;
  width: 160px;
  text-align: center;
}
.resultSection .info .score p.halfScore {
  margin: 0;
  line-height: 1;
  display: flex;
  justify-content: center;
  align-items: center;
}
.resultSection .info .score p.halfScore + p.halfScore {
  margin: 20px 0 0 0;
}
.resultSection .info .score p.halfScore .thespa { font-size: 35px; width: 50px; text-align: center;}
.resultSection .info .score p.halfScore .jp { font-size: 20px; font-weight: bold;}
.resultSection .info .score div { display: none;}

.resultSection .info .score::after {
  content: "VS";
  display: block;
  text-align: center;
  font-family: 'THESPA', sans-serif; 
  font-size: 1000%;
  line-height: 1;
  width: 100%;
}
.resultSection .show-score .info .score div { display: inline-block;}
.resultSection .show-score .info .score::after { display: none;}
.resultSection .info p.situation {
  text-align: center;
}
.resultSection .info p.situation span {
  background: #002c5b;
  color: #fff;
  font-size: 130%;
  font-weight: bold;
  display: inline-block;
  width: min(100%, 300px);
  padding: 2px 0;
}

@media only screen and (max-width: 782px) {
  .resultSection .info {
    width: 54vw;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
  .resultSection .info h4 { font-size: max(3.5vw, 16px); line-height: 1.4;}
  .resultSection .info h4 .week {
    margin-left: 0.5vw;
    margin-right: 1vw;
  }
  .resultSection .info p.stadium { margin: 5px 0 0 0; font-size: 2.8vw;}
  .resultSection .info .score .total,
  .resultSection .info .score::after {
    font-size: 18vw;
  }
  .resultSection .info .score .total { width: 16.5vw;}
  .resultSection .info .score p.halfScore + p.halfScore {
    margin: 10px 0 0 0;
  }
  .resultSection .info .score p.halfScore .thespa { font-size: 5vw; width: 8vw;}
  .resultSection .info .score p.halfScore .jp { font-size: 3vw;}

  .resultSection .info p.situation span { width: 40vw; font-size: min(4vw, 18px);}
}
.resultSection .goalInfos {
  background: #fff;
  padding: 0 35px 40px;
}
.resultSection .goalInfos h4 {
  text-align: center;
  font-size: 35px;
}
body[data-situationid="1"] .resultSection .goalInfos h4 { display: none;}
.resultSection .goalInfos .ul-flex {
  display: flex;
  flex-wrap: wrap;
}
.resultSection .goalInfos .ul-flex ul {width: calc(50% - 10px);}
.resultSection .goalInfos ul li {
  margin: 5px 5px 0 5px;
  background: #c7a840;
  color: #fff;
  font-weight: bold;
  padding: 15px 20px 15px 40px;
  box-sizing: border-box;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.resultSection .goalInfos li.template { display: none;}
.resultSection .goalInfos li .en { font-size: 114%;}
@media only screen and (max-width: 782px) {
  .resultSection .goalInfos {
    padding: 0 2.5vw 3vw;
  }
  .resultSection .goalInfos h4 {
    text-align: center;
    font-size: 25px;
  }
  .resultSection .goalInfos .ul-flex ul {width: calc(50% - 1.5vw);}
  .resultSection .goalInfos ul li {
    margin: 5px 0.75vw 0 0.75vw;
    padding: 1vw 2vw;
    letter-spacing: 0;
    font-size: min(3vw,14px);
  }
}

section.homeevent {
  margin-top: 100px;
}
section.homeevent img { width: 100%; height: auto;}

.bg_gold {
  background: #c7a840;
  color: #002c5b;
  font-weight: bold;
  text-align: center;
  padding: 15px 0;
}
@media only screen and (max-width: 782px) {
  section.homeevent {
    margin-top: 40px;
  }

  .bg_gold {
    padding: 12px 0;
    font-size: 12px;
  }
}

.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;}
@media only screen and (max-width: 782px) {
  .tab {margin-top: 10vw;}
  .tab li { width: 50%;}
  .tab li a { height: 50px; }
}

.h301 {
  margin: 60px 0 20px;
  display: flex;
  align-items: baseline;
  font-size: 40px;
  font-weight: bold;
}
.h301 .en { font-weight: 700; text-transform: uppercase;}
.h301 .small { font-size: 50%; margin-left: 20px;}
@media only screen and (max-width: 782px) {
  .h301 { font-size: 20px; display: block; margin: 6vw 0;}
  .h301 .small { margin-left: 0px; display: block; line-height: 1;}
}
.hide { display: none;}

.teams {
  display: flex;
}
.teams > *:first-child { width: calc(50% + 60px);}
.teams > *:last-child { width: calc(50% - 60px);}

.icon_team {
  margin: 20px 0 0 0;
  display: flex;
  align-items: center;
}
.icon_team figure {
  width: 60px;
  margin-right: 5px;
}
.icon_team figure img {
  width: 100%;
  height: 60px;
  object-fit: contain;
  object-position: left 50%;
}
.icon_team span {
  font-size: 130%;
  font-weight: bold;
}
@media only screen and (max-width: 782px) {
  .teams > *:first-child { width: 50%;}
  .teams > *:last-child { width: 50%;}
  .icon_team {
    margin: 2.5vw 0 0 0;
    flex-direction: column;
  }
  .icon_team figure {
    width: 50px;
    margin-right: 0;
  }
  .icon_team figure img {
    height: 50px;
    object-position: 50% 50%;
  }
  .icon_team span {
    font-size: 2.5vw;
  }
}

.timeline {
  margin-top: 20px;
  letter-spacing: 0;
}
.timeline li {
  margin: 5px 0 0 0;
  background: #fff;
  position: relative;
  box-sizing: border-box;
  min-height: 50px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.timeline li.template { display: none;}
.timeline li .time {
  width: 150px;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: absolute;
  left: calc(50% - 75px);
  top: 0;
}
.timeline li .time span {
  width: 45%;
}
.timeline li .time span.sec {
  font-family: 'Montserrat', sans-serif;
  font-weight: bold;
  font-size: 22px;
  text-align: right;
}
.timeline li .time span.action {font-size: 14px;}
.timeline .red {color: #e21a44;}
.timeline li .goal {background: url("../img/games/goal@2x.png") no-repeat left 50% / 20px 20px;}
.timeline li .substitution {background: url("../img/games/substitution@2x.png") no-repeat left 50% / 16px 20px;}
.timeline li .yellow {background: url("../img/games/yellow@2x.png") no-repeat left 50% / 15px 20px;}
.timeline li .redcard {background: url("../img/games/redcard@2x.png") no-repeat left 50% / 15px 20px;}
.timeline li .myTeam,
.timeline li .oppTeam {
  width: calc(50% - 75px);
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  box-sizing: border-box;
  padding: 8px 0;
  font-size: 15px;
  font-weight: bold;
}
.timeline li .myTeam {
  justify-content: flex-end;
  background-position: right 50%;
  padding-right: 30px;
}
.timeline li .oppTeam {
  justify-content: flex-start;
  background-position: left 50%;
  padding-left: 30px;
}
.timeline li .substitution span[data-key="playerName"] + [data-key="uni"]::before { content: "→"; display: inline-block; padding: 0 3px;}
.timeline li span[data-key="uni"] { margin-right: 5px;}
@media only screen and (max-width: 782px) {
  .timeline { margin-top: 10px;}
  .timeline li {
    margin: 2.5px 0 0 0;
    min-height: 40px;
  }
  .timeline li .time {
    width: 40px;
    left: calc(50% - 20px);
  }
  .timeline li .time span {
    width: 100%;
  }
  .timeline li .time span.sec {
    font-size: 15px;
    text-align: center;
  }
  .timeline li .time span.action {display: none;}
  .timeline li .goal,
  .timeline li .substitution,
  .timeline li .yellow,
  .timeline li .redcard {background-size: auto 15px;}
  .timeline li .myTeam,
  .timeline li .oppTeam {
    width: calc(50% - 20px);
    padding: 5px 0;
    font-size: max(10px, 1.8vw);
  }
  .timeline li .myTeam {
    padding-right: 20px;
  }
  .timeline li .oppTeam {
    padding-left: 20px;
  }
}

.tb01 { margin-top: 60px; width:100%;}
.tb01 th {
  background: #002c5b;
  color: #fff;
  padding: 10px 3px;
  text-align: center;
  font-weight: bold;
}
.tb01 td {
  background: #fff;
  border-top: #f1f1f1 5px solid;
  padding: 10px 3px;
  text-align: center;
}
.tb01 td { font-size: 86%;}
@media only screen and (max-width: 782px) {
  .tb01 th,
  .tb01 td { font-size: 12px; letter-spacing: 0;}
  .tb01 td { border-top: #f1f1f1 2.5px solid;}
}

.h501 {
  background: #002c5b;
  color: #fff;
  padding: 10px 25px;
  font-weight: bold;
  font-size: 114%;
  margin: 5px 0 0 0;
}
ul.members li {
  background: #fff;
  margin: 5px 0 0 0;
  padding: 5px 25px;
  display: flex;
  justify-content: space-between;
}
ul.members li.template { display: none;}
ul.members.director li {padding: 10px 25px;}
ul.members li p {
  margin-top: 0;
  font-weight: bold;
  display: flex;
  align-items: center;
  font-size: 114%;
  letter-spacing: 0;
}
ul.members li p.substi { justify-content: flex-end;}
ul.members .position { width: 35px; white-space: nowrap; font-family: 'Montserrat', sans-serif;}
ul.members .thespa { width: 60px; text-align: center; font-weight: normal;}
ul.members .name { font-size: 75%; padding: 0 15px;}
ul.members li p.substi .name { min-width: 100px;}
ul.members .sec { 
  width: 65px; box-sizing: border-box; padding-left: 25px;white-space: nowrap; font-family: 'Montserrat', sans-serif;
  background: url("../img/games/substitution@2x.png") no-repeat left 50% / 16px 20px;
}
@media only screen and (max-width: 782px) {
  .h501 {
    padding: 6px 3vw;
    font-size: 100%;
    margin-top: 2.5px;
  }
  ul.members li {
    padding: 3px 3vw;
    margin-top: 2.5px;
  }
  ul.members.director li {padding: 8px 3vw;}
  ul.members li p { font-size: 90%; }
  ul.members .position { width: 30px; white-space: nowrap; font-family: 'Montserrat', sans-serif;}
  ul.members .thespa { width: 22px; text-align: center; font-weight: normal;}
  ul.members .name { font-size: 11px; padding: 0 7px;}
  ul.members li p.substi .name { min-width: 60px;}
  ul.members .sec { 
    width: 45px; padding-left: 18px;
    background-size: auto 15px;
  }
}

.dl-flex {
  display: flex;
  width: calc(100% + 5px);
}
.dl-flex dl {
  width: calc(25% - 5px);
  margin-right: 5px;
  text-align: center;
  display: flex;
  flex-direction: column;
}
.dl-flex dl dt {
  background: #002c5b;
  color: #fff;
  padding: 10px 25px;
  font-weight: bold;
  font-size: 86%;
}
.dl-flex dl dd {
  margin-top: 5px;
  background: #fff;
  padding: 20px 15px;
  height: 100%;
}
@media only screen and (max-width: 782px) {
  .dl-flex {
    flex-wrap: wrap;
    width: calc(100% + 2.5px);
  }
  .dl-flex dl {
    width: calc(50% - 2.5px);
    margin-right: 2.5px;
    margin-bottom: 3vw;
  }
  .dl-flex dl dt {
    padding: 5px 15px;
  }
  .dl-flex dl dd {
    margin-top: 2.5px;
    padding: 13px 10px;
    font-size: 86%;
  }
}

.dl-flex.gameEndInfo [data-xml]{
  display: inline-block;
}
[data-xml="Temperature"],[data-xml="Humidity"] {
  margin-left: 1em;
}

#movie {
  width: min(100%, 1080px);
  overflow: hidden;
  position: relative;
  margin: 0 auto;
}
#movie::after {
  content: "";
  padding: 56.25% 0 0 0;
  display: block;
}
#movie iframe {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}

.comment {
  background: #fff;
  padding: 60px;
}
.comment.previewComment {
  margin-top: 100px;
}
.comment + .comment {margin-top: 10px;}
figure.eyecatch {
  margin-bottom: 60px;
}
figure.eyecatch img {
  width: 100%;
  height: auto;
}
.h401 {
  font-size: 30px;
  font-weight: bold;
  margin-top: 50px;
  margin-bottom: 20px;
}
.h301 + .h401 { margin-top: -20px;}
.h401 .small { font-size: 16px;}
@media only screen and (max-width: 782px) {
  #movie {
    width: auto;
    padding: 0 3vw;
  }
  .comment.previewComment {
    margin-top: 50px;
  }
  .comment {padding: 3vw;}
  .comment + .comment {margin-top: 5px;}
  figure.eyecatch { margin-bottom: 3vw;}
  .h401 {
    font-size: 16px;
    margin-top: 25px;
    margin-bottom: 10px;
  }
  .h301 + .h401 { margin-top: -10px;}
  .h401 .small { font-size: 12px;}
}

.comment .flex {
  display: flex;
  align-items: flex-end;
}
.comment .flex figure {
  width: 200px;
  margin-right: 50px;
}
.comment .flex .text {
  margin-bottom: 20px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.comment .flex .text p { line-height: 1; margin: 0;}
.comment .flex .text .position { font-size: 30px;}
.comment .flex .text .uni { font-size: 50px;}
.comment .flex .text .name { font-size: 30px; font-weight: bold; line-height: 1.5; margin-top: 10px;}
.comment .flex .text .name .thespa { font-size: 17px; display: inline-block; margin-left: 20px; text-transform: uppercase;}
@media only screen and (max-width: 782px) {
  .comment .flex {
    display: flex;
    align-items: flex-end;
  }
  .comment .flex figure {
    width: 105px;
    margin-right: 25px;
  }
  .comment .flex .text {
    margin-bottom: 10px;
  }
  .comment .flex .text .position { font-size: 15px;}
  .comment .flex .text .uni { font-size: 25px;}
  .comment .flex .text .name { font-size: 15px; margin-top: 5px;}
  .comment .flex .text .name .thespa { font-size: 10px; margin-left: 10px;}
}

.prev_next {
  margin: 120px 0 200px;
  border-top: #c2c6d3 1px solid;
  position: relative;
  padding: 30px 0;
  font-weight: bold;
  font-size: 90%;
}
.prev_next .go2index {
  width: 220px;
  position: absolute;
  top: 30px;
  left: calc(50% - 110px);
  z-index: 2;
}
.prev_next ul {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: space-between;
}
.prev_next li a { position: relative;}
.prev_next li.prev a {padding-left: 25px;}
.prev_next li.next a {padding-right: 25px;}
.prev_next li a::before {
  position: absolute;
  content: "";
  width: 10px;
  height: 10px;
  border-top: #002c5b 1px solid;
  border-left: #002c5b 1px solid;
  box-sizing: border-box;
  top: calc(50% - 5px);
}
.prev_next li.prev a::before {
  transform: rotate(-45deg);
  left: 0;
}
.prev_next li.next a::before {
  transform: rotate(135deg);
  right: 0;
}
@media only screen and (max-width: 782px) {
  .prev_next {
    margin: 60px 0 200px;
    padding: 0px 0;
  }
  .prev_next a {
    display: inline-block;
    height: 50px;
    line-height: 50px;
    min-width: 50px;
  }
  .prev_next .go2index {
    width: 80px;
    top: 0px;
    left: calc(50% - 40px);
  }
}

.situationID3 { display: none !important;}
body[data-situationid='3'] .situationID3 { display: block !important;}
body[data-situationid='3'] .dl-flex dl.situationID3 { display: flex !important;}

body[data-situationid='1'] .afterKickoff { display: none !important;}