@charset "UTF-8";

main {
  background: #e8e8f0;
  padding: 60px 0 100px;
  min-height: 50vh;
}

@media (max-width: 768px) {
  main {
    padding: 30px 0 50px;
  }
}

header .wrap {
  max-width: 1220px;
}

.pageTitle {
  background: #fff;
  padding-bottom: 40px;
  padding-top: 40px;
}

@media (max-width: 768px) {
  .pageTitle {
    padding-bottom: 25px;
  }
}

.pageTitle > * {
  max-width: 1220px;
  height: 330px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: url(../img/info/title.png) no-repeat center center;
  background-size: cover !important;
  line-height: normal;
}

@media (max-width: 768px) {
  .pageTitle > * {
    height: 280px;
  }
}

.pageTitle h1 {
  color: #fff;
  font-size: 2.6rem;
  font-family: var(--oswald);
  font-weight: 500;
}

@media (max-width: 768px) {
  .pageTitle h1 {
    font-size: 2.4em;
  }
}

.newsList dl {
  display: grid;
  grid-template-columns: 110px auto;
  gap: 30px 10px;
}

@media (max-width: 768px) {
  .newsList dl {
    display: block;
  }
}

.newsList a {
  text-decoration: underline;
  opacity: 1;
}

.newsList a:hover {
  opacity: 1;
  text-decoration: none;
}

.infoTab {
  border-bottom: solid 2px #172a88;
  display: flex;
  justify-content: center;
  gap: 10px;
  list-style: none;
  padding: 0;
  margin: 0 0 80px;
  box-sizing: border-box;
}

@media (max-width: 768px) {
  .infoTab {
    margin: 0 0 50px;
  }
}

.infoTab li > * {
  width: 310px;
  max-width: 40vw;
  justify-content: center;
  display: flex;
  border-radius: 5px 5px 0 0;
  margin-bottom: -2px;
  padding: 10px;
  text-decoration: none;
}

@media (max-width: 768px) {
  .infoTab li > * {
    padding: 5px;
  }
}

.infoTab a {
  background: #191d6a;
  color: #fff;
}

.infoTab a:hover {
  text-decoration: none;
  opacity: 0.8;
}

.infoTab span {
  background: #e8e8f0;
  color: #191d6a;
  border-left: solid 2px #172a88;
  border-right: solid 2px #172a88;
  border-top: solid 2px #172a88;
}

.infoTable dl {
  border-bottom: solid 1px #172a88;
  display: flex;
  padding: 20px 0;
}

@media (max-width: 768px) {
  .infoTable dl {
    display: block;
  }
}

.infoTable dl:first-child {
  border-top: solid 1px #172a88;
}

.infoTable dl dt {
  color: #191d6a;
  width: 175px;
}

@media (max-width: 768px) {
  .infoTable dl dt {
    margin-bottom: 10px;
  }
}

.infoTable dl dd {
  flex: 1;
  color: #231815;
}

.infoTable dl a {
  text-decoration: underline;
}

.infoTable dl a:hover {
  text-decoration: none;
  opacity: 1;
}

.newsDetail .wrap {
  display: flex;
  flex-direction: column;
  min-height: 60vh;
}

.newsDetail .date {
  font-size: 0.9rem;
}

.newsDetail h2 {
  font-size: 1.3rem;
  font-weight: bold;
  color: #172a88;
  margin: 35px 0 10px;
}

.newsDetail * p {
  margin-top: 2em;
}

.newsDetail a {
  text-decoration: underline;
  opacity: 1;
}

.newsDetail a:hover {
  opacity: 1;
  text-decoration: none;
}

.Dpagination {
  display: grid;
  grid-template-columns: repeat(3, auto);
  padding: 50px 0 0;
  margin: auto 0 0;
  list-style: none;
}

.Dpagination li {
  position: relative;
}

.Dpagination li:first-child {
  padding-left: 20px;
}

.Dpagination li:first-child:has(a)::before {
  content: "";
  width: 0.4em;
  height: 0.4em;
  display: block;
  border-top: solid 3px #191d6a;
  border-right: solid 3px #191d6a;
  rotate: -135deg;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0px;
  margin: auto;
}

.Dpagination li:nth-child(2) {
  text-align: center;
}

.Dpagination li:last-child {
  padding-right: 20px;
  text-align: right;
}

.Dpagination li:last-child:has(a)::before {
  content: "";
  width: 0.4em;
  height: 0.4em;
  display: block;
  border-top: solid 3px #191d6a;
  border-right: solid 3px #191d6a;
  rotate: 45deg;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0px;
  margin: auto;
}

main .contact .wrap {
  width: 1090px;
  max-width: 95%;
}

.smf-form {
  margin-top: 60px;
  display: grid;
  gap: 30px;
}

@media (max-width: 768px) {
  .smf-form {
    margin-top: 40px;
    gap: 20px;
  }
}

.smf-form .wp-block-snow-monkey-forms-item {
  display: grid;
  grid-template-columns: 160px auto;
  gap: 20px;
  align-items: flex-start;
}

@media (max-width: 768px) {
  .smf-form .wp-block-snow-monkey-forms-item {
    grid-template-columns: 100%;
  }
}

.smf-form .wp-block-snow-monkey-forms-item .smf-item__col--label {
  padding-top: 1.3em;
}

.smf-form .wp-block-snow-monkey-forms-item .smf-item__col--controls input,
.smf-form .wp-block-snow-monkey-forms-item .smf-item__col--controls textarea {
  width: 100%;
  border: 0;
  background: #fff;
  padding: 10px;
  height: 315px;
  box-sizing: border-box;
}

@media (max-width: 768px) {
  .smf-form .wp-block-snow-monkey-forms-item .smf-item__col--controls input,
  .smf-form .wp-block-snow-monkey-forms-item .smf-item__col--controls textarea {
    height: 250px;
  }
}

.smf-form .wp-block-snow-monkey-forms-item .smf-item__col--controls input {
  height: 70px;
}

@media (max-width: 768px) {
  .smf-form .wp-block-snow-monkey-forms-item .smf-item__col--controls input {
    height: 50px;
  }
}

.smf-button-control {
  display: flex;
  justify-content: center;
  margin-top: 50px;
}

.smf-button-control__control {
  border: 0;
  background: #006934 !important;
  border: solid 1px #006934 !important;
  color: #fff !important;
  display: inline-flex !important;
  justify-content: center;
  align-items: center;
  padding: 10px;
  height: 60px;
  width: 315px;
  line-height: normal;
  box-sizing: border-box;
  text-align: center;
  border-radius: 1000px !important;
  cursor: pointer;
  position: relative;
  z-index: 1;
  overflow: hidden;
}

.smf-button-control__control::after {
  background: #fff;
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  width: 100%;
  height: 100%;
  transform: scale(0, 1);
  transform-origin: left top;
  transition: 0.2s cubic-bezier(0.45, 0, 0.55, 1);
  z-index: -1;
}

.smf-button-control__control:hover {
  text-decoration: none;
  opacity: 1;
  color: #006934 !important;
}

.smf-button-control__control:hover::after {
  transform: scale(1, 1);
}

@media (max-width: 768px) {
  .smf-button-control__control {
    height: 50px;
    width: 250px;
  }
}

.sponsor main {
  background: #fff;
}

.spBnr {
  color: #1e2b59;
  font-family: var(--oswald);
  font-size: 1.3rem;
  display: flex;
  flex-direction: column;
  gap: 50px;
}

.spBnr dd {
  display: flex;
  justify-content: center;
  gap: 15px;
  flex-wrap: wrap;
  margin-top: 20px;
}

.spBnr dd > * {
  max-width: 100%;
}

.spBnr dd.sz01 > * {
  width: 320px;
}

.spBnr dd.sz02 > * {
  width: 220px;
}

@media (max-width: 768px) {
  .spBnr dd.sz02 > * {
    width: 165px;
  }
}

.spBnr dd.sz03 > * {
  width: 182px;
}

@media (max-width: 768px) {
  .spBnr dd.sz03 > * {
    width: 165px;
  }
}

.spBnr dd.sz04 > * {
  width: 144px;
}

@media (max-width: 768px) {
  .spBnr dd.sz04 > * {
    width: 105px;
  }
}

.spBnr dd.sz05 > * {
  width: 100px;
}

@media (max-width: 768px) {
  .spBnr dd.sz05 > * {
    width: 80px;
  }
}

.textBnr {
  margin-top: 90px;
  font-size: 0.8em;
}

.textBnr ul {
  column-count: 3;
  column-gap: 20px;
  gap: 20px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.textBnr ul li {
  display: inline-block;
  width: 100%;
  /* margin-top: 20px; */
}

@media (max-width: 768px) {
  .textBnr ul {
    display: flex;
    flex-direction: column;
    text-align: center;
  }
}

.results .menu {
  background: #fff;
  box-sizing: border-box;
  display: flex;
  list-style: none;
  justify-content: center;
  padding: 10px;
  gap: 15px;
  margin-bottom: 50px;
  flex-wrap: wrap;
  margin-top: 50px;
}

.results .menu li a {
  text-decoration: underline;
  color: #000;
}

.results .btn {
  background: #8b94c3;
  color: #fff;
  text-align: center;
  width: 100%;
  max-width: 315px;
  padding: 10px;
  box-sizing: border-box;
  border-radius: 100px;
}

.results .btn::after {
  content: "";
  display: inline-block;
  width: 15px;
  height: 15px;
  margin-left: 10px;
  background: url(../img/result/ico_blank.svg) no-repeat;
  background-size: 100%;
}

.results h2 {
  font-size: 3rem;
  font-weight: 500;
  font-family: var(--oswald);
  color: #000;
  text-align: left;
  line-height: normal;
  margin-bottom: 30px;
}

@media (max-width: 768px) {
  .results h2 {
    margin-bottom: 10px;
    font-size: 2rem;
  }
}

.results h3 {
  background: #7f81a9;
  color: #fff;
  padding: 10px;
  text-align: left;
  margin: 40px 0 20px;
}

.results h3 a {
  color: #fff;
  text-decoration: underline;
}

@media (max-width: 768px) {
  .results h3 {
    margin: 20px 0 10px;
  }
}

.results table {
  height: auto !important;
  width: 100% !important;
}

.results table.type02 tbody {
  margin-bottom: 50px;
}

@media (max-width: 768px) {
  .results table.type02 tbody {
    display: flex;
    flex-direction: column;
  }
}

.results tr {
  height: auto !important;
  border-bottom: solid 15px #e8e8f0;
}

@media (max-width: 768px) {
  .results tr {
    display: grid;
    gap: 10px 0;
    grid-template-columns: 80px auto;
  }

  .results .session tr {
    grid-template-columns: 80px 20vw auto 20vw 50px;
  }

  .results .type02 tr {
    display: contents;
  }
}

.results .type02 tr {
  border-bottom: 0;
}

.results table + h2 {
  margin-top: 50px;
}

@media (max-width: 768px) {
  .results table + h2 {
    margin-top: 30px;
  }
}

.results th {
  vertical-align: middle;
  background: #b4b4b5;
  color: #000;
  font-weight: 500;
  width: 85px !important;
  padding: 15px 0;
  text-align: center;
  border-left: solid 15px #e8e8f0;
  border-bottom: 0;
  font-size: 1rem;
  line-height: 1em;
}

.results th.blue {
  background: #7cc1e3;
}

.results th.pink {
  background: #e99dc0;
}

.results th.gray {
  background: #b4b4b5;
}

.results th.none {
  background: none;
}

.results th:first-child {
  border-left: 0;
}

@media (max-width: 768px) {
  .results th {
    box-sizing: border-box;
    line-height: normal;
    border-left: none;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 5px;
    width: auto !important;
    height: auto !important;
  }

  .results th.none {
    display: none;
  }

  .results .type02 th:nth-child(2) {
    order: 3;
  }

  .results .type02 th:nth-child(3) {
    order: 5;
  }

  .results .type02 th:nth-child(4) {
    order: 7;
  }
}

.results td {
  font-family: "Noto Sans JP", sans-serif;
  background: #d1d2e1;
  padding: 5px;
  vertical-align: middle;
  text-align: center;
  border: 0;
  font-weight: 500;
  font-size: 1.1rem;
  width: 17.3%;
}

.results .session td {
  width: 11.95%;
}

.results td:nth-child(5) {
  border-right: solid 15px #e8e8f0;
}

.results td.none {
  background: none;
}

.results .type02 td {
  border-left: solid 15px #e8e8f0;
  padding: 10px;
  text-align: left;
}

.results .type02 td:first-child {
  border-left: 0;
}

@media (max-width: 768px) {
  .results td {
    width: 100%;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    font-size: 0.9rem;
    padding: 5px;
    width: auto !important;
    height: auto !important;
  }

  .results .session td {
    width: auto !important;
    height: auto !important;
  }

  .results td.none {
    display: none;
  }

  .results td:nth-child(5) {
    border-right: 0;
  }

  .results .type02 td {
    border-left: 0;
    justify-content: flex-start;
    align-items: flex-start;
    margin-bottom: 10px;
  }

  .results .type02 td:nth-child(1) {
    order: 2;
  }

  .results .type02 td:nth-child(2) {
    order: 4;
  }

  .results .type02 td:nth-child(3) {
    order: 6;
  }

  .results .type02 td:nth-child(4) {
    order: 8;
  }
}

.results td.ja,
.results td.ca,
.results td.ko,
.results td.sw,
.results td.gr,
.results td.fin,
.results td.sc,
.results td.swiss,
.results td.usa,
.results td.ru,
.results td.ita,
.results td.grico {
  font-size: 0.9rem;
  line-height: normal;
  font-weight: 400;
}

.results td.ja::before,
.results td.ca::before,
.results td.ko::before,
.results td.sw::before,
.results td.gr::before,
.results td.fin::before,
.results td.sc::before,
.results td.swiss::before,
.results td.usa::before,
.results td.ru::before,
.results td.ita::before,
.results td.grico::before {
  content: "";
  display: block;
  width: 100%;
  width: 26px;
  height: 26px;
  margin: auto auto 2px;
}

@media (max-width: 768px) {
  .results td.ja,
  .results td.ca,
  .results td.ko,
  .results td.sw,
  .results td.gr,
  .results td.fin,
  .results td.sc,
  .results td.swiss,
  .results td.usa,
  .results td.ru,
  .results td.ita,
  .results td.grico {
    box-sizing: border-box;
    font-size: 0.7rem;
    width: auto !important;
    height: auto !important;
  }
}

.results td.ja::before {
  background: url(../img/teams/japan.png) no-repeat center center;
  background-size: 100%;
}

.results td.ca::before {
  background: url(../img/teams/canada.png) no-repeat center center;
  background-size: 100%;
}

.results td.ko::before {
  background: url(../img/teams/korea.png) no-repeat center center;
  background-size: 100%;
}

.results td.sw::before {
  background: url(../img/teams/sweden.png) no-repeat center center;
  background-size: 100%;
}

.results td.gr::before {
  background: url(../img/teams/germany.png) no-repeat center center;
  background-size: 100%;
}

.results td.ita::before {
  background: url(../img/teams/italy.png) no-repeat center center;
  background-size: 100%;
}

.results td.fin::before {
  background: url(../img/teams/fin.png) no-repeat center center;
  background-size: 100%;
}

.results td.sc::before {
  background: url(../img/teams/sc.png) no-repeat center center;
  background-size: 100%;
}

.results td.swiss::before {
  background: url(../img/teams/swiss.png) no-repeat center center;
  background-size: 100%;
}

.results td.usa::before {
  background: url(../img/teams/usa.png) no-repeat center center;
  background-size: 100%;
}

.results td.ru::before {
  background: url(../img/teams/russia.png) no-repeat center center;
  background-size: 100%;
}

.results td.grico::before {
  background: #b4b4b5;
  width: 26px;
  height: 26px;
  border-radius: 100px;
}

.results td span,
.results td pre {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  display: flex;
  align-items: center;
  justify-content: flex-start !important;
  margin-bottom: 10px;
}

.results td span::before,
.results td pre::before {
  content: "";
  display: inline-block;
  width: 100%;
  width: 26px;
  height: 26px;
  margin-right: 10px;
}

.results td span.ja::before,
.results td pre.ja::before {
  background: url(../img/teams/japan.png) no-repeat center center;
  background-size: 100%;
}

.results td span.ita::before,
.results td pre.ita::before {
  background: url(../img/teams/italy.png) no-repeat center center;
  background-size: 100%;
}

.results td span.ca::before,
.results td pre.ca::before {
  background: url(../img/teams/canada.png) no-repeat center center;
  background-size: 100%;
}

.results td span.ko::before,
.results td pre.ko::before {
  background: url(../img/teams/korea.png) no-repeat center center;
  background-size: 100%;
}

.results td span.sw::before,
.results td pre.sw::before {
  background: url(../img/teams/sweden.png) no-repeat center center;
  background-size: 100%;
}

.results td span.gr::before,
.results td pre.gr::before {
  background: url(../img/teams/germany.png) no-repeat center center;
  background-size: 100%;
}

.results td span.fin::before,
.results td pre.fin::before {
  background: url(../img/teams/fin.png) no-repeat center center;
  background-size: 100%;
}

.results td span.sc::before,
.results td pre.sc::before {
  background: url(../img/teams/sc.png) no-repeat center center;
  background-size: 100%;
}

.results td span.swiss::before,
.results td pre.swiss::before {
  background: url(../img/teams/swiss.png) no-repeat center center;
  background-size: 100%;
}

.results td span.usa::before,
.results td pre.usa::before {
  background: url(../img/teams/usa.png) no-repeat center center;
  background-size: 100%;
}

.results td span.ru::before,
.results td pre.ru::before {
  background: url(../img/teams/russia.png) no-repeat center center;
  background-size: 100%;
}

.results td.movie {
  font-size: 0.7rem;
  line-height: normal;
  font-weight: 400;
  width: 70px;
}

.results td.movie a {
  text-decoration: none;
  font-size: 0;
  height: 30px;
  display: block;
}

.results td.movie a::before {
  content: "";
  display: block;
  width: 100%;
  width: 32px;
  height: 26px;
  margin: auto auto auto;
  background: url(../img/result/ico_mo.png) no-repeat center center;
  background-size: 100%;
}

.results td.movie a:hover {
  opacity: 0.8;
}

.results td.movie a:hover::before {
  opacity: 0.8;
}

.pagination {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 50px;
}

.champions main table td span {
  display: block;
  width: 35px;
  height: 35px;
  text-align: center;
  margin: 0 0 10px;
}

.champions main table td span.japan {
  background: url(../img/teams/japan.png) no-repeat center center;
  background-size: contain;
}

.champions main table td span.canada {
  background: url(../img/teams/canada.png) no-repeat center center;
  background-size: contain;
}

.champions main table td span.finland {
  background: url(../img/teams/finland.png) no-repeat center center;
  background-size: contain;
}

.champions main table td span.scotland {
  background: url(../img/teams/scotland.png) no-repeat center center;
  background-size: contain;
}

.champions main table td span.south-korea {
  background: url(../img/teams/korea.png) no-repeat center center;
  background-size: contain;
}

.champions main table td span.sweden {
  background: url(../img/teams/sweden.png) no-repeat center center;
  background-size: contain;
}

.champions main table td span.switzerland {
  background: url(../img/teams/swiss.png) no-repeat center center;
  background-size: contain;
}

.champions main table td span.USA {
  background: url(../img/teams/usa.png) no-repeat center center;
  background-size: contain;
}

.champions main table td span.russia {
  background: url(../img/teams/russia.png) no-repeat center center;
  background-size: contain;
}

.champions main table td span.germany {
  background: url(../img/teams/germany.png) no-repeat center center;
  background-size: contain;
}

.teams .infoTab a:hover {
  opacity: 1;
}

.teams .infoTab .active a {
  background: #e8e8f0;
  color: #191d6a;
  border-left: solid 2px #172a88;
  border-right: solid 2px #172a88;
  border-top: solid 2px #172a88;
}

.teams .teamslist {
  gap: 50px 100px;
  grid-template-columns: 1fr 1fr;
}

.teams .teamslist.active {
  display: grid;
}

@media (max-width: 768px) {
  .teams .teamslist {
    grid-template-columns: 1fr;
  }
}

.teams .teamslist h2 {
  font-size: 2.4rem;
  font-family: var(--oswald);
  font-weight: bold;
  padding-left: 70px;
  background: url(../img/teams/japan.png) no-repeat 0 0;
  background-size: 50px;
  padding-top: 15px;
  margin-top: 10px;
  margin-bottom: 10px;
  min-height: 50px;
}

.teams .teamslist h2 span {
  font-size: 1.1rem;
  font-weight: normal;
  margin-left: 20px;
}

.teams .teamslist h2.ca {
  background: url(../img/teams/canada.png) no-repeat left center;
  background-size: 50px;
}

.teams .teamslist h2.ko {
  background: url(../img/teams/korea.png) no-repeat left center;
  background-size: 50px;
}

.teams .teamslist h2.sw {
  background: url(../img/teams/sweden.png) no-repeat left center;
  background-size: 50px;
}

.teams .teamslist h2.ca {
  background: url(../img/teams/canada.png) no-repeat left center;
  background-size: 50px;
}

.teams .teamslist h2.USA {
  background: url(../img/teams/usa.png) no-repeat left center;
  background-size: 50px;
}

.teams .teamslist h2.ru {
  background: url(../img/teams/russia.png) no-repeat left center;
  background-size: 50px;
}

.teams .teamslist h2.sc {
  background: url(../img/teams/scotland.png) no-repeat left center;
  background-size: 50px;
}

.teams .teamslist h2.fin {
  background: url(../img/teams/finland.png) no-repeat left center;
  background-size: 50px;
}

.teams .teamslist h2.swiss {
  background: url(../img/teams/swiss.png) no-repeat left center;
  background-size: 50px;
}

.teams .teamslist h2.ger {
  background: url(../img/teams/germany.png) no-repeat left center;
  background-size: 50px;
}

.teams .teamslist h2.ita {
  background: url(../img/teams/italy.png) no-repeat left center;
  background-size: 50px;
}

.teams .teamslist h2.nor {
  background: url(../img/teams/norway.png) no-repeat left center;
  background-size: 50px;
}

.teams .teamslist p {
  font-family: var(--oswald);
  font-weight: bold;
  line-height: 1.5em;
  padding-left: 70px;
}

.teams .teamslist p small {
  font-size: 0.8em;
  margin-left: 10px;
  font-weight: normal;
}

.teams .teamslist ul {
  list-style: none;
  padding: 10px 0;
  margin: 10px 0;
  font-size: 0.8em;
  border-top: solid 1px #e99dc0;
}

.teams .teamslist#Men ul {
  border-top: solid 1px #7cc1e3;
}

body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  h2 {
  font-size: 1.3rem;
  border-top: solid 1px #171a65;
  border-bottom: solid 1px #171a65;
  padding: 25px 0;
  margin-bottom: 60px;
}

body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  h3 {
  font-size: 1.1rem;
  border-top: solid 3px #171a65;
  border-bottom: solid 1px #b3b4cd;
  padding: 25px 0;
  margin-bottom: 30px;
}

body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  h4 {
  font-size: 1rem;
  padding: 15px 20px;
  border-left: solid 1px #171a65;
  margin-bottom: 30px;
}

body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  p {
  margin-bottom: 3rem;
  line-height: 1.7;
}

body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  ul,
body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  ol {
  margin: 30px 0;
  padding-left: 2em;
}

body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  ul
  li,
body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  ol
  li {
  line-height: 1.7;
  margin-bottom: 0.5rem;
}

body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  a {
  text-decoration: underline;
}

body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  a:hover {
  text-decoration: none;
}

body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  .wp-block-table {
  margin: 30px 0;
}

body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  table {
  border: solid 1px #171a65;
}

body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  table
  th {
  background: #b3b4cd;
  border: solid 1px #171a65;
  border-bottom: solid 1px #171a65;
}

body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  table
  thead {
  border-bottom: 1px solid !important;
}

body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  table
  td {
  border: solid 1px #171a65;
}

body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  .wp-block-button__link {
  text-decoration: none;
  color: #fff;
  background-color: #006934;
  border: #006934 solid 1px;
  width: 315px;
  max-width: 100%;
  padding: 20px;
  margin: 20px 0;
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
  z-index: 1;
}

body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  .wp-block-button__link:hover {
  text-decoration: none;
  color: #006934;
  opacity: 1;
}

body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  .wp-block-button__link::after {
  display: block;
  background: #fff;
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  width: 100%;
  height: 100%;
  transform: scale(0, 1);
  transform-origin: left top;
  transition: 0.2s cubic-bezier(0.45, 0, 0.55, 1);
  z-index: -1;
}

body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  .wp-block-button__link:hover::after {
  transform: scale(1, 1);
}

body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  .wp-block-button.is-style-outline--8c90aa4a632bcbf311afac9ed558c5ad
  .wp-block-button__link {
  text-decoration: none;
  background: 0;
  border: #006934 solid 1px;
  color: #006934;
  width: 315px;
  max-width: 100%;
  padding: 20px;
  margin: 20px 0;
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
  z-index: 1;
}

body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  .wp-block-button.is-style-outline--8c90aa4a632bcbf311afac9ed558c5ad
  .wp-block-button__link:hover {
  text-decoration: none;
  color: #fff;
  opacity: 1;
}

body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  .wp-block-button.is-style-outline--8c90aa4a632bcbf311afac9ed558c5ad
  .wp-block-button__link::after {
  display: block;
  background: #006934;
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  width: 100%;
  height: 100%;
  transform: scale(0, 1);
  transform-origin: left top;
  transition: 0.2s cubic-bezier(0.45, 0, 0.55, 1);
  z-index: -1;
}

body:not(.champions):not(.news):not(.newseng):not(.information):not(.informationeng):not(.results):not(.sponsor):not(
    .contact
  ):not(.teams):not(.tickets):not(.teams-test):not(.access)
  main
  .wp-block-button.is-style-outline--8c90aa4a632bcbf311afac9ed558c5ad
  .wp-block-button__link:hover::after {
  transform: scale(1, 1);
}

body .grecaptcha-badge {
  display: none;
}

body.contact .grecaptcha-badge {
  display: block;
}

.tickets .icoList {
  top: 150px;
}

.tickets .fade {
  opacity: 0;
  transform: translateY(30px);
  transition:
    opacity 1.5s,
    transform 1s;
}

.tickets .fade.fadeinA {
  opacity: 1;
  transform: translateY(0px);
}

@keyframes fadein {
  from {
    opacity: 0;
    transform: translatey(20px);
  }

  to {
    opacity: 1;
    transform: translatey(0);
  }
}

.tickets main {
  padding-top: 10px;
  background: #fff;
  text-align: center;
}

.tickets main h1 {
  width: 665px;
  margin: auto;
  margin-bottom: 50px;
  max-width: 100%;
  position: relative;
}

@media (max-width: 768px) {
  .tickets main h1 {
    width: 80%;
    margin-top: 150px;
  }
}

.tickets main h2 {
  text-align: center;
  border: 0;
  padding: 0;
  margin-bottom: 30px;
}

.tickets main h2 img {
  margin: auto;
}

@media (max-width: 768px) {
  .tickets main h2 {
    text-align: center;
  }

  .tickets main .sec02 h2 {
    width: 45.3vw;
    margin: 20px auto;
  }

  .tickets main .sec03 h2 {
    width: 63.3vw;
    margin: 20px auto;
  }

  .tickets main .sec04 h2 {
    width: 68.3vw;
    margin: 20px auto;
  }

  .tickets main .sec05 h2 {
    width: 92vw;
    margin: 20px auto;
  }

  .tickets main .sec06 h2 {
    width: 43.5vw;
    margin: 20px auto;
  }

  .tickets main .sec07 h2 {
    width: 82.5vw;
    margin: 20px auto;
  }
}

.tickets main section {
  margin-top: 150px;
  color: #141f40;
}

@media (max-width: 768px) {
  .tickets main section {
    margin-top: 70px;
  }
}

.tickets main nav {
  margin: 65px 0 0;
}

.tickets main nav ul {
  padding: 0;
  margin: 0;
  list-style: none;
  margin: auto;
  width: 865px;
  max-width: 100%;
  height: 363px;
  background: url(../img/ticket/navbg.svg) no-repeat center bottom;
  background-size: 100%;
  position: relative;
}

@media (max-width: 768px) {
  .tickets main nav ul {
    width: 100%;
    height: 40vw;
  }
}

.tickets main nav ul li {
  position: absolute;
  width: 180px;
}

.tickets main nav ul li.li01 {
  bottom: 45px;
  left: 125px;
  z-index: 2;
}

.tickets main nav ul li.li02 {
  bottom: 160px;
  left: 75px;
}

.tickets main nav ul li.li03 {
  bottom: 210px;
  left: 330px;
}

.tickets main nav ul li.li04 {
  bottom: 165px;
  left: 540px;
}

.tickets main nav ul li.li05 {
  bottom: 45px;
  left: 610px;
}

.tickets main nav ul li.li06 {
  bottom: 15px;
  left: 380px;
}

.tickets main nav ul li:hover {
  width: 200px;
  opacity: 1;
}

.tickets main nav ul li:hover img {
  opacity: 1;
}

.tickets main nav ul li a:hover {
  opacity: 1 !important;
}

@media (max-width: 865px) {
  .tickets main nav ul li {
    width: 20vw;
  }

  .tickets main nav ul li.li01 {
    bottom: 5vw;
    left: 15vw;
    z-index: 2;
  }

  .tickets main nav ul li.li02 {
    bottom: 18vw;
    left: 10vw;
  }

  .tickets main nav ul li.li03 {
    bottom: 22vw;
    left: 38vw;
  }

  .tickets main nav ul li.li04 {
    bottom: 18vw;
    left: 63vw;
  }

  .tickets main nav ul li.li05 {
    bottom: 5vw;
    left: 70vw;
  }

  .tickets main nav ul li.li06 {
    bottom: 1vw;
    left: 42vw;
  }

  .tickets main nav ul li:hover {
    width: 20vw;
  }
}

.tickets main .lead01 {
  text-align: left;
  margin-top: -140px;
  position: relative;
  z-index: 1;
}

@media (max-width: 768px) {
  .tickets main .lead01 {
    margin-top: -13vw;
  }

  .tickets main .lead01 img {
    max-width: 83%;
  }
}

.tickets main .sec01 > div {
  position: relative;
}

.tickets main .fanfunico {
  width: 180px;
  position: absolute;
  top: 90px;
  right: 10px;
}

.tickets main .fanfunico a {
  display: block;
  position: relative;
  z-index: 99999;
}

.tickets main .fanfunico.fixed {
  position: fixed;
  top: 50px;
  right: 10px;
  opacity: 0.7;
  z-index: 5;
  width: 100px;
}

@media (max-width: 768px) {
  .tickets main .fanfunico {
    right: 0;
    top: 10px;
    width: 70px;
    height: 70px;
  }

  .tickets main .fanfunico.fixed {
    top: 70px;
  }
}

.tickets main .btnT01 {
  display: inline-block;
  padding: 10px 25px;
  border: solid 1px #7d7d7d;
  line-height: normal;
  box-sizing: border-box;
  border-radius: 20px;
  color: #7d7d7d;
  z-index: 1;
  position: relative;
  font-size: 1.3rem;
  overflow: hidden;
}

.tickets main .btnT01:hover {
  color: #fff;
  text-decoration: none;
}

.tickets main .btnT01::after {
  background: #7d7d7d;
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  width: 100%;
  height: 100%;
  transform: scale(0, 1);
  transform-origin: left top;
  transition: 0.2s cubic-bezier(0.45, 0, 0.55, 1);
  z-index: -1;
}

.tickets main .btnT01:hover::after {
  transform: scale(1, 1);
}

.tickets main .sec02 .flex {
  gap: 80px;
  align-items: center;
  justify-content: center;
}

@media (max-width: 768px) {
  .tickets main .sec02 .flex {
    gap: 40px;
    margin-bottom: 40px;
  }
}

.tickets main .sec02 .flex figure {
  width: 520px;
}

.tickets main .sec02 .flex figure.or02 {
  order: 2;
}

.tickets main .sec02 .flex .sb {
  width: 500px;
  background: #eaf5fc;
  padding: 30px 20px;
  box-sizing: border-box;
  position: relative;
  font-size: 0.9em;
  text-align: left;
}

.tickets main .sec02 .flex .sb:before {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 13px solid transparent;
  border-bottom: 13px solid transparent;
  border-right: 13px solid #eaf5fc;
  border-left: 0;
  position: absolute;
  left: -13px;
  top: calc(50% - 13px);
}

.tickets main .sec02 .flex .sb.or02 {
  order: 1;
}

.tickets main .sec02 .flex .sb.or02:before {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 13px solid transparent;
  border-bottom: 13px solid transparent;
  border-left: 13px solid #eaf5fc;
  border-right: 0;
  position: absolute;
  left: auto;
  right: -13px;
  top: calc(50% - 13px);
}

@media (max-width: 768px) {
  .tickets main .sec02 .flex .sb {
    width: 100%;
  }

  .tickets main .sec02 .flex .sb::before {
    left: 0;
    right: 0;
    margin: auto;
    top: -13px;
    border-top: 0;
    border-bottom: 13px solid #eaf5fc;
    border-right: 13px solid transparent;
    border-left: 13px solid transparent;
  }

  .tickets main .sec02 .flex .sb.or02 {
    order: 2;
  }

  .tickets main .sec02 .flex .sb.or02::before {
    left: 0;
    right: 0;
    margin: auto;
    top: -13px;
    border-top: 0;
    border-bottom: 13px solid #eaf5fc;
    border-right: 13px solid transparent;
    border-left: 13px solid transparent;
  }
}

.tickets main .sec05 .flex {
  gap: 70px;
  text-align: left;
}

.tickets main .sec05 .flex h3 {
  font-size: 1.6em;
  font-weight: bold;
  margin: 10px 0;
  font-family: "Zen Maru Gothic", serif;
}

.tickets main .sec05 .flex dl {
  display: flex;
  flex-direction: column;
  gap: 30px;
}

.tickets main .sec05 .flex dl dt {
  order: 2;
  margin-top: auto;
}

@media (max-width: 768px) {
  .tickets main .sec05 .flex {
    gap: 40px;
  }
}

.tickets main .sec07 {
  font-size: 1rem;
}

.tickets main .sec07 dl {
  text-align: center;
  margin-top: 30px;
}

.tickets main .sec07 dl dt {
  font-weight: bold;
  font-size: 1.4rem;
}

.tickets main .sec07 .flex {
  text-align: left;
  gap: 50px;
}

.tickets main .sec07 .flex h3 {
  text-align: left;
  font-weight: bold;
  margin-bottom: 10px;
}

.tickets main .sec07 .flex figure {
  width: 500px;
  text-align: center;
}

.tickets main .sec07 .flex .fl1 {
  flex: 1;
}

.tickets main .sec07 .flex .fl1 a {
  text-decoration: underline;
}

.tickets main .sec07 .alignL {
  text-align: left;
}

.tickets main .sec07 h3 {
  font-size: 1.6rem;
  font-weight: bold;
  margin-bottom: 20px;
  line-height: normal;
}

.tickets main .sec07 h4 {
  font-weight: bold;
  font-size: 1.1rem;
}

.tickets main .sec07 .wrap02 {
  width: 795px;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  text-align: left;
}

.tickets main .sec07 .wrap02 h4 {
  font-size: 1rem;
}

.tickets main .sec07 .wrap02 h4 span {
  color: #7d7d7d;
  font-weight: 700;
}

.tickets main .sec07 .wrap02 h4::first-letter {
  font-size: 1.5rem;
  color: #141f40;
}

.tickets main .slide02 {
  list-style: none !important;
  padding: 0;
  margin: 0;
  width: 520px;
}

.tickets main .slide02 span {
  display: block;
  margin-bottom: 10px;
}

.tickets main .slide02 ul {
  list-style: none;
  display: flex;
  justify-content: center;
  gap: 10px;
  padding: 0;
  margin-top: 20px;
}

.tickets main .slide02 button {
  width: 10px;
  text-indent: -9999px;
  overflow: hidden;
  height: 10px;
  color: #7d7d7d;
  border-radius: 100px;
  border: 0;
  padding: 0;
}

.slick-active .tickets main .slide02 button {
  background: #231815;
}

@media (max-width: 768px) {
  .tickets main .slide02 {
    width: 300px;
  }
}

.tickets main img {
  max-width: 100%;
}

.move01 {
  position: absolute;
  bottom: 5px;
  left: 90px;
  width: 158px;
  animation: 0.5s ease-in 0.5s infinite alternate forwards expansion;
}

@media (max-width: 768px) {
  .move01 {
    width: 18vw;
    left: 12vw;
    bottom: 1vw;
  }
}

@keyframes expansion {
  0% {
    width: 158px;
  }

  100% {
    width: 180px;
    left: 80px;
  }
}

@media (max-width: 768px) {
  @keyframes expansion {
    0% {
      width: 18vw;
    }

    100% {
      width: 20vw;
      left: 11vw;
    }
  }
}

.move02 {
  position: absolute;
  display: block;
  bottom: 0px;
  left: 0;
  right: 0;
  margin: auto;
  width: 370px;
  animation: 0.5s ease-in 0.5s infinite alternate forwards expansion02;
}

@media (max-width: 768px) {
  .move02 {
    width: 60vw;
  }
}

@keyframes expansion02 {
  0% {
    width: 370px;
  }

  100% {
    width: 400px;
  }
}

@media (max-width: 768px) {
  @keyframes expansion02 {
    0% {
      width: 60vw;
    }

    100% {
      width: 63vw;
    }
  }
}

.lead02 {
  position: relative;
  width: 850px;
  margin: auto;
  max-width: 100%;
}

.lead02 .lead02-1,
.lead02 .lead02-2,
.lead02 .lead02-3 {
  position: absolute;
  animation: 0.5s ease-in 0.5s infinite alternate forwards expansion03;
}

.lead02 .lead02-1 img,
.lead02 .lead02-2 img,
.lead02 .lead02-3 img {
  width: 100%;
}

.lead02 .lead02-1 {
  left: 326px;
  top: 65px;
  width: 3em;
  font-size: 1rem;
}

@media (max-width: 850px) {
  .lead02 .lead02-1 {
    left: 36.2vw;
    top: 7.5vw;
    font-size: 1.8vw;
  }
}

.lead02 .lead02-2 {
  left: 419px;
  top: 65px;
  width: 3em;
  font-size: 2.2rem;
}

@media (max-width: 850px) {
  .lead02 .lead02-2 {
    left: 46.5vw;
    top: 7.5vw;
    font-size: 3.8vw;
  }
}

.lead02 .lead02-3 {
  left: 533px;
  top: 65px;
  width: 3em;
  font-size: 1.4rem;
}

@media (max-width: 850px) {
  .lead02 .lead02-3 {
    left: 59.5vw;
    top: 7.5vw;
    font-size: 2.4vw;
  }
}

@keyframes expansion03 {
  0% {
    width: 2.7em;
  }

  100% {
    width: 3.2em;
  }
}

.move03 {
  position: relative;
}

.move03 span {
  display: inline-block;
  animation: 0.7s ease-in 0.7s infinite alternate expansion04;
}

@keyframes expansion04 {
  0% {
    transform: rotate(-10deg);
  }

  100% {
    transform: rotate(10deg);
  }
}

.access main {
  font-size: 1.1rem;
}

@media (max-width: 768px) {
  .access main {
    font-size: 0.9rem;
  }
}

.access main small {
  font-size: 0.9rem;
}

.access main iframe {
  height: 690px;
  width: 900px;
  max-width: 100%;
}

@media (max-width: 768px) {
  .access main iframe {
    height: 350px;
  }
}

.access main .infoTab {
  margin-bottom: 60px;
}

.access main .infoTab .active a {
  background: #e8e8f0;
  color: #191d6a;
  border-left: solid 2px #172a88;
  border-right: solid 2px #172a88;
  border-top: solid 2px #172a88;
}

.access main h2 {
  font-size: 1.2em;
  border-top: solid 1px #171a65;
  border-bottom: solid 1px #171a65;
  padding: 25px 0;
  text-align: center;
  font-weight: bold;
  color: #171a65;
  line-height: normal;
}

.access main dl {
  width: 525px;
  line-height: 2em;
}

@media (max-width: 768px) {
  .access main dl {
    width: 100%;
  }
}

.access main dl dt {
  font-size: 1.2em;
  border-top: solid 1px #171a65;
  border-bottom: solid 1px #171a65;
  padding: 25px 0;
  text-align: center;
  font-weight: bold;
  color: #171a65;
  margin-bottom: 30px;
}

.access main dl.car dt {
  background: url(../img/access/ico01.svg) no-repeat center left 22%;
  background-size: 66px;
}

@media (max-width: 1100px) {
  .access main dl.car dt {
    background-position: center left calc(50% - 120px);
  }
}

.access main dl.train dt {
  background: url(../img/access/ico02.svg) no-repeat center left 23%;
  background-size: 43px;
}

.access main #english dl.train dt {
  background-position: center left 15%;
}

@media (max-width: 1100px) {
  .access main dl.train dt {
    background-position: center left calc(50% - 120px);
  }

  .access main #english dl.train dt {
    padding-left: 60px;
    background-position: center left calc(50% - 130px);
  }
}

/* 
追加分 */
.new-food-wrap {
  display: flex;
  flex-wrap: wrap;
  width: 75%;
  padding: 0;
  gap: 3%;
  list-style: none;
  margin: 0 auto;
  justify-content: center;
}

@media (max-width: 768px) {
  .new-food-wrap {
    width: 100%;
  }
}

.new-food-wrap p {
  font-weight: 600;
}
.new-food-wrap li {
  width: 30%;
  margin-bottom: 30px;
}
@media (max-width: 768px) {
  .new-food-wrap li {
    width: 48%;
  }
  .new-food-wrap li:first-child {
    margin-top: 20px;
  }
}

.food-bottom-text {
  margin-top: 50px;
  line-height: 30px;
  width: 75%;
  margin: 0 auto;
  text-align: left;
  font-weight: 600;
}

@media (max-width: 768px) {
  .food-bottom-text {
    width: 100%;
  }
}
.food-bottom-text .small {
  margin-top: 10px;
  display: block;
}
@media (max-width: 768px) {
  .food-bottom-text .small {
    line-height: 24px;
  }
}

/* ==========================
  モーダル（ポップアップ）
========================== */
.js_modalBtnWrap {
  width: 300px;
  max-width: 100%;
  margin: 0 auto;
  text-align: center;
}
.js_modalWrap {
  opacity: 0;
  z-index: -1;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
.js_modalWrap.active {
  animation: modalOpen 0.3s ease forwards;
}
.js_modalWrap.active2 {
  animation: modalClose 0.3s ease forwards;
}
.js_modalBG {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6);
}
.js_modalContInner {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  width: 500px;
  max-width: 100%;
  background-color: #fff;
  max-height: 600px;
  padding: 40px;
}
.js_modalCont {
  max-height: 520px;
}
.js_modalCont > * + * {
  margin-top: 10px;
}
.js_modalContInner > .js_modalClose + * {
  margin-top: 0;
}
.js_modalClose {
  display: block;
  position: absolute;
  top: 2.5px;
  right: -50px;
  width: 10px;
  height: 10px;
  overflow: hidden;
  cursor: pointer;
  z-index: 1001;
  background-color: #fff;
  padding: 14px;
  border-radius: 33px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 768px) {
  .js_modalClose {
    right: 0;
    top: -40px;
  }
}
.js_modalClose::before,
.js_modalClose::after {
  content: "";
  background-color: #222;
  position: absolute;
  top: 5px;
  right: 12px;
  width: 3px;
  height: 18px;
}
.js_modalClose::before {
  transform: rotate(45deg);
}
.js_modalClose::after {
  transform: rotate(-45deg);
}

@keyframes modalOpen {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
    z-index: 1000;
  }
}
@keyframes modalClose {
  0% {
    opacity: 1;
    z-index: 1000;
  }
  100% {
    opacity: 0;
  }
}
.new-food-logo {
  margin: 20px 0 10px;
}
@media (max-width: 768px) {
  .new-food-logo {
    width: 160px;
    margin: 10px 0 0;
  }
}
/* ==========================
  コンテンツの中身
========================== */
.ly_inner {
  width: 100%;
  max-width: 1080px;
  margin: 100px auto;
  padding: 40px;
  background-color: #ccc;
}
.ly_inner h2 {
  font-size: 150%;
  font-weight: bold;
  margin-bottom: 30px;
}
.md_textblock > * + * {
  margin-top: 10px;
}
.md_textblock > * + .js_modalBtnWrap {
  margin-top: 20px;
}

/* PC幅に適用 */
@media (min-width: 768px) {
  .hp_sp {
    display: none !important;
  }
}
/* スマホ幅に適用 */
@media (max-width: 768px) {
  .hp_pc {
    display: none !important;
  }
  .js_modalContInner {
    padding: 20px;
    width: 80%;
  }
  .js_modalCont {
    max-height: 360px;
  }
  .tickets main .js_modalCont img {
    max-width: 370px;
    min-width: 185px;
    width: 100%;
  }
}
